blob: 656cf803c006200c37f81628f6f895d059556e70 [file] [log] [blame]
Nicholas Mc Guire202799b2015-01-30 08:01:52 +01001completions - wait for completion handling
2==========================================
3
4This document was originally written based on 3.18.0 (linux-next)
5
6Introduction:
7-------------
8
9If you have one or more threads of execution that must wait for some process
Jonathan Corbet7085f6c2015-03-27 10:16:35 -060010to have reached a point or a specific state, completions can provide a
11race-free solution to this problem. Semantically they are somewhat like a
12pthread_barrier and have similar use-cases.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010013
Jonathan Corbet7085f6c2015-03-27 10:16:35 -060014Completions are a code synchronization mechanism which is preferable to any
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010015misuse of locks. Any time you think of using yield() or some quirky
Jonathan Corbet7085f6c2015-03-27 10:16:35 -060016msleep(1) loop to allow something else to proceed, you probably want to
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010017look into using one of the wait_for_completion*() calls instead. The
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050018advantage of using completions is clear intent of the code, but also more
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010019efficient code as both threads can continue until the result is actually
20needed.
21
22Completions are built on top of the generic event infrastructure in Linux,
Jonathan Corbet7085f6c2015-03-27 10:16:35 -060023with the event reduced to a simple flag (appropriately called "done") in
24struct completion that tells the waiting threads of execution if they
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010025can continue safely.
26
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050027As completions are scheduling related, the code is found in
Brian Norrisdc927262016-11-15 14:42:14 -080028kernel/sched/completion.c.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010029
30
31Usage:
32------
33
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050034There are three parts to using completions, the initialization of the
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010035struct completion, the waiting part through a call to one of the variants of
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050036wait_for_completion() and the signaling side through a call to complete()
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010037or complete_all(). Further there are some helper functions for checking the
38state of completions.
39
40To use completions one needs to include <linux/completion.h> and
41create a variable of type struct completion. The structure used for
42handling of completions is:
43
44 struct completion {
45 unsigned int done;
46 wait_queue_head_t wait;
47 };
48
49providing the wait queue to place tasks on for waiting and the flag for
50indicating the state of affairs.
51
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050052Completions should be named to convey the intent of the waiter. A good
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010053example is:
54
55 wait_for_completion(&early_console_added);
56
57 complete(&early_console_added);
58
59Good naming (as always) helps code readability.
60
61
62Initializing completions:
63-------------------------
64
65Initialization of dynamically allocated completions, often embedded in
66other structures, is done with:
67
68 void init_completion(&done);
69
70Initialization is accomplished by initializing the wait queue and setting
71the default state to "not available", that is, "done" is set to 0.
72
73The re-initialization function, reinit_completion(), simply resets the
74done element to "not available", thus again to 0, without touching the
Jonathan Corbet7085f6c2015-03-27 10:16:35 -060075wait queue. Calling init_completion() twice on the same completion object is
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010076most likely a bug as it re-initializes the queue to an empty queue and
77enqueued tasks could get "lost" - use reinit_completion() in that case.
78
79For static declaration and initialization, macros are available. These are:
80
81 static DECLARE_COMPLETION(setup_done)
82
83used for static declarations in file scope. Within functions the static
84initialization should always use:
85
86 DECLARE_COMPLETION_ONSTACK(setup_done)
87
88suitable for automatic/local variables on the stack and will make lockdep
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050089happy. Note also that one needs to make *sure* the completion passed to
Nicholas Mc Guire202799b2015-01-30 08:01:52 +010090work threads remains in-scope, and no references remain to on-stack data
91when the initiating function returns.
92
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -050093Using on-stack completions for code that calls any of the _timeout or
94_interruptible/_killable variants is not advisable as they will require
95additional synchronization to prevent the on-stack completion object in
96the timeout/signal cases from going out of scope. Consider using dynamically
97allocated completions when intending to use the _interruptible/_killable
98or _timeout variants of wait_for_completion().
99
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100100
101Waiting for completions:
102------------------------
103
104For a thread of execution to wait for some concurrent work to finish, it
105calls wait_for_completion() on the initialized completion structure.
106A typical usage scenario is:
107
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600108 struct completion setup_done;
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100109 init_completion(&setup_done);
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500110 initialize_work(...,&setup_done,...)
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100111
112 /* run non-dependent code */ /* do setup */
113
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500114 wait_for_completion(&setup_done); complete(setup_done)
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100115
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500116This is not implying any temporal order on wait_for_completion() and the
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100117call to complete() - if the call to complete() happened before the call
118to wait_for_completion() then the waiting side simply will continue
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500119immediately as all dependencies are satisfied if not it will block until
120completion is signaled by complete().
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100121
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600122Note that wait_for_completion() is calling spin_lock_irq()/spin_unlock_irq(),
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100123so it can only be called safely when you know that interrupts are enabled.
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600124Calling it from hard-irq or irqs-off atomic contexts will result in
125hard-to-detect spurious enabling of interrupts.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100126
127wait_for_completion():
128
129 void wait_for_completion(struct completion *done):
130
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600131The default behavior is to wait without a timeout and to mark the task as
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100132uninterruptible. wait_for_completion() and its variants are only safe
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500133in process context (as they can sleep) but not in atomic context,
134interrupt context, with disabled irqs. or preemption is disabled - see also
135try_wait_for_completion() below for handling completion in atomic/interrupt
136context.
137
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100138As all variants of wait_for_completion() can (obviously) block for a long
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500139time, you probably don't want to call this with held mutexes.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100140
141
142Variants available:
143-------------------
144
145The below variants all return status and this status should be checked in
146most(/all) cases - in cases where the status is deliberately not checked you
147probably want to make a note explaining this (e.g. see
148arch/arm/kernel/smp.c:__cpu_up()).
149
150A common problem that occurs is to have unclean assignment of return types,
151so care should be taken with assigning return-values to variables of proper
152type. Checking for the specific meaning of return values also has been found
153to be quite inaccurate e.g. constructs like
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500154if (!wait_for_completion_interruptible_timeout(...)) would execute the same
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100155code path for successful completion and for the interrupted case - which is
156probably not what you want.
157
158 int wait_for_completion_interruptible(struct completion *done)
159
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500160This function marks the task TASK_INTERRUPTIBLE. If a signal was received
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600161while waiting it will return -ERESTARTSYS; 0 otherwise.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100162
163 unsigned long wait_for_completion_timeout(struct completion *done,
164 unsigned long timeout)
165
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500166The task is marked as TASK_UNINTERRUPTIBLE and will wait at most 'timeout'
167(in jiffies). If timeout occurs it returns 0 else the remaining time in
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600168jiffies (but at least 1). Timeouts are preferably calculated with
169msecs_to_jiffies() or usecs_to_jiffies(). If the returned timeout value is
170deliberately ignored a comment should probably explain why (e.g. see
171drivers/mfd/wm8350-core.c wm8350_read_auxadc())
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100172
173 long wait_for_completion_interruptible_timeout(
174 struct completion *done, unsigned long timeout)
175
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600176This function passes a timeout in jiffies and marks the task as
177TASK_INTERRUPTIBLE. If a signal was received it will return -ERESTARTSYS;
178otherwise it returns 0 if the completion timed out or the remaining time in
179jiffies if completion occurred.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100180
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600181Further variants include _killable which uses TASK_KILLABLE as the
182designated tasks state and will return -ERESTARTSYS if it is interrupted or
183else 0 if completion was achieved. There is a _timeout variant as well:
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100184
185 long wait_for_completion_killable(struct completion *done)
186 long wait_for_completion_killable_timeout(struct completion *done,
187 unsigned long timeout)
188
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500189The _io variants wait_for_completion_io() behave the same as the non-_io
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100190variants, except for accounting waiting time as waiting on IO, which has
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500191an impact on how the task is accounted in scheduling stats.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100192
193 void wait_for_completion_io(struct completion *done)
194 unsigned long wait_for_completion_io_timeout(struct completion *done
195 unsigned long timeout)
196
197
198Signaling completions:
199----------------------
200
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500201A thread that wants to signal that the conditions for continuation have been
202achieved calls complete() to signal exactly one of the waiters that it can
203continue.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100204
205 void complete(struct completion *done)
206
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500207or calls complete_all() to signal all current and future waiters.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100208
209 void complete_all(struct completion *done)
210
211The signaling will work as expected even if completions are signaled before
212a thread starts waiting. This is achieved by the waiter "consuming"
213(decrementing) the done element of struct completion. Waiting threads
214wakeup order is the same in which they were enqueued (FIFO order).
215
216If complete() is called multiple times then this will allow for that number
217of waiters to continue - each call to complete() will simply increment the
218done element. Calling complete_all() multiple times is a bug though. Both
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500219complete() and complete_all() can be called in hard-irq/atomic context safely.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100220
221There only can be one thread calling complete() or complete_all() on a
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500222particular struct completion at any time - serialized through the wait
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100223queue spinlock. Any such concurrent calls to complete() or complete_all()
224probably are a design bug.
225
226Signaling completion from hard-irq context is fine as it will appropriately
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500227lock with spin_lock_irqsave/spin_unlock_irqrestore and it will never sleep.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100228
229
230try_wait_for_completion()/completion_done():
231--------------------------------------------
232
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500233The try_wait_for_completion() function will not put the thread on the wait
234queue but rather returns false if it would need to enqueue (block) the thread,
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600235else it consumes one posted completion and returns true.
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100236
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500237 bool try_wait_for_completion(struct completion *done)
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100238
Jonathan Corbet7085f6c2015-03-27 10:16:35 -0600239Finally, to check the state of a completion without changing it in any way,
240call completion_done(), which returns false if there are no posted
241completions that were not yet consumed by waiters (implying that there are
242waiters) and true otherwise;
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100243
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500244 bool completion_done(struct completion *done)
Nicholas Mc Guire202799b2015-01-30 08:01:52 +0100245
246Both try_wait_for_completion() and completion_done() are safe to be called in
Nicholas Mc Guire4988aaa2015-02-20 12:28:48 -0500247hard-irq or atomic context.