[PATCH v2 00/33] Enable Intel Resource Allocation in Resource Director Technology

From: Fenghua Yu
Date: Thu Sep 08 2016 - 02:58:22 EST


From: Fenghua Yu <fenghua.yu@xxxxxxxxx>

L3 cache allocation allows per task control over which areas of the last
level cache are available for allocation. It is the first resource that
can be controlled as part of Intel Resource Director Technology (RDT).
This patch series creates a framework that will make it easy to add
additional resources (like L2 cache).

See Intel Software Developer manual volume 3, chapter 17 for architectural
details. Also Documentation/x86/intel_rdt.txt and
Documentation/x86/intel_rdt_ui.txt (in parts 0001 & 0013 of this patch
series).

A previous implementation used "cgroups" as the user interface. This was
rejected.

The new interface:
1) Aligns better with the h/w capabilities provided
2) Gives finer control (per thread instead of process)
3) Gives control over kernel threads as well as user threads
4) Allows resource allocation policies to be tied to certain cpus across
all contexts (tglx request)

Note 1: that parts 1-12 are largely unchanged from what was posted last
year except for the removal of cgroup pieces and dynamic CAT/CDP switch.

Note 2: This patch set is an infrastructure for future multi-resources
support. Some code are not only for L3. For example, cat_l3_enabled
is checked after initialization and mount time. This doesn't make
sense for L3 only. But it's easy to add L2 support on top of the
current patch set.

Changes:
v2:
- Merge and reorder some patches
- "tasks" has higher priority than "cpus".
- Re-write UI doc.
- Add include/linux/resctrl.h
- Remove rg_list
- A few other changes.

Fenghua Yu (21):
cacheinfo: Introduce cache id
Documentation, ABI: Add a document entry for cache id
x86, intel_cacheinfo: Enable cache id in x86
drivers/base/cacheinfo.c: Export some cacheinfo functions for others
to use
Documentation, x86: Documentation for Intel resource allocation user
interface
sched.h: Add rg_list and rdtgroup in task_struct
magic number for resctrl file system
x86/intel_rdt.h: Header for inter_rdt.c
x86/intel_rdt_rdtgroup.h: Header for user interface
x86/intel_rdt.c: Extend RDT to per cache and per resources
x86/intel_rdt_rdtgroup.c: User interface for RDT
x86/intel_rdt_rdtgroup.c: Create info directory
include/linux/resctrl.h: Define fork and exit functions in a new
header file
Task fork and exit for rdtgroup
x86/intel_rdt_rdtgroup.c: Implement resctrl file system commands
x86/intel_rdt_rdtgroup.c: Read and write cpus
x86/intel_rdt_rdtgroup.c: Tasks iterator and write
x86/intel_rdt_rdtgroup.c: Process schemata input from resctrl
interface
Documentation/kernel-parameters: Add kernel parameter "resctrl" for
CAT
MAINTAINERS: Add maintainer for Intel RDT resource allocation
x86/Makefile: Build intel_rdt_rdtgroup.c

Vikas Shivappa (12):
x86/intel_rdt: Cache Allocation documentation
x86/intel_rdt: Add support for Cache Allocation detection
x86/intel_rdt: Add Class of service management
x86/intel_rdt: Add L3 cache capacity bitmask management
x86/intel_rdt: Implement scheduling support for Intel RDT
x86/intel_rdt: Hot cpu support for Cache Allocation
x86/intel_rdt: Intel haswell Cache Allocation enumeration
Define CONFIG_INTEL_RDT
x86/intel_rdt: Intel Code Data Prioritization detection
x86/intel_rdt: Adds support to enable Code Data Prioritization
x86/intel_rdt: Class of service and capacity bitmask management for
CDP
x86/intel_rdt: Hot cpu update for code data prioritization

Documentation/ABI/testing/sysfs-devices-system-cpu | 17 +
Documentation/kernel-parameters.txt | 13 +
Documentation/x86/intel_rdt.txt | 109 ++
Documentation/x86/intel_rdt_ui.txt | 164 +++
MAINTAINERS | 9 +
arch/x86/Kconfig | 13 +
arch/x86/events/intel/cqm.c | 24 +-
arch/x86/include/asm/cpufeature.h | 10 +-
arch/x86/include/asm/cpufeatures.h | 9 +-
arch/x86/include/asm/disabled-features.h | 4 +-
arch/x86/include/asm/intel_rdt.h | 129 ++
arch/x86/include/asm/intel_rdt_rdtgroup.h | 164 +++
arch/x86/include/asm/pqr_common.h | 27 +
arch/x86/include/asm/processor.h | 3 +
arch/x86/include/asm/required-features.h | 4 +-
arch/x86/kernel/cpu/Makefile | 2 +
arch/x86/kernel/cpu/common.c | 19 +
arch/x86/kernel/cpu/intel_cacheinfo.c | 20 +
arch/x86/kernel/cpu/intel_rdt.c | 802 ++++++++++++
arch/x86/kernel/cpu/intel_rdt_rdtgroup.c | 1362 ++++++++++++++++++++
arch/x86/kernel/cpu/intel_rdt_schemata.c | 674 ++++++++++
arch/x86/kernel/process_64.c | 6 +
drivers/base/cacheinfo.c | 7 +-
include/linux/cacheinfo.h | 5 +
include/linux/resctrl.h | 12 +
include/linux/sched.h | 3 +
include/uapi/linux/magic.h | 2 +
kernel/exit.c | 2 +
kernel/fork.c | 2 +
29 files changed, 3589 insertions(+), 28 deletions(-)
create mode 100644 Documentation/x86/intel_rdt.txt
create mode 100644 Documentation/x86/intel_rdt_ui.txt
create mode 100644 arch/x86/include/asm/intel_rdt.h
create mode 100644 arch/x86/include/asm/intel_rdt_rdtgroup.h
create mode 100644 arch/x86/include/asm/pqr_common.h
create mode 100644 arch/x86/kernel/cpu/intel_rdt.c
create mode 100644 arch/x86/kernel/cpu/intel_rdt_rdtgroup.c
create mode 100644 arch/x86/kernel/cpu/intel_rdt_schemata.c
create mode 100644 include/linux/resctrl.h

--
2.5.0