]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
x86,fs/resctrl: Rename struct rdt_mon_domain and rdt_hw_mon_domain
authorTony Luck <tony.luck@intel.com>
Wed, 17 Dec 2025 17:20:55 +0000 (09:20 -0800)
committerBorislav Petkov (AMD) <bp@alien8.de>
Mon, 5 Jan 2026 10:17:25 +0000 (11:17 +0100)
The upcoming telemetry event monitoring is not tied to the L3 resource and
will have a new domain structure.

Rename the L3 resource specific domain data structures to include "l3_"
in their names to avoid confusion between the different resource specific
domain structures:
rdt_mon_domain -> rdt_l3_mon_domain
rdt_hw_mon_domain -> rdt_hw_l3_mon_domain

No functional change.

Signed-off-by: Tony Luck <tony.luck@intel.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Reviewed-by: Reinette Chatre <reinette.chatre@intel.com>
Link: https://lore.kernel.org/20251217172121.12030-1-tony.luck@intel.com
arch/x86/kernel/cpu/resctrl/core.c
arch/x86/kernel/cpu/resctrl/internal.h
arch/x86/kernel/cpu/resctrl/monitor.c
fs/resctrl/ctrlmondata.c
fs/resctrl/internal.h
fs/resctrl/monitor.c
fs/resctrl/rdtgroup.c
include/linux/resctrl.h

index 1fab4c67d273f6488bd4f3154d88a24c868bb046..cc1b846f964513dc64add50ecaa0349dee10a807 100644 (file)
@@ -368,7 +368,7 @@ static void ctrl_domain_free(struct rdt_hw_ctrl_domain *hw_dom)
        kfree(hw_dom);
 }
 
