Commit 9ab021a1 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'x86_cache_for_6.7_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull x86 resource control updates from Borislav Petkov:

 - Add support for non-contiguous capacity bitmasks being added to
   Intel's CAT implementation

 - Other improvements to resctrl code: better configuration,
   simplifications, debugging support, fixes

* tag 'x86_cache_for_6.7_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  x86/resctrl: Display RMID of resource group
  x86/resctrl: Add support for the files of MON groups only
  x86/resctrl: Display CLOSID for resource group
  x86/resctrl: Introduce "-o debug" mount option
  x86/resctrl: Move default group file creation to mount
  x86/resctrl: Unwind properly from rdt_enable_ctx()
  x86/resctrl: Rename rftype flags for consistency
  x86/resctrl: Simplify rftype flag definitions
  x86/resctrl: Add multiple tasks to the resctrl group at once
  Documentation/x86: Document resctrl's new sparse_masks
  x86/resctrl: Add sparse_masks file in info
  x86/resctrl: Enable non-contiguous CBMs in Intel CAT
  x86/resctrl: Rename arch_has_sparse_bitmaps
  x86/resctrl: Fix remaining kernel-doc warnings
parents f84a52ee 4cee14bc
...@@ -35,7 +35,7 @@ about the feature from resctrl's info directory. ...@@ -35,7 +35,7 @@ about the feature from resctrl's info directory.
To use the feature mount the file system:: To use the feature mount the file system::
# mount -t resctrl resctrl [-o cdp[,cdpl2][,mba_MBps]] /sys/fs/resctrl # mount -t resctrl resctrl [-o cdp[,cdpl2][,mba_MBps][,debug]] /sys/fs/resctrl
mount options are: mount options are:
...@@ -46,6 +46,9 @@ mount options are: ...@@ -46,6 +46,9 @@ mount options are:
"mba_MBps": "mba_MBps":
Enable the MBA Software Controller(mba_sc) to specify MBA Enable the MBA Software Controller(mba_sc) to specify MBA
bandwidth in MBps bandwidth in MBps
"debug":
Make debug files accessible. Available debug files are annotated with
"Available only with debug option".
L2 and L3 CDP are controlled separately. L2 and L3 CDP are controlled separately.
...@@ -124,6 +127,13 @@ related to allocation: ...@@ -124,6 +127,13 @@ related to allocation:
"P": "P":
Corresponding region is pseudo-locked. No Corresponding region is pseudo-locked. No
sharing allowed. sharing allowed.
"sparse_masks":
Indicates if non-contiguous 1s value in CBM is supported.
"0":
Only contiguous 1s value in CBM is supported.
"1":
Non-contiguous 1s value in CBM is supported.
Memory bandwidth(MB) subdirectory contains the following files Memory bandwidth(MB) subdirectory contains the following files
with respect to allocation: with respect to allocation:
...@@ -299,7 +309,14 @@ All groups contain the following files: ...@@ -299,7 +309,14 @@ All groups contain the following files:
"tasks": "tasks":
Reading this file shows the list of all tasks that belong to Reading this file shows the list of all tasks that belong to
this group. Writing a task id to the file will add a task to the this group. Writing a task id to the file will add a task to the
group. If the group is a CTRL_MON group the task is removed from group. Multiple tasks can be added by separating the task ids
with commas. Tasks will be assigned sequentially. Multiple
failures are not supported. A single failure encountered while
attempting to assign a task will cause the operation to abort and
already added tasks before the failure will remain in the group.
Failures will be logged to /sys/fs/resctrl/info/last_cmd_status.
If the group is a CTRL_MON group the task is removed from
whichever previous CTRL_MON group owned the task and also from whichever previous CTRL_MON group owned the task and also from
any MON group that owned the task. If the group is a MON group, any MON group that owned the task. If the group is a MON group,
then the task must already belong to the CTRL_MON parent of this then the task must already belong to the CTRL_MON parent of this
...@@ -342,6 +359,10 @@ When control is enabled all CTRL_MON groups will also contain: ...@@ -342,6 +359,10 @@ When control is enabled all CTRL_MON groups will also contain:
file. On successful pseudo-locked region creation the mode will file. On successful pseudo-locked region creation the mode will
automatically change to "pseudo-locked". automatically change to "pseudo-locked".
"ctrl_hw_id":
Available only with debug option. The identifier used by hardware
for the control group. On x86 this is the CLOSID.
When monitoring is enabled all MON groups will also contain: When monitoring is enabled all MON groups will also contain:
"mon_data": "mon_data":
...@@ -355,6 +376,10 @@ When monitoring is enabled all MON groups will also contain: ...@@ -355,6 +376,10 @@ When monitoring is enabled all MON groups will also contain:
the sum for all tasks in the CTRL_MON group and all tasks in the sum for all tasks in the CTRL_MON group and all tasks in
MON groups. Please see example section for more details on usage. MON groups. Please see example section for more details on usage.
"mon_hw_id":
Available only with debug option. The identifier used by hardware
for the monitor group. On x86 this is the RMID.
Resource allocation rules Resource allocation rules
------------------------- -------------------------
...@@ -445,12 +470,13 @@ For cache resources we describe the portion of the cache that is available ...@@ -445,12 +470,13 @@ For cache resources we describe the portion of the cache that is available
for allocation using a bitmask. The maximum value of the mask is defined for allocation using a bitmask. The maximum value of the mask is defined
by each cpu model (and may be different for different cache levels). It by each cpu model (and may be different for different cache levels). It
is found using CPUID, but is also provided in the "info" directory of is found using CPUID, but is also provided in the "info" directory of
the resctrl file system in "info/{resource}/cbm_mask". Intel hardware the resctrl file system in "info/{resource}/cbm_mask". Some Intel hardware
requires that these masks have all the '1' bits in a contiguous block. So requires that these masks have all the '1' bits in a contiguous block. So
0x3, 0x6 and 0xC are legal 4-bit masks with two bits set, but 0x5, 0x9 0x3, 0x6 and 0xC are legal 4-bit masks with two bits set, but 0x5, 0x9
and 0xA are not. On a system with a 20-bit mask each bit represents 5% and 0xA are not. Check /sys/fs/resctrl/info/{resource}/sparse_masks
of the capacity of the cache. You could partition the cache into four if non-contiguous 1s value is supported. On a system with a 20-bit mask
equal parts with masks: 0x1f, 0x3e0, 0x7c00, 0xf8000. each bit represents 5% of the capacity of the cache. You could partition
the cache into four equal parts with masks: 0x1f, 0x3e0, 0x7c00, 0xf8000.
Memory bandwidth Allocation and monitoring Memory bandwidth Allocation and monitoring
========================================== ==========================================
......
...@@ -152,6 +152,7 @@ static inline void cache_alloc_hsw_probe(void) ...@@ -152,6 +152,7 @@ static inline void cache_alloc_hsw_probe(void)
r->cache.cbm_len = 20; r->cache.cbm_len = 20;
r->cache.shareable_bits = 0xc0000; r->cache.shareable_bits = 0xc0000;
r->cache.min_cbm_bits = 2; r->cache.min_cbm_bits = 2;
r->cache.arch_has_sparse_bitmasks = false;
r->alloc_capable = true; r->alloc_capable = true;
rdt_alloc_capable = true; rdt_alloc_capable = true;
...@@ -267,15 +268,18 @@ static void rdt_get_cache_alloc_cfg(int idx, struct rdt_resource *r) ...@@ -267,15 +268,18 @@ static void rdt_get_cache_alloc_cfg(int idx, struct rdt_resource *r)
{ {
struct rdt_hw_resource *hw_res = resctrl_to_arch_res(r); struct rdt_hw_resource *hw_res = resctrl_to_arch_res(r);
union cpuid_0x10_1_eax eax; union cpuid_0x10_1_eax eax;
union cpuid_0x10_x_ecx ecx;
union cpuid_0x10_x_edx edx; union cpuid_0x10_x_edx edx;
u32 ebx, ecx; u32 ebx;
cpuid_count(0x00000010, idx, &eax.full, &ebx, &ecx, &edx.full); cpuid_count(0x00000010, idx, &eax.full, &ebx, &ecx.full, &edx.full);
hw_res->num_closid = edx.split.cos_max + 1; hw_res->num_closid = edx.split.cos_max + 1;
r->cache.cbm_len = eax.split.cbm_len + 1; r->cache.cbm_len = eax.split.cbm_len + 1;
r->default_ctrl = BIT_MASK(eax.split.cbm_len + 1) - 1; r->default_ctrl = BIT_MASK(eax.split.cbm_len + 1) - 1;
r->cache.shareable_bits = ebx & r->default_ctrl; r->cache.shareable_bits = ebx & r->default_ctrl;
r->data_width = (r->cache.cbm_len + 3) / 4; r->data_width = (r->cache.cbm_len + 3) / 4;
if (boot_cpu_data.x86_vendor == X86_VENDOR_INTEL)
r->cache.arch_has_sparse_bitmasks = ecx.split.noncont;
r->alloc_capable = true; r->alloc_capable = true;
} }
...@@ -872,7 +876,6 @@ static __init void rdt_init_res_defs_intel(void) ...@@ -872,7 +876,6 @@ static __init void rdt_init_res_defs_intel(void)
if (r->rid == RDT_RESOURCE_L3 || if (r->rid == RDT_RESOURCE_L3 ||
r->rid == RDT_RESOURCE_L2) { r->rid == RDT_RESOURCE_L2) {
r->cache.arch_has_sparse_bitmaps = false;
r->cache.arch_has_per_cpu_cfg = false; r->cache.arch_has_per_cpu_cfg = false;
r->cache.min_cbm_bits = 1; r->cache.min_cbm_bits = 1;
} else if (r->rid == RDT_RESOURCE_MBA) { } else if (r->rid == RDT_RESOURCE_MBA) {
...@@ -892,7 +895,7 @@ static __init void rdt_init_res_defs_amd(void) ...@@ -892,7 +895,7 @@ static __init void rdt_init_res_defs_amd(void)
if (r->rid == RDT_RESOURCE_L3 || if (r->rid == RDT_RESOURCE_L3 ||
r->rid == RDT_RESOURCE_L2) { r->rid == RDT_RESOURCE_L2) {
r->cache.arch_has_sparse_bitmaps = true; r->cache.arch_has_sparse_bitmasks = true;
r->cache.arch_has_per_cpu_cfg = true; r->cache.arch_has_per_cpu_cfg = true;
r->cache.min_cbm_bits = 0; r->cache.min_cbm_bits = 0;
} else if (r->rid == RDT_RESOURCE_MBA) { } else if (r->rid == RDT_RESOURCE_MBA) {
......
...@@ -87,10 +87,12 @@ int parse_bw(struct rdt_parse_data *data, struct resctrl_schema *s, ...@@ -87,10 +87,12 @@ int parse_bw(struct rdt_parse_data *data, struct resctrl_schema *s,
/* /*
* Check whether a cache bit mask is valid. * Check whether a cache bit mask is valid.
* For Intel the SDM says: * On Intel CPUs, non-contiguous 1s value support is indicated by CPUID:
* Please note that all (and only) contiguous '1' combinations * - CPUID.0x10.1:ECX[3]: L3 non-contiguous 1s value supported if 1
* are allowed (e.g. FFFFH, 0FF0H, 003CH, etc.). * - CPUID.0x10.2:ECX[3]: L2 non-contiguous 1s value supported if 1
* Additionally Haswell requires at least two bits set. *
* Haswell does not support a non-contiguous 1s value and additionally
* requires at least two bits set.
* AMD allows non-contiguous bitmasks. * AMD allows non-contiguous bitmasks.
*/ */
static bool cbm_validate(char *buf, u32 *data, struct rdt_resource *r) static bool cbm_validate(char *buf, u32 *data, struct rdt_resource *r)
...@@ -113,8 +115,8 @@ static bool cbm_validate(char *buf, u32 *data, struct rdt_resource *r) ...@@ -113,8 +115,8 @@ static bool cbm_validate(char *buf, u32 *data, struct rdt_resource *r)
first_bit = find_first_bit(&val, cbm_len); first_bit = find_first_bit(&val, cbm_len);
zero_bit = find_next_zero_bit(&val, cbm_len, first_bit); zero_bit = find_next_zero_bit(&val, cbm_len, first_bit);
/* Are non-contiguous bitmaps allowed? */ /* Are non-contiguous bitmasks allowed? */
if (!r->cache.arch_has_sparse_bitmaps && if (!r->cache.arch_has_sparse_bitmasks &&
(find_next_bit(&val, cbm_len, zero_bit) < cbm_len)) { (find_next_bit(&val, cbm_len, zero_bit) < cbm_len)) {
rdt_last_cmd_printf("The mask %lx has non-consecutive 1-bits\n", val); rdt_last_cmd_printf("The mask %lx has non-consecutive 1-bits\n", val);
return false; return false;
......
...@@ -59,6 +59,7 @@ struct rdt_fs_context { ...@@ -59,6 +59,7 @@ struct rdt_fs_context {
bool enable_cdpl2; bool enable_cdpl2;
bool enable_cdpl3; bool enable_cdpl3;
bool enable_mba_mbps; bool enable_mba_mbps;
bool enable_debug;
}; };
static inline struct rdt_fs_context *rdt_fc2context(struct fs_context *fc) static inline struct rdt_fs_context *rdt_fc2context(struct fs_context *fc)
...@@ -243,18 +244,17 @@ struct rdtgroup { ...@@ -243,18 +244,17 @@ struct rdtgroup {
*/ */
#define RFTYPE_INFO BIT(0) #define RFTYPE_INFO BIT(0)
#define RFTYPE_BASE BIT(1) #define RFTYPE_BASE BIT(1)
#define RF_CTRLSHIFT 4 #define RFTYPE_CTRL BIT(4)
#define RF_MONSHIFT 5 #define RFTYPE_MON BIT(5)
#define RF_TOPSHIFT 6 #define RFTYPE_TOP BIT(6)
#define RFTYPE_CTRL BIT(RF_CTRLSHIFT)
#define RFTYPE_MON BIT(RF_MONSHIFT)
#define RFTYPE_TOP BIT(RF_TOPSHIFT)
#define RFTYPE_RES_CACHE BIT(8) #define RFTYPE_RES_CACHE BIT(8)
#define RFTYPE_RES_MB BIT(9) #define RFTYPE_RES_MB BIT(9)
#define RF_CTRL_INFO (RFTYPE_INFO | RFTYPE_CTRL) #define RFTYPE_DEBUG BIT(10)
#define RF_MON_INFO (RFTYPE_INFO | RFTYPE_MON) #define RFTYPE_CTRL_INFO (RFTYPE_INFO | RFTYPE_CTRL)
#define RF_TOP_INFO (RFTYPE_INFO | RFTYPE_TOP) #define RFTYPE_MON_INFO (RFTYPE_INFO | RFTYPE_MON)
#define RF_CTRL_BASE (RFTYPE_BASE | RFTYPE_CTRL) #define RFTYPE_TOP_INFO (RFTYPE_INFO | RFTYPE_TOP)
#define RFTYPE_CTRL_BASE (RFTYPE_BASE | RFTYPE_CTRL)
#define RFTYPE_MON_BASE (RFTYPE_BASE | RFTYPE_MON)
/* List of all resource groups */ /* List of all resource groups */
extern struct list_head rdt_all_groups; extern struct list_head rdt_all_groups;
...@@ -270,7 +270,7 @@ void __exit rdtgroup_exit(void); ...@@ -270,7 +270,7 @@ void __exit rdtgroup_exit(void);
* @mode: Access mode * @mode: Access mode
* @kf_ops: File operations * @kf_ops: File operations
* @flags: File specific RFTYPE_FLAGS_* flags * @flags: File specific RFTYPE_FLAGS_* flags
* @fflags: File specific RF_* or RFTYPE_* flags * @fflags: File specific RFTYPE_* flags
* @seq_show: Show content of the file * @seq_show: Show content of the file
* @write: Write to the file * @write: Write to the file
*/ */
...@@ -492,6 +492,15 @@ union cpuid_0x10_3_eax { ...@@ -492,6 +492,15 @@ union cpuid_0x10_3_eax {
unsigned int full; unsigned int full;
}; };
/* CPUID.(EAX=10H, ECX=ResID).ECX */
union cpuid_0x10_x_ecx {
struct {
unsigned int reserved:3;
unsigned int noncont:1;
} split;
unsigned int full;
};
/* CPUID.(EAX=10H, ECX=ResID).EDX */ /* CPUID.(EAX=10H, ECX=ResID).EDX */
union cpuid_0x10_x_edx { union cpuid_0x10_x_edx {
struct { struct {
......
This diff is collapsed.
...@@ -94,7 +94,7 @@ struct rdt_domain { ...@@ -94,7 +94,7 @@ struct rdt_domain {
* zero CBM. * zero CBM.
* @shareable_bits: Bitmask of shareable resource with other * @shareable_bits: Bitmask of shareable resource with other
* executing entities * executing entities
* @arch_has_sparse_bitmaps: True if a bitmap like f00f is valid. * @arch_has_sparse_bitmasks: True if a bitmask like f00f is valid.
* @arch_has_per_cpu_cfg: True if QOS_CFG register for this cache * @arch_has_per_cpu_cfg: True if QOS_CFG register for this cache
* level has CPU scope. * level has CPU scope.
*/ */
...@@ -102,7 +102,7 @@ struct resctrl_cache { ...@@ -102,7 +102,7 @@ struct resctrl_cache {
unsigned int cbm_len; unsigned int cbm_len;
unsigned int min_cbm_bits; unsigned int min_cbm_bits;
unsigned int shareable_bits; unsigned int shareable_bits;
bool arch_has_sparse_bitmaps; bool arch_has_sparse_bitmasks;
bool arch_has_per_cpu_cfg; bool arch_has_per_cpu_cfg;
}; };
......
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