summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2013-07-11 19:14:38 +0200
committerLennart Poettering <lennart@poettering.net>2013-07-11 19:14:38 +0200
commit9d12709626bccc0cae677a7035f62efe6aabb4ab (patch)
tree2e6efd8ece92eed8c0f9d7ada70a2a72b739a43f
parent05b23cae8ebf6fbafd23ab8a0b0cfed747745d15 (diff)
loginctl: suppress cgroup tree output if cgroup is empty
same for machinectl
-rw-r--r--src/login/loginctl.c17
-rw-r--r--src/machine/machinectl.c13
2 files changed, 22 insertions, 8 deletions
diff --git a/src/login/loginctl.c b/src/login/loginctl.c
index 93f4beed37..736db6a11b 100644
--- a/src/login/loginctl.c
+++ b/src/login/loginctl.c
@@ -35,8 +35,9 @@
#include "build.h"
#include "strv.h"
#include "unit-name.h"
-#include "cgroup-show.h"
#include "sysfs-show.h"
+#include "cgroup-show.h"
+#include "cgroup-util.h"
#include "spawn-polkit-agent.h"
static char **arg_property = NULL;
@@ -262,7 +263,7 @@ static int list_seats(DBusConnection *bus, char **args, unsigned n) {
return 0;
}
-static int show_unit_cgroup(DBusConnection *bus, const char *interface, const char *unit) {
+static int show_unit_cgroup(DBusConnection *bus, const char *interface, const char *unit, pid_t leader) {
const char *property = "ControlGroup";
_cleanup_dbus_message_unref_ DBusMessage *reply = NULL;
_cleanup_free_ char *path = NULL;
@@ -313,6 +314,12 @@ static int show_unit_cgroup(DBusConnection *bus, const char *interface, const ch
dbus_message_iter_get_basic(&sub, &cgroup);
+ if (isempty(cgroup))
+ return 0;
+
+ if (cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER, cgroup, false) != 0 && leader <= 0)
+ return 0;
+
output_flags =
arg_all * OUTPUT_SHOW_ALL |
arg_full * OUTPUT_FULL_WIDTH;
@@ -323,7 +330,7 @@ static int show_unit_cgroup(DBusConnection *bus, const char *interface, const ch
else
c = 0;
- show_cgroup_by_path(cgroup, "\t\t ", c, false, output_flags);
+ show_cgroup_and_extra(SYSTEMD_CGROUP_CONTROLLER, cgroup, "\t\t ", c, false, &leader, leader > 0, output_flags);
return 0;
}
@@ -441,7 +448,7 @@ static void print_session_status_info(DBusConnection *bus, SessionStatusInfo *i)
if (i->scope) {
printf("\t Unit: %s\n", i->scope);
- show_unit_cgroup(bus, "org.freedesktop.systemd1.Scope", i->scope);
+ show_unit_cgroup(bus, "org.freedesktop.systemd1.Scope", i->scope, i->leader);
}
}
@@ -483,7 +490,7 @@ static void print_user_status_info(DBusConnection *bus, UserStatusInfo *i) {
if (i->slice) {
printf("\t Unit: %s\n", i->slice);
- show_unit_cgroup(bus, "org.freedesktop.systemd1.Slice", i->slice);
+ show_unit_cgroup(bus, "org.freedesktop.systemd1.Slice", i->slice, 0);
}
}
diff --git a/src/machine/machinectl.c b/src/machine/machinectl.c
index cd640e76ae..97c2193551 100644
--- a/src/machine/machinectl.c
+++ b/src/machine/machinectl.c
@@ -36,6 +36,7 @@
#include "strv.h"
#include "unit-name.h"
#include "cgroup-show.h"
+#include "cgroup-util.h"
#include "spawn-polkit-agent.h"
static char **arg_property = NULL;
@@ -125,7 +126,7 @@ static int list_machines(DBusConnection *bus, char **args, unsigned n) {
return 0;
}
-static int show_scope_cgroup(DBusConnection *bus, const char *unit) {
+static int show_scope_cgroup(DBusConnection *bus, const char *unit, pid_t leader) {
const char *interface = "org.freedesktop.systemd1.Scope";
const char *property = "ControlGroup";
_cleanup_dbus_message_unref_ DBusMessage *reply = NULL;
@@ -177,6 +178,12 @@ static int show_scope_cgroup(DBusConnection *bus, const char *unit) {
dbus_message_iter_get_basic(&sub, &cgroup);
+ if (isempty(cgroup))
+ return 0;
+
+ if (cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER, cgroup, false) != 0 && leader <= 0)
+ return 0;
+
output_flags =
arg_all * OUTPUT_SHOW_ALL |
arg_full * OUTPUT_FULL_WIDTH;
@@ -187,7 +194,7 @@ static int show_scope_cgroup(DBusConnection *bus, const char *unit) {
else
c = 0;
- show_cgroup_by_path(cgroup, "\t\t ", c, false, output_flags);
+ show_cgroup_and_extra(SYSTEMD_CGROUP_CONTROLLER, cgroup, "\t\t ", c, false, &leader, leader > 0, output_flags);
return 0;
}
@@ -249,7 +256,7 @@ static void print_machine_status_info(DBusConnection *bus, MachineStatusInfo *i)
if (i->scope) {
printf("\t Unit: %s\n", i->scope);
- show_scope_cgroup(bus, i->scope);
+ show_scope_cgroup(bus, i->scope, i->leader);
}
}