From fc20ad5ccdf4b302515c8815a49dc4b04e72c314d6bdf3bf7a54ced2b603cf24 Mon Sep 17 00:00:00 2001 From: Franck Bui Date: Thu, 21 Mar 2024 14:15:59 +0000 Subject: [PATCH] - The following patches have been merged into SUSE/v255 branch hence removed from the OBS project. 5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch 5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch 5008-test-Add-effective-cgroup-limits-testing.patch 5009-cgroup-Restrict-effective-limits-with-global-resourc.patch 5010-cgroup-Rename-effective-limits-internal-table.patch - Import commit 56b53b17bcd8311dfb53f05b359b2812593883ab 56b53b17bc cgroup: Rename effective limits internal table (jsc#PED-5659) 7c9202317c cgroup: Restrict effective limits with global resource provision (jsc#PED-5659) da858e68eb test: Add effective cgroup limits testing (jsc#PED-5659) 2f013357a5 test: Convert rlimit test to subtest of generic limit testing (jsc#PED-5659) 0a3ea7f367 cgroup: Add EffectiveMemoryMax=, EffectiveMemoryHigh= and EffectiveTasksMax= properties (jsc#PED-5659) OBS-URL: https://build.opensuse.org/package/show/Base:System/systemd?expand=0&rev=1507 --- ...tiveMemoryMax-EffectiveMemoryHigh-an.patch | 668 ------------------ ...mit-test-to-subtest-of-generic-limit.patch | 97 --- ...-Add-effective-cgroup-limits-testing.patch | 111 --- ...effective-limits-with-global-resourc.patch | 56 -- ...name-effective-limits-internal-table.patch | 66 -- systemd-v255.4+suse.17.gbe772961ad.tar.xz | 3 - systemd-v255.4+suse.22.g56b53b17bc.tar.xz | 3 + systemd.changes | 20 + systemd.spec | 10 +- 9 files changed, 24 insertions(+), 1010 deletions(-) delete mode 100644 5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch delete mode 100644 5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch delete mode 100644 5008-test-Add-effective-cgroup-limits-testing.patch delete mode 100644 5009-cgroup-Restrict-effective-limits-with-global-resourc.patch delete mode 100644 5010-cgroup-Rename-effective-limits-internal-table.patch delete mode 100644 systemd-v255.4+suse.17.gbe772961ad.tar.xz create mode 100644 systemd-v255.4+suse.22.g56b53b17bc.tar.xz diff --git a/5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch b/5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch deleted file mode 100644 index 717746c2..00000000 --- a/5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch +++ /dev/null @@ -1,668 +0,0 @@ -From 840527985f03a4327fc0fe78e45d889742601698 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Michal=20Koutn=C3=BD?= -Date: Fri, 11 Aug 2023 13:51:20 +0200 -Subject: [PATCH 5006/5010] cgroup: Add EffectiveMemoryMax=, - EffectiveMemoryHigh= and EffectiveTasksMax= properties - -Users become perplexed when they run their workload in a unit with no -explicit limits configured (moreover, listing the limit property would -even show it's infinity) but they experience unexpected resource -limitation. - -The memory and pid limits come as the most visible, therefore add new -unit read-only properties: -- EffectiveMemoryMax=, -- EffectiveMemoryHigh=, -- EffectiveTasksMax=. - -These properties represent the most stringent limit systemd is aware of -for the given unit -- and that is typically(*) the effective value. - -Implement the properties by simply traversing all parents in the -leaf-slice tree and picking the minimum value. Note that effective -limits are thus defined even for units that don't enable explicit -accounting (because of the hierarchy). - -(*) The evasive case is when systemd runs in a cgroupns and cannot -reason about outer setup. Complete solution would need kernel support. - -(cherry picked from commit 4fb0d2dc140c9a2c01c236d2a8dc09a44157e896) - -[mkoutny: fixes jsc#PED-5659] ---- - man/org.freedesktop.systemd1.xml | 126 ++++++++++++++++++++++++++++++ - man/systemd.resource-control.xml | 11 ++- - src/core/cgroup.c | 48 ++++++++++++ - src/core/cgroup.h | 13 +++ - src/core/dbus-unit.c | 25 ++++++ - src/shared/bus-print-properties.c | 6 +- - 6 files changed, 224 insertions(+), 5 deletions(-) - -diff --git a/man/org.freedesktop.systemd1.xml b/man/org.freedesktop.systemd1.xml -index a1bcbba02f..59733c0039 100644 ---- a/man/org.freedesktop.systemd1.xml -+++ b/man/org.freedesktop.systemd1.xml -@@ -2786,6 +2786,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -2794,6 +2798,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -3419,6 +3425,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - - - -+ -+ -+ -+ - - - -@@ -3427,6 +3437,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - - - -+ -+ - - - -@@ -4061,6 +4073,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - - - -+ -+ -+ -+ - - - -@@ -4069,6 +4085,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2eservice { - - - -+ -+ - - - -@@ -4865,6 +4883,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -4873,6 +4895,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -5508,6 +5532,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - - - -+ -+ -+ -+ - - - -@@ -5516,6 +5544,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - - - -+ -+ - - - -@@ -6132,6 +6162,10 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - - - -+ -+ -+ -+ - - - -@@ -6140,6 +6174,8 @@ node /org/freedesktop/systemd1/unit/avahi_2ddaemon_2esocket { - - - -+ -+ - - - -@@ -6810,6 +6846,10 @@ node /org/freedesktop/systemd1/unit/home_2emount { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -6818,6 +6858,8 @@ node /org/freedesktop/systemd1/unit/home_2emount { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -7381,6 +7423,10 @@ node /org/freedesktop/systemd1/unit/home_2emount { - - - -+ -+ -+ -+ - - - -@@ -7389,6 +7435,8 @@ node /org/freedesktop/systemd1/unit/home_2emount { - - - -+ -+ - - - -@@ -7919,6 +7967,10 @@ node /org/freedesktop/systemd1/unit/home_2emount { - - - -+ -+ -+ -+ - - - -@@ -7927,6 +7979,8 @@ node /org/freedesktop/systemd1/unit/home_2emount { - - - -+ -+ - - - -@@ -8720,6 +8774,10 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -8728,6 +8786,8 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -9277,6 +9337,10 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - - - -+ -+ -+ -+ - - - -@@ -9285,6 +9349,8 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - - - -+ -+ - - - -@@ -9801,6 +9867,10 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - - - -+ -+ -+ -+ - - - -@@ -9809,6 +9879,8 @@ node /org/freedesktop/systemd1/unit/dev_2dsda3_2eswap { - - - -+ -+ - - - -@@ -10461,6 +10533,10 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -10469,6 +10545,8 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -10644,6 +10722,10 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - - - -+ -+ -+ -+ - - - -@@ -10652,6 +10734,8 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - - - -+ -+ - - - -@@ -10832,6 +10916,10 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - - - -+ -+ -+ -+ - - - -@@ -10840,6 +10928,8 @@ node /org/freedesktop/systemd1/unit/system_2eslice { - - - -+ -+ - - - -@@ -11046,6 +11136,10 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t MemoryAvailable = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveMemoryHigh = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t CPUUsageNSec = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly ay EffectiveCPUs = [...]; -@@ -11054,6 +11148,8 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t TasksCurrent = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") -+ readonly t EffectiveTasksMax = ...; -+ @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressBytes = ...; - @org.freedesktop.DBus.Property.EmitsChangedSignal("false") - readonly t IPIngressPackets = ...; -@@ -11249,6 +11345,10 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - - - -+ -+ -+ -+ - - - -@@ -11257,6 +11357,8 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - - - -+ -+ - - - -@@ -11467,6 +11569,10 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - - - -+ -+ -+ -+ - - - -@@ -11475,6 +11581,8 @@ node /org/freedesktop/systemd1/unit/session_2d1_2escope { - - - -+ -+ - - - -@@ -11866,6 +11974,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Socket Unit Objects -@@ -11897,6 +12008,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Mount Unit Objects -@@ -11926,6 +12040,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Swap Unit Objects -@@ -11955,6 +12072,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Slice Unit Objects -@@ -11975,6 +12095,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Scope Unit Objects -@@ -11996,6 +12119,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ - MemorySwapCurrent, - MemorySwapPeak, and - MemoryZSwapCurrent were added in version 255. -+ EffectiveMemoryHigh, -+ EffectiveMemoryMax, -+ EffectiveTasksMax were added in version 256. - - - Job Objects -diff --git a/man/systemd.resource-control.xml b/man/systemd.resource-control.xml -index 42f265c950..bd8b6a5719 100644 ---- a/man/systemd.resource-control.xml -+++ b/man/systemd.resource-control.xml -@@ -406,7 +406,9 @@ CPUWeight=20 DisableControllers=cpu / \ - system. If assigned the - special value infinity, no memory throttling is applied. This controls the - memory.high control group attribute. For details about this control group attribute, see -- Memory Interface Files. -+ Memory Interface Files. -+ The effective configuration is reported as EffectiveMemoryHigh= -+ (see also EffectiveMemoryMax=). - - While StartupMemoryHigh= applies to the startup and shutdown phases of the system, - MemoryHigh= applies to normal runtime of the system, and if the former is not set also to -@@ -434,7 +436,9 @@ CPUWeight=20 DisableControllers=cpu / \ - percentage value may be specified, which is taken relative to the installed physical memory on the system. If - assigned the special value infinity, no memory limit is applied. This controls the - memory.max control group attribute. For details about this control group attribute, see -- Memory Interface Files. -+ Memory Interface Files. -+ The effective configuration is reported as EffectiveMemoryMax= (the value is -+ the most stringent limit of the unit and parent slices). - - While StartupMemoryMax= applies to the startup and shutdown phases of the system, - MemoryMax= applies to normal runtime of the system, and if the former is not set also to -@@ -560,7 +564,8 @@ CPUWeight=20 DisableControllers=cpu / \ - limit is applied. This controls the pids.max control group attribute. For - details about this control group attribute, the - pids controller -- . -+ . -+ The effective configuration is reported as EffectiveTasksMax=. - - The system default for this setting may be controlled with - DefaultTasksMax= in -diff --git a/src/core/cgroup.c b/src/core/cgroup.c -index 61ac4df1a6..78ca67216a 100644 ---- a/src/core/cgroup.c -+++ b/src/core/cgroup.c -@@ -4243,6 +4243,46 @@ int unit_get_ip_accounting( - return r; - } - -+static uint64_t unit_get_effective_limit_one(Unit *u, CGroupLimitType type) { -+ CGroupContext *cc; -+ -+ assert(u); -+ assert(UNIT_HAS_CGROUP_CONTEXT(u)); -+ -+ cc = unit_get_cgroup_context(u); -+ switch (type) { -+ /* Note: on legacy/hybrid hierarchies memory_max stays CGROUP_LIMIT_MAX unless configured -+ * explicitly. Effective value of MemoryLimit= (cgroup v1) is not implemented. */ -+ case CGROUP_LIMIT_MEMORY_MAX: -+ return cc->memory_max; -+ case CGROUP_LIMIT_MEMORY_HIGH: -+ return cc->memory_high; -+ case CGROUP_LIMIT_TASKS_MAX: -+ return cgroup_tasks_max_resolve(&cc->tasks_max); -+ default: -+ assert_not_reached(); -+ } -+} -+ -+int unit_get_effective_limit(Unit *u, CGroupLimitType type, uint64_t *ret) { -+ uint64_t infimum; -+ -+ assert(u); -+ assert(ret); -+ assert(type >= 0); -+ assert(type < _CGROUP_LIMIT_TYPE_MAX); -+ -+ if (!UNIT_HAS_CGROUP_CONTEXT(u)) -+ return -EINVAL; -+ -+ infimum = unit_get_effective_limit_one(u, type); -+ for (Unit *slice = UNIT_GET_SLICE(u); slice; slice = UNIT_GET_SLICE(slice)) -+ infimum = MIN(infimum, unit_get_effective_limit_one(slice, type)); -+ -+ *ret = infimum; -+ return 0; -+} -+ - static int unit_get_io_accounting_raw(Unit *u, uint64_t ret[static _CGROUP_IO_ACCOUNTING_METRIC_MAX]) { - static const char *const field_names[_CGROUP_IO_ACCOUNTING_METRIC_MAX] = { - [CGROUP_IO_READ_BYTES] = "rbytes=", -@@ -4663,3 +4703,11 @@ static const char* const cgroup_memory_accounting_metric_table[_CGROUP_MEMORY_AC - }; - - DEFINE_STRING_TABLE_LOOKUP(cgroup_memory_accounting_metric, CGroupMemoryAccountingMetric); -+ -+static const char *const cgroup_limit_type_table[_CGROUP_LIMIT_TYPE_MAX] = { -+ [CGROUP_LIMIT_MEMORY_MAX] = "EffectiveMemoryMax", -+ [CGROUP_LIMIT_MEMORY_HIGH] = "EffectiveMemoryHigh", -+ [CGROUP_LIMIT_TASKS_MAX] = "EffectiveTasksMax", -+}; -+ -+DEFINE_STRING_TABLE_LOOKUP(cgroup_limit_type, CGroupLimitType); -diff --git a/src/core/cgroup.h b/src/core/cgroup.h -index f1b674b4b7..54bce91ea1 100644 ---- a/src/core/cgroup.h -+++ b/src/core/cgroup.h -@@ -276,6 +276,15 @@ typedef enum CGroupMemoryAccountingMetric { - _CGROUP_MEMORY_ACCOUNTING_METRIC_INVALID = -EINVAL, - } CGroupMemoryAccountingMetric; - -+/* Used for limits whose value sets have infimum */ -+typedef enum CGroupLimitType { -+ CGROUP_LIMIT_MEMORY_MAX, -+ CGROUP_LIMIT_MEMORY_HIGH, -+ CGROUP_LIMIT_TASKS_MAX, -+ _CGROUP_LIMIT_TYPE_MAX, -+ _CGROUP_LIMIT_INVALID = -EINVAL, -+} CGroupLimitType; -+ - typedef struct Unit Unit; - typedef struct Manager Manager; - typedef enum ManagerState ManagerState; -@@ -374,6 +383,7 @@ int unit_get_tasks_current(Unit *u, uint64_t *ret); - int unit_get_cpu_usage(Unit *u, nsec_t *ret); - int unit_get_io_accounting(Unit *u, CGroupIOAccountingMetric metric, bool allow_cache, uint64_t *ret); - int unit_get_ip_accounting(Unit *u, CGroupIPAccountingMetric metric, uint64_t *ret); -+int unit_get_effective_limit(Unit *u, CGroupLimitType type, uint64_t *ret); - - int unit_reset_cpu_accounting(Unit *u); - void unit_reset_memory_accounting_last(Unit *u); -@@ -425,5 +435,8 @@ CGroupIPAccountingMetric cgroup_ip_accounting_metric_from_string(const char *s) - const char* cgroup_io_accounting_metric_to_string(CGroupIOAccountingMetric m) _const_; - CGroupIOAccountingMetric cgroup_io_accounting_metric_from_string(const char *s) _pure_; - -+const char* cgroup_limit_type_to_string(CGroupLimitType m) _const_; -+CGroupLimitType cgroup_limit_type_from_string(const char *s) _pure_; -+ - const char* cgroup_memory_accounting_metric_to_string(CGroupMemoryAccountingMetric m) _const_; - CGroupMemoryAccountingMetric cgroup_memory_accounting_metric_from_string(const char *s) _pure_; -diff --git a/src/core/dbus-unit.c b/src/core/dbus-unit.c -index 1a037b7035..ac6add4700 100644 ---- a/src/core/dbus-unit.c -+++ b/src/core/dbus-unit.c -@@ -1441,6 +1441,28 @@ static int property_get_io_counter( - return sd_bus_message_append(reply, "t", value); - } - -+static int property_get_effective_limit( -+ sd_bus *bus, -+ const char *path, -+ const char *interface, -+ const char *property, -+ sd_bus_message *reply, -+ void *userdata, -+ sd_bus_error *error) { -+ -+ uint64_t value = CGROUP_LIMIT_MAX; -+ Unit *u = ASSERT_PTR(userdata); -+ ssize_t type; -+ -+ assert(bus); -+ assert(reply); -+ assert(property); -+ -+ assert_se((type = cgroup_limit_type_from_string(property)) >= 0); -+ (void) unit_get_effective_limit(u, type, &value); -+ return sd_bus_message_append(reply, "t", value); -+} -+ - int bus_unit_method_attach_processes(sd_bus_message *message, void *userdata, sd_bus_error *error) { - _cleanup_(sd_bus_creds_unrefp) sd_bus_creds *creds = NULL; - _cleanup_set_free_ Set *pids = NULL; -@@ -1562,10 +1584,13 @@ const sd_bus_vtable bus_unit_cgroup_vtable[] = { - SD_BUS_PROPERTY("MemorySwapPeak", "t", property_get_memory_accounting, 0, 0), - SD_BUS_PROPERTY("MemoryZSwapCurrent", "t", property_get_memory_accounting, 0, 0), - SD_BUS_PROPERTY("MemoryAvailable", "t", property_get_available_memory, 0, 0), -+ SD_BUS_PROPERTY("EffectiveMemoryMax", "t", property_get_effective_limit, 0, 0), -+ SD_BUS_PROPERTY("EffectiveMemoryHigh", "t", property_get_effective_limit, 0, 0), - SD_BUS_PROPERTY("CPUUsageNSec", "t", property_get_cpu_usage, 0, 0), - SD_BUS_PROPERTY("EffectiveCPUs", "ay", property_get_cpuset_cpus, 0, 0), - SD_BUS_PROPERTY("EffectiveMemoryNodes", "ay", property_get_cpuset_mems, 0, 0), - SD_BUS_PROPERTY("TasksCurrent", "t", property_get_current_tasks, 0, 0), -+ SD_BUS_PROPERTY("EffectiveTasksMax", "t", property_get_effective_limit, 0, 0), - SD_BUS_PROPERTY("IPIngressBytes", "t", property_get_ip_counter, 0, 0), - SD_BUS_PROPERTY("IPIngressPackets", "t", property_get_ip_counter, 0, 0), - SD_BUS_PROPERTY("IPEgressBytes", "t", property_get_ip_counter, 0, 0), -diff --git a/src/shared/bus-print-properties.c b/src/shared/bus-print-properties.c -index 6704e1ef3d..99b1cc7c70 100644 ---- a/src/shared/bus-print-properties.c -+++ b/src/shared/bus-print-properties.c -@@ -164,9 +164,11 @@ static int bus_print_property(const char *name, const char *expected_value, sd_b - - bus_print_property_value(name, expected_value, flags, "[not set]"); - -- else if ((ENDSWITH_SET(name, "MemoryLow", "MemoryMin", "MemoryHigh", "MemoryMax", "MemorySwapMax", "MemoryZSwapMax", "MemoryLimit") && -+ else if ((ENDSWITH_SET(name, "MemoryLow", "MemoryMin", -+ "MemoryHigh", "MemoryMax", -+ "MemorySwapMax", "MemoryZSwapMax", "MemoryLimit") && - u == CGROUP_LIMIT_MAX) || -- (STR_IN_SET(name, "TasksMax", "DefaultTasksMax") && u == UINT64_MAX) || -+ (endswith(name, "TasksMax") && u == UINT64_MAX) || - (startswith(name, "Limit") && u == UINT64_MAX) || - (startswith(name, "DefaultLimit") && u == UINT64_MAX)) - --- -2.35.3 - diff --git a/5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch b/5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch deleted file mode 100644 index 983b9d32..00000000 --- a/5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch +++ /dev/null @@ -1,97 +0,0 @@ -From 207784eeaab0c274dc087056f20523d7c10939fe Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Michal=20Koutn=C3=BD?= -Date: Wed, 9 Aug 2023 22:42:36 +0200 -Subject: [PATCH 5007/5010] test: Convert rlimit test to subtest of generic - limit testing - -No functional change intended. Preparation for new tests. - -(cherry picked from commit 834ca54624ae1d61ec4fcf3a63b10271c38c4860) - -[mkoutny: fixes jsc#PED-5659] ---- - test/units/testsuite-05.rlimit.sh | 25 +++++++++++++++++++++++++ - test/units/testsuite-05.service | 2 +- - test/units/testsuite-05.sh | 22 +++------------------- - 3 files changed, 29 insertions(+), 20 deletions(-) - create mode 100755 test/units/testsuite-05.rlimit.sh - -diff --git a/test/units/testsuite-05.rlimit.sh b/test/units/testsuite-05.rlimit.sh -new file mode 100755 -index 0000000000..bbf3adbe65 ---- /dev/null -+++ b/test/units/testsuite-05.rlimit.sh -@@ -0,0 +1,25 @@ -+#!/usr/bin/env bash -+# SPDX-License-Identifier: LGPL-2.1-or-later -+set -eux -+set -o pipefail -+ -+P=/run/systemd/system.conf.d -+mkdir $P -+ -+cat >$P/rlimits.conf <$P/rlimits.conf < -Date: Wed, 9 Aug 2023 22:43:31 +0200 -Subject: [PATCH 5008/5010] test: Add effective cgroup limits testing - -(cherry picked from commit ce35bb95c7b6fe9a48d2b8628bd690279b17fffa) - -[mkoutny: fixes jsc#PED-5659] ---- - test/units/testsuite-05.effective-limit.sh | 68 ++++++++++++++++++++++ - test/units/util.sh | 9 +++ - 2 files changed, 77 insertions(+) - create mode 100755 test/units/testsuite-05.effective-limit.sh - -diff --git a/test/units/testsuite-05.effective-limit.sh b/test/units/testsuite-05.effective-limit.sh -new file mode 100755 -index 0000000000..3ff8e83140 ---- /dev/null -+++ b/test/units/testsuite-05.effective-limit.sh -@@ -0,0 +1,68 @@ -+#!/usr/bin/env bash -+# SPDX-License-Identifier: LGPL-2.1-or-later -+set -eux -+set -o pipefail -+ -+# shellcheck source=test/units/util.sh -+. "$(dirname "$0")"/util.sh -+ -+pre=test05 -+cat >/run/systemd/system/"$pre"alpha.slice </run/systemd/system/"$pre"alpha-beta.slice </run/systemd/system/"$pre"alpha-beta-gamma.slice < '$2'" >&2 -+ exit 1 -+ fi -+)} -+ - assert_in() {( - set +ex - --- -2.35.3 - diff --git a/5009-cgroup-Restrict-effective-limits-with-global-resourc.patch b/5009-cgroup-Restrict-effective-limits-with-global-resourc.patch deleted file mode 100644 index 6ea10d2c..00000000 --- a/5009-cgroup-Restrict-effective-limits-with-global-resourc.patch +++ /dev/null @@ -1,56 +0,0 @@ -From 355275a7708d09f7be27ea239478cb3c6defbb9a Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Michal=20Koutn=C3=BD?= -Date: Mon, 14 Aug 2023 19:59:57 +0200 -Subject: [PATCH 5009/5010] cgroup: Restrict effective limits with global - resource provision - -Global resource (whole system or root cg's (e.g. in a container)) is -also a well-defined limit for memory and tasks, take it into account -when calculating effective limits. - -(cherry picked from commit 93f8e88d23bd383b5134f32c1e2ee315ac3a38c8) - -[mkoutny: fixes jsc#PED-5659] ---- - man/systemd.resource-control.xml | 2 +- - src/core/cgroup.c | 11 +++++++++++ - 2 files changed, 12 insertions(+), 1 deletion(-) - -diff --git a/man/systemd.resource-control.xml b/man/systemd.resource-control.xml -index bd8b6a5719..c2aa5b57e8 100644 ---- a/man/systemd.resource-control.xml -+++ b/man/systemd.resource-control.xml -@@ -438,7 +438,7 @@ CPUWeight=20 DisableControllers=cpu / \ - memory.max control group attribute. For details about this control group attribute, see - Memory Interface Files. - The effective configuration is reported as EffectiveMemoryMax= (the value is -- the most stringent limit of the unit and parent slices). -+ the most stringent limit of the unit and parent slices and it is capped by physical memory). - - While StartupMemoryMax= applies to the startup and shutdown phases of the system, - MemoryMax= applies to normal runtime of the system, and if the former is not set also to -diff --git a/src/core/cgroup.c b/src/core/cgroup.c -index 78ca67216a..285fa200d6 100644 ---- a/src/core/cgroup.c -+++ b/src/core/cgroup.c -@@ -4249,6 +4249,17 @@ static uint64_t unit_get_effective_limit_one(Unit *u, CGroupLimitType type) { - assert(u); - assert(UNIT_HAS_CGROUP_CONTEXT(u)); - -+ if (unit_has_name(u, SPECIAL_ROOT_SLICE)) -+ switch (type) { -+ case CGROUP_LIMIT_MEMORY_MAX: -+ case CGROUP_LIMIT_MEMORY_HIGH: -+ return physical_memory(); -+ case CGROUP_LIMIT_TASKS_MAX: -+ return system_tasks_max(); -+ default: -+ assert_not_reached(); -+ } -+ - cc = unit_get_cgroup_context(u); - switch (type) { - /* Note: on legacy/hybrid hierarchies memory_max stays CGROUP_LIMIT_MAX unless configured --- -2.35.3 - diff --git a/5010-cgroup-Rename-effective-limits-internal-table.patch b/5010-cgroup-Rename-effective-limits-internal-table.patch deleted file mode 100644 index d4bcc774..00000000 --- a/5010-cgroup-Rename-effective-limits-internal-table.patch +++ /dev/null @@ -1,66 +0,0 @@ -From ae7d09f074e554a241ba66a2dee2a0cb4b3a0162 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Michal=20Koutn=C3=BD?= -Date: Mon, 22 Jan 2024 16:58:18 +0100 -Subject: [PATCH 5010/5010] cgroup: Rename effective limits internal table - -Post-merge fixup of commit 4fb0d2dc14 ("cgroup: Add EffectiveMemoryMax=, -EffectiveMemoryHigh= and EffectiveTasksMax= properties"), no functional -change intended. - -(cherry picked from commit 8ad614890bba66b5f6b590d6a3e1b8b04a920126) - -[mkoutny: fixes jsc#PED-5659] ---- - src/core/cgroup.c | 4 ++-- - src/core/cgroup.h | 4 ++-- - src/core/dbus-unit.c | 2 +- - 3 files changed, 5 insertions(+), 5 deletions(-) - -diff --git a/src/core/cgroup.c b/src/core/cgroup.c -index 285fa200d6..0c30aefe80 100644 ---- a/src/core/cgroup.c -+++ b/src/core/cgroup.c -@@ -4715,10 +4715,10 @@ static const char* const cgroup_memory_accounting_metric_table[_CGROUP_MEMORY_AC - - DEFINE_STRING_TABLE_LOOKUP(cgroup_memory_accounting_metric, CGroupMemoryAccountingMetric); - --static const char *const cgroup_limit_type_table[_CGROUP_LIMIT_TYPE_MAX] = { -+static const char *const cgroup_effective_limit_type_table[_CGROUP_LIMIT_TYPE_MAX] = { - [CGROUP_LIMIT_MEMORY_MAX] = "EffectiveMemoryMax", - [CGROUP_LIMIT_MEMORY_HIGH] = "EffectiveMemoryHigh", - [CGROUP_LIMIT_TASKS_MAX] = "EffectiveTasksMax", - }; - --DEFINE_STRING_TABLE_LOOKUP(cgroup_limit_type, CGroupLimitType); -+DEFINE_STRING_TABLE_LOOKUP(cgroup_effective_limit_type, CGroupLimitType); -diff --git a/src/core/cgroup.h b/src/core/cgroup.h -index 54bce91ea1..6e3d05b7d2 100644 ---- a/src/core/cgroup.h -+++ b/src/core/cgroup.h -@@ -435,8 +435,8 @@ CGroupIPAccountingMetric cgroup_ip_accounting_metric_from_string(const char *s) - const char* cgroup_io_accounting_metric_to_string(CGroupIOAccountingMetric m) _const_; - CGroupIOAccountingMetric cgroup_io_accounting_metric_from_string(const char *s) _pure_; - --const char* cgroup_limit_type_to_string(CGroupLimitType m) _const_; --CGroupLimitType cgroup_limit_type_from_string(const char *s) _pure_; -+const char* cgroup_effective_limit_type_to_string(CGroupLimitType m) _const_; -+CGroupLimitType cgroup_effective_limit_type_from_string(const char *s) _pure_; - - const char* cgroup_memory_accounting_metric_to_string(CGroupMemoryAccountingMetric m) _const_; - CGroupMemoryAccountingMetric cgroup_memory_accounting_metric_from_string(const char *s) _pure_; -diff --git a/src/core/dbus-unit.c b/src/core/dbus-unit.c -index ac6add4700..bb19831814 100644 ---- a/src/core/dbus-unit.c -+++ b/src/core/dbus-unit.c -@@ -1458,7 +1458,7 @@ static int property_get_effective_limit( - assert(reply); - assert(property); - -- assert_se((type = cgroup_limit_type_from_string(property)) >= 0); -+ assert_se((type = cgroup_effective_limit_type_from_string(property)) >= 0); - (void) unit_get_effective_limit(u, type, &value); - return sd_bus_message_append(reply, "t", value); - } --- -2.35.3 - diff --git a/systemd-v255.4+suse.17.gbe772961ad.tar.xz b/systemd-v255.4+suse.17.gbe772961ad.tar.xz deleted file mode 100644 index d02dd74d..00000000 --- a/systemd-v255.4+suse.17.gbe772961ad.tar.xz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:e2e2c1c6c6acd082a80b9c2b3503ba2a62589c04070235756925a34f4f1418d4 -size 10771792 diff --git a/systemd-v255.4+suse.22.g56b53b17bc.tar.xz b/systemd-v255.4+suse.22.g56b53b17bc.tar.xz new file mode 100644 index 00000000..c2a499a7 --- /dev/null +++ b/systemd-v255.4+suse.22.g56b53b17bc.tar.xz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:a55e1ddf7c66e69b057cf1bc8a51c0c6d3936b1633881c42c1585a9c8cfda53e +size 10774060 diff --git a/systemd.changes b/systemd.changes index aaca3c6b..4767ab3b 100644 --- a/systemd.changes +++ b/systemd.changes @@ -1,3 +1,23 @@ +------------------------------------------------------------------- +Thu Mar 21 13:37:16 UTC 2024 - Franck Bui + +- The following patches have been merged into SUSE/v255 branch hence removed + from the OBS project. + + 5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch + 5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch + 5008-test-Add-effective-cgroup-limits-testing.patch + 5009-cgroup-Restrict-effective-limits-with-global-resourc.patch + 5010-cgroup-Rename-effective-limits-internal-table.patch + +- Import commit 56b53b17bcd8311dfb53f05b359b2812593883ab + + 56b53b17bc cgroup: Rename effective limits internal table (jsc#PED-5659) + 7c9202317c cgroup: Restrict effective limits with global resource provision (jsc#PED-5659) + da858e68eb test: Add effective cgroup limits testing (jsc#PED-5659) + 2f013357a5 test: Convert rlimit test to subtest of generic limit testing (jsc#PED-5659) + 0a3ea7f367 cgroup: Add EffectiveMemoryMax=, EffectiveMemoryHigh= and EffectiveTasksMax= properties (jsc#PED-5659) + ------------------------------------------------------------------- Wed Mar 20 17:31:16 UTC 2024 - Franck Bui diff --git a/systemd.spec b/systemd.spec index b301c731..6d5f10fa 100644 --- a/systemd.spec +++ b/systemd.spec @@ -28,7 +28,7 @@ %else %define systemd_version 255.4 %define systemd_release 0 -%define archive_version +suse.17.gbe772961ad +%define archive_version +suse.22.g56b53b17bc %endif %define systemd_major %{sub %systemd_version 1 3} @@ -231,7 +231,6 @@ Patch: 0008-sysv-generator-translate-Required-Start-into-a-Wants.patch %endif %if %{without upstream} - # Patches listed below are put in quarantine. Normally all changes must go to # upstream first and then are cherry-picked in the SUSE git repository. But for # very few cases, some stuff might be broken in upstream and need to be fixed or @@ -239,13 +238,6 @@ Patch: 0008-sysv-generator-translate-Required-Start-into-a-Wants.patch # will be removed as soon as a proper fix will be merged by upstream. Patch: 5001-Revert-udev-update-devlink-with-the-newer-device-nod.patch Patch: 5002-Revert-udev-revert-workarounds-for-issues-caused-by-.patch -# jsc#PED-5659 -Patch: 5006-cgroup-Add-EffectiveMemoryMax-EffectiveMemoryHigh-an.patch -Patch: 5007-test-Convert-rlimit-test-to-subtest-of-generic-limit.patch -Patch: 5008-test-Add-effective-cgroup-limits-testing.patch -Patch: 5009-cgroup-Restrict-effective-limits-with-global-resourc.patch -Patch: 5010-cgroup-Rename-effective-limits-internal-table.patch - %endif %description