library: generalize then add former 'ps' systemd logic
Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
d187304854
commit
9d8ad6419f
@ -157,7 +157,7 @@ if test "x$with_systemd" != xno; then
|
|||||||
PKG_CHECK_MODULES([SYSTEMD], [libsystemd-login >= 206], [], [
|
PKG_CHECK_MODULES([SYSTEMD], [libsystemd-login >= 206], [], [
|
||||||
AC_CHECK_LIB(systemd-login, sd_pid_get_slice, [have_systemd=yes], [have_systemd=no])
|
AC_CHECK_LIB(systemd-login, sd_pid_get_slice, [have_systemd=yes], [have_systemd=no])
|
||||||
if test "x$have_systemd" = xno; then
|
if test "x$have_systemd" = xno; then
|
||||||
AC_MSG_ERROR([systemd support missing/incomplete])
|
AC_MSG_ERROR([systemd support missing/incomplete (requires >= 206)])
|
||||||
fi
|
fi
|
||||||
SYSTEMD_LIBS="-lsystemd-login"
|
SYSTEMD_LIBS="-lsystemd-login"
|
||||||
])
|
])
|
||||||
|
@ -12,6 +12,10 @@ LIBprocps_AGE=0
|
|||||||
|
|
||||||
lib_LTLIBRARIES = libprocps.la
|
lib_LTLIBRARIES = libprocps.la
|
||||||
|
|
||||||
|
if WITH_SYSTEMD
|
||||||
|
AM_LDFLAGS = @SYSTEMD_LIBS@
|
||||||
|
endif
|
||||||
|
|
||||||
libprocps_ladir = $(ladir)
|
libprocps_ladir = $(ladir)
|
||||||
libprocps_la_LIBADD = $(LIB_KPARTS)
|
libprocps_la_LIBADD = $(LIB_KPARTS)
|
||||||
libprocps_la_LDFLAGS = \
|
libprocps_la_LDFLAGS = \
|
||||||
|
@ -37,6 +37,9 @@
|
|||||||
#include <sys/dir.h>
|
#include <sys/dir.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
#include <systemd/sd-login.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
// sometimes it's easier to do this manually, w/o gcc helping
|
// sometimes it's easier to do this manually, w/o gcc helping
|
||||||
#ifdef PROF
|
#ifdef PROF
|
||||||
@ -87,11 +90,20 @@ static inline void free_acquired (proc_t *p, int reuse) {
|
|||||||
#ifdef QUICK_THREADS
|
#ifdef QUICK_THREADS
|
||||||
if (!IS_THREAD(p)) {
|
if (!IS_THREAD(p)) {
|
||||||
#endif
|
#endif
|
||||||
if (p->environ) free((void*)*p->environ);
|
if (p->environ) free((void*)*p->environ);
|
||||||
if (p->cmdline) free((void*)*p->cmdline);
|
if (p->cmdline) free((void*)*p->cmdline);
|
||||||
if (p->cgroup) free((void*)*p->cgroup);
|
if (p->cgroup) free((void*)*p->cgroup);
|
||||||
if (p->supgid) free(p->supgid);
|
if (p->supgid) free(p->supgid);
|
||||||
if (p->supgrp) free(p->supgrp);
|
if (p->supgrp) free(p->supgrp);
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
if (p->sd_mach) free(p->sd_mach);
|
||||||
|
if (p->sd_ouid) free(p->sd_ouid);
|
||||||
|
if (p->sd_seat) free(p->sd_seat);
|
||||||
|
if (p->sd_sess) free(p->sd_sess);
|
||||||
|
if (p->sd_slice) free(p->sd_slice);
|
||||||
|
if (p->sd_unit) free(p->sd_unit);
|
||||||
|
if (p->sd_uunit) free(p->sd_uunit);
|
||||||
|
#endif
|
||||||
#ifdef QUICK_THREADS
|
#ifdef QUICK_THREADS
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -496,6 +508,40 @@ static void ns2proc(const char *directory, proc_t *restrict p) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
static void sd2proc(proc_t *restrict p) {
|
||||||
|
char buf[64];
|
||||||
|
uid_t uid;
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_machine_name(p->tid, &p->sd_mach))
|
||||||
|
p->sd_mach = strdup("-");
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_owner_uid(p->tid, &uid))
|
||||||
|
p->sd_ouid = strdup("-");
|
||||||
|
else {
|
||||||
|
snprintf(buf, sizeof(buf), "%d", (int)uid);
|
||||||
|
p->sd_ouid = strdup(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_session(p->tid, &p->sd_sess)) {
|
||||||
|
p->sd_sess = strdup("-");
|
||||||
|
p->sd_seat = strdup("-");
|
||||||
|
} else {
|
||||||
|
if (0 > sd_session_get_seat(p->sd_sess, &p->sd_seat))
|
||||||
|
p->sd_seat = strdup("-");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_slice(p->tid, &p->sd_slice))
|
||||||
|
p->sd_slice = strdup("-");
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_unit(p->tid, &p->sd_unit))
|
||||||
|
p->sd_unit = strdup("-");
|
||||||
|
|
||||||
|
if (0 > sd_pid_get_user_unit(p->tid, &p->sd_uunit))
|
||||||
|
p->sd_uunit = strdup("-");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
///////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
@ -889,6 +935,10 @@ static proc_t* simple_readproc(PROCTAB *restrict const PT, proc_t *restrict cons
|
|||||||
if (unlikely(flags & PROC_FILLNS)) // read /proc/#/ns/*
|
if (unlikely(flags & PROC_FILLNS)) // read /proc/#/ns/*
|
||||||
ns2proc(path, p);
|
ns2proc(path, p);
|
||||||
|
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
|
||||||
|
sd2proc(p);
|
||||||
|
#endif
|
||||||
return p;
|
return p;
|
||||||
next_proc:
|
next_proc:
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -992,6 +1042,11 @@ static proc_t* simple_readtask(PROCTAB *restrict const PT, const proc_t *restric
|
|||||||
} else
|
} else
|
||||||
t->cgroup = NULL;
|
t->cgroup = NULL;
|
||||||
|
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
|
||||||
|
sd2proc(t);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef QUICK_THREADS
|
#ifdef QUICK_THREADS
|
||||||
} else {
|
} else {
|
||||||
t->size = p->size;
|
t->size = p->size;
|
||||||
@ -1007,6 +1062,15 @@ static proc_t* simple_readtask(PROCTAB *restrict const PT, const proc_t *restric
|
|||||||
if (t->supgid) free(t->supgid);
|
if (t->supgid) free(t->supgid);
|
||||||
t->supgid = p->supgid;
|
t->supgid = p->supgid;
|
||||||
t->supgrp = p->supgrp;
|
t->supgrp = p->supgrp;
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
t->sd_mach = p->sd_mach;
|
||||||
|
t->sd_ouid = p->sd_ouid;
|
||||||
|
t->sd_seat = p->sd_seat;
|
||||||
|
t->sd_sess = p->sd_sess;
|
||||||
|
t->sd_slice = p->sd_slice;
|
||||||
|
t->sd_unit = p->sd_unit;
|
||||||
|
t->sd_uunit = p->sd_uunit;
|
||||||
|
#endif
|
||||||
MK_THREAD(t);
|
MK_THREAD(t);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -171,6 +171,16 @@ typedef struct proc_t {
|
|||||||
#endif
|
#endif
|
||||||
long
|
long
|
||||||
ns[NUM_NS]; // (ns subdir) inode number of namespaces
|
ns[NUM_NS]; // (ns subdir) inode number of namespaces
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
char
|
||||||
|
*sd_mach, // n/a systemd vm/container name
|
||||||
|
*sd_ouid, // n/a systemd session owner uid
|
||||||
|
*sd_seat, // n/a systemd login session seat
|
||||||
|
*sd_sess, // n/a systemd login session id
|
||||||
|
*sd_slice, // n/a systemd slice unit
|
||||||
|
*sd_unit, // n/a systemd system unit id
|
||||||
|
*sd_uunit; // n/a systemd user unit id
|
||||||
|
#endif
|
||||||
} proc_t;
|
} proc_t;
|
||||||
|
|
||||||
// PROCTAB: data structure holding the persistent information readproc needs
|
// PROCTAB: data structure holding the persistent information readproc needs
|
||||||
@ -281,6 +291,7 @@ extern proc_t * get_proc_stats(pid_t pid, proc_t *p);
|
|||||||
#define PROC_FILLSUPGRP 0x0400 // resolve supplementary group id -> group name
|
#define PROC_FILLSUPGRP 0x0400 // resolve supplementary group id -> group name
|
||||||
#define PROC_FILLOOM 0x0800 // fill in proc_t oom_score and oom_adj
|
#define PROC_FILLOOM 0x0800 // fill in proc_t oom_score and oom_adj
|
||||||
#define PROC_FILLNS 0x8000 // fill in proc_t namespace information
|
#define PROC_FILLNS 0x8000 // fill in proc_t namespace information
|
||||||
|
#define PROC_FILLSYSTEMD 0x80000 // fill in proc_t systemd information
|
||||||
|
|
||||||
#define PROC_LOOSE_TASKS 0x2000 // treat threads as if they were processes
|
#define PROC_LOOSE_TASKS 0x2000 // treat threads as if they were processes
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user