Merge tag '6.7-rc-smb3-client-fixes-part1' of git://git.samba.org/sfrench/cifs-2.6
[linux-block.git] / Documentation / scheduler / completion.rst
CommitLineData
d6a3b247 1================================================
0c373344
IM
2Completions - "wait for completion" barrier APIs
3================================================
202799be
NMG
4
5Introduction:
6-------------
7
0c373344 8If you have one or more threads that must wait for some kernel activity
7085f6c3
JC
9to have reached a point or a specific state, completions can provide a
10race-free solution to this problem. Semantically they are somewhat like a
0c373344 11pthread_barrier() and have similar use-cases.
202799be 12
7085f6c3 13Completions are a code synchronization mechanism which is preferable to any
0c373344
IM
14misuse of locks/semaphores and busy-loops. Any time you think of using
15yield() or some quirky msleep(1) loop to allow something else to proceed,
16you probably want to look into using one of the wait_for_completion*()
17calls and complete() instead.
18
19The advantage of using completions is that they have a well defined, focused
20purpose which makes it very easy to see the intent of the code, but they
21also result in more efficient code as all threads can continue execution
22until the result is actually needed, and both the waiting and the signalling
23is highly efficient using low level scheduler sleep/wakeup facilities.
24
25Completions are built on top of the waitqueue and wakeup infrastructure of
26the Linux scheduler. The event the threads on the waitqueue are waiting for
27is reduced to a simple flag in 'struct completion', appropriately called "done".
28
29As completions are scheduling related, the code can be found in
dc92726e 30kernel/sched/completion.c.
202799be
NMG
31
32
33Usage:
34------
35
0c373344
IM
36There are three main parts to using completions:
37
38 - the initialization of the 'struct completion' synchronization object
39 - the waiting part through a call to one of the variants of wait_for_completion(),
40 - the signaling side through a call to complete() or complete_all().
41
42There are also some helper functions for checking the state of completions.
43Note that while initialization must happen first, the waiting and signaling
44part can happen in any order. I.e. it's entirely normal for a thread
45to have marked a completion as 'done' before another thread checks whether
46it has to wait for it.
202799be 47
0c373344
IM
48To use completions you need to #include <linux/completion.h> and
49create a static or dynamic variable of type 'struct completion',
d6a3b247 50which has only two fields::
202799be
NMG
51
52 struct completion {
53 unsigned int done;
54 wait_queue_head_t wait;
55 };
56
0c373344
IM
57This provides the ->wait waitqueue to place tasks on for waiting (if any), and
58the ->done completion flag for indicating whether it's completed or not.
202799be 59
0c373344 60Completions should be named to refer to the event that is being synchronized on.
d6a3b247 61A good example is::
202799be
NMG
62
63 wait_for_completion(&early_console_added);
64
65 complete(&early_console_added);
66
0c373344
IM
67Good, intuitive naming (as always) helps code readability. Naming a completion
68'complete' is not helpful unless the purpose is super obvious...
202799be
NMG
69
70
71Initializing completions:
72-------------------------
73
11e13696
NMG
74Dynamically allocated completion objects should preferably be embedded in data
75structures that are assured to be alive for the life-time of the function/driver,
76to prevent races with asynchronous complete() calls from occurring.
77
78Particular care should be taken when using the _timeout() or _killable()/_interruptible()
79variants of wait_for_completion(), as it must be assured that memory de-allocation
80does not happen until all related activities (complete() or reinit_completion())
81have taken place, even if these wait functions return prematurely due to a timeout
82or a signal triggering.
83
84Initializing of dynamically allocated completion objects is done via a call to
d6a3b247 85init_completion()::
202799be 86
0c373344 87 init_completion(&dynamic_object->done);
202799be 88
0c373344
IM
89In this call we initialize the waitqueue and set ->done to 0, i.e. "not completed"
90or "not done".
202799be
NMG
91
92The re-initialization function, reinit_completion(), simply resets the
0c373344
IM
93->done field to 0 ("not done"), without touching the waitqueue.
94Callers of this function must make sure that there are no racy
95wait_for_completion() calls going on in parallel.
96
97Calling init_completion() on the same completion object twice is
202799be 98most likely a bug as it re-initializes the queue to an empty queue and
0c373344
IM
99enqueued tasks could get "lost" - use reinit_completion() in that case,
100but be aware of other races.
202799be 101
0c373344 102For static declaration and initialization, macros are available.
202799be 103
d6a3b247
MCC
104For static (or global) declarations in file scope you can use
105DECLARE_COMPLETION()::
202799be 106
0c373344
IM
107 static DECLARE_COMPLETION(setup_done);
108 DECLARE_COMPLETION(setup_done);
202799be 109
0c373344
IM
110Note that in this case the completion is boot time (or module load time)
111initialized to 'not done' and doesn't require an init_completion() call.
202799be 112
0c373344 113When a completion is declared as a local variable within a function,
11e13696
NMG
114then the initialization should always use DECLARE_COMPLETION_ONSTACK()
115explicitly, not just to make lockdep happy, but also to make it clear
d6a3b247 116that limited scope had been considered and is intentional::
202799be 117
0c373344
IM
118 DECLARE_COMPLETION_ONSTACK(setup_done)
119
0c373344 120Note that when using completion objects as local variables you must be
11e13696
NMG
121acutely aware of the short life time of the function stack: the function
122must not return to a calling context until all activities (such as waiting
123threads) have ceased and the completion object is completely unused.
124
125To emphasise this again: in particular when using some of the waiting API variants
126with more complex outcomes, such as the timeout or signalling (_timeout(),
127_killable() and _interruptible()) variants, the wait might complete
128prematurely while the object might still be in use by another thread - and a return
129from the wait_on_completion*() caller function will deallocate the function
130stack and cause subtle data corruption if a complete() is done in some
131other thread. Simple testing might not trigger these kinds of races.
132
133If unsure, use dynamically allocated completion objects, preferably embedded
134in some other long lived object that has a boringly long life time which
135exceeds the life time of any helper threads using the completion object,
136or has a lock or other synchronization mechanism to make sure complete()
137is not called on a freed object.
138
139A naive DECLARE_COMPLETION() on the stack triggers a lockdep warning.
202799be
NMG
140
141Waiting for completions:
142------------------------
143
0c373344 144For a thread to wait for some concurrent activity to finish, it
d6a3b247 145calls wait_for_completion() on the initialized completion structure::
0c373344
IM
146
147 void wait_for_completion(struct completion *done)
148
d6a3b247 149A typical usage scenario is::
202799be 150
0c373344
IM
151 CPU#1 CPU#2
152
7085f6c3 153 struct completion setup_done;
0c373344 154
202799be 155 init_completion(&setup_done);
0c373344 156 initialize_work(...,&setup_done,...);
202799be 157
0c373344 158 /* run non-dependent code */ /* do setup */
202799be 159
f98b161b 160 wait_for_completion(&setup_done); complete(&setup_done);
202799be 161
0c373344
IM
162This is not implying any particular order between wait_for_completion() and
163the call to complete() - if the call to complete() happened before the call
202799be 164to wait_for_completion() then the waiting side simply will continue
7b6abce7 165immediately as all dependencies are satisfied; if not, it will block until
4988aaa6 166completion is signaled by complete().
202799be 167
7085f6c3 168Note that wait_for_completion() is calling spin_lock_irq()/spin_unlock_irq(),
202799be 169so it can only be called safely when you know that interrupts are enabled.
0c373344
IM
170Calling it from IRQs-off atomic contexts will result in hard-to-detect
171spurious enabling of interrupts.
202799be 172
7085f6c3 173The default behavior is to wait without a timeout and to mark the task as
202799be 174uninterruptible. wait_for_completion() and its variants are only safe
4988aaa6 175in process context (as they can sleep) but not in atomic context,
0c373344 176interrupt context, with disabled IRQs, or preemption is disabled - see also
4988aaa6
NMG
177try_wait_for_completion() below for handling completion in atomic/interrupt
178context.
179
202799be 180As all variants of wait_for_completion() can (obviously) block for a long
0c373344
IM
181time depending on the nature of the activity they are waiting for, so in
182most cases you probably don't want to call this with held mutexes.
202799be
NMG
183
184
0c373344
IM
185wait_for_completion*() variants available:
186------------------------------------------
202799be
NMG
187
188The below variants all return status and this status should be checked in
189most(/all) cases - in cases where the status is deliberately not checked you
190probably want to make a note explaining this (e.g. see
191arch/arm/kernel/smp.c:__cpu_up()).
192
193A common problem that occurs is to have unclean assignment of return types,
0c373344
IM
194so take care to assign return-values to variables of the proper type.
195
196Checking for the specific meaning of return values also has been found
d6a3b247 197to be quite inaccurate, e.g. constructs like::
0c373344
IM
198
199 if (!wait_for_completion_interruptible_timeout(...))
200
201... would execute the same code path for successful completion and for the
d6a3b247 202interrupted case - which is probably not what you want::
202799be
NMG
203
204 int wait_for_completion_interruptible(struct completion *done)
205
0c373344 206This function marks the task TASK_INTERRUPTIBLE while it is waiting.
d6a3b247 207If a signal was received while waiting it will return -ERESTARTSYS; 0 otherwise::
202799be 208
0c373344 209 unsigned long wait_for_completion_timeout(struct completion *done, unsigned long timeout)
202799be 210
4988aaa6 211The task is marked as TASK_UNINTERRUPTIBLE and will wait at most 'timeout'
0c373344
IM
212jiffies. If a timeout occurs it returns 0, else the remaining time in
213jiffies (but at least 1).
214
215Timeouts are preferably calculated with msecs_to_jiffies() or usecs_to_jiffies(),
216to make the code largely HZ-invariant.
217
218If the returned timeout value is deliberately ignored a comment should probably explain
d6a3b247 219why (e.g. see drivers/mfd/wm8350-core.c wm8350_read_auxadc())::
202799be 220
0c373344 221 long wait_for_completion_interruptible_timeout(struct completion *done, unsigned long timeout)
202799be 222
7085f6c3
JC
223This function passes a timeout in jiffies and marks the task as
224TASK_INTERRUPTIBLE. If a signal was received it will return -ERESTARTSYS;
0c373344 225otherwise it returns 0 if the completion timed out, or the remaining time in
7085f6c3 226jiffies if completion occurred.
202799be 227
7085f6c3 228Further variants include _killable which uses TASK_KILLABLE as the
0c373344 229designated tasks state and will return -ERESTARTSYS if it is interrupted,
d6a3b247 230or 0 if completion was achieved. There is a _timeout variant as well::
202799be
NMG
231
232 long wait_for_completion_killable(struct completion *done)
0c373344 233 long wait_for_completion_killable_timeout(struct completion *done, unsigned long timeout)
202799be 234
4988aaa6 235The _io variants wait_for_completion_io() behave the same as the non-_io
0c373344 236variants, except for accounting waiting time as 'waiting on IO', which has
d6a3b247 237an impact on how the task is accounted in scheduling/IO stats::
202799be
NMG
238
239 void wait_for_completion_io(struct completion *done)
0c373344 240 unsigned long wait_for_completion_io_timeout(struct completion *done, unsigned long timeout)
202799be
NMG
241
242
243Signaling completions:
244----------------------
245
4988aaa6
NMG
246A thread that wants to signal that the conditions for continuation have been
247achieved calls complete() to signal exactly one of the waiters that it can
d6a3b247 248continue::
202799be
NMG
249
250 void complete(struct completion *done)
251
d6a3b247 252... or calls complete_all() to signal all current and future waiters::
202799be
NMG
253
254 void complete_all(struct completion *done)
255
256The signaling will work as expected even if completions are signaled before
257a thread starts waiting. This is achieved by the waiter "consuming"
0c373344 258(decrementing) the done field of 'struct completion'. Waiting threads
202799be
NMG
259wakeup order is the same in which they were enqueued (FIFO order).
260
261If complete() is called multiple times then this will allow for that number
262of waiters to continue - each call to complete() will simply increment the
0c373344
IM
263done field. Calling complete_all() multiple times is a bug though. Both
264complete() and complete_all() can be called in IRQ/atomic context safely.
202799be 265
0c373344
IM
266There can only be one thread calling complete() or complete_all() on a
267particular 'struct completion' at any time - serialized through the wait
202799be
NMG
268queue spinlock. Any such concurrent calls to complete() or complete_all()
269probably are a design bug.
270
0c373344 271Signaling completion from IRQ context is fine as it will appropriately
01aa9d51 272lock with spin_lock_irqsave()/spin_unlock_irqrestore() and it will never
d6a3b247 273sleep.
202799be
NMG
274
275
276try_wait_for_completion()/completion_done():
277--------------------------------------------
278
4988aaa6
NMG
279The try_wait_for_completion() function will not put the thread on the wait
280queue but rather returns false if it would need to enqueue (block) the thread,
d6a3b247 281else it consumes one posted completion and returns true::
202799be 282
4988aaa6 283 bool try_wait_for_completion(struct completion *done)
202799be 284
0c373344 285Finally, to check the state of a completion without changing it in any way,
7085f6c3
JC
286call completion_done(), which returns false if there are no posted
287completions that were not yet consumed by waiters (implying that there are
d6a3b247 288waiters) and true otherwise::
202799be 289
4988aaa6 290 bool completion_done(struct completion *done)
202799be
NMG
291
292Both try_wait_for_completion() and completion_done() are safe to be called in
0c373344 293IRQ or atomic context.