Skip to content

Commit

Permalink
specs-go/config: add Intel RDT/MBA Linux support
Browse files Browse the repository at this point in the history
Add support for Intel Resource Director Technology (RDT) /
Memory Bandwidth Allocation (MBA). Add memory bandwidth resource
constraints in Linux-specific configuration.

This is the prerequisite of this runc proposal:
opencontainers/runc#1596

For more information about Intel RDT/MBA, please refer to:
opencontainers/runc#1596

Signed-off-by: Xiaochen Shen <xiaochen.shen@intel.com>
  • Loading branch information
xiaochenshen committed Oct 18, 2017
1 parent 4ebb31e commit 2fd9272
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 9 deletions.
28 changes: 23 additions & 5 deletions config-linux.md
Original file line number Diff line number Diff line change
Expand Up @@ -466,19 +466,37 @@ The following parameters can be specified to set up the controller:
The following parameters can be specified for the container:

* **`l3CacheSchema`** *(string, OPTIONAL)* - specifies the schema for L3 cache id and capacity bitmask (CBM).
If `l3CacheSchema` is set, runtimes MUST write the value to the `schemata` file in the `<container-id>` directory discussed in `intelRdt`.
* **`memBwSchema`** *(array of objects, OPTIONAL)* - specifies the schema of memory bandwidth (b/w) percentage per L3 cache id.
Each entry has the following structure:
* **`cache_id`** *(uint32, REQUIRED)* - L3 cache id
* **`bw_percentage`** *(uint32, REQUIRED)* - memory bandwidth (b/w) percentage

If `l3CacheSchema` or `memBwSchema` is set, runtimes MUST write the value to the `schemata` file in the `<container-id>` directory discussed in `intelRdt`.

If `l3CacheSchema` is not set, runtimes MUST NOT write to `schemata` files in any `resctrl` pseudo-filesystems.
If neither `l3CacheSchema` nor `memBwSchema` is set, runtimes MUST NOT write to `schemata` files in any `resctrl` pseudo-filesystems.

### Example

Consider a two-socket machine with two L3 caches where the default CBM is 0xfffff and the max CBM length is 20 bits.
Tasks inside the container only have access to the "upper" 80% of L3 cache id 0 and the "lower" 50% L3 cache id 1:
Consider a two-socket machine with two L3 caches where the default CBM is 0x7ff and the max CBM length is 11 bits,
and minimum memory b/w of 10% with a memory b/w granularity of 10%.

Tasks inside the container only have access to the "upper" 7/11 of L3 cache on socket 0 and the "lower" 5/11 L3 cache on socket 1,
and may use a maximum memory b/w of 20% on socket 0 and 70% on socket 1.

```json
"linux": {
"intelRdt": {
"l3CacheSchema": "L3:0=ffff0;1=3ff"
"l3CacheSchema": "L3:0=7f0;1=1f",
"memBwSchema": [
{
"cache_id": 0,
"bw_percentage": 20
},
{
"cache_id": 1,
"bw_percentage": 70
},
]
}
}
```
Expand Down
7 changes: 7 additions & 0 deletions schema/config-linux.json
Original file line number Diff line number Diff line change
Expand Up @@ -273,6 +273,13 @@
"l3CacheSchema": {
"id": "https://opencontainers.org/schema/bundle/linux/intelRdt/l3CacheSchema",
"type": "string"
},
"memBwSchema": {
"id": "https://opencontainers.org/schema/bundle/linux/intelRdt/memBwSchema",
"type": "array",
"items": {
"$ref": "defs-linux.json#/definitions/IntelRdtMemBwSchema"
}
}
}
}
Expand Down
15 changes: 15 additions & 0 deletions schema/defs-linux.json
Original file line number Diff line number Diff line change
Expand Up @@ -265,6 +265,21 @@
"required": [
"type"
]
},
"IntelRdtMemBwSchema": {
"type": "object",
"properties": {
"cache_id": {
"$ref": "defs.json#/definitions/uint32"
},
"bw_percentage": {
"$ref": "defs.json#/definitions/uint32"
}
},
"required": [
"cache_id",
"bw_percentage"
]
}
}
}
18 changes: 14 additions & 4 deletions specs-go/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -158,8 +158,8 @@ type Linux struct {
ReadonlyPaths []string `json:"readonlyPaths,omitempty"`
// MountLabel specifies the selinux context for the mounts in the container.
MountLabel string `json:"mountLabel,omitempty"`
// IntelRdt contains Intel Resource Director Technology (RDT) information
// for handling resource constraints (e.g., L3 cache) for the container
// IntelRdt contains Intel Resource Director Technology (RDT) information for
// handling resource constraints (e.g., L3 cache, memory bandwidth) for the container
IntelRdt *LinuxIntelRdt `json:"intelRdt,omitempty"`
}

Expand Down Expand Up @@ -561,10 +561,20 @@ type LinuxSyscall struct {
Args []LinuxSeccompArg `json:"args,omitempty"`
}

// LinuxIntelRdt has container runtime resource constraints
// for Intel RDT/CAT which introduced in Linux 4.10 kernel
// LinuxMemBwSchema specifies memory bandwidth (b/w) percentage per L3 cache id
type LinuxMemBwSchema struct {
CacheId uinit32 `json:"cacheId,omitempty"`
BwPercentage uinit32 `json:"bwPercentage,omitempty"`
}

// LinuxIntelRdt has container runtime resource constraints for Intel RDT
// CAT and MBA features which introduced in Linux 4.10 and 4.12 kernel
type LinuxIntelRdt struct {
// The schema for L3 cache id and capacity bitmask (CBM)
// Format: "L3:<cache_id0>=<cbm0>;<cache_id1>=<cbm1>;..."
L3CacheSchema string `json:"l3CacheSchema,omitempty"`

// The schema of memory bandwidth (b/w) percentage per L3 cache id
// Format: "MB:<cache_id0>=bandwidth0;<cache_id1>=bandwidth1;..."
MemBwSchema []LinuxMemBwSchema `json:"memBwSchema,omitempty"`
}

0 comments on commit 2fd9272

Please sign in to comment.