Commit 2197f9a1 authored by Steffen Klassert's avatar Steffen Klassert Committed by Herbert Xu

padata: update documentation

This patch updates the padata documentation to the changed
API of padata_start/padata_stop and padata_do parallel.
Signed-off-by: default avatarSteffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 5f1a8c1b
...@@ -22,12 +22,15 @@ actually be done; it should be a multithreaded queue, naturally. ...@@ -22,12 +22,15 @@ actually be done; it should be a multithreaded queue, naturally.
There are functions for enabling and disabling the instance: There are functions for enabling and disabling the instance:
void padata_start(struct padata_instance *pinst); int padata_start(struct padata_instance *pinst);
void padata_stop(struct padata_instance *pinst); void padata_stop(struct padata_instance *pinst);
These functions literally do nothing beyond setting or clearing the These functions are setting or clearing the "PADATA_INIT" flag;
"padata_start() was called" flag; if that flag is not set, other functions if that flag is not set, other functions will refuse to work.
will refuse to work. padata_start returns zero on success (flag set) or -EINVAL if the
padata cpumask contains no active cpu (flag not set).
padata_stop clears the flag and blocks until the padata instance
is unused.
The list of CPUs to be used can be adjusted with these functions: The list of CPUs to be used can be adjusted with these functions:
...@@ -63,12 +66,10 @@ The submission of work is done with: ...@@ -63,12 +66,10 @@ The submission of work is done with:
The pinst and padata structures must be set up as described above; cb_cpu The pinst and padata structures must be set up as described above; cb_cpu
specifies which CPU will be used for the final callback when the work is specifies which CPU will be used for the final callback when the work is
done; it must be in the current instance's CPU mask. The return value from done; it must be in the current instance's CPU mask. The return value from
padata_do_parallel() is a little strange; zero is an error return padata_do_parallel() is zero on success, indicating that the work is in
indicating that the caller forgot the padata_start() formalities. -EBUSY progress. -EBUSY means that somebody, somewhere else is messing with the
means that somebody, somewhere else is messing with the instance's CPU instance's CPU mask, while -EINVAL is a complaint about cb_cpu not being
mask, while -EINVAL is a complaint about cb_cpu not being in that CPU mask. in that CPU mask or about a not running instance.
If all goes well, this function will return -EINPROGRESS, indicating that
the work is in progress.
Each task submitted to padata_do_parallel() will, in turn, be passed to Each task submitted to padata_do_parallel() will, in turn, be passed to
exactly one call to the above-mentioned parallel() function, on one CPU, so exactly one call to the above-mentioned parallel() function, on one CPU, so
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment