completion.txt 9.8 KB
Newer Older
1 2 3 4 5 6 7 8 9
completions - wait for completion handling
==========================================

This document was originally written based on 3.18.0 (linux-next)

Introduction:
-------------

If you have one or more threads of execution that must wait for some process
10 11 12
to have reached a point or a specific state, completions can provide a
race-free solution to this problem. Semantically they are somewhat like a
pthread_barrier and have similar use-cases.
13

14
Completions are a code synchronization mechanism which is preferable to any
15
misuse of locks. Any time you think of using yield() or some quirky
16
msleep(1) loop to allow something else to proceed, you probably want to
17
look into using one of the wait_for_completion*() calls instead. The
18
advantage of using completions is clear intent of the code, but also more
19 20 21 22
efficient code as both threads can continue until the result is actually
needed.

Completions are built on top of the generic event infrastructure in Linux,
23 24
with the event reduced to a simple flag (appropriately called "done") in
struct completion that tells the waiting threads of execution if they
25 26
can continue safely.

27
As completions are scheduling related, the code is found in
28 29 30 31 32 33 34
kernel/sched/completion.c - for details on completion design and
implementation see completions-design.txt


Usage:
------

35
There are three parts to using completions, the initialization of the
36
struct completion, the waiting part through a call to one of the variants of
37
wait_for_completion() and the signaling side through a call to complete()
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
or complete_all(). Further there are some helper functions for checking the
state of completions.

To use completions one needs to include <linux/completion.h> and
create a variable of type struct completion. The structure used for
handling of completions is:

	struct completion {
		unsigned int done;
		wait_queue_head_t wait;
	};

providing the wait queue to place tasks on for waiting and the flag for
indicating the state of affairs.

53
Completions should be named to convey the intent of the waiter. A good
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
example is:

	wait_for_completion(&early_console_added);

	complete(&early_console_added);

Good naming (as always) helps code readability.


Initializing completions:
-------------------------

Initialization of dynamically allocated completions, often embedded in
other structures, is done with:

	void init_completion(&done);

Initialization is accomplished by initializing the wait queue and setting
the default state to "not available", that is, "done" is set to 0.

The re-initialization function, reinit_completion(), simply resets the
done element to "not available", thus again to 0, without touching the
76
wait queue. Calling init_completion() twice on the same completion object is
77 78 79 80 81 82 83 84 85 86 87 88 89
most likely a bug as it re-initializes the queue to an empty queue and
enqueued tasks could get "lost" - use reinit_completion() in that case.

For static declaration and initialization, macros are available. These are:

	static DECLARE_COMPLETION(setup_done)

used for static declarations in file scope. Within functions the static
initialization should always use:

	DECLARE_COMPLETION_ONSTACK(setup_done)

suitable for automatic/local variables on the stack and will make lockdep
90
happy. Note also that one needs to make *sure* the completion passed to
91 92 93
work threads remains in-scope, and no references remain to on-stack data
when the initiating function returns.

94 95 96 97 98 99 100
Using on-stack completions for code that calls any of the _timeout or
_interruptible/_killable variants is not advisable as they will require
additional synchronization to prevent the on-stack completion object in
the timeout/signal cases from going out of scope. Consider using dynamically
allocated completions when intending to use the _interruptible/_killable
or _timeout variants of wait_for_completion().

101 102 103 104 105 106 107 108

Waiting for completions:
------------------------

For a thread of execution to wait for some concurrent work to finish, it
calls wait_for_completion() on the initialized completion structure.
A typical usage scenario is:

109
	struct completion setup_done;
110
	init_completion(&setup_done);
111
	initialize_work(...,&setup_done,...)
112 113 114

	/* run non-dependent code */              /* do setup */

115
	wait_for_completion(&setup_done);         complete(setup_done)
116

117
This is not implying any temporal order on wait_for_completion() and the
118 119
call to complete() - if the call to complete() happened before the call
to wait_for_completion() then the waiting side simply will continue
120 121
immediately as all dependencies are satisfied if not it will block until
completion is signaled by complete().
122

123
Note that wait_for_completion() is calling spin_lock_irq()/spin_unlock_irq(),
124
so it can only be called safely when you know that interrupts are enabled.
125 126
Calling it from hard-irq or irqs-off atomic contexts will result in
hard-to-detect spurious enabling of interrupts.
127 128 129 130 131

wait_for_completion():

	void wait_for_completion(struct completion *done):

132
The default behavior is to wait without a timeout and to mark the task as
133
uninterruptible. wait_for_completion() and its variants are only safe
134 135 136 137 138
in process context (as they can sleep) but not in atomic context,
interrupt context, with disabled irqs. or preemption is disabled - see also
try_wait_for_completion() below for handling completion in atomic/interrupt
context.

