From 41106d849490e0f51783f4e5609ac421ce09e8cd Mon Sep 17 00:00:00 2001 From: Filipe Brandenburger Date: Dec 15 2020 17:55:19 +0000 Subject: core: downgrade CPUQuotaPeriodSec= clamping logs to debug After the first warning log, further messages are downgraded to LOG_DEBUG. (cherry picked from commit 527ede0c638b47b62a87900438a8a09dea42889e) Related: #1770379 patch_name: 0399-core-downgrade-CPUQuotaPeriodSec-clamping-logs-to-de.patch present_in_specfile: true location_in_specfile: 399 squash_commits: true --- diff --git a/src/core/cgroup.c b/src/core/cgroup.c index 45fd64a..f8b351a 100644 --- a/src/core/cgroup.c +++ b/src/core/cgroup.c @@ -544,9 +544,10 @@ static usec_t cgroup_cpu_adjust_period_and_log(Unit *u, usec_t period, usec_t qu if (new_period != period) { char v[FORMAT_TIMESPAN_MAX]; - log_unit_full(u, LOG_WARNING, 0, + log_unit_full(u, u->warned_clamping_cpu_quota_period ? LOG_DEBUG : LOG_WARNING, 0, "Clamping CPU interval for cpu.max: period is now %s", format_timespan(v, sizeof(v), new_period, 1)); + u->warned_clamping_cpu_quota_period = true; } return new_period; diff --git a/src/core/dbus-cgroup.c b/src/core/dbus-cgroup.c index c8b918e..4555b33 100644 --- a/src/core/dbus-cgroup.c +++ b/src/core/dbus-cgroup.c @@ -712,6 +712,7 @@ int bus_cgroup_set_property( if (!UNIT_WRITE_FLAGS_NOOP(flags)) { c->cpu_quota_per_sec_usec = u64; + u->warned_clamping_cpu_quota_period = false; unit_invalidate_cgroup(u, CGROUP_MASK_CPU); if (c->cpu_quota_per_sec_usec == USEC_INFINITY) @@ -735,6 +736,7 @@ int bus_cgroup_set_property( if (!UNIT_WRITE_FLAGS_NOOP(flags)) { c->cpu_quota_period_usec = u64; + u->warned_clamping_cpu_quota_period = false; unit_invalidate_cgroup(u, CGROUP_MASK_CPU); if (c->cpu_quota_period_usec == USEC_INFINITY) unit_write_setting(u, flags, "CPUQuotaPeriodSec", "CPUQuotaPeriodSec="); diff --git a/src/core/unit.h b/src/core/unit.h index 39179f5..b40ff9b 100644 --- a/src/core/unit.h +++ b/src/core/unit.h @@ -356,6 +356,9 @@ typedef struct Unit { bool exported_log_rate_limit_interval:1; bool exported_log_rate_limit_burst:1; + /* Whether we warned about clamping the CPU quota period */ + bool warned_clamping_cpu_quota_period:1; + /* When writing transient unit files, stores which section we stored last. If < 0, we didn't write any yet. If * == 0 we are in the [Unit] section, if > 0 we are in the unit type-specific section. */ int last_section_private:2;