From: Kaitao Cheng <[email protected]>

A later change will make list_for_each_entry() cache the next element
before entering the loop body. The ww-mutex torture path can move list
entries while it resolves a wound/wait conflict and then continue from
the adjusted cursor.

Keep the list walk open-coded so the loop step observes the cursor
selected by the body. This preserves the existing stress-test traversal
semantics and prepares the code for the list iterator update.

Signed-off-by: Kaitao Cheng <[email protected]>
---
 kernel/locking/locktorture.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/kernel/locking/locktorture.c b/kernel/locking/locktorture.c
index e618bcf75e2d..0eb75e9bccaa 100644
--- a/kernel/locking/locktorture.c
+++ b/kernel/locking/locktorture.c
@@ -644,7 +644,9 @@ __acquires(torture_ww_mutex_2)
 
        ww_acquire_init(ctx, &torture_ww_class);
 
-       list_for_each_entry(ll, &list, link) {
+       for (ll = list_first_entry(&list, typeof(*ll), link);
+            !list_entry_is_head(ll, &list, link);
+            ll = list_next_entry(ll, link)) {
                int err;
 
                err = ww_mutex_lock(ll->lock, ctx);
-- 
2.43.0

Reply via email to