139
As all variants of wait_for_completion() can (obviously) block for a long
140
time, you probably don't want to call this with held mutexes.
141 142 143 144 145 146 147 148 149 150 151 152 153 154


Variants available:
-------------------

The below variants all return status and this status should be checked in
most(/all) cases - in cases where the status is deliberately not checked you
probably want to make a note explaining this (e.g. see
arch/arm/kernel/smp.c:__cpu_up()).

A common problem that occurs is to have unclean assignment of return types,
so care should be taken with assigning return-values to variables of proper
type. Checking for the specific meaning of return values also has been found
to be quite inaccurate e.g. constructs like
155
if (!wait_for_completion_interruptible_timeout(...)) would execute the same
156 157 158 159 160
code path for successful completion and for the interrupted case - which is
probably not what you want.

	int wait_for_completion_interruptible(struct completion *done)

161
This function marks the task TASK_INTERRUPTIBLE. If a signal was received
162
while waiting it will return -ERESTARTSYS; 0 otherwise.
163 164 165 166

	unsigned long wait_for_completion_timeout(struct completion *done,
		unsigned long timeout)

167 168
The task is marked as TASK_UNINTERRUPTIBLE and will wait at most 'timeout'
(in jiffies). If timeout occurs it returns 0 else the remaining time in
169 170 171 172
jiffies (but at least 1). Timeouts are preferably calculated with
msecs_to_jiffies() or usecs_to_jiffies(). If the returned timeout value is
deliberately ignored a comment should probably explain why (e.g. see
drivers/mfd/wm8350-core.c wm8350_read_auxadc())
173 174 175 176

	long wait_for_completion_interruptible_timeout(
		struct completion *done, unsigned long timeout)

177 178 179 180
This function passes a timeout in jiffies and marks the task as
TASK_INTERRUPTIBLE. If a signal was received it will return -ERESTARTSYS;
otherwise it returns 0 if the completion timed out or the remaining time in
jiffies if completion occurred.
181

182 183 184
Further variants include _killable which uses TASK_KILLABLE as the
designated tasks state and will return -ERESTARTSYS if it is interrupted or
else 0 if completion was achieved.  There is a _timeout variant as well:
185 186 187 188 189

	long wait_for_completion_killable(struct completion *done)
	long wait_for_completion_killable_timeout(struct completion *done,
		unsigned long timeout)

190
The _io variants wait_for_completion_io() behave the same as the non-_io
191
variants, except for accounting waiting time as waiting on IO, which has
192
an impact on how the task is accounted in scheduling stats.
193 194 195 196 197 198 199 200 201

	void wait_for_completion_io(struct completion *done)
	unsigned long wait_for_completion_io_timeout(struct completion *done
		unsigned long timeout)


Signaling completions:
----------------------

202 203 204
A thread that wants to signal that the conditions for continuation have been
achieved calls complete() to signal exactly one of the waiters that it can
continue.
205 206 207

	void complete(struct completion *done)

208
or calls complete_all() to signal all current and future waiters.
209 210 211 212 213 214 215 216 217 218 219

	void complete_all(struct completion *done)

The signaling will work as expected even if completions are signaled before
a thread starts waiting. This is achieved by the waiter "consuming"
(decrementing) the done element of struct completion. Waiting threads
wakeup order is the same in which they were enqueued (FIFO order).

If complete() is called multiple times then this will allow for that number
of waiters to continue - each call to complete() will simply increment the
done element. Calling complete_all() multiple times is a bug though. Both
220
complete() and complete_all() can be called in hard-irq/atomic context safely.
221 222

There only can be one thread calling complete() or complete_all() on a
223
particular struct completion at any time - serialized through the wait
224 225 226 227
queue spinlock. Any such concurrent calls to complete() or complete_all()
probably are a design bug.

Signaling completion from hard-irq context is fine as it will appropriately
228
lock with spin_lock_irqsave/spin_unlock_irqrestore and it will never sleep.
229 230 231 232 233


try_wait_for_completion()/completion_done():
--------------------------------------------

234 235
The try_wait_for_completion() function will not put the thread on the wait
queue but rather returns false if it would need to enqueue (block) the thread,
236
else it consumes one posted completion and returns true.
237

238
	bool try_wait_for_completion(struct completion *done)
239

240 241 242 243
Finally, to check the state of a completion without changing it in any way, 
call completion_done(), which returns false if there are no posted
completions that were not yet consumed by waiters (implying that there are
waiters) and true otherwise;
244

245
	bool completion_done(struct completion *done)
246 247

Both try_wait_for_completion() and completion_done() are safe to be called in
248
hard-irq or atomic context.