Home
last modified time | relevance | path

Searched full:rcu (Results 1 – 25 of 1450) sorted by relevance

12345678910>>...58

/linux-6.12.1/kernel/rcu/
DKconfig.debug3 # RCU-related debugging configuration options
6 menu "RCU Debugging"
12 bool "RCU list lockdep debugging"
16 Enable RCU lockdep checking for list usages. By default it is
17 turned off since there are several list RCU users that still
27 tristate "performance tests for RCU"
33 tests on the RCU infrastructure. The kernel module may be built
36 Say Y here if you want RCU performance tests to be built into
38 Say M if you want the RCU performance tests to build as a module.
42 tristate "torture tests for RCU"
[all …]
DKconfig3 # RCU-related configuration options
6 menu "RCU Subsystem"
14 This option selects the RCU implementation that is
24 This option selects the RCU implementation that is
36 This option selects the RCU implementation that is
39 memory footprint of RCU.
42 bool "Make expert-level adjustments to RCU configuration"
46 expert-level adjustments to RCU configuration. By default,
50 obscure RCU options to be set up.
52 Say Y if you need to make expert-level adjustments to RCU.
[all …]
Dupdate.c50 #include "rcu.h"
68 * rcu_read_lock_held_common() - might we be in RCU-sched read-side critical section?
77 * RCU-sched read-side critical section. In absence of
78 * CONFIG_DEBUG_LOCK_ALLOC, this assumes we are in an RCU-sched read-side
80 * of preemption (including disabling irqs) counts as an RCU-sched
82 * that required that they be called within an RCU-sched read-side
88 * Note that if the CPU is in the idle loop from an RCU point of view (ie:
91 * rcu_read_lock(). The reason for this is that RCU ignores CPUs that are
93 * so such a CPU is effectively never in an RCU read-side critical section
94 * regardless of what RCU primitives it invokes. This state of affairs is
[all …]
/linux-6.12.1/Documentation/RCU/
DwhatisRCU.rst3 What is RCU? -- "Read, Copy, Update"
6 Please note that the "What is RCU?" LWN series is an excellent place
7 to start learning about RCU:
9 | 1. What is RCU, Fundamentally? https://lwn.net/Articles/262464/
10 | 2. What is RCU? Part 2: Usage https://lwn.net/Articles/263130/
11 | 3. RCU part 3: the RCU API https://lwn.net/Articles/264090/
12 | 4. The RCU API, 2010 Edition https://lwn.net/Articles/418853/
14 | 5. The RCU API, 2014 Edition https://lwn.net/Articles/609904/
16 | 6. The RCU API, 2019 Edition https://lwn.net/Articles/777036/
21 | 1. Unraveling RCU Mysteries: Fundamentals https://www.linuxfoundation.org/webinars/unrav…
[all …]
Drcu.rst3 RCU Concepts
6 The basic idea behind RCU (read-copy update) is to split destructive
11 since dropped their references. For example, an RCU-protected deletion
14 information on using RCU with linked lists.
19 - Why would anyone want to use RCU?
21 The advantage of RCU's two-part approach is that RCU readers need
25 on modern CPUs is what gives RCU its performance advantages
26 in read-mostly situations. The fact that RCU readers need not
30 if the RCU readers give no indication when they are done?
32 Just as with spinlocks, RCU readers are not permitted to
[all …]
DRTFP.txt4 This document describes RCU-related publications, and is followed by
6 be found at http://www.rdrop.com/users/paulmck/RCU/. For others, browsers
9 The first thing resembling RCU was published in 1980, when Kung and Lehman
23 serialization, which is an RCU-like mechanism that relies on the presence
31 (In contrast, implementation of RCU is permitted only in software licensed
35 At first glance, this has nothing to do with RCU, but nevertheless
37 RCU implementation in DYNIX/ptx. In 1988, Barbara Liskov published
66 synchronization [HMassalinPhD]. RCU makes extremely heavy use of
91 1995 also saw the first publication of DYNIX/ptx's RCU mechanism
98 mechanism, which is quite similar to RCU [Gamsa99]. These operating
[all …]
Dlockdep.rst4 RCU and lockdep checking
7 All flavors of RCU have lockdep checking available, so that lockdep is
8 aware of when each task enters and leaves any flavor of RCU read-side
9 critical section. Each flavor of RCU is tracked separately (but note
11 tracking to include RCU state, which can sometimes help when debugging
14 In addition, RCU provides the following primitives that check lockdep's
17 rcu_read_lock_held() for normal RCU.
18 rcu_read_lock_bh_held() for RCU-bh.
19 rcu_read_lock_sched_held() for RCU-sched.
20 rcu_read_lock_any_held() for any of normal RCU, RCU-bh, and RCU-sched.
[all …]
Dstallwarn.rst4 Using RCU's CPU Stall Detector
7 This document first discusses what sorts of issues RCU's CPU stall
13 What Causes RCU CPU Stall Warnings?
16 So your kernel printed an RCU CPU stall warning. The next question is
17 "What caused it?" The following problems can result in RCU CPU stall
20 - A CPU looping in an RCU read-side critical section.
37 RCU CPU stall warning messages. Especially if you have added
40 - Anything that prevents RCU's grace-period kthreads from running.
48 happen to preempt a low-priority task in the middle of an RCU
51 in which case the next RCU grace period can never complete, which
[all …]
Dchecklist.rst4 Review Checklist for RCU Patches
9 that make use of RCU. Violating any of the rules listed below will
14 0. Is RCU being applied to a read-mostly situation? If the data
17 performance measurements show that RCU is nonetheless the right
18 tool for the job. Yes, RCU does reduce read-side overhead by
20 of RCU will do much more reading than updating.
22 Another exception is where performance is not an issue, and RCU
27 Yet another exception is where the low real-time latency of RCU's
30 One final exception is where RCU readers are used to prevent
40 RCU does allow *readers* to run (almost) naked, but *writers* must
[all …]
DUP.rst3 RCU on Uniprocessor Systems
18 Suppose that an RCU-based algorithm scans a linked list containing
40 Suppose that an RCU-based algorithm again scans a linked list containing
45 RCU usage, since call_rcu() must wait for a grace period to elapse.
48 underlying RCU, namely that call_rcu() defers invoking its arguments until
49 all RCU read-side critical sections currently executing have completed.
85 What locking restriction must RCU callbacks respect?
89 It is important to note that userspace RCU implementations *do*
93 Nevertheless, people writing userspace RCU implementations are strongly
100 Permitting call_rcu() to immediately invoke its arguments breaks RCU,
[all …]
Dlockdep-splat.rst4 Lockdep-RCU Splat
7 Lockdep-RCU was added to the Linux kernel in early 2010
9 misuses of the RCU API, most notably using one of the rcu_dereference()
10 family to access an RCU-protected pointer without the proper protection.
11 When such misuse is detected, an lockdep-RCU splat is emitted.
13 The usual cause of a lockdep-RCU splat is someone accessing an
14 RCU-protected data structure without either (1) being in the right kind of
15 RCU read-side critical section or (2) holding the right update-side lock.
20 So let's look at an example RCU lockdep splat from 3.0-rc5, one that
24 WARNING: suspicious RCU usage
[all …]
Dtorture.rst4 RCU Torture Test Operation
11 The CONFIG_RCU_TORTURE_TEST config option is available for all RCU
26rcu-torture:--- Start of test: nreaders=16 nfakewriters=4 stat_interval=30 verbose=0 test_no_idle_…
27rcu-torture: rtc: (null) ver: 155441 tfle: 0 rta: 155441 rtaf: 8884 rtf: 155440 rtmbe: 0…
28 rcu-torture: Reader Pipe: 727860534 34213 0 0 0 0 0 0 0 0 0
29 rcu-torture: Reader Batch: 727877838 17003 0 0 0 0 0 0 0 0 0
30rcu-torture: Free-Block Circulation: 155440 155440 155440 155440 155440 155440 155440 155440 1554…
31rcu-torture:--- End of test: SUCCESS: nreaders=16 nfakewriters=4 stat_interval=30 verbose=0 test_n…
36 the RCU torture test. The printk()s use KERN_ALERT, so they should
41 automatic determination as to whether RCU operated correctly.
[all …]
Drcubarrier.rst3 RCU and Unloadable Modules
8 RCU updaters sometimes use call_rcu() to initiate an asynchronous wait for
10 struct placed within the RCU-protected data structure and another pointer
16 call_rcu(&p->rcu, p_callback);
23 struct pstruct *p = container_of(rp, struct pstruct, rcu);
34 If we unload the module while some RCU callbacks are pending,
37 http://lwn.net/images/ns/kernel/rcu-drop.jpg.
45 heavy RCU-callback load, then some of the callbacks might be deferred in
56 outstanding RCU callbacks to complete. Please note that rcu_barrier()
57 does **not** imply synchronize_rcu(), in particular, if there are no RCU
[all …]
/linux-6.12.1/tools/memory-model/
Dlinux-kernel.cat54 let gp = po ; [Sync-rcu | Sync-srcu] ; po?
59 let barrier = fencerel(Barrier | Rmb | Wmb | Mb | Sync-rcu | Sync-srcu |
61 Rcu-lock | Rcu-unlock | Srcu-lock | Srcu-unlock) |
111 (* RCU *)
119 * In the definition of rcu-fence below, the po term at the left-hand side
121 * out. They have been moved into the definitions of rcu-link and rb.
124 let rcu-gp = [Sync-rcu] (* Compare with gp *)
126 let rcu-rscsi = rcu-rscs^-1
131 * one but two non-rf relations, but only in conjunction with an RCU
134 let rcu-link = po? ; hb* ; pb* ; prop ; po
[all …]
Dlinux-kernel.bell28 'rcu-lock (*rcu_read_lock*) ||
29 'rcu-unlock (*rcu_read_unlock*) ||
30 'sync-rcu (*synchronize_rcu*) ||
44 (* Compute matching pairs of nested Rcu-lock and Rcu-unlock *)
45 let rcu-rscs = let rec
46 unmatched-locks = Rcu-lock \ domain(matched)
47 and unmatched-unlocks = Rcu-unlock \ range(matched)
57 flag ~empty Rcu-lock \ domain(rcu-rscs) as unmatched-rcu-lock
58 flag ~empty Rcu-unlock \ range(rcu-rscs) as unmatched-rcu-unlock
69 (* Check for use of synchronize_srcu() inside an RCU critical section *)
[all …]
/linux-6.12.1/Documentation/RCU/Design/Requirements/
DRequirements.rst2 A Tour Through RCU's Requirements
18 Read-copy update (RCU) is a synchronization mechanism that is often used
19 as a replacement for reader-writer locking. RCU is unusual in that
20 updaters do not block readers, which means that RCU's read-side
23 this concurrency between RCU readers and updaters does raise the
24 question of exactly what RCU readers are doing, which in turn raises the
25 question of exactly what RCU's requirements are.
27 This document therefore summarizes RCU's requirements, and can be
28 thought of as an informal, high-level specification for RCU. It is
29 important to understand that RCU's specification is primarily empirical
[all …]
/linux-6.12.1/kernel/
Dcontext_tracking.c6 * This is used by RCU to remove its dependency on the timer tick while a CPU
16 * RCU extended quiescent state bits imported from kernel/rcu/tree.c
26 #include <trace/events/rcu.h>
41 /* Record the current task on exiting RCU-tasks (dyntick-idle entry). */
49 /* Record no current task on entering RCU-tasks (dyntick-idle exit). */
57 /* Turn on heavyweight RCU tasks trace readers on kernel exit. */
66 /* Turn off heavyweight RCU tasks trace readers on kernel entry. */
78 * RCU is watching prior to the call to this function and is no longer
86 * CPUs seeing atomic_add_return() must see prior RCU read-side in ct_kernel_exit_state()
92 // RCU is no longer watching. Better be in extended quiescent state! in ct_kernel_exit_state()
[all …]
/linux-6.12.1/include/linux/
Drcupdate.h50 // not-yet-completed RCU grace periods.
164 * Note a quasi-voluntary context switch for RCU-tasks's benefit.
234 * rcu_trace_implies_rcu_gp - does an RCU Tasks Trace grace period imply an RCU grace period?
236 * As an accident of implementation, an RCU Tasks Trace grace period also
237 * acts as an RCU grace period. However, this could change at any time.
246 * cond_resched_tasks_rcu_qs - Report potential quiescent states to RCU
249 * report potential quiescent states to RCU-tasks even if the cond_resched()
259 * rcu_softirq_qs_periodic - Report RCU and RCU-Tasks quiescent states
266 * provide both RCU and RCU-Tasks quiescent states. Note that this macro
269 * Because regions of code that have disabled softirq act as RCU read-side
[all …]
Drculist.h8 * RCU-protected list version
14 * INIT_LIST_HEAD_RCU - Initialize a list_head visible to RCU readers
29 * return the ->next pointer of a list_head in an rcu safe
45 * Check during list traversal that we are within an RCU reader
55 "RCU-list traversed in non-reader section!"); \
61 "RCU-list traversed without holding the required lock!");\
89 * list_add_rcu - add a new entry to rcu-protected list
110 * list_add_tail_rcu - add a new entry to rcu-protected list
136 * the entry is in an undefined state. It is useful for RCU based
152 * or call_rcu() must be used to defer freeing until an RCU
[all …]
/linux-6.12.1/Documentation/filesystems/
Dpath-lookup.txt22 Since 2.5.62 kernel, dcache has been using a new locking model that uses RCU to
34 Since 2.6.38, RCU is used to make a significant part of the entire path walk
36 even stores into cachelines of common dentries). This is known as "rcu-walk"
84 The hash lists are RCU protected, so list walking is not serialised with
85 concurrent updates (insertion, deletion from the hash). This is a standard RCU
100 Back to the rename case. In usual RCU protected lists, the only operations that
102 list. The object will not be reused until an RCU grace period is complete.
103 This ensures the RCU list traversal primitives can run over the object without
104 problems (see RCU documentation for how this works).
114 new list before waiting for a grace period, this can result in a concurrent RCU
[all …]
/linux-6.12.1/Documentation/devicetree/bindings/phy/
Dlantiq,vrx200-pcie-phy.yaml45 lantiq,rcu:
47 description: phandle to the RCU syscon
49 lantiq,rcu-endian-offset:
51 description: the offset of the endian registers for this PHY instance in the RCU syscon
53 lantiq,rcu-big-endian-mask:
73 - lantiq,rcu
74 - lantiq,rcu-endian-offset
75 - lantiq,rcu-big-endian-mask
84 lantiq,rcu = <&rcu0>;
85 lantiq,rcu-endian-offset = <0x4c>;
[all …]
/linux-6.12.1/tools/rcu/
Drcu-cbs.py4 # Dump out the number of RCU callbacks outstanding.
6 # On older kernels having multiple flavors of RCU, this dumps out the
9 # Usage: sudo drgn rcu-cbs.py
22 rdp0 = prog.variable('rcu_preempt_data', 'kernel/rcu/tree.c');
29 'kernel/rcu/tree.c');
34 rdp0 = prog.variable('rcu_data', 'kernel/rcu/tree.c');
39 # Sum up RCU callbacks.
44 # print("CPU " + str(cpu) + " RCU callbacks: " + str(len));
46 print("Number of RCU callbacks in flight: " + str(sum));
/linux-6.12.1/io_uring/
Deventfd.c17 struct rcu_head rcu; member
26 static void io_eventfd_free(struct rcu_head *rcu) in io_eventfd_free() argument
28 struct io_ev_fd *ev_fd = container_of(rcu, struct io_ev_fd, rcu); in io_eventfd_free()
34 static void io_eventfd_do_signal(struct rcu_head *rcu) in io_eventfd_do_signal() argument
36 struct io_ev_fd *ev_fd = container_of(rcu, struct io_ev_fd, rcu); in io_eventfd_do_signal()
41 io_eventfd_free(rcu); in io_eventfd_do_signal()
51 guard(rcu)(); in io_eventfd_signal() local
75 call_rcu_hurry(&ev_fd->rcu, io_eventfd_do_signal); in io_eventfd_signal()
81 call_rcu(&ev_fd->rcu, io_eventfd_free); in io_eventfd_signal()
156 call_rcu(&ev_fd->rcu, io_eventfd_free); in io_eventfd_unregister()
/linux-6.12.1/include/trace/events/
Drcu.h3 #define TRACE_SYSTEM rcu
48 * RCU flavor, the grace-period number, and a string identifying the
99 * "NoGPkthread": The RCU grace-period kthread has not yet started.
142 * distinguished by the type of RCU, the new grace-period number, the
145 * All but the type of RCU are extracted from the rcu_node structure.
179 * the RCU flavor, the expedited grace-period sequence number, and a string
216 * string identifying the RCU flavor, an integer identifying the rcu_node
254 * Tracepoint for RCU no-CBs CPU callback handoffs. This event is intended
257 * The first argument is the name of the RCU flavor, and the second is
307 * Tracepoint for tasks blocking within preemptible-RCU read-side
[all …]
/linux-6.12.1/Documentation/translations/it_IT/RCU/
Dtorture.rst6 Le operazioni RCU per le verifiche *torture*
13 RCU. L'opzione creerà un modulo rcutorture che potrete caricare per avviare le
26rcu-torture:--- Start of test: nreaders=16 nfakewriters=4 stat_interval=30 verbose=0 test_no_idle_…
27rcu-torture: rtc: (null) ver: 155441 tfle: 0 rta: 155441 rtaf: 8884 rtf: 155440 rtmbe: 0…
28 rcu-torture: Reader Pipe: 727860534 34213 0 0 0 0 0 0 0 0 0
29 rcu-torture: Reader Batch: 727877838 17003 0 0 0 0 0 0 0 0 0
30rcu-torture: Free-Block Circulation: 155440 155440 155440 155440 155440 155440 155440 155440 1554…
31rcu-torture:--- End of test: SUCCESS: nreaders=16 nfakewriters=4 stat_interval=30 verbose=0 test_n…
47 * "ver": Il numero di volte dall'avvio che il processo scrittore di RCU ha
52 illuderti che RCU stia funzionando mentre invece non è il caso. :-/
[all …]

12345678910>>...58