Commit c103d4d4 authored by Tony Luck's avatar Tony Luck Committed by Borislav Petkov (AMD)

x86/resctrl: Prepare to split rdt_domain structure

The rdt_domain structure is used for both control and monitor features.
It is about to be split into separate structures for these two usages
because the scope for control and monitoring features for a resource
will be different for future resources.

To allow for common code that scans a list of domains looking for a
specific domain id, move all the common fields ("list", "id", "cpu_mask")
into their own structure within the rdt_domain structure.
Signed-off-by: default avatarTony Luck <tony.luck@intel.com>
Signed-off-by: default avatarBorislav Petkov (AMD) <bp@alien8.de>
Reviewed-by: default avatarReinette Chatre <reinette.chatre@intel.com>
Tested-by: default avatarBabu Moger <babu.moger@amd.com>
Link: https://lore.kernel.org/r/20240628215619.76401-3-tony.luck@intel.com
parent f436cb69
...@@ -355,9 +355,9 @@ struct rdt_domain *get_domain_from_cpu(int cpu, struct rdt_resource *r) ...@@ -355,9 +355,9 @@ struct rdt_domain *get_domain_from_cpu(int cpu, struct rdt_resource *r)
lockdep_assert_cpus_held(); lockdep_assert_cpus_held();
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
/* Find the domain that contains this CPU */ /* Find the domain that contains this CPU */
if (cpumask_test_cpu(cpu, &d->cpu_mask)) if (cpumask_test_cpu(cpu, &d->hdr.cpu_mask))
return d; return d;
} }
...@@ -393,12 +393,12 @@ struct rdt_domain *rdt_find_domain(struct rdt_resource *r, int id, ...@@ -393,12 +393,12 @@ struct rdt_domain *rdt_find_domain(struct rdt_resource *r, int id,
struct list_head *l; struct list_head *l;
list_for_each(l, &r->domains) { list_for_each(l, &r->domains) {
d = list_entry(l, struct rdt_domain, list); d = list_entry(l, struct rdt_domain, hdr.list);
/* When id is found, return its domain. */ /* When id is found, return its domain. */
if (id == d->id) if (id == d->hdr.id)
return d; return d;
/* Stop searching when finding id's position in sorted list. */ /* Stop searching when finding id's position in sorted list. */
if (id < d->id) if (id < d->hdr.id)
break; break;
} }
...@@ -526,7 +526,7 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r) ...@@ -526,7 +526,7 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r)
d = rdt_find_domain(r, id, &add_pos); d = rdt_find_domain(r, id, &add_pos);
if (d) { if (d) {
cpumask_set_cpu(cpu, &d->cpu_mask); cpumask_set_cpu(cpu, &d->hdr.cpu_mask);
if (r->cache.arch_has_per_cpu_cfg) if (r->cache.arch_has_per_cpu_cfg)
rdt_domain_reconfigure_cdp(r); rdt_domain_reconfigure_cdp(r);
return; return;
...@@ -537,8 +537,8 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r) ...@@ -537,8 +537,8 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r)
return; return;
d = &hw_dom->d_resctrl; d = &hw_dom->d_resctrl;
d->id = id; d->hdr.id = id;
cpumask_set_cpu(cpu, &d->cpu_mask); cpumask_set_cpu(cpu, &d->hdr.cpu_mask);
rdt_domain_reconfigure_cdp(r); rdt_domain_reconfigure_cdp(r);
...@@ -552,11 +552,11 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r) ...@@ -552,11 +552,11 @@ static void domain_add_cpu(int cpu, struct rdt_resource *r)
return; return;
} }
list_add_tail_rcu(&d->list, add_pos); list_add_tail_rcu(&d->hdr.list, add_pos);
err = resctrl_online_domain(r, d); err = resctrl_online_domain(r, d);
if (err) { if (err) {
list_del_rcu(&d->list); list_del_rcu(&d->hdr.list);
synchronize_rcu(); synchronize_rcu();
domain_free(hw_dom); domain_free(hw_dom);
} }
...@@ -583,10 +583,10 @@ static void domain_remove_cpu(int cpu, struct rdt_resource *r) ...@@ -583,10 +583,10 @@ static void domain_remove_cpu(int cpu, struct rdt_resource *r)
} }
hw_dom = resctrl_to_arch_dom(d); hw_dom = resctrl_to_arch_dom(d);
cpumask_clear_cpu(cpu, &d->cpu_mask); cpumask_clear_cpu(cpu, &d->hdr.cpu_mask);
if (cpumask_empty(&d->cpu_mask)) { if (cpumask_empty(&d->hdr.cpu_mask)) {
resctrl_offline_domain(r, d); resctrl_offline_domain(r, d);
list_del_rcu(&d->list); list_del_rcu(&d->hdr.list);
synchronize_rcu(); synchronize_rcu();
/* /*
......
...@@ -69,7 +69,7 @@ int parse_bw(struct rdt_parse_data *data, struct resctrl_schema *s, ...@@ -69,7 +69,7 @@ int parse_bw(struct rdt_parse_data *data, struct resctrl_schema *s,
cfg = &d->staged_config[s->conf_type]; cfg = &d->staged_config[s->conf_type];
if (cfg->have_new_ctrl) { if (cfg->have_new_ctrl) {
rdt_last_cmd_printf("Duplicate domain %d\n", d->id); rdt_last_cmd_printf("Duplicate domain %d\n", d->hdr.id);
return -EINVAL; return -EINVAL;
} }
...@@ -148,7 +148,7 @@ int parse_cbm(struct rdt_parse_data *data, struct resctrl_schema *s, ...@@ -148,7 +148,7 @@ int parse_cbm(struct rdt_parse_data *data, struct resctrl_schema *s,
cfg = &d->staged_config[s->conf_type]; cfg = &d->staged_config[s->conf_type];
if (cfg->have_new_ctrl) { if (cfg->have_new_ctrl) {
rdt_last_cmd_printf("Duplicate domain %d\n", d->id); rdt_last_cmd_printf("Duplicate domain %d\n", d->hdr.id);
return -EINVAL; return -EINVAL;
} }
...@@ -231,8 +231,8 @@ static int parse_line(char *line, struct resctrl_schema *s, ...@@ -231,8 +231,8 @@ static int parse_line(char *line, struct resctrl_schema *s,
return -EINVAL; return -EINVAL;
} }
dom = strim(dom); dom = strim(dom);
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
if (d->id == dom_id) { if (d->hdr.id == dom_id) {
data.buf = dom; data.buf = dom;
data.rdtgrp = rdtgrp; data.rdtgrp = rdtgrp;
if (r->parse_ctrlval(&data, s, d)) if (r->parse_ctrlval(&data, s, d))
...@@ -280,7 +280,7 @@ int resctrl_arch_update_one(struct rdt_resource *r, struct rdt_domain *d, ...@@ -280,7 +280,7 @@ int resctrl_arch_update_one(struct rdt_resource *r, struct rdt_domain *d,
u32 idx = get_config_index(closid, t); u32 idx = get_config_index(closid, t);
struct msr_param msr_param; struct msr_param msr_param;
if (!cpumask_test_cpu(smp_processor_id(), &d->cpu_mask)) if (!cpumask_test_cpu(smp_processor_id(), &d->hdr.cpu_mask))
return -EINVAL; return -EINVAL;
hw_dom->ctrl_val[idx] = cfg_val; hw_dom->ctrl_val[idx] = cfg_val;
...@@ -306,7 +306,7 @@ int resctrl_arch_update_domains(struct rdt_resource *r, u32 closid) ...@@ -306,7 +306,7 @@ int resctrl_arch_update_domains(struct rdt_resource *r, u32 closid)
/* Walking r->domains, ensure it can't race with cpuhp */ /* Walking r->domains, ensure it can't race with cpuhp */
lockdep_assert_cpus_held(); lockdep_assert_cpus_held();
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
hw_dom = resctrl_to_arch_dom(d); hw_dom = resctrl_to_arch_dom(d);
msr_param.res = NULL; msr_param.res = NULL;
for (t = 0; t < CDP_NUM_TYPES; t++) { for (t = 0; t < CDP_NUM_TYPES; t++) {
...@@ -330,7 +330,7 @@ int resctrl_arch_update_domains(struct rdt_resource *r, u32 closid) ...@@ -330,7 +330,7 @@ int resctrl_arch_update_domains(struct rdt_resource *r, u32 closid)
} }
} }
if (msr_param.res) if (msr_param.res)
smp_call_function_any(&d->cpu_mask, rdt_ctrl_update, &msr_param, 1); smp_call_function_any(&d->hdr.cpu_mask, rdt_ctrl_update, &msr_param, 1);
} }
return 0; return 0;
...@@ -450,7 +450,7 @@ static void show_doms(struct seq_file *s, struct resctrl_schema *schema, int clo ...@@ -450,7 +450,7 @@ static void show_doms(struct seq_file *s, struct resctrl_schema *schema, int clo
lockdep_assert_cpus_held(); lockdep_assert_cpus_held();
seq_printf(s, "%*s:", max_name_width, schema->name); seq_printf(s, "%*s:", max_name_width, schema->name);
list_for_each_entry(dom, &r->domains, list) { list_for_each_entry(dom, &r->domains, hdr.list) {
if (sep) if (sep)
seq_puts(s, ";"); seq_puts(s, ";");
...@@ -460,7 +460,7 @@ static void show_doms(struct seq_file *s, struct resctrl_schema *schema, int clo ...@@ -460,7 +460,7 @@ static void show_doms(struct seq_file *s, struct resctrl_schema *schema, int clo
ctrl_val = resctrl_arch_get_config(r, dom, closid, ctrl_val = resctrl_arch_get_config(r, dom, closid,
schema->conf_type); schema->conf_type);
seq_printf(s, r->format_str, dom->id, max_data_width, seq_printf(s, r->format_str, dom->hdr.id, max_data_width,
ctrl_val); ctrl_val);
sep = true; sep = true;
} }
...@@ -489,7 +489,7 @@ int rdtgroup_schemata_show(struct kernfs_open_file *of, ...@@ -489,7 +489,7 @@ int rdtgroup_schemata_show(struct kernfs_open_file *of,
} else { } else {
seq_printf(s, "%s:%d=%x\n", seq_printf(s, "%s:%d=%x\n",
rdtgrp->plr->s->res->name, rdtgrp->plr->s->res->name,
rdtgrp->plr->d->id, rdtgrp->plr->d->hdr.id,
rdtgrp->plr->cbm); rdtgrp->plr->cbm);
} }
} else { } else {
...@@ -537,7 +537,7 @@ void mon_event_read(struct rmid_read *rr, struct rdt_resource *r, ...@@ -537,7 +537,7 @@ void mon_event_read(struct rmid_read *rr, struct rdt_resource *r,
return; return;
} }
cpu = cpumask_any_housekeeping(&d->cpu_mask, RESCTRL_PICK_ANY_CPU); cpu = cpumask_any_housekeeping(&d->hdr.cpu_mask, RESCTRL_PICK_ANY_CPU);
/* /*
* cpumask_any_housekeeping() prefers housekeeping CPUs, but * cpumask_any_housekeeping() prefers housekeeping CPUs, but
...@@ -546,7 +546,7 @@ void mon_event_read(struct rmid_read *rr, struct rdt_resource *r, ...@@ -546,7 +546,7 @@ void mon_event_read(struct rmid_read *rr, struct rdt_resource *r,
* counters on some platforms if its called in IRQ context. * counters on some platforms if its called in IRQ context.
*/ */
if (tick_nohz_full_cpu(cpu)) if (tick_nohz_full_cpu(cpu))
smp_call_function_any(&d->cpu_mask, mon_event_count, rr, 1); smp_call_function_any(&d->hdr.cpu_mask, mon_event_count, rr, 1);
else else
smp_call_on_cpu(cpu, smp_mon_event_count, rr, false); smp_call_on_cpu(cpu, smp_mon_event_count, rr, false);
......
...@@ -281,7 +281,7 @@ int resctrl_arch_rmid_read(struct rdt_resource *r, struct rdt_domain *d, ...@@ -281,7 +281,7 @@ int resctrl_arch_rmid_read(struct rdt_resource *r, struct rdt_domain *d,
resctrl_arch_rmid_read_context_check(); resctrl_arch_rmid_read_context_check();
if (!cpumask_test_cpu(smp_processor_id(), &d->cpu_mask)) if (!cpumask_test_cpu(smp_processor_id(), &d->hdr.cpu_mask))
return -EINVAL; return -EINVAL;
ret = __rmid_read(rmid, eventid, &msr_val); ret = __rmid_read(rmid, eventid, &msr_val);
...@@ -364,7 +364,7 @@ void __check_limbo(struct rdt_domain *d, bool force_free) ...@@ -364,7 +364,7 @@ void __check_limbo(struct rdt_domain *d, bool force_free)
* CLOSID and RMID because there may be dependencies between them * CLOSID and RMID because there may be dependencies between them
* on some architectures. * on some architectures.
*/ */
trace_mon_llc_occupancy_limbo(entry->closid, entry->rmid, d->id, val); trace_mon_llc_occupancy_limbo(entry->closid, entry->rmid, d->hdr.id, val);
} }
if (force_free || !rmid_dirty) { if (force_free || !rmid_dirty) {
...@@ -490,7 +490,7 @@ static void add_rmid_to_limbo(struct rmid_entry *entry) ...@@ -490,7 +490,7 @@ static void add_rmid_to_limbo(struct rmid_entry *entry)
idx = resctrl_arch_rmid_idx_encode(entry->closid, entry->rmid); idx = resctrl_arch_rmid_idx_encode(entry->closid, entry->rmid);
entry->busy = 0; entry->busy = 0;
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
/* /*
* For the first limbo RMID in the domain, * For the first limbo RMID in the domain,
* setup up the limbo worker. * setup up the limbo worker.
...@@ -801,7 +801,7 @@ void cqm_handle_limbo(struct work_struct *work) ...@@ -801,7 +801,7 @@ void cqm_handle_limbo(struct work_struct *work)
__check_limbo(d, false); __check_limbo(d, false);
if (has_busy_rmid(d)) { if (has_busy_rmid(d)) {
d->cqm_work_cpu = cpumask_any_housekeeping(&d->cpu_mask, d->cqm_work_cpu = cpumask_any_housekeeping(&d->hdr.cpu_mask,
RESCTRL_PICK_ANY_CPU); RESCTRL_PICK_ANY_CPU);
schedule_delayed_work_on(d->cqm_work_cpu, &d->cqm_limbo, schedule_delayed_work_on(d->cqm_work_cpu, &d->cqm_limbo,
delay); delay);
...@@ -825,7 +825,7 @@ void cqm_setup_limbo_handler(struct rdt_domain *dom, unsigned long delay_ms, ...@@ -825,7 +825,7 @@ void cqm_setup_limbo_handler(struct rdt_domain *dom, unsigned long delay_ms,
unsigned long delay = msecs_to_jiffies(delay_ms); unsigned long delay = msecs_to_jiffies(delay_ms);
int cpu; int cpu;
cpu = cpumask_any_housekeeping(&dom->cpu_mask, exclude_cpu); cpu = cpumask_any_housekeeping(&dom->hdr.cpu_mask, exclude_cpu);
dom->cqm_work_cpu = cpu; dom->cqm_work_cpu = cpu;
if (cpu < nr_cpu_ids) if (cpu < nr_cpu_ids)
...@@ -868,7 +868,7 @@ void mbm_handle_overflow(struct work_struct *work) ...@@ -868,7 +868,7 @@ void mbm_handle_overflow(struct work_struct *work)
* Re-check for housekeeping CPUs. This allows the overflow handler to * Re-check for housekeeping CPUs. This allows the overflow handler to
* move off a nohz_full CPU quickly. * move off a nohz_full CPU quickly.
*/ */
d->mbm_work_cpu = cpumask_any_housekeeping(&d->cpu_mask, d->mbm_work_cpu = cpumask_any_housekeeping(&d->hdr.cpu_mask,
RESCTRL_PICK_ANY_CPU); RESCTRL_PICK_ANY_CPU);
schedule_delayed_work_on(d->mbm_work_cpu, &d->mbm_over, delay); schedule_delayed_work_on(d->mbm_work_cpu, &d->mbm_over, delay);
...@@ -897,7 +897,7 @@ void mbm_setup_overflow_handler(struct rdt_domain *dom, unsigned long delay_ms, ...@@ -897,7 +897,7 @@ void mbm_setup_overflow_handler(struct rdt_domain *dom, unsigned long delay_ms,
*/ */
if (!resctrl_mounted || !resctrl_arch_mon_capable()) if (!resctrl_mounted || !resctrl_arch_mon_capable())
return; return;
cpu = cpumask_any_housekeeping(&dom->cpu_mask, exclude_cpu); cpu = cpumask_any_housekeeping(&dom->hdr.cpu_mask, exclude_cpu);
dom->mbm_work_cpu = cpu; dom->mbm_work_cpu = cpu;
if (cpu < nr_cpu_ids) if (cpu < nr_cpu_ids)
......
...@@ -221,7 +221,7 @@ static int pseudo_lock_cstates_constrain(struct pseudo_lock_region *plr) ...@@ -221,7 +221,7 @@ static int pseudo_lock_cstates_constrain(struct pseudo_lock_region *plr)
int cpu; int cpu;
int ret; int ret;
for_each_cpu(cpu, &plr->d->cpu_mask) { for_each_cpu(cpu, &plr->d->hdr.cpu_mask) {
pm_req = kzalloc(sizeof(*pm_req), GFP_KERNEL); pm_req = kzalloc(sizeof(*pm_req), GFP_KERNEL);
if (!pm_req) { if (!pm_req) {
rdt_last_cmd_puts("Failure to allocate memory for PM QoS\n"); rdt_last_cmd_puts("Failure to allocate memory for PM QoS\n");
...@@ -300,7 +300,7 @@ static int pseudo_lock_region_init(struct pseudo_lock_region *plr) ...@@ -300,7 +300,7 @@ static int pseudo_lock_region_init(struct pseudo_lock_region *plr)
return -ENODEV; return -ENODEV;
/* Pick the first cpu we find that is associated with the cache. */ /* Pick the first cpu we find that is associated with the cache. */
plr->cpu = cpumask_first(&plr->d->cpu_mask); plr->cpu = cpumask_first(&plr->d->hdr.cpu_mask);
if (!cpu_online(plr->cpu)) { if (!cpu_online(plr->cpu)) {
rdt_last_cmd_printf("CPU %u associated with cache not online\n", rdt_last_cmd_printf("CPU %u associated with cache not online\n",
...@@ -854,10 +854,10 @@ bool rdtgroup_pseudo_locked_in_hierarchy(struct rdt_domain *d) ...@@ -854,10 +854,10 @@ bool rdtgroup_pseudo_locked_in_hierarchy(struct rdt_domain *d)
* associated with them. * associated with them.
*/ */
for_each_alloc_capable_rdt_resource(r) { for_each_alloc_capable_rdt_resource(r) {
list_for_each_entry(d_i, &r->domains, list) { list_for_each_entry(d_i, &r->domains, hdr.list) {
if (d_i->plr) if (d_i->plr)
cpumask_or(cpu_with_psl, cpu_with_psl, cpumask_or(cpu_with_psl, cpu_with_psl,
&d_i->cpu_mask); &d_i->hdr.cpu_mask);
} }
} }
...@@ -865,7 +865,7 @@ bool rdtgroup_pseudo_locked_in_hierarchy(struct rdt_domain *d) ...@@ -865,7 +865,7 @@ bool rdtgroup_pseudo_locked_in_hierarchy(struct rdt_domain *d)
* Next test if new pseudo-locked region would intersect with * Next test if new pseudo-locked region would intersect with
* existing region. * existing region.
*/ */
if (cpumask_intersects(&d->cpu_mask, cpu_with_psl)) if (cpumask_intersects(&d->hdr.cpu_mask, cpu_with_psl))
ret = true; ret = true;
free_cpumask_var(cpu_with_psl); free_cpumask_var(cpu_with_psl);
...@@ -1197,7 +1197,7 @@ static int pseudo_lock_measure_cycles(struct rdtgroup *rdtgrp, int sel) ...@@ -1197,7 +1197,7 @@ static int pseudo_lock_measure_cycles(struct rdtgroup *rdtgrp, int sel)
} }
plr->thread_done = 0; plr->thread_done = 0;
cpu = cpumask_first(&plr->d->cpu_mask); cpu = cpumask_first(&plr->d->hdr.cpu_mask);
if (!cpu_online(cpu)) { if (!cpu_online(cpu)) {
ret = -ENODEV; ret = -ENODEV;
goto out; goto out;
...@@ -1527,7 +1527,7 @@ static int pseudo_lock_dev_mmap(struct file *filp, struct vm_area_struct *vma) ...@@ -1527,7 +1527,7 @@ static int pseudo_lock_dev_mmap(struct file *filp, struct vm_area_struct *vma)
* may be scheduled elsewhere and invalidate entries in the * may be scheduled elsewhere and invalidate entries in the
* pseudo-locked region. * pseudo-locked region.
*/ */
if (!cpumask_subset(current->cpus_ptr, &plr->d->cpu_mask)) { if (!cpumask_subset(current->cpus_ptr, &plr->d->hdr.cpu_mask)) {
mutex_unlock(&rdtgroup_mutex); mutex_unlock(&rdtgroup_mutex);
return -EINVAL; return -EINVAL;
} }
......
...@@ -98,7 +98,7 @@ void rdt_staged_configs_clear(void) ...@@ -98,7 +98,7 @@ void rdt_staged_configs_clear(void)
lockdep_assert_held(&rdtgroup_mutex); lockdep_assert_held(&rdtgroup_mutex);
for_each_alloc_capable_rdt_resource(r) { for_each_alloc_capable_rdt_resource(r) {
list_for_each_entry(dom, &r->domains, list) list_for_each_entry(dom, &r->domains, hdr.list)
memset(dom->staged_config, 0, sizeof(dom->staged_config)); memset(dom->staged_config, 0, sizeof(dom->staged_config));
} }
} }
...@@ -317,7 +317,7 @@ static int rdtgroup_cpus_show(struct kernfs_open_file *of, ...@@ -317,7 +317,7 @@ static int rdtgroup_cpus_show(struct kernfs_open_file *of,
rdt_last_cmd_puts("Cache domain offline\n"); rdt_last_cmd_puts("Cache domain offline\n");
ret = -ENODEV; ret = -ENODEV;
} else { } else {
mask = &rdtgrp->plr->d->cpu_mask; mask = &rdtgrp->plr->d->hdr.cpu_mask;
seq_printf(s, is_cpu_list(of) ? seq_printf(s, is_cpu_list(of) ?
"%*pbl\n" : "%*pb\n", "%*pbl\n" : "%*pb\n",
cpumask_pr_args(mask)); cpumask_pr_args(mask));
...@@ -1021,12 +1021,12 @@ static int rdt_bit_usage_show(struct kernfs_open_file *of, ...@@ -1021,12 +1021,12 @@ static int rdt_bit_usage_show(struct kernfs_open_file *of,
cpus_read_lock(); cpus_read_lock();
mutex_lock(&rdtgroup_mutex); mutex_lock(&rdtgroup_mutex);
hw_shareable = r->cache.shareable_bits; hw_shareable = r->cache.shareable_bits;
list_for_each_entry(dom, &r->domains, list) { list_for_each_entry(dom, &r->domains, hdr.list) {
if (sep) if (sep)
seq_putc(seq, ';'); seq_putc(seq, ';');
sw_shareable = 0; sw_shareable = 0;
exclusive = 0; exclusive = 0;
seq_printf(seq, "%d=", dom->id); seq_printf(seq, "%d=", dom->hdr.id);
for (i = 0; i < closids_supported(); i++) { for (i = 0; i < closids_supported(); i++) {
if (!closid_allocated(i)) if (!closid_allocated(i))
continue; continue;
...@@ -1343,7 +1343,7 @@ static bool rdtgroup_mode_test_exclusive(struct rdtgroup *rdtgrp) ...@@ -1343,7 +1343,7 @@ static bool rdtgroup_mode_test_exclusive(struct rdtgroup *rdtgrp)
if (r->rid == RDT_RESOURCE_MBA || r->rid == RDT_RESOURCE_SMBA) if (r->rid == RDT_RESOURCE_MBA || r->rid == RDT_RESOURCE_SMBA)
continue; continue;
has_cache = true; has_cache = true;
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
ctrl = resctrl_arch_get_config(r, d, closid, ctrl = resctrl_arch_get_config(r, d, closid,
s->conf_type); s->conf_type);
if (rdtgroup_cbm_overlaps(s, d, ctrl, closid, false)) { if (rdtgroup_cbm_overlaps(s, d, ctrl, closid, false)) {
...@@ -1458,7 +1458,7 @@ unsigned int rdtgroup_cbm_to_size(struct rdt_resource *r, ...@@ -1458,7 +1458,7 @@ unsigned int rdtgroup_cbm_to_size(struct rdt_resource *r,
return size; return size;
num_b = bitmap_weight(&cbm, r->cache.cbm_len); num_b = bitmap_weight(&cbm, r->cache.cbm_len);
ci = get_cpu_cacheinfo_level(cpumask_any(&d->cpu_mask), r->scope); ci = get_cpu_cacheinfo_level(cpumask_any(&d->hdr.cpu_mask), r->scope);
if (ci) if (ci)
size = ci->size / r->cache.cbm_len * num_b; size = ci->size / r->cache.cbm_len * num_b;
...@@ -1502,7 +1502,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of, ...@@ -1502,7 +1502,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of,
size = rdtgroup_cbm_to_size(rdtgrp->plr->s->res, size = rdtgroup_cbm_to_size(rdtgrp->plr->s->res,
rdtgrp->plr->d, rdtgrp->plr->d,
rdtgrp->plr->cbm); rdtgrp->plr->cbm);
seq_printf(s, "%d=%u\n", rdtgrp->plr->d->id, size); seq_printf(s, "%d=%u\n", rdtgrp->plr->d->hdr.id, size);
} }
goto out; goto out;
} }
...@@ -1514,7 +1514,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of, ...@@ -1514,7 +1514,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of,
type = schema->conf_type; type = schema->conf_type;
sep = false; sep = false;
seq_printf(s, "%*s:", max_name_width, schema->name); seq_printf(s, "%*s:", max_name_width, schema->name);
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
if (sep) if (sep)
seq_putc(s, ';'); seq_putc(s, ';');
if (rdtgrp->mode == RDT_MODE_PSEUDO_LOCKSETUP) { if (rdtgrp->mode == RDT_MODE_PSEUDO_LOCKSETUP) {
...@@ -1532,7 +1532,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of, ...@@ -1532,7 +1532,7 @@ static int rdtgroup_size_show(struct kernfs_open_file *of,
else else
size = rdtgroup_cbm_to_size(r, d, ctrl); size = rdtgroup_cbm_to_size(r, d, ctrl);
} }
seq_printf(s, "%d=%u", d->id, size); seq_printf(s, "%d=%u", d->hdr.id, size);
sep = true; sep = true;
} }
seq_putc(s, '\n'); seq_putc(s, '\n');
...@@ -1592,7 +1592,7 @@ static void mon_event_config_read(void *info) ...@@ -1592,7 +1592,7 @@ static void mon_event_config_read(void *info)
static void mondata_config_read(struct rdt_domain *d, struct mon_config_info *mon_info) static void mondata_config_read(struct rdt_domain *d, struct mon_config_info *mon_info)
{ {
smp_call_function_any(&d->cpu_mask, mon_event_config_read, mon_info, 1); smp_call_function_any(&d->hdr.cpu_mask, mon_event_config_read, mon_info, 1);
} }
static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid) static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid)
...@@ -1604,7 +1604,7 @@ static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid ...@@ -1604,7 +1604,7 @@ static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid
cpus_read_lock(); cpus_read_lock();
mutex_lock(&rdtgroup_mutex); mutex_lock(&rdtgroup_mutex);
list_for_each_entry(dom, &r->domains, list) { list_for_each_entry(dom, &r->domains, hdr.list) {
if (sep) if (sep)
seq_puts(s, ";"); seq_puts(s, ";");
...@@ -1612,7 +1612,7 @@ static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid ...@@ -1612,7 +1612,7 @@ static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid
mon_info.evtid = evtid; mon_info.evtid = evtid;
mondata_config_read(dom, &mon_info); mondata_config_read(dom, &mon_info);
seq_printf(s, "%d=0x%02x", dom->id, mon_info.mon_config); seq_printf(s, "%d=0x%02x", dom->hdr.id, mon_info.mon_config);
sep = true; sep = true;
} }
seq_puts(s, "\n"); seq_puts(s, "\n");
...@@ -1678,7 +1678,7 @@ static void mbm_config_write_domain(struct rdt_resource *r, ...@@ -1678,7 +1678,7 @@ static void mbm_config_write_domain(struct rdt_resource *r,
* are scoped at the domain level. Writing any of these MSRs * are scoped at the domain level. Writing any of these MSRs
* on one CPU is observed by all the CPUs in the domain. * on one CPU is observed by all the CPUs in the domain.
*/ */
smp_call_function_any(&d->cpu_mask, mon_event_config_write, smp_call_function_any(&d->hdr.cpu_mask, mon_event_config_write,
&mon_info, 1); &mon_info, 1);
/* /*
...@@ -1728,8 +1728,8 @@ static int mon_config_write(struct rdt_resource *r, char *tok, u32 evtid) ...@@ -1728,8 +1728,8 @@ static int mon_config_write(struct rdt_resource *r, char *tok, u32 evtid)
return -EINVAL; return -EINVAL;
} }
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
if (d->id == dom_id) { if (d->hdr.id == dom_id) {
mbm_config_write_domain(r, d, evtid, val); mbm_config_write_domain(r, d, evtid, val);
goto next; goto next;
} }
...@@ -2276,14 +2276,14 @@ static int set_cache_qos_cfg(int level, bool enable) ...@@ -2276,14 +2276,14 @@ static int set_cache_qos_cfg(int level, bool enable)
return -ENOMEM; return -ENOMEM;
r_l = &rdt_resources_all[level].r_resctrl; r_l = &rdt_resources_all[level].r_resctrl;
list_for_each_entry(d, &r_l->domains, list) { list_for_each_entry(d, &r_l->domains, hdr.list) {
if (r_l->cache.arch_has_per_cpu_cfg) if (r_l->cache.arch_has_per_cpu_cfg)
/* Pick all the CPUs in the domain instance */ /* Pick all the CPUs in the domain instance */
for_each_cpu(cpu, &d->cpu_mask) for_each_cpu(cpu, &d->hdr.cpu_mask)
cpumask_set_cpu(cpu, cpu_mask); cpumask_set_cpu(cpu, cpu_mask);
else else
/* Pick one CPU from each domain instance to update MSR */ /* Pick one CPU from each domain instance to update MSR */
cpumask_set_cpu(cpumask_any(&d->cpu_mask), cpu_mask); cpumask_set_cpu(cpumask_any(&d->hdr.cpu_mask), cpu_mask);
} }
/* Update QOS_CFG MSR on all the CPUs in cpu_mask */ /* Update QOS_CFG MSR on all the CPUs in cpu_mask */
...@@ -2312,7 +2312,7 @@ void rdt_domain_reconfigure_cdp(struct rdt_resource *r) ...@@ -2312,7 +2312,7 @@ void rdt_domain_reconfigure_cdp(struct rdt_resource *r)
static int mba_sc_domain_allocate(struct rdt_resource *r, struct rdt_domain *d) static int mba_sc_domain_allocate(struct rdt_resource *r, struct rdt_domain *d)
{ {
u32 num_closid = resctrl_arch_get_num_closid(r); u32 num_closid = resctrl_arch_get_num_closid(r);
int cpu = cpumask_any(&d->cpu_mask); int cpu = cpumask_any(&d->hdr.cpu_mask);
int i; int i;
d->mbps_val = kcalloc_node(num_closid, sizeof(*d->mbps_val), d->mbps_val = kcalloc_node(num_closid, sizeof(*d->mbps_val),
...@@ -2361,7 +2361,7 @@ static int set_mba_sc(bool mba_sc) ...@@ -2361,7 +2361,7 @@ static int set_mba_sc(bool mba_sc)
r->membw.mba_sc = mba_sc; r->membw.mba_sc = mba_sc;
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
for (i = 0; i < num_closid; i++) for (i = 0; i < num_closid; i++)
d->mbps_val[i] = MBA_MAX_MBPS; d->mbps_val[i] = MBA_MAX_MBPS;
} }
...@@ -2700,7 +2700,7 @@ static int rdt_get_tree(struct fs_context *fc) ...@@ -2700,7 +2700,7 @@ static int rdt_get_tree(struct fs_context *fc)
if (is_mbm_enabled()) { if (is_mbm_enabled()) {
r = &rdt_resources_all[RDT_RESOURCE_L3].r_resctrl; r = &rdt_resources_all[RDT_RESOURCE_L3].r_resctrl;
list_for_each_entry(dom, &r->domains, list) list_for_each_entry(dom, &r->domains, hdr.list)
mbm_setup_overflow_handler(dom, MBM_OVERFLOW_INTERVAL, mbm_setup_overflow_handler(dom, MBM_OVERFLOW_INTERVAL,
RESCTRL_PICK_ANY_CPU); RESCTRL_PICK_ANY_CPU);
} }
...@@ -2827,13 +2827,13 @@ static int reset_all_ctrls(struct rdt_resource *r) ...@@ -2827,13 +2827,13 @@ static int reset_all_ctrls(struct rdt_resource *r)
* CBMs in all domains to the maximum mask value. Pick one CPU * CBMs in all domains to the maximum mask value. Pick one CPU
* from each domain to update the MSRs below. * from each domain to update the MSRs below.
*/ */
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
hw_dom = resctrl_to_arch_dom(d); hw_dom = resctrl_to_arch_dom(d);
for (i = 0; i < hw_res->num_closid; i++) for (i = 0; i < hw_res->num_closid; i++)
hw_dom->ctrl_val[i] = r->default_ctrl; hw_dom->ctrl_val[i] = r->default_ctrl;
msr_param.dom = d; msr_param.dom = d;
smp_call_function_any(&d->cpu_mask, rdt_ctrl_update, &msr_param, 1); smp_call_function_any(&d->hdr.cpu_mask, rdt_ctrl_update, &msr_param, 1);
} }
return 0; return 0;
...@@ -3031,7 +3031,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn, ...@@ -3031,7 +3031,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn,
char name[32]; char name[32];
int ret; int ret;
sprintf(name, "mon_%s_%02d", r->name, d->id); sprintf(name, "mon_%s_%02d", r->name, d->hdr.id);
/* create the directory */ /* create the directory */
kn = kernfs_create_dir(parent_kn, name, parent_kn->mode, prgrp); kn = kernfs_create_dir(parent_kn, name, parent_kn->mode, prgrp);
if (IS_ERR(kn)) if (IS_ERR(kn))
...@@ -3047,7 +3047,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn, ...@@ -3047,7 +3047,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn,
} }
priv.u.rid = r->rid; priv.u.rid = r->rid;
priv.u.domid = d->id; priv.u.domid = d->hdr.id;
list_for_each_entry(mevt, &r->evt_list, list) { list_for_each_entry(mevt, &r->evt_list, list) {
priv.u.evtid = mevt->evtid; priv.u.evtid = mevt->evtid;
ret = mon_addfile(kn, mevt->name, priv.priv); ret = mon_addfile(kn, mevt->name, priv.priv);
...@@ -3098,7 +3098,7 @@ static int mkdir_mondata_subdir_alldom(struct kernfs_node *parent_kn, ...@@ -3098,7 +3098,7 @@ static int mkdir_mondata_subdir_alldom(struct kernfs_node *parent_kn,
/* Walking r->domains, ensure it can't race with cpuhp */ /* Walking r->domains, ensure it can't race with cpuhp */
lockdep_assert_cpus_held(); lockdep_assert_cpus_held();
list_for_each_entry(dom, &r->domains, list) { list_for_each_entry(dom, &r->domains, hdr.list) {
ret = mkdir_mondata_subdir(parent_kn, dom, r, prgrp); ret = mkdir_mondata_subdir(parent_kn, dom, r, prgrp);
if (ret) if (ret)
return ret; return ret;
...@@ -3257,7 +3257,7 @@ static int __init_one_rdt_domain(struct rdt_domain *d, struct resctrl_schema *s, ...@@ -3257,7 +3257,7 @@ static int __init_one_rdt_domain(struct rdt_domain *d, struct resctrl_schema *s,
*/ */
tmp_cbm = cfg->new_ctrl; tmp_cbm = cfg->new_ctrl;
if (bitmap_weight(&tmp_cbm, r->cache.cbm_len) < r->cache.min_cbm_bits) { if (bitmap_weight(&tmp_cbm, r->cache.cbm_len) < r->cache.min_cbm_bits) {
rdt_last_cmd_printf("No space on %s:%d\n", s->name, d->id); rdt_last_cmd_printf("No space on %s:%d\n", s->name, d->hdr.id);
return -ENOSPC; return -ENOSPC;
} }
cfg->have_new_ctrl = true; cfg->have_new_ctrl = true;
...@@ -3280,7 +3280,7 @@ static int rdtgroup_init_cat(struct resctrl_schema *s, u32 closid) ...@@ -3280,7 +3280,7 @@ static int rdtgroup_init_cat(struct resctrl_schema *s, u32 closid)
struct rdt_domain *d; struct rdt_domain *d;
int ret; int ret;
list_for_each_entry(d, &s->res->domains, list) { list_for_each_entry(d, &s->res->domains, hdr.list) {
ret = __init_one_rdt_domain(d, s, closid); ret = __init_one_rdt_domain(d, s, closid);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -3295,7 +3295,7 @@ static void rdtgroup_init_mba(struct rdt_resource *r, u32 closid) ...@@ -3295,7 +3295,7 @@ static void rdtgroup_init_mba(struct rdt_resource *r, u32 closid)
struct resctrl_staged_config *cfg; struct resctrl_staged_config *cfg;
struct rdt_domain *d; struct rdt_domain *d;
list_for_each_entry(d, &r->domains, list) { list_for_each_entry(d, &r->domains, hdr.list) {
if (is_mba_sc(r)) { if (is_mba_sc(r)) {
d->mbps_val[closid] = MBA_MAX_MBPS; d->mbps_val[closid] = MBA_MAX_MBPS;
continue; continue;
...@@ -3941,7 +3941,7 @@ void resctrl_offline_domain(struct rdt_resource *r, struct rdt_domain *d) ...@@ -3941,7 +3941,7 @@ void resctrl_offline_domain(struct rdt_resource *r, struct rdt_domain *d)
* per domain monitor data directories. * per domain monitor data directories.
*/ */
if (resctrl_mounted && resctrl_arch_mon_capable()) if (resctrl_mounted && resctrl_arch_mon_capable())
rmdir_mondata_subdir_allrdtgrp(r, d->id); rmdir_mondata_subdir_allrdtgrp(r, d->hdr.id);
if (is_mbm_enabled()) if (is_mbm_enabled())
cancel_delayed_work(&d->mbm_over); cancel_delayed_work(&d->mbm_over);
......
...@@ -59,10 +59,20 @@ struct resctrl_staged_config { ...@@ -59,10 +59,20 @@ struct resctrl_staged_config {
}; };
/** /**
* struct rdt_domain - group of CPUs sharing a resctrl resource * struct rdt_domain_hdr - common header for different domain types
* @list: all instances of this resource * @list: all instances of this resource
* @id: unique id for this instance * @id: unique id for this instance
* @cpu_mask: which CPUs share this resource * @cpu_mask: which CPUs share this resource
*/
struct rdt_domain_hdr {
struct list_head list;
int id;
struct cpumask cpu_mask;
};
/**
* struct rdt_domain - group of CPUs sharing a resctrl resource
* @hdr: common header for different domain types
* @rmid_busy_llc: bitmap of which limbo RMIDs are above threshold * @rmid_busy_llc: bitmap of which limbo RMIDs are above threshold
* @mbm_total: saved state for MBM total bandwidth * @mbm_total: saved state for MBM total bandwidth
* @mbm_local: saved state for MBM local bandwidth * @mbm_local: saved state for MBM local bandwidth
...@@ -77,9 +87,7 @@ struct resctrl_staged_config { ...@@ -77,9 +87,7 @@ struct resctrl_staged_config {
* by closid * by closid
*/ */
struct rdt_domain { struct rdt_domain {
struct list_head list; struct rdt_domain_hdr hdr;
int id;
struct cpumask cpu_mask;
unsigned long *rmid_busy_llc; unsigned long *rmid_busy_llc;
struct mbm_state *mbm_total; struct mbm_state *mbm_total;
struct mbm_state *mbm_local; struct mbm_state *mbm_local;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment