sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}(hhparenthuba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget#/translations/zh_CN/core-api/padatamodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}(hhhh2ubah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/zh_TW/core-api/padatamodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}(hhhhFubah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/it_IT/core-api/padatamodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}(hhhhZubah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/ja_JP/core-api/padatamodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}(hhhhnubah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/ko_KR/core-api/padatamodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}(hhhhubah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/sp_SP/core-api/padatamodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhcomment)}(h SPDX-License-Identifier: GPL-2.0h]h SPDX-License-Identifier: GPL-2.0}(hhhhubah}(h]h ]h"]h$]h&] xml:spacepreserveuh1hhhhhh=/var/lib/git/docbuild/linux/Documentation/core-api/padata.rsthKubhsection)}(hhh](htitle)}(h'The padata parallel execution mechanismh]h'The padata parallel execution mechanism}(hhhhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhhhKubh field_list)}(hhh]hfield)}(hhh](h field_name)}(hDateh]hDate}(hhhhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhKubh field_body)}(h May 2020 h]h paragraph)}(hMay 2020h]hMay 2020}(hhhhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhubah}(h]h ]h"]h$]h&]uh1hhhubeh}(h]h ]h"]h$]h&]uh1hhhhKhhhhubah}(h]h ]h"]h$]h&]uh1hhhhhhhhKubh)}(hPadata is a mechanism by which the kernel can farm jobs out to be done in parallel on multiple CPUs while optionally retaining their ordering.h]hPadata is a mechanism by which the kernel can farm jobs out to be done in parallel on multiple CPUs while optionally retaining their ordering.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hhhhubh)}(hIt was originally developed for IPsec, which needs to perform encryption and decryption on large numbers of packets without reordering those packets. This is currently the sole consumer of padata's serialized job support.h]hIt was originally developed for IPsec, which needs to perform encryption and decryption on large numbers of packets without reordering those packets. This is currently the sole consumer of padata’s serialized job support.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hhhhubh)}(h{Padata also supports multithreaded jobs, splitting up the job evenly while load balancing and coordinating between threads.h]h{Padata also supports multithreaded jobs, splitting up the job evenly while load balancing and coordinating between threads.}(hj)hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh)}(hhh](h)}(hRunning Serialized Jobsh]hRunning Serialized Jobs}(hj:hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hhhhhKubh)}(hhh](h)}(h Initializingh]h Initializing}(hjKhjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhhhhhKubh)}(hThe first step in using padata to run serialized jobs is to set up a padata_instance structure for overall control of how jobs are to be run::h]hThe first step in using padata to run serialized jobs is to set up a padata_instance structure for overall control of how jobs are to be run:}(hThe first step in using padata to run serialized jobs is to set up a padata_instance structure for overall control of how jobs are to be run:hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjFhhubh literal_block)}(hR#include struct padata_instance *padata_alloc(const char *name);h]hR#include struct padata_instance *padata_alloc(const char *name);}(hhhjhubah}(h]h ]h"]h$]h&]hhuh1jfhhhKhjFhhubh)}(h&'name' simply identifies the instance.h]h*‘name’ simply identifies the instance.}(hjxhjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hjFhhubh)}(hCThen, complete padata initialization by allocating a padata_shell::h]hBThen, complete padata initialization by allocating a padata_shell:}(hBThen, complete padata initialization by allocating a padata_shell:hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK"hjFhhubjg)}(hGstruct padata_shell *padata_alloc_shell(struct padata_instance *pinst);h]hGstruct padata_shell *padata_alloc_shell(struct padata_instance *pinst);}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhhhK$hjFhhubh)}(hA padata_shell is used to submit a job to padata and allows a series of such jobs to be serialized independently. A padata_instance may have one or more padata_shells associated with it, each allowing a separate series of jobs.h]hA padata_shell is used to submit a job to padata and allows a series of such jobs to be serialized independently. A padata_instance may have one or more padata_shells associated with it, each allowing a separate series of jobs.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK&hjFhhubeh}(h] initializingah ]h"] initializingah$]h&]uh1hhj5hhhhhKubh)}(hhh](h)}(hModifying cpumasksh]hModifying cpumasks}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK+ubh)}(hThe CPUs used to run jobs can be changed in two ways, programmatically with padata_set_cpumask() or via sysfs. The former is defined::h]hThe CPUs used to run jobs can be changed in two ways, programmatically with padata_set_cpumask() or via sysfs. The former is defined:}(hThe CPUs used to run jobs can be changed in two ways, programmatically with padata_set_cpumask() or via sysfs. The former is defined:hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK-hjhhubjg)}(hvint padata_set_cpumask(struct padata_instance *pinst, int cpumask_type, cpumask_var_t cpumask);h]hvint padata_set_cpumask(struct padata_instance *pinst, int cpumask_type, cpumask_var_t cpumask);}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhhhK0hjhhubh)}(hXUHere cpumask_type is one of PADATA_CPU_PARALLEL or PADATA_CPU_SERIAL, where a parallel cpumask describes which processors will be used to execute jobs submitted to this instance in parallel and a serial cpumask defines which processors are allowed to be used as the serialization callback processor. cpumask specifies the new cpumask to use.h]hXUHere cpumask_type is one of PADATA_CPU_PARALLEL or PADATA_CPU_SERIAL, where a parallel cpumask describes which processors will be used to execute jobs submitted to this instance in parallel and a serial cpumask defines which processors are allowed to be used as the serialization callback processor. cpumask specifies the new cpumask to use.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK3hjhhubh)}(hX%There may be sysfs files for an instance's cpumasks. For example, pcrypt's live in /sys/kernel/pcrypt/. Within an instance's directory there are two files, parallel_cpumask and serial_cpumask, and either cpumask may be changed by echoing a bitmask into the file, for example::h]hX*There may be sysfs files for an instance’s cpumasks. For example, pcrypt’s live in /sys/kernel/pcrypt/. Within an instance’s directory there are two files, parallel_cpumask and serial_cpumask, and either cpumask may be changed by echoing a bitmask into the file, for example:}(hX$There may be sysfs files for an instance's cpumasks. For example, pcrypt's live in /sys/kernel/pcrypt/. Within an instance's directory there are two files, parallel_cpumask and serial_cpumask, and either cpumask may be changed by echoing a bitmask into the file, for example:hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK9hjhhubjg)}(h5echo f > /sys/kernel/pcrypt/pencrypt/parallel_cpumaskh]h5echo f > /sys/kernel/pcrypt/pencrypt/parallel_cpumask}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhhhK>hjhhubh)}(hmReading one of these files shows the user-supplied cpumask, which may be different from the 'usable' cpumask.h]hqReading one of these files shows the user-supplied cpumask, which may be different from the ‘usable’ cpumask.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK@hjhhubh)}(hXePadata maintains two pairs of cpumasks internally, the user-supplied cpumasks and the 'usable' cpumasks. (Each pair consists of a parallel and a serial cpumask.) The user-supplied cpumasks default to all possible CPUs on instance allocation and may be changed as above. The usable cpumasks are always a subset of the user-supplied cpumasks and contain only the online CPUs in the user-supplied masks; these are the cpumasks padata actually uses. So it is legal to supply a cpumask to padata that contains offline CPUs. Once an offline CPU in the user-supplied cpumask comes online, padata is going to use it.h]hXiPadata maintains two pairs of cpumasks internally, the user-supplied cpumasks and the ‘usable’ cpumasks. (Each pair consists of a parallel and a serial cpumask.) The user-supplied cpumasks default to all possible CPUs on instance allocation and may be changed as above. The usable cpumasks are always a subset of the user-supplied cpumasks and contain only the online CPUs in the user-supplied masks; these are the cpumasks padata actually uses. So it is legal to supply a cpumask to padata that contains offline CPUs. Once an offline CPU in the user-supplied cpumask comes online, padata is going to use it.}(hj hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKChjhhubh)}(h_Changing the CPU masks are expensive operations, so it should not be done with great frequency.h]h_Changing the CPU masks are expensive operations, so it should not be done with great frequency.}(hj.hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKMhjhhubeh}(h]modifying-cpumasksah ]h"]modifying cpumasksah$]h&]uh1hhj5hhhhhK+ubh)}(hhh](h)}(h Running A Jobh]h Running A Job}(hjGhjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhhhhhKQubh)}(h|Actually submitting work to the padata instance requires the creation of a padata_priv structure, which represents one job::h]h{Actually submitting work to the padata instance requires the creation of a padata_priv structure, which represents one job:}(h{Actually submitting work to the padata instance requires the creation of a padata_priv structure, which represents one job:hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKShjBhhubjg)}(hstruct padata_priv { /* Other stuff here... */ void (*parallel)(struct padata_priv *padata); void (*serial)(struct padata_priv *padata); };h]hstruct padata_priv { /* Other stuff here... */ void (*parallel)(struct padata_priv *padata); void (*serial)(struct padata_priv *padata); };}(hhhjbubah}(h]h ]h"]h$]h&]hhuh1jfhhhKVhjBhhubh)}(hXvThis structure will almost certainly be embedded within some larger structure specific to the work to be done. Most of its fields are private to padata, but the structure should be zeroed at initialisation time, and the parallel() and serial() functions should be provided. Those functions will be called in the process of getting the work done as we will see momentarily.h]hXvThis structure will almost certainly be embedded within some larger structure specific to the work to be done. Most of its fields are private to padata, but the structure should be zeroed at initialisation time, and the parallel() and serial() functions should be provided. Those functions will be called in the process of getting the work done as we will see momentarily.}(hjrhjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK\hjBhhubh)}(h(The submission of the job is done with::h]h'The submission of the job is done with:}(h'The submission of the job is done with:hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKchjBhhubjg)}(hpint padata_do_parallel(struct padata_shell *ps, struct padata_priv *padata, int *cb_cpu);h]hpint padata_do_parallel(struct padata_shell *ps, struct padata_priv *padata, int *cb_cpu);}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhhhKehjBhhubh)}(hXeThe ps and padata structures must be set up as described above; cb_cpu points to the preferred CPU to be used for the final callback when the job is done; it must be in the current instance's CPU mask (if not the cb_cpu pointer is updated to point to the CPU actually chosen). The return value from padata_do_parallel() is zero on success, indicating that the job is in progress. -EBUSY means that somebody, somewhere else is messing with the instance's CPU mask, while -EINVAL is a complaint about cb_cpu not being in the serial cpumask, no online CPUs in the parallel or serial cpumasks, or a stopped instance.h]hXiThe ps and padata structures must be set up as described above; cb_cpu points to the preferred CPU to be used for the final callback when the job is done; it must be in the current instance’s CPU mask (if not the cb_cpu pointer is updated to point to the CPU actually chosen). The return value from padata_do_parallel() is zero on success, indicating that the job is in progress. -EBUSY means that somebody, somewhere else is messing with the instance’s CPU mask, while -EINVAL is a complaint about cb_cpu not being in the serial cpumask, no online CPUs in the parallel or serial cpumasks, or a stopped instance.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhjBhhubh)}(hXEach job submitted to padata_do_parallel() will, in turn, be passed to exactly one call to the above-mentioned parallel() function, on one CPU, so true parallelism is achieved by submitting multiple jobs. parallel() runs with software interrupts disabled and thus cannot sleep. The parallel() function gets the padata_priv structure pointer as its lone parameter; information about the actual work to be done is probably obtained by using container_of() to find the enclosing structure.h]hXEach job submitted to padata_do_parallel() will, in turn, be passed to exactly one call to the above-mentioned parallel() function, on one CPU, so true parallelism is achieved by submitting multiple jobs. parallel() runs with software interrupts disabled and thus cannot sleep. The parallel() function gets the padata_priv structure pointer as its lone parameter; information about the actual work to be done is probably obtained by using container_of() to find the enclosing structure.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKrhjBhhubh)}(hXDNote that parallel() has no return value; the padata subsystem assumes that parallel() will take responsibility for the job from this point. The job need not be completed during this call, but, if parallel() leaves work outstanding, it should be prepared to be called again with a new job before the previous one completes.h]hXDNote that parallel() has no return value; the padata subsystem assumes that parallel() will take responsibility for the job from this point. The job need not be completed during this call, but, if parallel() leaves work outstanding, it should be prepared to be called again with a new job before the previous one completes.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKzhjBhhubeh}(h] running-a-jobah ]h"] running a jobah$]h&]uh1hhj5hhhhhKQubh)}(hhh](h)}(hSerializing Jobsh]hSerializing Jobs}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hWhen a job does complete, parallel() (or whatever function actually finishes the work) should inform padata of the fact with a call to::h]hWhen a job does complete, parallel() (or whatever function actually finishes the work) should inform padata of the fact with a call to:}(hWhen a job does complete, parallel() (or whatever function actually finishes the work) should inform padata of the fact with a call to:hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjg)}(h2void padata_do_serial(struct padata_priv *padata);h]h2void padata_do_serial(struct padata_priv *padata);}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhhhKhjhhubh)}(hXAt some point in the future, padata_do_serial() will trigger a call to the serial() function in the padata_priv structure. That call will happen on the CPU requested in the initial call to padata_do_parallel(); it, too, is run with local software interrupts disabled. Note that this call may be deferred for a while since the padata code takes pains to ensure that jobs are completed in the order in which they were submitted.h]hXAt some point in the future, padata_do_serial() will trigger a call to the serial() function in the padata_priv structure. That call will happen on the CPU requested in the initial call to padata_do_parallel(); it, too, is run with local software interrupts disabled. Note that this call may be deferred for a while since the padata code takes pains to ensure that jobs are completed in the order in which they were submitted.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h]serializing-jobsah ]h"]serializing jobsah$]h&]uh1hhj5hhhhhKubh)}(hhh](h)}(h Destroyingh]h Destroying}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hCleaning up a padata instance predictably involves calling the two free functions that correspond to the allocation in reverse::h]hCleaning up a padata instance predictably involves calling the two free functions that correspond to the allocation in reverse:}(hCleaning up a padata instance predictably involves calling the two free functions that correspond to the allocation in reverse:hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjg)}(havoid padata_free_shell(struct padata_shell *ps); void padata_free(struct padata_instance *pinst);h]havoid padata_free_shell(struct padata_shell *ps); void padata_free(struct padata_instance *pinst);}(hhhj1ubah}(h]h ]h"]h$]h&]hhuh1jfhhhKhjhhubh)}(hoIt is the user's responsibility to ensure all outstanding jobs are complete before any of the above are called.h]hqIt is the user’s responsibility to ensure all outstanding jobs are complete before any of the above are called.}(hjAhj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h] destroyingah ]h"] destroyingah$]h&]uh1hhj5hhhhhKubeh}(h]running-serialized-jobsah ]h"]running serialized jobsah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hRunning Multithreaded Jobsh]hRunning Multithreaded Jobs}(hjbhj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hhhhhKubh)}(hX9A multithreaded job has a main thread and zero or more helper threads, with the main thread participating in the job and then waiting until all helpers have finished. padata splits the job into units called chunks, where a chunk is a piece of the job that one thread completes in one call to the thread function.h]hX9A multithreaded job has a main thread and zero or more helper threads, with the main thread participating in the job and then waiting until all helpers have finished. padata splits the job into units called chunks, where a chunk is a piece of the job that one thread completes in one call to the thread function.}(hjphjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj]hhubh)}(hXA user has to do three things to run a multithreaded job. First, describe the job by defining a padata_mt_job structure, which is explained in the Interface section. This includes a pointer to the thread function, which padata will call each time it assigns a job chunk to a thread. Then, define the thread function, which accepts three arguments, ``start``, ``end``, and ``arg``, where the first two delimit the range that the thread operates on and the last is a pointer to the job's shared state, if any. Prepare the shared state, which is typically allocated on the main thread's stack. Last, call padata_do_multithreaded(), which will return once the job is finished.h](hX_A user has to do three things to run a multithreaded job. First, describe the job by defining a padata_mt_job structure, which is explained in the Interface section. This includes a pointer to the thread function, which padata will call each time it assigns a job chunk to a thread. Then, define the thread function, which accepts three arguments, }(hX_A user has to do three things to run a multithreaded job. First, describe the job by defining a padata_mt_job structure, which is explained in the Interface section. This includes a pointer to the thread function, which padata will call each time it assigns a job chunk to a thread. Then, define the thread function, which accepts three arguments, hj|hhhNhNubhliteral)}(h ``start``h]hstart}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh, }(h, hj|hhhNhNubj)}(h``end``h]hend}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh, and }(h, and hj|hhhNhNubj)}(h``arg``h]harg}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubhX+, where the first two delimit the range that the thread operates on and the last is a pointer to the job’s shared state, if any. Prepare the shared state, which is typically allocated on the main thread’s stack. Last, call padata_do_multithreaded(), which will return once the job is finished.}(hX', where the first two delimit the range that the thread operates on and the last is a pointer to the job's shared state, if any. Prepare the shared state, which is typically allocated on the main thread's stack. Last, call padata_do_multithreaded(), which will return once the job is finished.hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj]hhubeh}(h]running-multithreaded-jobsah ]h"]running multithreaded jobsah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Interfaceh]h Interface}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](singlepadata_priv (C struct) c.padata_privhNtauh1jhjhhhNhNubhdesc)}(hhh](hdesc_signature)}(h padata_privh]hdesc_signature_line)}(hstruct padata_privh](hdesc_sig_keyword)}(hstructh]hstruct}(hhhjhhhNhNubah}(h]h ]kah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKubhdesc_sig_space)}(h h]h }(hhhjhhhNhNubah}(h]h ]wah"]h$]h&]uh1jhjhhhjhKubh desc_name)}(h padata_privh]h desc_sig_name)}(hjh]h padata_priv}(hhhj,hhhNhNubah}(h]h ]nah"]h$]h&]uh1j*hj&ubah}(h]h ](sig-namedescnameeh"]h$]h&]hhuh1j$hjhhhjhKubeh}(h]h ]h"]h$]h&]hh add_permalinkuh1jsphinx_line_type declaratorhjhhhjhKubah}(h]jah ](sig sig-objecteh"]h$]h&] is_multilineuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjhhubh desc_content)}(hhh]h)}(hRepresents one jobh]hRepresents one job}(hj\hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjWhhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhKubeh}(h]h ](cstructeh"]h$]h&]domainjrobjtypejsdesctypejsnoindexuh1jhhhjhNhNubh container)}(hX**Definition**:: struct padata_priv { struct list_head list; struct parallel_data *pd; int cb_cpu; unsigned int seq_nr; int info; void (*parallel)(struct padata_priv *padata); void (*serial)(struct padata_priv *padata); }; **Members** ``list`` List entry, to attach to the padata lists. ``pd`` Pointer to the internal control structure. ``cb_cpu`` Callback cpu for serializatioon. ``seq_nr`` Sequence number of the parallelized data object. ``info`` Used to pass information from the parallel to the serial function. ``parallel`` Parallel execution function. ``serial`` Serial complete function.h](h)}(h**Definition**::h](hstrong)}(h**Definition**h]h Definition}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(h:hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj}ubjg)}(hstruct padata_priv { struct list_head list; struct parallel_data *pd; int cb_cpu; unsigned int seq_nr; int info; void (*parallel)(struct padata_priv *padata); void (*serial)(struct padata_priv *padata); };h]hstruct padata_priv { struct list_head list; struct parallel_data *pd; int cb_cpu; unsigned int seq_nr; int info; void (*parallel)(struct padata_priv *padata); void (*serial)(struct padata_priv *padata); };}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK hj}ubh)}(h **Members**h]j)}(hjh]hMembers}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK*hj}ubhdefinition_list)}(hhh](hdefinition_list_item)}(h4``list`` List entry, to attach to the padata lists. h](hterm)}(h``list``h]j)}(hjh]hlist}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubh definition)}(hhh]h)}(h*List entry, to attach to the padata lists.h]h*List entry, to attach to the padata lists.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h2``pd`` Pointer to the internal control structure. h](j)}(h``pd``h]j)}(hjh]hpd}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj ubj)}(hhh]h)}(h*Pointer to the internal control structure.h]h*Pointer to the internal control structure.}(hj-hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hKhj(ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj'hKhjubj)}(h,``cb_cpu`` Callback cpu for serializatioon. h](j)}(h ``cb_cpu``h]j)}(hjKh]hcb_cpu}(hhhjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjEubj)}(hhh]h)}(h Callback cpu for serializatioon.h]h Callback cpu for serializatioon.}(hjfhjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hKhjaubah}(h]h ]h"]h$]h&]uh1jhjEubeh}(h]h ]h"]h$]h&]uh1jhj`hKhjubj)}(h<``seq_nr`` Sequence number of the parallelized data object. h](j)}(h ``seq_nr``h]j)}(hjh]hseq_nr}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK hj~ubj)}(hhh]h)}(h0Sequence number of the parallelized data object.h]h0Sequence number of the parallelized data object.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK hjubah}(h]h ]h"]h$]h&]uh1jhj~ubeh}(h]h ]h"]h$]h&]uh1jhjhK hjubj)}(hL``info`` Used to pass information from the parallel to the serial function. h](j)}(h``info``h]j)}(hjh]hinfo}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK!hjubj)}(hhh]h)}(hBUsed to pass information from the parallel to the serial function.h]hBUsed to pass information from the parallel to the serial function.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK!hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhK!hjubj)}(h*``parallel`` Parallel execution function. h](j)}(h ``parallel``h]j)}(hjh]hparallel}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK"hjubj)}(hhh]h)}(hParallel execution function.h]hParallel execution function.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hK"hj ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhj hK"hjubj)}(h$``serial`` Serial complete function.h](j)}(h ``serial``h]j)}(hj/h]hserial}(hhhj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK"hj)ubj)}(hhh]h)}(hSerial complete function.h]hSerial complete function.}(hjJhjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK#hjEubah}(h]h ]h"]h$]h&]uh1jhj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhK"hjubeh}(h]h ]h"]h$]h&]uh1jhj}ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_list (C struct) c.padata_listhNtauh1jhjhhhNhNubj)}(hhh](j)}(h padata_listh]j)}(hstruct padata_listh](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK0ubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjhhhjhK0ubj%)}(h padata_listh]j+)}(hjh]h padata_list}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjhhhjhK0ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhK0ubah}(h]j|ah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK)hj~hhubjV)}(hhh]h)}(hone per work type per CPUh]hone per work type per CPU}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK/hjhhubah}(h]h ]h"]h$]h&]uh1jUhj~hhhjhK0ubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxjjyjjzuh1jhhhjhNhNubj|)}(h**Definition**:: struct padata_list { struct list_head list; spinlock_t lock; }; **Members** ``list`` List head. ``lock`` List lock.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK3hjubjg)}(hNstruct padata_list { struct list_head list; spinlock_t lock; };h]hNstruct padata_list { struct list_head list; spinlock_t lock; };}(hhhj ubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK5hjubh)}(h **Members**h]j)}(hjh]hMembers}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK:hjubj)}(hhh](j)}(h``list`` List head. h](j)}(h``list``h]j)}(hj9h]hlist}(hhhj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK2hj3ubj)}(hhh]h)}(h List head.h]h List head.}(hjThjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhK2hjOubah}(h]h ]h"]h$]h&]uh1jhj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhK2hj0ubj)}(h``lock`` List lock.h](j)}(h``lock``h]j)}(hjrh]hlock}(hhhjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK2hjlubj)}(hhh]h)}(h List lock.h]h List lock.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK3hjubah}(h]h ]h"]h$]h&]uh1jhjlubeh}(h]h ]h"]h$]h&]uh1jhjhK2hj0ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_serial_queue (C struct)c.padata_serial_queuehNtauh1jhjhhhNhNubj)}(hhh](j)}(hpadata_serial_queueh]j)}(hstruct padata_serial_queueh](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK;ubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjhhhjhK;ubj%)}(hpadata_serial_queueh]j+)}(hjh]hpadata_serial_queue}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjhhhjhK;ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhK;ubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK9hjhhubjV)}(hhh]h)}(hThe percpu padata serial queueh]hThe percpu padata serial queue}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK:hj hhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhK;ubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxj'jyj'jzuh1jhhhjhNhNubj|)}(hXK**Definition**:: struct padata_serial_queue { struct padata_list serial; struct work_struct work; struct parallel_data *pd; }; **Members** ``serial`` List to wait for serialization after reordering. ``work`` work struct for serialization. ``pd`` Backpointer to the internal control structure.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubh:}(hjhj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK>hj+ubjg)}(hstruct padata_serial_queue { struct padata_list serial; struct work_struct work; struct parallel_data *pd; };h]hstruct padata_serial_queue { struct padata_list serial; struct work_struct work; struct parallel_data *pd; };}(hhhjLubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK@hj+ubh)}(h **Members**h]j)}(hj]h]hMembers}(hhhj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKFhj+ubj)}(hhh](j)}(h<``serial`` List to wait for serialization after reordering. h](j)}(h ``serial``h]j)}(hj|h]hserial}(hhhj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK=hjvubj)}(hhh]h)}(h0List to wait for serialization after reordering.h]h0List to wait for serialization after reordering.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK=hjubah}(h]h ]h"]h$]h&]uh1jhjvubeh}(h]h ]h"]h$]h&]uh1jhjhK=hjsubj)}(h(``work`` work struct for serialization. h](j)}(h``work``h]j)}(hjh]hwork}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK>hjubj)}(hhh]h)}(hwork struct for serialization.h]hwork struct for serialization.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK>hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhK>hjsubj)}(h5``pd`` Backpointer to the internal control structure.h](j)}(h``pd``h]j)}(hjh]hpd}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK>hjubj)}(hhh]h)}(h.Backpointer to the internal control structure.h]h.Backpointer to the internal control structure.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK?hj ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhj hK>hjsubeh}(h]h ]h"]h$]h&]uh1jhj+ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_cpumask (C struct)c.padata_cpumaskhNtauh1jhjhhhNhNubj)}(hhh](j)}(hpadata_cpumaskh]j)}(hstruct padata_cpumaskh](j)}(hjh]hstruct}(hhhjH hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjD hhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKHubj)}(h h]h }(hhhjV hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjD hhhjU hKHubj%)}(hpadata_cpumaskh]j+)}(hjB h]hpadata_cpumask}(hhhjh hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjd ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjD hhhjU hKHubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj@ hhhjU hKHubah}(h]j; ah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKEhj= hhubjV)}(hhh]h)}(h,The cpumasks for the parallel/serial workersh]h,The cpumasks for the parallel/serial workers}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKGhj hhubah}(h]h ]h"]h$]h&]uh1jUhj= hhhjU hKHubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxj jyj jzuh1jhhhjhNhNubj|)}(h**Definition**:: struct padata_cpumask { cpumask_var_t pcpu; cpumask_var_t cbcpu; }; **Members** ``pcpu`` cpumask for the parallel workers. ``cbcpu`` cpumask for the serial (callback) workers.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh:}(hjhj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKKhj ubjg)}(hKstruct padata_cpumask { cpumask_var_t pcpu; cpumask_var_t cbcpu; };h]hKstruct padata_cpumask { cpumask_var_t pcpu; cpumask_var_t cbcpu; };}(hhhj ubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKMhj ubh)}(h **Members**h]j)}(hj h]hMembers}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKRhj ubj)}(hhh](j)}(h+``pcpu`` cpumask for the parallel workers. h](j)}(h``pcpu``h]j)}(hj h]hpcpu}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKJhj ubj)}(hhh]h)}(h!cpumask for the parallel workers.h]h!cpumask for the parallel workers.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKJhj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj hKJhj ubj)}(h4``cbcpu`` cpumask for the serial (callback) workers.h](j)}(h ``cbcpu``h]j)}(hj1 h]hcbcpu}(hhhj3 hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKJhj+ ubj)}(hhh]h)}(h*cpumask for the serial (callback) workers.h]h*cpumask for the serial (callback) workers.}(hjL hjJ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKKhjG ubah}(h]h ]h"]h$]h&]uh1jhj+ ubeh}(h]h ]h"]h$]h&]uh1jhjF hKJhj ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jparallel_data (C struct)c.parallel_datahNtauh1jhjhhhNhNubj)}(hhh](j)}(h parallel_datah]j)}(hstruct parallel_datah](j)}(hjh]hstruct}(hhhj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKSubj)}(h h]h }(hhhj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhj hhhj hKSubj%)}(h parallel_datah]j+)}(hj h]h parallel_data}(hhhj hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hj hhhj hKSubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj hhhj hKSubah}(h]j~ ah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKQhj hhubjV)}(hhh]h)}(hQInternal control structure, covers everything that depends on the cpumask in use.h]hQInternal control structure, covers everything that depends on the cpumask in use.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKRhj hhubah}(h]h ]h"]h$]h&]uh1jUhj hhhj hKSubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxj jyj jzuh1jhhhjhNhNubj|)}(hX**Definition**:: struct parallel_data { struct padata_shell *ps; struct padata_list __percpu *reorder_list; struct padata_serial_queue __percpu *squeue; refcount_t refcnt; unsigned int seq_nr; unsigned int processed; int cpu; struct padata_cpumask cpumask; struct work_struct reorder_work; spinlock_t lock; }; **Members** ``ps`` padata_shell object. ``reorder_list`` percpu reorder lists ``squeue`` percpu padata queues used for serialuzation. ``refcnt`` Number of objects holding a reference on this parallel_data. ``seq_nr`` Sequence number of the parallelized data object. ``processed`` Number of already processed objects. ``cpu`` Next CPU to be processed. ``cpumask`` The cpumasks in use for parallel and serial workers. ``reorder_work`` work struct for reordering. ``lock`` Reorder lock.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh:}(hjhj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKVhj ubjg)}(hXstruct parallel_data { struct padata_shell *ps; struct padata_list __percpu *reorder_list; struct padata_serial_queue __percpu *squeue; refcount_t refcnt; unsigned int seq_nr; unsigned int processed; int cpu; struct padata_cpumask cpumask; struct work_struct reorder_work; spinlock_t lock; };h]hXstruct parallel_data { struct padata_shell *ps; struct padata_list __percpu *reorder_list; struct padata_serial_queue __percpu *squeue; refcount_t refcnt; unsigned int seq_nr; unsigned int processed; int cpu; struct padata_cpumask cpumask; struct work_struct reorder_work; spinlock_t lock; };}(hhhj ubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKXhj ubh)}(h **Members**h]j)}(hj h]hMembers}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKehj ubj)}(hhh](j)}(h``ps`` padata_shell object. h](j)}(h``ps``h]j)}(hj; h]hps}(hhhj= hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9 ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKVhj5 ubj)}(hhh]h)}(hpadata_shell object.h]hpadata_shell object.}(hjV hjT hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjP hKVhjQ ubah}(h]h ]h"]h$]h&]uh1jhj5 ubeh}(h]h ]h"]h$]h&]uh1jhjP hKVhj2 ubj)}(h&``reorder_list`` percpu reorder lists h](j)}(h``reorder_list``h]j)}(hjt h]h reorder_list}(hhhjv hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKWhjn ubj)}(hhh]h)}(hpercpu reorder listsh]hpercpu reorder lists}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKWhj ubah}(h]h ]h"]h$]h&]uh1jhjn ubeh}(h]h ]h"]h$]h&]uh1jhj hKWhj2 ubj)}(h8``squeue`` percpu padata queues used for serialuzation. h](j)}(h ``squeue``h]j)}(hj h]hsqueue}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKXhj ubj)}(hhh]h)}(h,percpu padata queues used for serialuzation.h]h,percpu padata queues used for serialuzation.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKXhj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj hKXhj2 ubj)}(hH``refcnt`` Number of objects holding a reference on this parallel_data. h](j)}(h ``refcnt``h]j)}(hj h]hrefcnt}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKYhj ubj)}(hhh]h)}(h hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj: ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK^hj6 ubj)}(hhh]h)}(h Reorder lock.h]h Reorder lock.}(hjW hjU hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK_hjR ubah}(h]h ]h"]h$]h&]uh1jhj6 ubeh}(h]h ]h"]h$]h&]uh1jhjQ hK^hj2 ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_shell (C struct)c.padata_shellhNtauh1jhjhhhNhNubj)}(hhh](j)}(h padata_shellh]j)}(hstruct padata_shellh](j)}(hjh]hstruct}(hhhj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKoubj)}(h h]h }(hhhj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhj hhhj hKoubj%)}(h padata_shellh]j+)}(hj h]h padata_shell}(hhhj hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hj hhhj hKoubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj hhhj hKoubah}(h]j ah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKehj hhubjV)}(hhh]h)}(hWrapper around struct parallel_data, its purpose is to allow the underlying control structure to be replaced on the fly using RCU.h]hWrapper around struct parallel_data, its purpose is to allow the underlying control structure to be replaced on the fly using RCU.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKnhj hhubah}(h]h ]h"]h$]h&]uh1jUhj hhhj hKoubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxj jyj jzuh1jhhhjhNhNubj|)}(hX**Definition**:: struct padata_shell { struct padata_instance *pinst; struct parallel_data __rcu *pd; struct parallel_data *opd; struct list_head list; }; **Members** ``pinst`` padat instance. ``pd`` Actual parallel_data structure which may be substituted on the fly. ``opd`` Pointer to old pd to be freed by padata_replace. ``list`` List entry in padata_instance list.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh:}(hjhj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKrhj ubjg)}(hstruct padata_shell { struct padata_instance *pinst; struct parallel_data __rcu *pd; struct parallel_data *opd; struct list_head list; };h]hstruct padata_shell { struct padata_instance *pinst; struct parallel_data __rcu *pd; struct parallel_data *opd; struct list_head list; };}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKthj ubh)}(h **Members**h]j)}(hj'h]hMembers}(hhhj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK{hj ubj)}(hhh](j)}(h``pinst`` padat instance. h](j)}(h ``pinst``h]j)}(hjFh]hpinst}(hhhjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKshj@ubj)}(hhh]h)}(hpadat instance.h]hpadat instance.}(hjahj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hKshj\ubah}(h]h ]h"]h$]h&]uh1jhj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hKshj=ubj)}(hK``pd`` Actual parallel_data structure which may be substituted on the fly. h](j)}(h``pd``h]j)}(hjh]hpd}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKthjyubj)}(hhh]h)}(hCActual parallel_data structure which may be substituted on the fly.h]hCActual parallel_data structure which may be substituted on the fly.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKthjubah}(h]h ]h"]h$]h&]uh1jhjyubeh}(h]h ]h"]h$]h&]uh1jhjhKthj=ubj)}(h9``opd`` Pointer to old pd to be freed by padata_replace. h](j)}(h``opd``h]j)}(hjh]hopd}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKuhjubj)}(hhh]h)}(h0Pointer to old pd to be freed by padata_replace.h]h0Pointer to old pd to be freed by padata_replace.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKuhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKuhj=ubj)}(h,``list`` List entry in padata_instance list.h](j)}(h``list``h]j)}(hjh]hlist}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKuhjubj)}(hhh]h)}(h#List entry in padata_instance list.h]h#List entry in padata_instance list.}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKvhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKuhj=ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_mt_job (C struct)c.padata_mt_jobhNtauh1jhjhhhNhNubj)}(hhh](j)}(h padata_mt_jobh]j)}(hstruct padata_mt_jobh](j)}(hjh]hstruct}(hhhjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGhhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKubj)}(h h]h }(hhhjYhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjGhhhjXhKubj%)}(h padata_mt_jobh]j+)}(hjEh]h padata_mt_job}(hhhjkhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjgubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjGhhhjXhKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjChhhjXhKubah}(h]j>ah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhK|hj@hhubjV)}(hhh]h)}(h represents one multithreaded jobh]h represents one multithreaded job}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jUhj@hhhjXhKubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxjjyjjzuh1jhhhjhNhNubj|)}(hXr**Definition**:: struct padata_mt_job { void (*thread_fn)(unsigned long start, unsigned long end, void *arg); void *fn_arg; unsigned long start; unsigned long size; unsigned long align; unsigned long min_chunk; int max_threads; bool numa_aware; }; **Members** ``thread_fn`` Called for each chunk of work that a padata thread does. ``fn_arg`` The thread function argument. ``start`` The start of the job (units are job-specific). ``size`` size of this node's work (units are job-specific). ``align`` Ranges passed to the thread function fall on this boundary, with the possible exceptions of the beginning and end of the job. ``min_chunk`` The minimum chunk size in job-specific units. This allows the client to communicate the minimum amount of work that's appropriate for one worker thread to do at once. ``max_threads`` Max threads to use for the job, actual number may be less depending on task size and minimum chunk size. ``numa_aware`` Distribute jobs to different nodes with CPU in a round robin fashion.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubjg)}(hX.struct padata_mt_job { void (*thread_fn)(unsigned long start, unsigned long end, void *arg); void *fn_arg; unsigned long start; unsigned long size; unsigned long align; unsigned long min_chunk; int max_threads; bool numa_aware; };h]hX.struct padata_mt_job { void (*thread_fn)(unsigned long start, unsigned long end, void *arg); void *fn_arg; unsigned long start; unsigned long size; unsigned long align; unsigned long min_chunk; int max_threads; bool numa_aware; };}(hhhjubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubh)}(h **Members**h]j)}(hjh]hMembers}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh](j)}(hG``thread_fn`` Called for each chunk of work that a padata thread does. h](j)}(h ``thread_fn``h]j)}(hjh]h thread_fn}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h8Called for each chunk of work that a padata thread does.h]h8Called for each chunk of work that a padata thread does.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h)``fn_arg`` The thread function argument. h](j)}(h ``fn_arg``h]j)}(hj4h]hfn_arg}(hhhj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj.ubj)}(hhh]h)}(hThe thread function argument.h]hThe thread function argument.}(hjOhjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhKhjJubah}(h]h ]h"]h$]h&]uh1jhj.ubeh}(h]h ]h"]h$]h&]uh1jhjIhKhjubj)}(h9``start`` The start of the job (units are job-specific). h](j)}(h ``start``h]j)}(hjmh]hstart}(hhhjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjgubj)}(hhh]h)}(h.The start of the job (units are job-specific).h]h.The start of the job (units are job-specific).}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h<``size`` size of this node's work (units are job-specific). h](j)}(h``size``h]j)}(hjh]hsize}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h2size of this node's work (units are job-specific).h]h4size of this node’s work (units are job-specific).}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``align`` Ranges passed to the thread function fall on this boundary, with the possible exceptions of the beginning and end of the job. h](j)}(h ``align``h]j)}(hjh]halign}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h}Ranges passed to the thread function fall on this boundary, with the possible exceptions of the beginning and end of the job.h]h}Ranges passed to the thread function fall on this boundary, with the possible exceptions of the beginning and end of the job.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``min_chunk`` The minimum chunk size in job-specific units. This allows the client to communicate the minimum amount of work that's appropriate for one worker thread to do at once. h](j)}(h ``min_chunk``h]j)}(hjh]h min_chunk}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(hThe minimum chunk size in job-specific units. This allows the client to communicate the minimum amount of work that's appropriate for one worker thread to do at once.h]hThe minimum chunk size in job-specific units. This allows the client to communicate the minimum amount of work that’s appropriate for one worker thread to do at once.}(hj4hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj/ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhj.hKhjubj)}(hy``max_threads`` Max threads to use for the job, actual number may be less depending on task size and minimum chunk size. h](j)}(h``max_threads``h]j)}(hjSh]h max_threads}(hhhjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjMubj)}(hhh]h)}(hhMax threads to use for the job, actual number may be less depending on task size and minimum chunk size.h]hhMax threads to use for the job, actual number may be less depending on task size and minimum chunk size.}(hjnhjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjiubah}(h]h ]h"]h$]h&]uh1jhjMubeh}(h]h ]h"]h$]h&]uh1jhjhhKhjubj)}(hT``numa_aware`` Distribute jobs to different nodes with CPU in a round robin fashion.h](j)}(h``numa_aware``h]j)}(hjh]h numa_aware}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(hEDistribute jobs to different nodes with CPU in a round robin fashion.h]hEDistribute jobs to different nodes with CPU in a round robin fashion.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_instance (C struct)c.padata_instancehNtauh1jhjhhhNhNubj)}(hhh](j)}(hpadata_instanceh]j)}(hstruct padata_instanceh](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjhhhjhKubj%)}(hpadata_instanceh]j+)}(hjh]hpadata_instance}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjhhhjhKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhKubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjhhubjV)}(hhh]h)}(hThe overall control structure.h]hThe overall control structure.}(hj,hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj'hhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhKubeh}(h]h ](jrstructeh"]h$]h&]jwjrjxjBjyjBjzuh1jhhhjhNhNubj|)}(hX**Definition**:: struct padata_instance { struct hlist_node cpu_online_node; struct hlist_node cpu_dead_node; struct workqueue_struct *parallel_wq; struct workqueue_struct *serial_wq; struct list_head pslist; struct padata_cpumask cpumask; struct kobject kobj; struct mutex lock; u8 flags; #define PADATA_INIT 1; #define PADATA_RESET 2; #define PADATA_INVALID 4; }; **Members** ``cpu_online_node`` Linkage for CPU online callback. ``cpu_dead_node`` Linkage for CPU offline callback. ``parallel_wq`` The workqueue used for parallel work. ``serial_wq`` The workqueue used for serial work. ``pslist`` List of padata_shell objects attached to this instance. ``cpumask`` User supplied cpumasks for parallel and serial works. ``kobj`` padata instance kernel object. ``lock`` padata instance lock. ``flags`` padata flags.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hhhjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubh:}(hjhjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjFubjg)}(hXstruct padata_instance { struct hlist_node cpu_online_node; struct hlist_node cpu_dead_node; struct workqueue_struct *parallel_wq; struct workqueue_struct *serial_wq; struct list_head pslist; struct padata_cpumask cpumask; struct kobject kobj; struct mutex lock; u8 flags; #define PADATA_INIT 1; #define PADATA_RESET 2; #define PADATA_INVALID 4; };h]hXstruct padata_instance { struct hlist_node cpu_online_node; struct hlist_node cpu_dead_node; struct workqueue_struct *parallel_wq; struct workqueue_struct *serial_wq; struct list_head pslist; struct padata_cpumask cpumask; struct kobject kobj; struct mutex lock; u8 flags; #define PADATA_INIT 1; #define PADATA_RESET 2; #define PADATA_INVALID 4; };}(hhhjgubah}(h]h ]h"]h$]h&]hhuh1jfhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjFubh)}(h **Members**h]j)}(hjxh]hMembers}(hhhjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjFubj)}(hhh](j)}(h5``cpu_online_node`` Linkage for CPU online callback. h](j)}(h``cpu_online_node``h]j)}(hjh]hcpu_online_node}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h Linkage for CPU online callback.h]h Linkage for CPU online callback.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h4``cpu_dead_node`` Linkage for CPU offline callback. h](j)}(h``cpu_dead_node``h]j)}(hjh]h cpu_dead_node}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h!Linkage for CPU offline callback.h]h!Linkage for CPU offline callback.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h6``parallel_wq`` The workqueue used for parallel work. h](j)}(h``parallel_wq``h]j)}(hj h]h parallel_wq}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h%The workqueue used for parallel work.h]h%The workqueue used for parallel work.}(hj$hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h2``serial_wq`` The workqueue used for serial work. h](j)}(h ``serial_wq``h]j)}(hjBh]h serial_wq}(hhhjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj<ubj)}(hhh]h)}(h#The workqueue used for serial work.h]h#The workqueue used for serial work.}(hj]hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhKhjXubah}(h]h ]h"]h$]h&]uh1jhj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhKhjubj)}(hC``pslist`` List of padata_shell objects attached to this instance. h](j)}(h ``pslist``h]j)}(hj{h]hpslist}(hhhj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjuubj)}(hhh]h)}(h7List of padata_shell objects attached to this instance.h]h7List of padata_shell objects attached to this instance.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hB``cpumask`` User supplied cpumasks for parallel and serial works. h](j)}(h ``cpumask``h]j)}(hjh]hcpumask}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(h5User supplied cpumasks for parallel and serial works.h]h5User supplied cpumasks for parallel and serial works.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h(``kobj`` padata instance kernel object. h](j)}(h``kobj``h]j)}(hjh]hkobj}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjubj)}(hhh]h)}(hpadata instance kernel object.h]hpadata instance kernel object.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``lock`` padata instance lock. h](j)}(h``lock``h]j)}(hj&h]hlock}(hhhj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhj ubj)}(hhh]h)}(hpadata instance lock.h]hpadata instance lock.}(hjAhj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hKhj<ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj;hKhjubj)}(h``flags`` padata flags.h](j)}(h ``flags``h]j)}(hj_h]hflags}(hhhjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjYubj)}(hhh]h)}(h padata flags.h]h padata flags.}(hjzhjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/core-api/padata:177: ./include/linux/padata.hhKhjuubah}(h]h ]h"]h$]h&]uh1jhjYubeh}(h]h ]h"]h$]h&]uh1jhjthKhjubeh}(h]h ]h"]h$]h&]uh1jhjFubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_do_parallel (C function)c.padata_do_parallelhNtauh1jhjhhhNhNubj)}(hhh](j)}(hYint padata_do_parallel (struct padata_shell *ps, struct padata_priv *padata, int *cb_cpu)h]j)}(hXint padata_do_parallel(struct padata_shell *ps, struct padata_priv *padata, int *cb_cpu)h](hdesc_sig_keyword_type)}(hinth]hint}(hhhjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjhhhjhKubj%)}(hpadata_do_parallelh]j+)}(hpadata_do_parallelh]hpadata_do_parallel}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjhhhjhKubhdesc_parameterlist)}(hB(struct padata_shell *ps, struct padata_priv *padata, int *cb_cpu)h](hdesc_parameter)}(hstruct padata_shell *psh](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubh)}(hhh]j+)}(h padata_shellh]h padata_shell}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ]h"]h$]h&] refdomainjrreftype identifier reftargetjmodnameN classnameN c:parent_keysphinx.domains.c LookupKey)}data]j6 ASTIdentifier)}j1jsbc.padata_do_parallelasbuh1hhjubj)}(h h]h }(hhhjChhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubhdesc_sig_punctuation)}(h*h]h*}(hhhjShhhNhNubah}(h]h ]pah"]h$]h&]uh1jQhjubj+)}(hpsh]hps}(hhhjbhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hstruct padata_priv *padatah](j)}(hjh]hstruct}(hhhj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjwubh)}(hhh]j+)}(h padata_privh]h padata_priv}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetjmodnameN classnameNj5j8)}j;]j?c.padata_do_parallelasbuh1hhjwubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjwubjR)}(hjUh]h*}(hhhjhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjwubj+)}(hpadatah]hpadata}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjwubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(h int *cb_cpuh](j)}(hinth]hint}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubjR)}(hjUh]h*}(hhhjhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjubj+)}(hcb_cpuh]hcb_cpu}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhKubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhjhhubjV)}(hhh]h)}(hpadata parallelization functionh]hpadata parallelization function}(hjAhj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhj<hhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhKubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxjWjyjWjzuh1jhhhjhNhNubj|)}(hXT**Parameters** ``struct padata_shell *ps`` padatashell ``struct padata_priv *padata`` object to be parallelized ``int *cb_cpu`` pointer to the CPU that the serialization callback function should run on. If it's not in the serial cpumask of **pinst** (i.e. cpumask.cbcpu), this function selects a fallback CPU and if none found, returns -EINVAL. **Description** The parallelization callback function will run with BHs off. **Note** Every object which is parallelized by padata_do_parallel must be seen by padata_do_serial. **Return** 0 on success or else negative error code.h](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hhhjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhj[ubj)}(hhh](j)}(h(``struct padata_shell *ps`` padatashell h](j)}(h``struct padata_shell *ps``h]j)}(hjh]hstruct padata_shell *ps}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhjzubj)}(hhh]h)}(h padatashellh]h padatashell}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjzubeh}(h]h ]h"]h$]h&]uh1jhjhKhjwubj)}(h9``struct padata_priv *padata`` object to be parallelized h](j)}(h``struct padata_priv *padata``h]j)}(hjh]hstruct padata_priv *padata}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhjubj)}(hhh]h)}(hobject to be parallelizedh]hobject to be parallelized}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjwubj)}(h``int *cb_cpu`` pointer to the CPU that the serialization callback function should run on. If it's not in the serial cpumask of **pinst** (i.e. cpumask.cbcpu), this function selects a fallback CPU and if none found, returns -EINVAL. h](j)}(h``int *cb_cpu``h]j)}(hjh]h int *cb_cpu}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhjubj)}(hhh]h)}(hpointer to the CPU that the serialization callback function should run on. If it's not in the serial cpumask of **pinst** (i.e. cpumask.cbcpu), this function selects a fallback CPU and if none found, returns -EINVAL.h](hspointer to the CPU that the serialization callback function should run on. If it’s not in the serial cpumask of }(hqpointer to the CPU that the serialization callback function should run on. If it's not in the serial cpumask of hj hhhNhNubj)}(h **pinst**h]hpinst}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh_ (i.e. cpumask.cbcpu), this function selects a fallback CPU and if none found, returns -EINVAL.}(h_ (i.e. cpumask.cbcpu), this function selects a fallback CPU and if none found, returns -EINVAL.hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjwubeh}(h]h ]h"]h$]h&]uh1jhj[ubh)}(h**Description**h]j)}(hjBh]h Description}(hhhjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chKhj[ubh)}(heh"]h$]h&]hhuh1j$hjhhhjhMubj)}(h(struct padata_priv *padata)h]j)}(hstruct padata_priv *padatah](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubh)}(hhh]j+)}(h padata_privh]h padata_priv}(hhhj0hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj-ubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetj2modnameN classnameNj5j8)}j;]j>)}j1jsbc.padata_do_serialasbuh1hhjubj)}(h h]h }(hhhjPhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubjR)}(hjUh]h*}(hhhj^hhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjubj+)}(hpadatah]hpadata}(hhhjkhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj ubah}(h]h ]h"]h$]h&]hhuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhMubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjhhubjV)}(hhh]h)}(hpadata serialization functionh]hpadata serialization function}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjhhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhMubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxjjyjjzuh1jhhhjhNhNubj|)}(h**Parameters** ``struct padata_priv *padata`` object to be serialized. **Description** padata_do_serial must be called for every parallelized object. The serialization callback function will run with BHs off.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubj)}(hhh]j)}(h8``struct padata_priv *padata`` object to be serialized. h](j)}(h``struct padata_priv *padata``h]j)}(hjh]hstruct padata_priv *padata}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubj)}(hhh]h)}(hobject to be serialized.h]hobject to be serialized.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubh)}(hypadata_do_serial must be called for every parallelized object. The serialization callback function will run with BHs off.h]hypadata_do_serial must be called for every parallelized object. The serialization callback function will run with BHs off.}(hj*hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j$padata_do_multithreaded (C function)c.padata_do_multithreadedhNtauh1jhjhhhNhNubj)}(hhh](j)}(h8void padata_do_multithreaded (struct padata_mt_job *job)h]j)}(h7void padata_do_multithreaded(struct padata_mt_job *job)h](j)}(hvoidh]hvoid}(hhhjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjShhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMubj)}(h h]h }(hhhjfhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjShhhjehMubj%)}(hpadata_do_multithreadedh]j+)}(hpadata_do_multithreadedh]hpadata_do_multithreaded}(hhhjxhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjtubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjShhhjehMubj)}(h(struct padata_mt_job *job)h]j)}(hstruct padata_mt_job *jobh](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubh)}(hhh]j+)}(h padata_mt_jobh]h padata_mt_job}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetjmodnameN classnameNj5j8)}j;]j>)}j1jzsbc.padata_do_multithreadedasbuh1hhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubjR)}(hjUh]h*}(hhhjhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjubj+)}(hjobh]hjob}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubah}(h]h ]h"]h$]h&]hhuh1jhjShhhjehMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjOhhhjehMubah}(h]jJah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjLhhubjV)}(hhh]h)}(hrun a multithreaded jobh]hrun a multithreaded job}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjhhubah}(h]h ]h"]h$]h&]uh1jUhjLhhhjehMubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxj0jyj0jzuh1jhhhjhNhNubj|)}(h**Parameters** ``struct padata_mt_job *job`` Description of the job. **Description** See the definition of struct padata_mt_job for more details.h](h)}(h**Parameters**h]j)}(hj:h]h Parameters}(hhhj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhj4ubj)}(hhh]j)}(h6``struct padata_mt_job *job`` Description of the job. h](j)}(h``struct padata_mt_job *job``h]j)}(hjYh]hstruct padata_mt_job *job}(hhhj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjSubj)}(hhh]h)}(hDescription of the job.h]hDescription of the job.}(hjthjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjoubah}(h]h ]h"]h$]h&]uh1jhjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjPubah}(h]h ]h"]h$]h&]uh1jhj4ubh)}(h**Description**h]j)}(hjh]h Description}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhj4ubh)}(heh"]h$]h&]hhuh1j$hjhhhjhMubj)}(hH(struct padata_instance *pinst, int cpumask_type, cpumask_var_t cpumask)h](j)}(hstruct padata_instance *pinsth](j)}(hjh]hstruct}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhj#hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubh)}(hhh]j+)}(hpadata_instanceh]hpadata_instance}(hhhj4hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj1ubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetj6modnameN classnameNj5j8)}j;]j>)}j1jsbc.padata_set_cpumaskasbuh1hhjubj)}(h h]h }(hhhjThhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubjR)}(hjUh]h*}(hhhjbhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjubj+)}(hpinsth]hpinst}(hhhjohhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hint cpumask_typeh](j)}(hinth]hint}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubj+)}(h cpumask_typeh]h cpumask_type}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hcpumask_var_t cpumaskh](h)}(hhh]j+)}(h cpumask_var_th]h cpumask_var_t}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetjmodnameN classnameNj5j8)}j;]jPc.padata_set_cpumaskasbuh1hhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubj+)}(hcpumaskh]hcpumask}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhMubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjhhubjV)}(hhh]h)}(hRSets specified by **cpumask_type** cpumask to the value equivalent to **cpumask**.h](hSets specified by }(hSets specified by hjhhhNhNubj)}(h**cpumask_type**h]h cpumask_type}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh$ cpumask to the value equivalent to }(h$ cpumask to the value equivalent to hjhhhNhNubj)}(h **cpumask**h]hcpumask}(hhhj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(h.hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjhhubah}(h]h ]h"]h$]h&]uh1jUhjhhhjhMubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxjVjyjVjzuh1jhhhjhNhNubj|)}(hX#**Parameters** ``struct padata_instance *pinst`` padata instance ``int cpumask_type`` PADATA_CPU_SERIAL or PADATA_CPU_PARALLEL corresponding to parallel and serial cpumasks respectively. ``cpumask_var_t cpumask`` the cpumask to use **Return** 0 on success or negative error codeh](h)}(h**Parameters**h]j)}(hj`h]h Parameters}(hhhjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjZubj)}(hhh](j)}(h2``struct padata_instance *pinst`` padata instance h](j)}(h!``struct padata_instance *pinst``h]j)}(hjh]hstruct padata_instance *pinst}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjyubj)}(hhh]h)}(hpadata instanceh]hpadata instance}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjyubeh}(h]h ]h"]h$]h&]uh1jhjhMhjvubj)}(hz``int cpumask_type`` PADATA_CPU_SERIAL or PADATA_CPU_PARALLEL corresponding to parallel and serial cpumasks respectively. h](j)}(h``int cpumask_type``h]j)}(hjh]hint cpumask_type}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubj)}(hhh]h)}(hdPADATA_CPU_SERIAL or PADATA_CPU_PARALLEL corresponding to parallel and serial cpumasks respectively.h]hdPADATA_CPU_SERIAL or PADATA_CPU_PARALLEL corresponding to parallel and serial cpumasks respectively.}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjvubj)}(h-``cpumask_var_t cpumask`` the cpumask to use h](j)}(h``cpumask_var_t cpumask``h]j)}(hjh]hcpumask_var_t cpumask}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubj)}(hhh]h)}(hthe cpumask to useh]hthe cpumask to use}(hj hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjvubeh}(h]h ]h"]h$]h&]uh1jhjZubh)}(h **Return**h]j)}(hj-h]hReturn}(hhhj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjZubh)}(h#0 on success or negative error codeh]h#0 on success or negative error code}(hjEhjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjZubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_alloc (C function)c.padata_allochNtauh1jhjhhhNhNubj)}(hhh](j)}(h8struct padata_instance * padata_alloc (const char *name)h]j)}(h6struct padata_instance *padata_alloc(const char *name)h](j)}(hjh]hstruct}(hhhjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjnhhhjhMubh)}(hhh]j+)}(hpadata_instanceh]hpadata_instance}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetjmodnameN classnameNj5j8)}j;]j>)}j1 padata_allocsbc.padata_allocasbuh1hhjnhhhjhMubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjnhhhjhMubjR)}(hjUh]h*}(hhhjhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjnhhhjhMubj%)}(h padata_alloch]j+)}(hjh]h padata_alloc}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjnhhhjhMubj)}(h(const char *name)h]j)}(hconst char *nameh](j)}(hconsth]hconst}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubj)}(hcharh]hchar}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjubjR)}(hjUh]h*}(hhhj$hhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjubj+)}(hnameh]hname}(hhhj1hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubah}(h]h ]h"]h$]h&]hhuh1jhjnhhhjhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjjhhhjhMubah}(h]jeah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjghhubjV)}(hhh]h)}(h)allocate and initialize a padata instanceh]h)allocate and initialize a padata instance}(hj^hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjYhhubah}(h]h ]h"]h$]h&]uh1jUhjghhhjhMubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxjtjyjtjzuh1jhhhjhNhNubj|)}(hx**Parameters** ``const char *name`` used to identify the instance **Return** new instance on success, NULL on errorh](h)}(h**Parameters**h]j)}(hj~h]h Parameters}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjxubj)}(hhh]j)}(h3``const char *name`` used to identify the instance h](j)}(h``const char *name``h]j)}(hjh]hconst char *name}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjubj)}(hhh]h)}(hused to identify the instanceh]hused to identify the instance}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjxubh)}(h **Return**h]j)}(hjh]hReturn}(hhhjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjxubh)}(h&new instance on success, NULL on errorh]h&new instance on success, NULL on error}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMhjxubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_free (C function) c.padata_freehNtauh1jhjhhhNhNubj)}(hhh](j)}(h0void padata_free (struct padata_instance *pinst)h]j)}(h/void padata_free(struct padata_instance *pinst)h](j)}(hvoidh]hvoid}(hhhjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM$ubj)}(h h]h }(hhhj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjhhhj+hM$ubj%)}(h padata_freeh]j+)}(h padata_freeh]h padata_free}(hhhj>hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj:ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hjhhhj+hM$ubj)}(h(struct padata_instance *pinst)h]j)}(hstruct padata_instance *pinsth](j)}(hjh]hstruct}(hhhjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjVubj)}(h h]h }(hhhjghhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjVubh)}(hhh]j+)}(hpadata_instanceh]hpadata_instance}(hhhjxhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjuubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetjzmodnameN classnameNj5j8)}j;]j>)}j1j@sb c.padata_freeasbuh1hhjVubj)}(h h]h }(hhhjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjVubjR)}(hjUh]h*}(hhhjhhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjVubj+)}(hpinsth]hpinst}(hhhjhhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjVubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjRubah}(h]h ]h"]h$]h&]hhuh1jhjhhhj+hM$ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhj+hM$ubah}(h]jah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM'hjhhubjV)}(hhh]h)}(hfree a padata instanceh]hfree a padata instance}(hjhjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM#hjhhubah}(h]h ]h"]h$]h&]uh1jUhjhhhj+hM$ubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxjjyjjzuh1jhhhjhNhNubj|)}(hK**Parameters** ``struct padata_instance *pinst`` padata instance to freeh](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hhhj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM'hjubj)}(hhh]j)}(h9``struct padata_instance *pinst`` padata instance to freeh](j)}(h!``struct padata_instance *pinst``h]j)}(hj h]hstruct padata_instance *pinst}(hhhj! hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM)hj ubj)}(hhh]h)}(hpadata instance to freeh]hpadata instance to free}(hj: hj8 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM%hj5 ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj4 hM)hj ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_alloc_shell (C function)c.padata_alloc_shellhNtauh1jhjhhhNhNubj)}(hhh](j)}(hHstruct padata_shell * padata_alloc_shell (struct padata_instance *pinst)h]j)}(hFstruct padata_shell *padata_alloc_shell(struct padata_instance *pinst)h](j)}(hjh]hstruct}(hhhjy hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhju hhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM/ubj)}(h h]h }(hhhj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhju hhhj hM/ubh)}(hhh]j+)}(h padata_shellh]h padata_shell}(hhhj hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj ubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetj modnameN classnameNj5j8)}j;]j>)}j1padata_alloc_shellsbc.padata_alloc_shellasbuh1hhju hhhj hM/ubj)}(h h]h }(hhhj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhju hhhj hM/ubjR)}(hjUh]h*}(hhhj hhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhju hhhj hM/ubj%)}(hpadata_alloc_shellh]j+)}(hj h]hpadata_alloc_shell}(hhhj hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hju hhhj hM/ubj)}(h(struct padata_instance *pinst)h]j)}(hstruct padata_instance *pinsth](j)}(hjh]hstruct}(hhhj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hhhj!hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhj ubh)}(hhh]j+)}(hpadata_instanceh]hpadata_instance}(hhhj!hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj!ubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetj!modnameN classnameNj5j8)}j;]j c.padata_alloc_shellasbuh1hhj ubj)}(h h]h }(hhhj/!hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhj ubjR)}(hjUh]h*}(hhhj=!hhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhj ubj+)}(hpinsth]hpinst}(hhhjJ!hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj ubah}(h]h ]h"]h$]h&]hhuh1jhju hhhj hM/ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjq hhhj hM/ubah}(h]jl ah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM4hjn hhubjV)}(hhh]h)}(h%Allocate and initialize padata shell.h]h%Allocate and initialize padata shell.}(hjw!hju!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM.hjr!hhubah}(h]h ]h"]h$]h&]uh1jUhjn hhhj hM/ubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxj!jyj!jzuh1jhhhjhNhNubj|)}(h**Parameters** ``struct padata_instance *pinst`` Parent padata_instance object. **Return** new shell on success, NULL on errorh](h)}(h**Parameters**h]j)}(hj!h]h Parameters}(hhhj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM2hj!ubj)}(hhh]j)}(hA``struct padata_instance *pinst`` Parent padata_instance object. h](j)}(h!``struct padata_instance *pinst``h]j)}(hj!h]hstruct padata_instance *pinst}(hhhj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM0hj!ubj)}(hhh]h)}(hParent padata_instance object.h]hParent padata_instance object.}(hj!hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hM0hj!ubah}(h]h ]h"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]uh1jhj!hM0hj!ubah}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h **Return**h]j)}(hj!h]hReturn}(hhhj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM2hj!ubh)}(h#new shell on success, NULL on errorh]h#new shell on success, NULL on error}(hj "hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM2hj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jpadata_free_shell (C function)c.padata_free_shellhNtauh1jhjhhhNhNubj)}(hhh](j)}(h0void padata_free_shell (struct padata_shell *ps)h]j)}(h/void padata_free_shell(struct padata_shell *ps)h](j)}(hvoidh]hvoid}(hhhj6"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2"hhhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMVubj)}(h h]h }(hhhjE"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhj2"hhhjD"hMVubj%)}(hpadata_free_shellh]j+)}(hpadata_free_shellh]hpadata_free_shell}(hhhjW"hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjS"ubah}(h]h ](j=j>eh"]h$]h&]hhuh1j$hj2"hhhjD"hMVubj)}(h(struct padata_shell *ps)h]j)}(hstruct padata_shell *psh](j)}(hjh]hstruct}(hhhjs"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjo"ubj)}(h h]h }(hhhj"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjo"ubh)}(hhh]j+)}(h padata_shellh]h padata_shell}(hhhj"hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hj"ubah}(h]h ]h"]h$]h&] refdomainjrreftypej1 reftargetj"modnameN classnameNj5j8)}j;]j>)}j1jY"sbc.padata_free_shellasbuh1hhjo"ubj)}(h h]h }(hhhj"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1jhjo"ubjR)}(hjUh]h*}(hhhj"hhhNhNubah}(h]h ]j^ah"]h$]h&]uh1jQhjo"ubj+)}(hpsh]hps}(hhhj"hhhNhNubah}(h]h ]j6ah"]h$]h&]uh1j*hjo"ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjk"ubah}(h]h ]h"]h$]h&]hhuh1jhj2"hhhjD"hMVubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj."hhhjD"hMVubah}(h]j)"ah ](jNjOeh"]h$]h&]jSuh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMYhj+"hhubjV)}(hhh]h)}(hfree a padata shellh]hfree a padata shell}(hj"hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMUhj"hhubah}(h]h ]h"]h$]h&]uh1jUhj+"hhhjD"hMVubeh}(h]h ](jrfunctioneh"]h$]h&]jwjrjxj#jyj#jzuh1jhhhjhNhNubj|)}(hB**Parameters** ``struct padata_shell *ps`` padata shell to freeh](h)}(h**Parameters**h]j)}(hj#h]h Parameters}(hhhj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMYhj#ubj)}(hhh]j)}(h0``struct padata_shell *ps`` padata shell to freeh](j)}(h``struct padata_shell *ps``h]j)}(hj8#h]hstruct padata_shell *ps}(hhhj:#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6#ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chM[hj2#ubj)}(hhh]h)}(hpadata shell to freeh]hpadata shell to free}(hjS#hjQ#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/core-api/padata:178: ./kernel/padata.chMWhjN#ubah}(h]h ]h"]h$]h&]uh1jhj2#ubeh}(h]h ]h"]h$]h&]uh1jhjM#hM[hj/#ubah}(h]h ]h"]h$]h&]uh1jhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1j{hjhhhNhNubeh}(h] interfaceah ]h"] interfaceah$]h&]uh1hhhhhhhhKubeh}(h]'the-padata-parallel-execution-mechanismah ]h"]'the padata parallel execution mechanismah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerj#error_encodingUTF-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confapep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacefile_insertion_enabled raw_enabledKline_length_limitM'syntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_link embed_imagesenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}nameids}(j#j#jZjWjjj?j<jjjj jRjOjjj~#j{#u nametypes}(j#NjZNjNj?NjNjNjRNjNj~#Nuh}(j#hjWj5jjFj<jjjBj jjOjjj]j{#jjjj|jjjj; j@ j~ j j j j>jCjjjjjjjJjOjjjejjjjjl jq j)"j."u footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}Rparse_messages]transform_messages] transformerN include_log] decorationNhhub.