mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 00:14:32 +09:00
oomd: move check if processes can be killed into oomd_cgroup_kill()
This also adds a debuuging log if the check failed.
Addresses https://github.com/systemd/systemd/pull/39773#discussion_r2549439336.
Follow-up for 38e9d40c80.
This commit is contained in:
committed by
Zbigniew Jędrzejewski-Szmek
parent
5da6a8ee6e
commit
332bce5bd7
@@ -237,6 +237,16 @@ int oomd_cgroup_kill(const char *path, bool recurse, bool dry_run) {
|
||||
|
||||
assert(path);
|
||||
|
||||
/* First try to send SIG0 recursively to ensure all child cgroups can be killed. */
|
||||
if (recurse)
|
||||
r = cg_kill_recursive(path, /* sig= */ 0, CGROUP_IGNORE_SELF,
|
||||
/* killed_pids= */ NULL, /* log_kill= */ NULL, /* userdata= */ NULL);
|
||||
else
|
||||
r = cg_kill(path, /* sig= */ 0, CGROUP_IGNORE_SELF,
|
||||
/* killed_pids= */ NULL, /* log_kill= */ NULL, /* userdata= */ NULL);
|
||||
if (r < 0)
|
||||
return log_debug_errno(r, "Failed to send SIG0 to processes in cgroup '%s': %m", path);
|
||||
|
||||
if (dry_run) {
|
||||
_cleanup_free_ char *cg_path = NULL;
|
||||
|
||||
@@ -337,12 +347,6 @@ int oomd_kill_by_pgscan_rate(Hashmap *h, const char *prefix, bool dry_run, char
|
||||
if (c->pgscan == 0 && c->current_memory_usage == 0)
|
||||
continue;
|
||||
|
||||
/* First try killing recursively to ensure all child cgroups can be killed. */
|
||||
r = cg_kill_recursive(c->path, /* sig= */ 0, CGROUP_IGNORE_SELF, /* killed_pids= */ NULL,
|
||||
/* log_kill= */ NULL, /* userdata= */ NULL);
|
||||
if (r < 0)
|
||||
continue;
|
||||
|
||||
r = oomd_cgroup_kill(c->path, /* recurse= */ true, /* dry_run= */ dry_run);
|
||||
if (r == -ENOMEM)
|
||||
return r; /* Treat oom as a hard error */
|
||||
@@ -387,12 +391,6 @@ int oomd_kill_by_swap_usage(Hashmap *h, uint64_t threshold_usage, bool dry_run,
|
||||
if (c->swap_usage <= threshold_usage)
|
||||
continue;
|
||||
|
||||
/* First try killing recursively to ensure all child cgroups can be killed. */
|
||||
r = cg_kill_recursive(c->path, /* sig= */ 0, CGROUP_IGNORE_SELF, /* killed_pids= */ NULL,
|
||||
/* log_kill= */ NULL, /* userdata= */ NULL);
|
||||
if (r < 0)
|
||||
continue;
|
||||
|
||||
r = oomd_cgroup_kill(c->path, /* recurse= */ true, /* dry_run= */ dry_run);
|
||||
if (r == -ENOMEM)
|
||||
return r; /* Treat oom as a hard error */
|
||||
|
||||
Reference in New Issue
Block a user