]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
doc/RCU/listRCU: refine example code for eliminating stale data
authorWei Yang <richard.weiyang@gmail.com>
Tue, 18 Feb 2025 00:50:47 +0000 (00:50 +0000)
committerJoel Fernandes <joelagnelf@nvidia.com>
Fri, 16 May 2025 13:00:54 +0000 (09:00 -0400)
This patch adjust the example code with following two purpose:

  * reduce the confusion on not releasing e->lock
  * emphasize e is valid and not stale with e->lock held

Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
CC: Boqun Feng <boqun.feng@gmail.com>
CC: Alan Huang <mmpgouride@gmail.com>
Reviewed-by: Alan Huang <mmpgouride@gmail.com>
Link: https://lore.kernel.org/r/20250218005047.27258-1-richard.weiyang@gmail.com
Signed-off-by: Boqun Feng <boqun.feng@gmail.com>
Signed-off-by: Joel Fernandes <joelagnelf@nvidia.com>
Documentation/RCU/listRCU.rst

index ed5c9d8c9afe904f42ba7aab479c83334ad60b46..d8bb98623c124e23f868d0ed8a2c23f135ff4ca2 100644 (file)
@@ -334,7 +334,7 @@ If the system-call audit module were to ever need to reject stale data, one way
 to accomplish this would be to add a ``deleted`` flag and a ``lock`` spinlock to the
 ``audit_entry`` structure, and modify audit_filter_task() as follows::
 
-       static enum audit_state audit_filter_task(struct task_struct *tsk)
+       static struct audit_entry *audit_filter_task(struct task_struct *tsk, char **key)
        {
                struct audit_entry *e;
                enum audit_state   state;
@@ -346,16 +346,18 @@ to accomplish this would be to add a ``deleted`` flag and a ``lock`` spinlock to
                                if (e->deleted) {
                                        spin_unlock(&e->lock);
                                        rcu_read_unlock();
-                                       return AUDIT_BUILD_CONTEXT;
+                                       return NULL;
                                }
                                rcu_read_unlock();
                                if (state == AUDIT_STATE_RECORD)
                                        *key = kstrdup(e->rule.filterkey, GFP_ATOMIC);
-                               return state;
+                               /* As long as e->lock is held, e is valid and
+                                * its value is not stale */
+                               return e;
                        }
                }
                rcu_read_unlock();
-               return AUDIT_BUILD_CONTEXT;
+               return NULL;
        }
 
 The ``audit_del_rule()`` function would need to set the ``deleted`` flag under the