-static void mon_domain_free(struct rdt_hw_mon_domain *hw_dom)
+static void mon_domain_free(struct rdt_hw_l3_mon_domain *hw_dom)
 {
        int idx;
 
@@ -405,7 +405,7 @@ static int domain_setup_ctrlval(struct rdt_resource *r, struct rdt_ctrl_domain *
  * @num_rmid:  The size of the MBM counter array
  * @hw_dom:    The domain that owns the allocated arrays
  */
-static int arch_domain_mbm_alloc(u32 num_rmid, struct rdt_hw_mon_domain *hw_dom)
+static int arch_domain_mbm_alloc(u32 num_rmid, struct rdt_hw_l3_mon_domain *hw_dom)
 {
        size_t tsize = sizeof(*hw_dom->arch_mbm_states[0]);
        enum resctrl_event_id eventid;
@@ -503,8 +503,8 @@ static void domain_add_cpu_ctrl(int cpu, struct rdt_resource *r)
 
 static void l3_mon_domain_setup(int cpu, int id, struct rdt_resource *r, struct list_head *add_pos)
 {
-       struct rdt_hw_mon_domain *hw_dom;
-       struct rdt_mon_domain *d;
+       struct rdt_hw_l3_mon_domain *hw_dom;
+       struct rdt_l3_mon_domain *d;
        struct cacheinfo *ci;
        int err;
 
@@ -653,13 +653,13 @@ static void domain_remove_cpu_mon(int cpu, struct rdt_resource *r)
 
        switch (r->rid) {
        case RDT_RESOURCE_L3: {
-               struct rdt_hw_mon_domain *hw_dom;
-               struct rdt_mon_domain *d;
+               struct rdt_hw_l3_mon_domain *hw_dom;
+               struct rdt_l3_mon_domain *d;
 
                if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                        return;
 
-               d = container_of(hdr, struct rdt_mon_domain, hdr);
+               d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
                hw_dom = resctrl_to_arch_mon_dom(d);
                resctrl_offline_mon_domain(r, hdr);
                list_del_rcu(&hdr->list);
index 4a916c84a322068906e66a953f7444b5f6ed7aa5..d73c0adf10260a930f44aa97960a6031a55fee54 100644 (file)
@@ -63,17 +63,17 @@ struct rdt_hw_ctrl_domain {
 };
 
 /**
- * struct rdt_hw_mon_domain - Arch private attributes of a set of CPUs that share
- *                           a resource for a monitor function
- * @d_resctrl: Properties exposed to the resctrl file system
+ * struct rdt_hw_l3_mon_domain - Arch private attributes of a set of CPUs sharing
+ *                              RDT_RESOURCE_L3 monitoring
+ * @d_resctrl:         Properties exposed to the resctrl file system
  * @arch_mbm_states:   Per-event pointer to the MBM event's saved state.
  *                     An MBM event's state is an array of struct arch_mbm_state
  *                     indexed by RMID on x86.
  *
  * Members of this structure are accessed via helpers that provide abstraction.
  */
-struct rdt_hw_mon_domain {
-       struct rdt_mon_domain           d_resctrl;
+struct rdt_hw_l3_mon_domain {
+       struct rdt_l3_mon_domain        d_resctrl;
        struct arch_mbm_state           *arch_mbm_states[QOS_NUM_L3_MBM_EVENTS];
 };
 
@@ -82,9 +82,9 @@ static inline struct rdt_hw_ctrl_domain *resctrl_to_arch_ctrl_dom(struct rdt_ctr
        return container_of(r, struct rdt_hw_ctrl_domain, d_resctrl);
 }
 
-static inline struct rdt_hw_mon_domain *resctrl_to_arch_mon_dom(struct rdt_mon_domain *r)
+static inline struct rdt_hw_l3_mon_domain *resctrl_to_arch_mon_dom(struct rdt_l3_mon_domain *r)
 {
-       return container_of(r, struct rdt_hw_mon_domain, d_resctrl);
+       return container_of(r, struct rdt_hw_l3_mon_domain, d_resctrl);
 }
 
 /**
@@ -140,7 +140,7 @@ static inline struct rdt_hw_resource *resctrl_to_arch_res(struct rdt_resource *r
 
 extern struct rdt_hw_resource rdt_resources_all[];
 
-void arch_mon_domain_online(struct rdt_resource *r, struct rdt_mon_domain *d);
+void arch_mon_domain_online(struct rdt_resource *r, struct rdt_l3_mon_domain *d);
 
 /* CPUID.(EAX=10H, ECX=ResID=1).EAX */
 union cpuid_0x10_1_eax {
index 3da970ea1903baa2d15c02ea2c279a10f48f6633..04b8f1e1f3149ea96533746d9550bcc255c9d425 100644 (file)
@@ -109,7 +109,7 @@ static inline u64 get_corrected_mbm_count(u32 rmid, unsigned long val)
  *
  * In RMID sharing mode there are fewer "logical RMID" values available
  * to accumulate data ("physical RMIDs" are divided evenly between SNC
- * nodes that share an L3 cache). Linux creates an rdt_mon_domain for
+ * nodes that share an L3 cache). Linux creates an rdt_l3_mon_domain for
  * each SNC node.
  *
  * The value loaded into IA32_PQR_ASSOC is the "logical RMID".
@@ -157,7 +157,7 @@ static int __rmid_read_phys(u32 prmid, enum resctrl_event_id eventid, u64 *val)
        return 0;
 }
 
-static struct arch_mbm_state *get_arch_mbm_state(struct rdt_hw_mon_domain *hw_dom,
+static struct arch_mbm_state *get_arch_mbm_state(struct rdt_hw_l3_mon_domain *hw_dom,
                                                 u32 rmid,
                                                 enum resctrl_event_id eventid)
 {
@@ -171,11 +171,11 @@ static struct arch_mbm_state *get_arch_mbm_state(struct rdt_hw_mon_domain *hw_do
        return state ? &state[rmid] : NULL;
 }
 
-void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                             u32 unused, u32 rmid,
                             enum resctrl_event_id eventid)
 {
-       struct rdt_hw_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
+       struct rdt_hw_l3_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
        int cpu = cpumask_any(&d->hdr.cpu_mask);
        struct arch_mbm_state *am;
        u32 prmid;
@@ -194,9 +194,9 @@ void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_mon_domain *d,
  * Assumes that hardware counters are also reset and thus that there is
  * no need to record initial non-zero counts.
  */
-void resctrl_arch_reset_rmid_all(struct rdt_resource *r, struct rdt_mon_domain *d)
+void resctrl_arch_reset_rmid_all(struct rdt_resource *r, struct rdt_l3_mon_domain *d)
 {
-       struct rdt_hw_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
+       struct rdt_hw_l3_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
        enum resctrl_event_id eventid;
        int idx;
 
@@ -217,10 +217,10 @@ static u64 mbm_overflow_count(u64 prev_msr, u64 cur_msr, unsigned int width)
        return chunks >> shift;
 }
 
-static u64 get_corrected_val(struct rdt_resource *r, struct rdt_mon_domain *d,
+static u64 get_corrected_val(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                             u32 rmid, enum resctrl_event_id eventid, u64 msr_val)
 {
-       struct rdt_hw_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
+       struct rdt_hw_l3_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
        struct rdt_hw_resource *hw_res = resctrl_to_arch_res(r);
        struct arch_mbm_state *am;
        u64 chunks;
@@ -242,9 +242,9 @@ int resctrl_arch_rmid_read(struct rdt_resource *r, struct rdt_domain_hdr *hdr,
                           u32 unused, u32 rmid, enum resctrl_event_id eventid,
                           u64 *val, void *ignored)
 {
-       struct rdt_hw_mon_domain *hw_dom;
+       struct rdt_hw_l3_mon_domain *hw_dom;
+       struct rdt_l3_mon_domain *d;
        struct arch_mbm_state *am;
-       struct rdt_mon_domain *d;
        u64 msr_val;
        u32 prmid;
        int cpu;
@@ -254,7 +254,7 @@ int resctrl_arch_rmid_read(struct rdt_resource *r, struct rdt_domain_hdr *hdr,
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                return -EINVAL;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
        hw_dom = resctrl_to_arch_mon_dom(d);
        cpu = cpumask_any(&hdr->cpu_mask);
        prmid = logical_rmid_to_physical_rmid(cpu, rmid);
@@ -308,11 +308,11 @@ static int __cntr_id_read(u32 cntr_id, u64 *val)
        return 0;
 }
 
-void resctrl_arch_reset_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_reset_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                             u32 unused, u32 rmid, int cntr_id,
                             enum resctrl_event_id eventid)
 {
-       struct rdt_hw_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
+       struct rdt_hw_l3_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
        struct arch_mbm_state *am;
 
        am = get_arch_mbm_state(hw_dom, rmid, eventid);
@@ -324,7 +324,7 @@ void resctrl_arch_reset_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
        }
 }
 
-int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_mon_domain *d,
+int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                           u32 unused, u32 rmid, int cntr_id,
                           enum resctrl_event_id eventid, u64 *val)
 {
@@ -354,7 +354,7 @@ int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_mon_domain *d,
  * must adjust RMID counter numbers based on SNC node. See
  * logical_rmid_to_physical_rmid() for code that does this.
  */
-void arch_mon_domain_online(struct rdt_resource *r, struct rdt_mon_domain *d)
+void arch_mon_domain_online(struct rdt_resource *r, struct rdt_l3_mon_domain *d)
 {
        if (snc_nodes_per_l3_cache > 1)
                msr_clear_bit(MSR_RMID_SNC_CONFIG, 0);
@@ -516,7 +516,7 @@ static void resctrl_abmc_set_one_amd(void *arg)
  */
 static void _resctrl_abmc_enable(struct rdt_resource *r, bool enable)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
 
        lockdep_assert_cpus_held();
 
@@ -555,11 +555,11 @@ static void resctrl_abmc_config_one_amd(void *info)
 /*
  * Send an IPI to the domain to assign the counter to RMID, event pair.
  */
-void resctrl_arch_config_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_config_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                              enum resctrl_event_id evtid, u32 rmid, u32 closid,
                              u32 cntr_id, bool assign)
 {
-       struct rdt_hw_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
+       struct rdt_hw_l3_mon_domain *hw_dom = resctrl_to_arch_mon_dom(d);
        union l3_qos_abmc_cfg abmc_cfg = { 0 };
        struct arch_mbm_state *am;
 
index 9242a2982e77b413fc0622c940fbba4b1354cd01..a3c734fe656e81d0554195fe16f4eb5bc04f8a6f 100644 (file)
@@ -600,9 +600,9 @@ int rdtgroup_mondata_show(struct seq_file *m, void *arg)
        struct kernfs_open_file *of = m->private;
        enum resctrl_res_level resid;
        enum resctrl_event_id evtid;
+       struct rdt_l3_mon_domain *d;
        struct rdt_domain_hdr *hdr;
        struct rmid_read rr = {0};
-       struct rdt_mon_domain *d;
        struct rdtgroup *rdtgrp;
        int domid, cpu, ret = 0;
        struct rdt_resource *r;
index 9912b774a580b376f1771e9798d3cfd0162b5b25..af47b6ddef62d961ebcb7bdb636cb1011b5fd6b0 100644 (file)
@@ -369,7 +369,7 @@ void mon_event_read(struct rmid_read *rr, struct rdt_resource *r,
 
 int resctrl_mon_resource_init(void);
 
-void mbm_setup_overflow_handler(struct rdt_mon_domain *dom,
+void mbm_setup_overflow_handler(struct rdt_l3_mon_domain *dom,
                                unsigned long delay_ms,
                                int exclude_cpu);
 
@@ -377,14 +377,14 @@ void mbm_handle_overflow(struct work_struct *work);
 
 bool is_mba_sc(struct rdt_resource *r);
 
-void cqm_setup_limbo_handler(struct rdt_mon_domain *dom, unsigned long delay_ms,
+void cqm_setup_limbo_handler(struct rdt_l3_mon_domain *dom, unsigned long delay_ms,
                             int exclude_cpu);
 
 void cqm_handle_limbo(struct work_struct *work);
 
-bool has_busy_rmid(struct rdt_mon_domain *d);
+bool has_busy_rmid(struct rdt_l3_mon_domain *d);
 
-void __check_limbo(struct rdt_mon_domain *d, bool force_free);
+void __check_limbo(struct rdt_l3_mon_domain *d, bool force_free);
 
 void resctrl_file_fflags_init(const char *config, unsigned long fflags);
 
index e1c12201388fbffa3c8cc7d15ae4772148458861..9edbe9805d331130c6dff3a0bc7b970adae2c3a8 100644 (file)
@@ -130,7 +130,7 @@ static void limbo_release_entry(struct rmid_entry *entry)
  * decrement the count. If the busy count gets to zero on an RMID, we
  * free the RMID
  */
-void __check_limbo(struct rdt_mon_domain *d, bool force_free)
+void __check_limbo(struct rdt_l3_mon_domain *d, bool force_free)
 {
        struct rdt_resource *r = resctrl_arch_get_resource(RDT_RESOURCE_L3);
        u32 idx_limit = resctrl_arch_system_num_rmid_idx();
@@ -188,7 +188,7 @@ void __check_limbo(struct rdt_mon_domain *d, bool force_free)
        resctrl_arch_mon_ctx_free(r, QOS_L3_OCCUP_EVENT_ID, arch_mon_ctx);
 }
 
-bool has_busy_rmid(struct rdt_mon_domain *d)
+bool has_busy_rmid(struct rdt_l3_mon_domain *d)
 {
        u32 idx_limit = resctrl_arch_system_num_rmid_idx();
 
@@ -289,7 +289,7 @@ int alloc_rmid(u32 closid)
 static void add_rmid_to_limbo(struct rmid_entry *entry)
 {
        struct rdt_resource *r = resctrl_arch_get_resource(RDT_RESOURCE_L3);
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        u32 idx;
 
        lockdep_assert_held(&rdtgroup_mutex);
@@ -342,7 +342,7 @@ void free_rmid(u32 closid, u32 rmid)
                list_add_tail(&entry->list, &rmid_free_lru);
 }
 
-static struct mbm_state *get_mbm_state(struct rdt_mon_domain *d, u32 closid,
+static struct mbm_state *get_mbm_state(struct rdt_l3_mon_domain *d, u32 closid,
                                       u32 rmid, enum resctrl_event_id evtid)
 {
        u32 idx = resctrl_arch_rmid_idx_encode(closid, rmid);
@@ -362,7 +362,7 @@ static struct mbm_state *get_mbm_state(struct rdt_mon_domain *d, u32 closid,
  * Return:
  * Valid counter ID on success, or -ENOENT on failure.
  */
-static int mbm_cntr_get(struct rdt_resource *r, struct rdt_mon_domain *d,
+static int mbm_cntr_get(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                        struct rdtgroup *rdtgrp, enum resctrl_event_id evtid)
 {
        int cntr_id;
@@ -389,7 +389,7 @@ static int mbm_cntr_get(struct rdt_resource *r, struct rdt_mon_domain *d,
  * Return:
  * Valid counter ID on success, or -ENOSPC on failure.
  */
-static int mbm_cntr_alloc(struct rdt_resource *r, struct rdt_mon_domain *d,
+static int mbm_cntr_alloc(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                          struct rdtgroup *rdtgrp, enum resctrl_event_id evtid)
 {
        int cntr_id;
@@ -408,7 +408,7 @@ static int mbm_cntr_alloc(struct rdt_resource *r, struct rdt_mon_domain *d,
 /*
  * mbm_cntr_free() - Clear the counter ID configuration details in the domain @d.
  */
-static void mbm_cntr_free(struct rdt_mon_domain *d, int cntr_id)
+static void mbm_cntr_free(struct rdt_l3_mon_domain *d, int cntr_id)
 {
        memset(&d->cntr_cfg[cntr_id], 0, sizeof(*d->cntr_cfg));
 }
@@ -418,7 +418,7 @@ static int __l3_mon_event_count(struct rdtgroup *rdtgrp, struct rmid_read *rr)
        int cpu = smp_processor_id();
        u32 closid = rdtgrp->closid;
        u32 rmid = rdtgrp->mon.rmid;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        int cntr_id = -ENOENT;
        struct mbm_state *m;
        u64 tval = 0;
@@ -427,7 +427,7 @@ static int __l3_mon_event_count(struct rdtgroup *rdtgrp, struct rmid_read *rr)
                rr->err = -EIO;
                return -EINVAL;
        }
-       d = container_of(rr->hdr, struct rdt_mon_domain, hdr);
+       d = container_of(rr->hdr, struct rdt_l3_mon_domain, hdr);
 
        if (rr->is_mbm_cntr) {
                cntr_id = mbm_cntr_get(rr->r, d, rdtgrp, rr->evtid);
@@ -470,7 +470,7 @@ static int __l3_mon_event_count_sum(struct rdtgroup *rdtgrp, struct rmid_read *r
        int cpu = smp_processor_id();
        u32 closid = rdtgrp->closid;
        u32 rmid = rdtgrp->mon.rmid;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        u64 tval = 0;
        int err, ret;
 
@@ -545,12 +545,12 @@ static void mbm_bw_count(struct rdtgroup *rdtgrp, struct rmid_read *rr)
        u64 cur_bw, bytes, cur_bytes;
        u32 closid = rdtgrp->closid;
        u32 rmid = rdtgrp->mon.rmid;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        struct mbm_state *m;
 
        if (!domain_header_is_valid(rr->hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                return;
-       d = container_of(rr->hdr, struct rdt_mon_domain, hdr);
+       d = container_of(rr->hdr, struct rdt_l3_mon_domain, hdr);
        m = get_mbm_state(d, closid, rmid, rr->evtid);
        if (WARN_ON_ONCE(!m))
                return;
@@ -650,7 +650,7 @@ static struct rdt_ctrl_domain *get_ctrl_domain_from_cpu(int cpu,
  * throttle MSRs already have low percentage values.  To avoid
  * unnecessarily restricting such rdtgroups, we also increase the bandwidth.
  */
-static void update_mba_bw(struct rdtgroup *rgrp, struct rdt_mon_domain *dom_mbm)
+static void update_mba_bw(struct rdtgroup *rgrp, struct rdt_l3_mon_domain *dom_mbm)
 {
        u32 closid, rmid, cur_msr_val, new_msr_val;
        struct mbm_state *pmbm_data, *cmbm_data;
@@ -718,7 +718,7 @@ static void update_mba_bw(struct rdtgroup *rgrp, struct rdt_mon_domain *dom_mbm)
        resctrl_arch_update_one(r_mba, dom_mba, closid, CDP_NONE, new_msr_val);
 }
 
-static void mbm_update_one_event(struct rdt_resource *r, struct rdt_mon_domain *d,
+static void mbm_update_one_event(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                                 struct rdtgroup *rdtgrp, enum resctrl_event_id evtid)
 {
        struct rmid_read rr = {0};
@@ -750,7 +750,7 @@ static void mbm_update_one_event(struct rdt_resource *r, struct rdt_mon_domain *
                resctrl_arch_mon_ctx_free(rr.r, rr.evtid, rr.arch_mon_ctx);
 }
 
-static void mbm_update(struct rdt_resource *r, struct rdt_mon_domain *d,
+static void mbm_update(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                       struct rdtgroup *rdtgrp)
 {
        /*
@@ -771,12 +771,12 @@ static void mbm_update(struct rdt_resource *r, struct rdt_mon_domain *d,
 void cqm_handle_limbo(struct work_struct *work)
 {
        unsigned long delay = msecs_to_jiffies(CQM_LIMBOCHECK_INTERVAL);
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
 
        cpus_read_lock();
        mutex_lock(&rdtgroup_mutex);
 
-       d = container_of(work, struct rdt_mon_domain, cqm_limbo.work);
+       d = container_of(work, struct rdt_l3_mon_domain, cqm_limbo.work);
 
        __check_limbo(d, false);
 
@@ -799,7 +799,7 @@ void cqm_handle_limbo(struct work_struct *work)
  * @exclude_cpu:   Which CPU the handler should not run on,
  *                RESCTRL_PICK_ANY_CPU to pick any CPU.
  */
-void cqm_setup_limbo_handler(struct rdt_mon_domain *dom, unsigned long delay_ms,
+void cqm_setup_limbo_handler(struct rdt_l3_mon_domain *dom, unsigned long delay_ms,
                             int exclude_cpu)
 {
        unsigned long delay = msecs_to_jiffies(delay_ms);
@@ -816,7 +816,7 @@ void mbm_handle_overflow(struct work_struct *work)
 {
        unsigned long delay = msecs_to_jiffies(MBM_OVERFLOW_INTERVAL);
        struct rdtgroup *prgrp, *crgrp;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        struct list_head *head;
        struct rdt_resource *r;
 
@@ -831,7 +831,7 @@ void mbm_handle_overflow(struct work_struct *work)
                goto out_unlock;
 
        r = resctrl_arch_get_resource(RDT_RESOURCE_L3);
-       d = container_of(work, struct rdt_mon_domain, mbm_over.work);
+       d = container_of(work, struct rdt_l3_mon_domain, mbm_over.work);
 
        list_for_each_entry(prgrp, &rdt_all_groups, rdtgroup_list) {
                mbm_update(r, d, prgrp);
@@ -865,7 +865,7 @@ out_unlock:
  * @exclude_cpu:   Which CPU the handler should not run on,
  *                RESCTRL_PICK_ANY_CPU to pick any CPU.
  */
-void mbm_setup_overflow_handler(struct rdt_mon_domain *dom, unsigned long delay_ms,
+void mbm_setup_overflow_handler(struct rdt_l3_mon_domain *dom, unsigned long delay_ms,
                                int exclude_cpu)
 {
        unsigned long delay = msecs_to_jiffies(delay_ms);
@@ -1120,7 +1120,7 @@ out_unlock:
  * mbm_cntr_free_all() - Clear all the counter ID configuration details in the
  *                      domain @d. Called when mbm_assign_mode is changed.
  */
-static void mbm_cntr_free_all(struct rdt_resource *r, struct rdt_mon_domain *d)
+static void mbm_cntr_free_all(struct rdt_resource *r, struct rdt_l3_mon_domain *d)
 {
        memset(d->cntr_cfg, 0, sizeof(*d->cntr_cfg) * r->mon.num_mbm_cntrs);
 }
@@ -1129,7 +1129,7 @@ static void mbm_cntr_free_all(struct rdt_resource *r, struct rdt_mon_domain *d)
  * resctrl_reset_rmid_all() - Reset all non-architecture states for all the
  *                           supported RMIDs.
  */
-static void resctrl_reset_rmid_all(struct rdt_resource *r, struct rdt_mon_domain *d)
+static void resctrl_reset_rmid_all(struct rdt_resource *r, struct rdt_l3_mon_domain *d)
 {
        u32 idx_limit = resctrl_arch_system_num_rmid_idx();
        enum resctrl_event_id evt;
@@ -1150,7 +1150,7 @@ static void resctrl_reset_rmid_all(struct rdt_resource *r, struct rdt_mon_domain
  * Assign the counter if @assign is true else unassign the counter. Reset the
  * associated non-architectural state.
  */
-static void rdtgroup_assign_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+static void rdtgroup_assign_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                                 enum resctrl_event_id evtid, u32 rmid, u32 closid,
                                 u32 cntr_id, bool assign)
 {
@@ -1170,7 +1170,7 @@ static void rdtgroup_assign_cntr(struct rdt_resource *r, struct rdt_mon_domain *
  * Return:
  * 0 on success, < 0 on failure.
  */
-static int rdtgroup_alloc_assign_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+static int rdtgroup_alloc_assign_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                                      struct rdtgroup *rdtgrp, struct mon_evt *mevt)
 {
        int cntr_id;
@@ -1205,7 +1205,7 @@ static int rdtgroup_alloc_assign_cntr(struct rdt_resource *r, struct rdt_mon_dom
  * Return:
  * 0 on success, < 0 on failure.
  */
-static int rdtgroup_assign_cntr_event(struct rdt_mon_domain *d, struct rdtgroup *rdtgrp,
+static int rdtgroup_assign_cntr_event(struct rdt_l3_mon_domain *d, struct rdtgroup *rdtgrp,
                                      struct mon_evt *mevt)
 {
        struct rdt_resource *r = resctrl_arch_get_resource(mevt->rid);
@@ -1255,7 +1255,7 @@ void rdtgroup_assign_cntrs(struct rdtgroup *rdtgrp)
  * rdtgroup_free_unassign_cntr() - Unassign and reset the counter ID configuration
  * for the event pointed to by @mevt within the domain @d and resctrl group @rdtgrp.
  */
-static void rdtgroup_free_unassign_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+static void rdtgroup_free_unassign_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                                        struct rdtgroup *rdtgrp, struct mon_evt *mevt)
 {
        int cntr_id;
@@ -1276,7 +1276,7 @@ static void rdtgroup_free_unassign_cntr(struct rdt_resource *r, struct rdt_mon_d
  * the event structure @mevt from the domain @d and the group @rdtgrp. Unassign
  * the counters from all the domains if @d is NULL else unassign from @d.
  */
-static void rdtgroup_unassign_cntr_event(struct rdt_mon_domain *d, struct rdtgroup *rdtgrp,
+static void rdtgroup_unassign_cntr_event(struct rdt_l3_mon_domain *d, struct rdtgroup *rdtgrp,
                                         struct mon_evt *mevt)
 {
        struct rdt_resource *r = resctrl_arch_get_resource(mevt->rid);
@@ -1351,7 +1351,7 @@ next_config:
 static void rdtgroup_update_cntr_event(struct rdt_resource *r, struct rdtgroup *rdtgrp,
                                       enum resctrl_event_id evtid)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        int cntr_id;
 
        list_for_each_entry(d, &r->mon_domains, hdr.list) {
@@ -1457,7 +1457,7 @@ ssize_t resctrl_mbm_assign_mode_write(struct kernfs_open_file *of, char *buf,
                                      size_t nbytes, loff_t off)
 {
        struct rdt_resource *r = rdt_kn_parent_priv(of->kn);
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        int ret = 0;
        bool enable;
 
@@ -1530,7 +1530,7 @@ int resctrl_num_mbm_cntrs_show(struct kernfs_open_file *of,
                               struct seq_file *s, void *v)
 {
        struct rdt_resource *r = rdt_kn_parent_priv(of->kn);
-       struct rdt_mon_domain *dom;
+       struct rdt_l3_mon_domain *dom;
        bool sep = false;
 
        cpus_read_lock();
@@ -1554,7 +1554,7 @@ int resctrl_available_mbm_cntrs_show(struct kernfs_open_file *of,
                                     struct seq_file *s, void *v)
 {
        struct rdt_resource *r = rdt_kn_parent_priv(of->kn);
-       struct rdt_mon_domain *dom;
+       struct rdt_l3_mon_domain *dom;
        bool sep = false;
        u32 cntrs, i;
        int ret = 0;
@@ -1595,7 +1595,7 @@ out_unlock:
 int mbm_L3_assignments_show(struct kernfs_open_file *of, struct seq_file *s, void *v)
 {
        struct rdt_resource *r = resctrl_arch_get_resource(RDT_RESOURCE_L3);
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        struct rdtgroup *rdtgrp;
        struct mon_evt *mevt;
        int ret = 0;
@@ -1658,7 +1658,7 @@ static struct mon_evt *mbm_get_mon_event_by_name(struct rdt_resource *r, char *n
        return NULL;
 }
 
-static int rdtgroup_modify_assign_state(char *assign, struct rdt_mon_domain *d,
+static int rdtgroup_modify_assign_state(char *assign, struct rdt_l3_mon_domain *d,
                                        struct rdtgroup *rdtgrp, struct mon_evt *mevt)
 {
        int ret = 0;
@@ -1684,7 +1684,7 @@ static int rdtgroup_modify_assign_state(char *assign, struct rdt_mon_domain *d,
 static int resctrl_parse_mbm_assignment(struct rdt_resource *r, struct rdtgroup *rdtgrp,
                                        char *event, char *tok)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        unsigned long dom_id = 0;
        char *dom_str, *id_str;
        struct mon_evt *mevt;
index 89ffe54fb0fc3cfb16d00d497617a271c76a4ef9..2ed435db19237b88fc4ed0fb7329ffed10252152 100644 (file)
@@ -1640,7 +1640,7 @@ static void mondata_config_read(struct resctrl_mon_config_info *mon_info)
 static int mbm_config_show(struct seq_file *s, struct rdt_resource *r, u32 evtid)
 {
        struct resctrl_mon_config_info mon_info;
-       struct rdt_mon_domain *dom;
+       struct rdt_l3_mon_domain *dom;
        bool sep = false;
 
        cpus_read_lock();
@@ -1688,7 +1688,7 @@ static int mbm_local_bytes_config_show(struct kernfs_open_file *of,
 }
 
 static void mbm_config_write_domain(struct rdt_resource *r,
-                                   struct rdt_mon_domain *d, u32 evtid, u32 val)
+                                   struct rdt_l3_mon_domain *d, u32 evtid, u32 val)
 {
        struct resctrl_mon_config_info mon_info = {0};
 
@@ -1729,8 +1729,8 @@ static void mbm_config_write_domain(struct rdt_resource *r,
 static int mon_config_write(struct rdt_resource *r, char *tok, u32 evtid)
 {
        char *dom_str = NULL, *id_str;
+       struct rdt_l3_mon_domain *d;
        unsigned long dom_id, val;
-       struct rdt_mon_domain *d;
 
        /* Walking r->domains, ensure it can't race with cpuhp */
        lockdep_assert_cpus_held();
@@ -2781,7 +2781,7 @@ static int rdt_get_tree(struct fs_context *fc)
 {
        struct rdt_fs_context *ctx = rdt_fc2context(fc);
        unsigned long flags = RFTYPE_CTRL_BASE;
-       struct rdt_mon_domain *dom;
+       struct rdt_l3_mon_domain *dom;
        struct rdt_resource *r;
        int ret;
 
@@ -3232,7 +3232,7 @@ static void rmdir_mondata_subdir_allrdtgrp(struct rdt_resource *r,
                                           struct rdt_domain_hdr *hdr)
 {
        struct rdtgroup *prgrp, *crgrp;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        char subname[32];
        bool snc_mode;
        char name[32];
@@ -3240,7 +3240,7 @@ static void rmdir_mondata_subdir_allrdtgrp(struct rdt_resource *r,
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                return;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
        snc_mode = r->mon_scope == RESCTRL_L3_NODE;
        sprintf(name, "mon_%s_%02d", r->name, snc_mode ? d->ci_id : hdr->id);
        if (snc_mode)
@@ -3258,8 +3258,8 @@ static int mon_add_all_files(struct kernfs_node *kn, struct rdt_domain_hdr *hdr,
                             struct rdt_resource *r, struct rdtgroup *prgrp,
                             bool do_sum)
 {
+       struct rdt_l3_mon_domain *d;
        struct rmid_read rr = {0};
-       struct rdt_mon_domain *d;
        struct mon_data *priv;
        struct mon_evt *mevt;
        int ret, domid;
@@ -3267,7 +3267,7 @@ static int mon_add_all_files(struct kernfs_node *kn, struct rdt_domain_hdr *hdr,
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                return -EINVAL;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
        for_each_mon_event(mevt) {
                if (mevt->rid != r->rid || !mevt->enabled)
                        continue;
@@ -3292,7 +3292,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn,
                                struct rdt_resource *r, struct rdtgroup *prgrp)
 {
        struct kernfs_node *kn, *ckn;
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        char name[32];
        bool snc_mode;
        int ret = 0;
@@ -3302,7 +3302,7 @@ static int mkdir_mondata_subdir(struct kernfs_node *parent_kn,
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                return -EINVAL;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
        snc_mode = r->mon_scope == RESCTRL_L3_NODE;
        sprintf(name, "mon_%s_%02d", r->name, snc_mode ? d->ci_id : d->hdr.id);
        kn = kernfs_find_and_get(parent_kn, name);
@@ -4246,7 +4246,7 @@ static void rdtgroup_setup_default(void)
        mutex_unlock(&rdtgroup_mutex);
 }
 
-static void domain_destroy_mon_state(struct rdt_mon_domain *d)
+static void domain_destroy_mon_state(struct rdt_l3_mon_domain *d)
 {
        int idx;
 
@@ -4270,14 +4270,14 @@ void resctrl_offline_ctrl_domain(struct rdt_resource *r, struct rdt_ctrl_domain
 
 void resctrl_offline_mon_domain(struct rdt_resource *r, struct rdt_domain_hdr *hdr)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
 
        mutex_lock(&rdtgroup_mutex);
 
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                goto out_unlock;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
 
        /*
         * If resctrl is mounted, remove all the
@@ -4319,7 +4319,7 @@ out_unlock:
  *
  * Returns 0 for success, or -ENOMEM.
  */
-static int domain_setup_mon_state(struct rdt_resource *r, struct rdt_mon_domain *d)
+static int domain_setup_mon_state(struct rdt_resource *r, struct rdt_l3_mon_domain *d)
 {
        u32 idx_limit = resctrl_arch_system_num_rmid_idx();
        size_t tsize = sizeof(*d->mbm_states[0]);
@@ -4377,7 +4377,7 @@ int resctrl_online_ctrl_domain(struct rdt_resource *r, struct rdt_ctrl_domain *d
 
 int resctrl_online_mon_domain(struct rdt_resource *r, struct rdt_domain_hdr *hdr)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        int err = -EINVAL;
 
        mutex_lock(&rdtgroup_mutex);
@@ -4385,7 +4385,7 @@ int resctrl_online_mon_domain(struct rdt_resource *r, struct rdt_domain_hdr *hdr
        if (!domain_header_is_valid(hdr, RESCTRL_MON_DOMAIN, RDT_RESOURCE_L3))
                goto out_unlock;
 
-       d = container_of(hdr, struct rdt_mon_domain, hdr);
+       d = container_of(hdr, struct rdt_l3_mon_domain, hdr);
        err = domain_setup_mon_state(r, d);
        if (err)
                goto out_unlock;
@@ -4432,10 +4432,10 @@ static void clear_childcpus(struct rdtgroup *r, unsigned int cpu)
        }
 }
 
-static struct rdt_mon_domain *get_mon_domain_from_cpu(int cpu,
-                                                     struct rdt_resource *r)
+static struct rdt_l3_mon_domain *get_mon_domain_from_cpu(int cpu,
+                                                        struct rdt_resource *r)
 {
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
 
        lockdep_assert_cpus_held();
 
@@ -4451,7 +4451,7 @@ static struct rdt_mon_domain *get_mon_domain_from_cpu(int cpu,
 void resctrl_offline_cpu(unsigned int cpu)
 {
        struct rdt_resource *l3 = resctrl_arch_get_resource(RDT_RESOURCE_L3);
-       struct rdt_mon_domain *d;
+       struct rdt_l3_mon_domain *d;
        struct rdtgroup *rdtgrp;
 
        mutex_lock(&rdtgroup_mutex);
index 9b9877fb3238a4e5c6174abf36cbb54d6aff3efe..79aaaabcdd3f94fd9eeec50fbadde4d44e9f7e29 100644 (file)
@@ -178,7 +178,7 @@ struct mbm_cntr_cfg {
 };
 
 /**
- * struct rdt_mon_domain - group of CPUs sharing a resctrl monitor resource
+ * struct rdt_l3_mon_domain - group of CPUs sharing RDT_RESOURCE_L3 monitoring
  * @hdr:               common header for different domain types
  * @ci_id:             cache info id for this domain
  * @rmid_busy_llc:     bitmap of which limbo RMIDs are above threshold
@@ -192,7 +192,7 @@ struct mbm_cntr_cfg {
  * @cntr_cfg:          array of assignable counters' configuration (indexed
  *                     by counter ID)
  */
-struct rdt_mon_domain {
+struct rdt_l3_mon_domain {
        struct rdt_domain_hdr           hdr;
        unsigned int                    ci_id;
        unsigned long                   *rmid_busy_llc;
@@ -367,10 +367,10 @@ struct resctrl_cpu_defaults {
 };
 
 struct resctrl_mon_config_info {
-       struct rdt_resource     *r;
-       struct rdt_mon_domain   *d;
-       u32                     evtid;
-       u32                     mon_config;
+       struct rdt_resource             *r;
+       struct rdt_l3_mon_domain        *d;
+       u32                             evtid;
+       u32                             mon_config;
 };
 
 /**
@@ -585,7 +585,7 @@ struct rdt_domain_hdr *resctrl_find_domain(struct list_head *h, int id,
  *
  * This can be called from any CPU.
  */
-void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                             u32 closid, u32 rmid,
                             enum resctrl_event_id eventid);
 
@@ -598,7 +598,7 @@ void resctrl_arch_reset_rmid(struct rdt_resource *r, struct rdt_mon_domain *d,
  *
  * This can be called from any CPU.
  */
-void resctrl_arch_reset_rmid_all(struct rdt_resource *r, struct rdt_mon_domain *d);
+void resctrl_arch_reset_rmid_all(struct rdt_resource *r, struct rdt_l3_mon_domain *d);
 
 /**
  * resctrl_arch_reset_all_ctrls() - Reset the control for each CLOSID to its
@@ -624,7 +624,7 @@ void resctrl_arch_reset_all_ctrls(struct rdt_resource *r);
  *
  * This can be called from any CPU.
  */
-void resctrl_arch_config_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_config_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                              enum resctrl_event_id evtid, u32 rmid, u32 closid,
                              u32 cntr_id, bool assign);
 
@@ -647,7 +647,7 @@ void resctrl_arch_config_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
  * Return:
  * 0 on success, or -EIO, -EINVAL etc on error.
  */
-int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_mon_domain *d,
+int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                           u32 closid, u32 rmid, int cntr_id,
                           enum resctrl_event_id eventid, u64 *val);
 
@@ -662,7 +662,7 @@ int resctrl_arch_cntr_read(struct rdt_resource *r, struct rdt_mon_domain *d,
  *
  * This can be called from any CPU.
  */
-void resctrl_arch_reset_cntr(struct rdt_resource *r, struct rdt_mon_domain *d,
+void resctrl_arch_reset_cntr(struct rdt_resource *r, struct rdt_l3_mon_domain *d,
                             u32 closid, u32 rmid, int cntr_id,
                             enum resctrl_event_id eventid);