x86/resctrl: Make ctrlval arrays the same size
authorJames Morse <james.morse@arm.com>
Wed, 28 Jul 2021 17:06:31 +0000 (17:06 +0000)
committerBorislav Petkov <bp@suse.de>
Wed, 11 Aug 2021 15:58:33 +0000 (17:58 +0200)
The CODE and DATA resources report a num_closid that is half the actual
size supported by the hardware. This behaviour is visible to user-space
when CDP is enabled.

The CODE and DATA resources have their own ctrlval arrays which are
half the size of the underlying hardware because num_closid was already
adjusted. One holds the odd configurations values, the other even.

Before the CDP resources can be merged, the 'half the closids' behaviour
needs to be implemented by schemata_list_create(), but this causes the
ctrl_val[] array to be full sized.

Remove the logic from the architecture specific rdt_get_cdp_config()
setup, and add it to schemata_list_create(). Functions that walk all the
configurations, such as domain_setup_ctrlval() and reset_all_ctrls(),
take num_closid directly from struct rdt_hw_resource also have
to halve num_closid as only the lower half of each array is in
use. domain_setup_ctrlval() and reset_all_ctrls() both copy struct
rdt_hw_resource's num_closid to a struct msr_param. Correct the value
here.

This is temporary as a subsequent patch will merge all three ctrl_val[]
arrays such that when CDP is in use, the CODA/DATA layout in the array
matches the hardware. reset_all_ctrls()'s loop over the whole of
ctrl_val[] is not touched as this is harmless, and will be required as
it is once the resources are merged.

Signed-off-by: James Morse <james.morse@arm.com>
Signed-off-by: Borislav Petkov <bp@suse.de>
Reviewed-by: Jamie Iles <jamie@nuviainc.com>
Reviewed-by: Reinette Chatre <reinette.chatre@intel.com>
Tested-by: Babu Moger <babu.moger@amd.com>
Link: https://lkml.kernel.org/r/20210728170637.25610-19-james.morse@arm.com
arch/x86/kernel/cpu/resctrl/core.c
arch/x86/kernel/cpu/resctrl/rdtgroup.c

index 755118a9ef389bd18fe3de906560a1d9b28924e5..9f8be5ee5e8a2cc5a9a370b544f1a8e8943dd196 100644 (file)
@@ -363,7 +363,7 @@ static void rdt_get_cdp_config(int level, int type)
        struct rdt_resource *r = &rdt_resources_all[type].r_resctrl;
        struct rdt_hw_resource *hw_res = resctrl_to_arch_res(r);
 
-       hw_res->num_closid = hw_res_l->num_closid / 2;
+       hw_res->num_closid = hw_res_l->num_closid;
        r->cache.cbm_len = r_l->cache.cbm_len;
        r->default_ctrl = r_l->default_ctrl;
        r->cache.shareable_bits = r_l->cache.shareable_bits;
@@ -549,6 +549,14 @@ static int domain_setup_ctrlval(struct rdt_resource *r, struct rdt_domain *d)
 
        m.low = 0;
        m.high = hw_res->num_closid;
+
+       /*
+        * temporary: the array is full-size, but cat_wrmsr() still re-maps
+        * the index.
+        */
+       if (hw_res->conf_type != CDP_NONE)
+               m.high /= 2;
+
        hw_res->msr_update(d, &m, r);
        return 0;
 }
index 61037b239327ecd2acc634af9a017b91017dbd4c..299af12c9fe4d14fffb2824c1738e2f498839411 100644 (file)
@@ -2154,6 +2154,8 @@ static int schemata_list_create(void)
                s->res = r;
                s->conf_type = resctrl_to_arch_res(r)->conf_type;
                s->num_closid = resctrl_arch_get_num_closid(r);
+               if (resctrl_arch_get_cdp_enabled(r->rid))
+                       s->num_closid /= 2;
 
                ret = snprintf(s->name, sizeof(s->name), r->name);
                if (ret >= sizeof(s->name)) {
@@ -2376,6 +2378,13 @@ static int reset_all_ctrls(struct rdt_resource *r)
        msr_param.low = 0;
        msr_param.high = hw_res->num_closid;
 
+       /*
+        * temporary: the array is full-sized, but cat_wrmsr() still re-maps
+        * the index.
+        */
+       if (hw_res->cdp_enabled)
+               msr_param.high /= 2;
+
        /*
         * Disable resource control for this resource by setting all
         * CBMs in all domains to the maximum mask value. Pick one CPU