mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-18 03:23:53 -04:00
cpuset: Propagate cpuset isolation update to workqueue through housekeeping
Until now, cpuset would propagate isolated partition changes to workqueues so that unbound workers get properly reaffined. Since housekeeping now centralizes, synchronize and propagates isolation cpumask changes, perform the work from that subsystem for consolidation and consistency purposes. For simplification purpose, the target function is adapted to take the new housekeeping mask instead of the isolated mask. Suggested-by: Tejun Heo <tj@kernel.org> Signed-off-by: Frederic Weisbecker <frederic@kernel.org> Reviewed-by: Waiman Long <longman@redhat.com> Acked-by: Tejun Heo <tj@kernel.org> Cc: "Michal Koutný" <mkoutny@suse.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Johannes Weiner <hannes@cmpxchg.org> Cc: Lai Jiangshan <jiangshanlai@gmail.com> Cc: Marco Crivellari <marco.crivellari@suse.com> Cc: Michal Hocko <mhocko@suse.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Tejun Heo <tj@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Vlastimil Babka <vbabka@suse.cz> Cc: Waiman Long <longman@redhat.com> Cc: cgroups@vger.kernel.org
This commit is contained in:
@@ -588,7 +588,7 @@ struct workqueue_attrs *alloc_workqueue_attrs_noprof(void);
|
|||||||
void free_workqueue_attrs(struct workqueue_attrs *attrs);
|
void free_workqueue_attrs(struct workqueue_attrs *attrs);
|
||||||
int apply_workqueue_attrs(struct workqueue_struct *wq,
|
int apply_workqueue_attrs(struct workqueue_struct *wq,
|
||||||
const struct workqueue_attrs *attrs);
|
const struct workqueue_attrs *attrs);
|
||||||
extern int workqueue_unbound_exclude_cpumask(cpumask_var_t cpumask);
|
extern int workqueue_unbound_housekeeping_update(const struct cpumask *hk);
|
||||||
|
|
||||||
extern bool queue_work_on(int cpu, struct workqueue_struct *wq,
|
extern bool queue_work_on(int cpu, struct workqueue_struct *wq,
|
||||||
struct work_struct *work);
|
struct work_struct *work);
|
||||||
|
|||||||
@@ -1254,6 +1254,7 @@ config CPUSETS
|
|||||||
bool "Cpuset controller"
|
bool "Cpuset controller"
|
||||||
depends on SMP
|
depends on SMP
|
||||||
select UNION_FIND
|
select UNION_FIND
|
||||||
|
select CPU_ISOLATION
|
||||||
help
|
help
|
||||||
This option will let you create and manage CPUSETs which
|
This option will let you create and manage CPUSETs which
|
||||||
allow dynamically partitioning a system into sets of CPUs and
|
allow dynamically partitioning a system into sets of CPUs and
|
||||||
|
|||||||
@@ -1482,15 +1482,12 @@ static void update_isolation_cpumasks(void)
|
|||||||
if (!isolated_cpus_updating)
|
if (!isolated_cpus_updating)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ret = workqueue_unbound_exclude_cpumask(isolated_cpus);
|
ret = housekeeping_update(isolated_cpus);
|
||||||
WARN_ON_ONCE(ret < 0);
|
WARN_ON_ONCE(ret < 0);
|
||||||
|
|
||||||
ret = tmigr_isolated_exclude_cpumask(isolated_cpus);
|
ret = tmigr_isolated_exclude_cpumask(isolated_cpus);
|
||||||
WARN_ON_ONCE(ret < 0);
|
WARN_ON_ONCE(ret < 0);
|
||||||
|
|
||||||
ret = housekeeping_update(isolated_cpus);
|
|
||||||
WARN_ON_ONCE(ret < 0);
|
|
||||||
|
|
||||||
isolated_cpus_updating = false;
|
isolated_cpus_updating = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -121,6 +121,7 @@ EXPORT_SYMBOL_GPL(housekeeping_test_cpu);
|
|||||||
int housekeeping_update(struct cpumask *isol_mask)
|
int housekeeping_update(struct cpumask *isol_mask)
|
||||||
{
|
{
|
||||||
struct cpumask *trial, *old = NULL;
|
struct cpumask *trial, *old = NULL;
|
||||||
|
int err;
|
||||||
|
|
||||||
lockdep_assert_cpus_held();
|
lockdep_assert_cpus_held();
|
||||||
|
|
||||||
@@ -148,6 +149,8 @@ int housekeeping_update(struct cpumask *isol_mask)
|
|||||||
pci_probe_flush_workqueue();
|
pci_probe_flush_workqueue();
|
||||||
mem_cgroup_flush_workqueue();
|
mem_cgroup_flush_workqueue();
|
||||||
vmstat_flush_workqueue();
|
vmstat_flush_workqueue();
|
||||||
|
err = workqueue_unbound_housekeeping_update(housekeeping_cpumask(HK_TYPE_DOMAIN));
|
||||||
|
WARN_ON_ONCE(err < 0);
|
||||||
|
|
||||||
kfree(old);
|
kfree(old);
|
||||||
|
|
||||||
|
|||||||
@@ -6959,13 +6959,16 @@ static int workqueue_apply_unbound_cpumask(const cpumask_var_t unbound_cpumask)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* workqueue_unbound_exclude_cpumask - Exclude given CPUs from unbound cpumask
|
* workqueue_unbound_housekeeping_update - Propagate housekeeping cpumask update
|
||||||
* @exclude_cpumask: the cpumask to be excluded from wq_unbound_cpumask
|
* @hk: the new housekeeping cpumask
|
||||||
*
|
*
|
||||||
* This function can be called from cpuset code to provide a set of isolated
|
* Update the unbound workqueue cpumask on top of the new housekeeping cpumask such
|
||||||
* CPUs that should be excluded from wq_unbound_cpumask.
|
* that the effective unbound affinity is the intersection of the new housekeeping
|
||||||
|
* with the requested affinity set via nohz_full=/isolcpus= or sysfs.
|
||||||
|
*
|
||||||
|
* Return: 0 on success and -errno on failure.
|
||||||
*/
|
*/
|
||||||
int workqueue_unbound_exclude_cpumask(cpumask_var_t exclude_cpumask)
|
int workqueue_unbound_housekeeping_update(const struct cpumask *hk)
|
||||||
{
|
{
|
||||||
cpumask_var_t cpumask;
|
cpumask_var_t cpumask;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@@ -6981,14 +6984,14 @@ int workqueue_unbound_exclude_cpumask(cpumask_var_t exclude_cpumask)
|
|||||||
* (HK_TYPE_WQ ∩ HK_TYPE_DOMAIN) house keeping mask and rewritten
|
* (HK_TYPE_WQ ∩ HK_TYPE_DOMAIN) house keeping mask and rewritten
|
||||||
* by any subsequent write to workqueue/cpumask sysfs file.
|
* by any subsequent write to workqueue/cpumask sysfs file.
|
||||||
*/
|
*/
|
||||||
if (!cpumask_andnot(cpumask, wq_requested_unbound_cpumask, exclude_cpumask))
|
if (!cpumask_and(cpumask, wq_requested_unbound_cpumask, hk))
|
||||||
cpumask_copy(cpumask, wq_requested_unbound_cpumask);
|
cpumask_copy(cpumask, wq_requested_unbound_cpumask);
|
||||||
if (!cpumask_equal(cpumask, wq_unbound_cpumask))
|
if (!cpumask_equal(cpumask, wq_unbound_cpumask))
|
||||||
ret = workqueue_apply_unbound_cpumask(cpumask);
|
ret = workqueue_apply_unbound_cpumask(cpumask);
|
||||||
|
|
||||||
/* Save the current isolated cpumask & export it via sysfs */
|
/* Save the current isolated cpumask & export it via sysfs */
|
||||||
if (!ret)
|
if (!ret)
|
||||||
cpumask_copy(wq_isolated_cpumask, exclude_cpumask);
|
cpumask_andnot(wq_isolated_cpumask, cpu_possible_mask, hk);
|
||||||
|
|
||||||
mutex_unlock(&wq_pool_mutex);
|
mutex_unlock(&wq_pool_mutex);
|
||||||
free_cpumask_var(cpumask);
|
free_cpumask_var(cpumask);
|
||||||
|
|||||||
Reference in New Issue
Block a user