library: make sure that the proc_t is now fixed length

The former variable length structure created potential
problems for library users like that referenced below.

We will now parallel the same approach newlib uses for
the configure options --enable-oomem & --with-systemd.
Thus, the --enable-oomem and OOMEM_ENABLE #define have
been eliminated and the --with-systemd option (#define
WITH_SYSTEMD) will hereafter impact one function only.

The proc_t struct itself will now *never* be impacted.

Reference(s):
https://gitlab.com/procps-ng/procps/issues/31

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2016-06-02 00:00:00 -05:00 committed by Craig Small
parent 10503c03d4
commit 32db4e99a6
3 changed files with 10 additions and 32 deletions

View File

@ -182,14 +182,6 @@ AC_ARG_ENABLE([examples],
) )
AM_CONDITIONAL(EXAMPLE_FILES, test "x$enable_examples" = xyes) AM_CONDITIONAL(EXAMPLE_FILES, test "x$enable_examples" = xyes)
AC_ARG_ENABLE([oomem],
AS_HELP_STRING([--enable-oomem], [add out-of-memory fields to the library and top]),
[], [enable_oomem=no]
)
if test "x$enable_oomem" = xyes; then
AC_DEFINE(OOMEM_ENABLE, 1, [add out-of-memory fields to the library and top])
fi
AC_ARG_ENABLE([sigwinch], AC_ARG_ENABLE([sigwinch],
AS_HELP_STRING([--enable-sigwinch], [reduce impact of x-windows resize operations on top]), AS_HELP_STRING([--enable-sigwinch], [reduce impact of x-windows resize operations on top]),
[], [enable_sigwinch=no] [], [enable_sigwinch=no]

View File

@ -95,7 +95,6 @@ static inline void free_acquired (proc_t *p, int reuse) {
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_mach) free(p->sd_mach);
if (p->sd_ouid) free(p->sd_ouid); if (p->sd_ouid) free(p->sd_ouid);
if (p->sd_seat) free(p->sd_seat); if (p->sd_seat) free(p->sd_seat);
@ -103,7 +102,6 @@ static inline void free_acquired (proc_t *p, int reuse) {
if (p->sd_slice) free(p->sd_slice); if (p->sd_slice) free(p->sd_slice);
if (p->sd_unit) free(p->sd_unit); if (p->sd_unit) free(p->sd_unit);
if (p->sd_uunit) free(p->sd_uunit); if (p->sd_uunit) free(p->sd_uunit);
#endif
#ifdef QUICK_THREADS #ifdef QUICK_THREADS
} }
#endif #endif
@ -467,7 +465,6 @@ static void supgrps_from_supgids (proc_t *p) {
} }
/////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////
#ifdef OOMEM_ENABLE
static void oomscore2proc(const char* S, proc_t *restrict P) static void oomscore2proc(const char* S, proc_t *restrict P)
{ {
sscanf(S, "%d", &P->oom_score); sscanf(S, "%d", &P->oom_score);
@ -477,7 +474,6 @@ static void oomadj2proc(const char* S, proc_t *restrict P)
{ {
sscanf(S, "%d", &P->oom_adj); sscanf(S, "%d", &P->oom_adj);
} }
#endif
/////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////
static const char *ns_names[] = { static const char *ns_names[] = {
@ -520,8 +516,8 @@ static void ns2proc(const char *directory, proc_t *restrict p) {
} }
} }
#ifdef WITH_SYSTEMD
static void sd2proc(proc_t *restrict p) { static void sd2proc(proc_t *restrict p) {
#ifdef WITH_SYSTEMD
char buf[64]; char buf[64];
uid_t uid; uid_t uid;
@ -534,7 +530,6 @@ static void sd2proc(proc_t *restrict p) {
snprintf(buf, sizeof(buf), "%d", (int)uid); snprintf(buf, sizeof(buf), "%d", (int)uid);
p->sd_ouid = strdup(buf); p->sd_ouid = strdup(buf);
} }
if (0 > sd_pid_get_session(p->tid, &p->sd_sess)) { if (0 > sd_pid_get_session(p->tid, &p->sd_sess)) {
p->sd_sess = strdup("-"); p->sd_sess = strdup("-");
p->sd_seat = strdup("-"); p->sd_seat = strdup("-");
@ -542,17 +537,22 @@ static void sd2proc(proc_t *restrict p) {
if (0 > sd_session_get_seat(p->sd_sess, &p->sd_seat)) if (0 > sd_session_get_seat(p->sd_sess, &p->sd_seat))
p->sd_seat = strdup("-"); p->sd_seat = strdup("-");
} }
if (0 > sd_pid_get_slice(p->tid, &p->sd_slice)) if (0 > sd_pid_get_slice(p->tid, &p->sd_slice))
p->sd_slice = strdup("-"); p->sd_slice = strdup("-");
if (0 > sd_pid_get_unit(p->tid, &p->sd_unit)) if (0 > sd_pid_get_unit(p->tid, &p->sd_unit))
p->sd_unit = strdup("-"); p->sd_unit = strdup("-");
if (0 > sd_pid_get_user_unit(p->tid, &p->sd_uunit)) if (0 > sd_pid_get_user_unit(p->tid, &p->sd_uunit))
p->sd_uunit = strdup("-"); p->sd_uunit = strdup("-");
} #else
p->sd_mach = strdup("?");
p->sd_ouid = strdup("?");
p->sd_seat = strdup("?");
p->sd_sess = strdup("?");
p->sd_slice = strdup("?");
p->sd_unit = strdup("?");
p->sd_uunit = strdup("?");
#endif #endif
}
/////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////
@ -992,22 +992,18 @@ static proc_t* simple_readproc(PROCTAB *restrict const PT, proc_t *restrict cons
} else } else
p->cgroup = NULL; p->cgroup = NULL;
#ifdef OOMEM_ENABLE
if (unlikely(flags & PROC_FILLOOM)) { if (unlikely(flags & PROC_FILLOOM)) {
if (likely(file2str(path, "oom_score", &ub) != -1)) if (likely(file2str(path, "oom_score", &ub) != -1))
oomscore2proc(ub.buf, p); oomscore2proc(ub.buf, p);
if (likely(file2str(path, "oom_adj", &ub) != -1)) if (likely(file2str(path, "oom_adj", &ub) != -1))
oomadj2proc(ub.buf, p); oomadj2proc(ub.buf, p);
} }
#endif
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 if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
sd2proc(p); sd2proc(p);
#endif
if (unlikely(flags & PROC_FILL_LXC)) // value the lxc name if (unlikely(flags & PROC_FILL_LXC)) // value the lxc name
p->lxcname = lxc_containers(path); p->lxcname = lxc_containers(path);
@ -1115,10 +1111,8 @@ 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 if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
sd2proc(t); sd2proc(t);
#endif
if (unlikely(flags & PROC_FILL_LXC)) // value the lxc name if (unlikely(flags & PROC_FILL_LXC)) // value the lxc name
t->lxcname = lxc_containers(path); t->lxcname = lxc_containers(path);
@ -1138,7 +1132,6 @@ 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_mach = p->sd_mach;
t->sd_ouid = p->sd_ouid; t->sd_ouid = p->sd_ouid;
t->sd_seat = p->sd_seat; t->sd_seat = p->sd_seat;
@ -1146,20 +1139,17 @@ static proc_t* simple_readtask(PROCTAB *restrict const PT, const proc_t *restric
t->sd_slice = p->sd_slice; t->sd_slice = p->sd_slice;
t->sd_unit = p->sd_unit; t->sd_unit = p->sd_unit;
t->sd_uunit = p->sd_uunit; t->sd_uunit = p->sd_uunit;
#endif
t->lxcname = p->lxcname; t->lxcname = p->lxcname;
MK_THREAD(t); MK_THREAD(t);
} }
#endif #endif
#ifdef OOMEM_ENABLE
if (unlikely(flags & PROC_FILLOOM)) { if (unlikely(flags & PROC_FILLOOM)) {
if (likely(file2str(path, "oom_score", &ub) != -1)) if (likely(file2str(path, "oom_score", &ub) != -1))
oomscore2proc(ub.buf, t); oomscore2proc(ub.buf, t);
if (likely(file2str(path, "oom_adj", &ub) != -1)) if (likely(file2str(path, "oom_adj", &ub) != -1))
oomadj2proc(ub.buf, t); oomadj2proc(ub.buf, t);
} }
#endif
if (unlikely(flags & PROC_FILLNS)) // read /proc/#/task/#/ns/* if (unlikely(flags & PROC_FILLNS)) // read /proc/#/task/#/ns/*
ns2proc(path, t); ns2proc(path, t);

View File

@ -167,14 +167,11 @@ typedef struct proc_t {
tpgid, // stat terminal process group id tpgid, // stat terminal process group id
exit_signal, // stat might not be SIGCHLD exit_signal, // stat might not be SIGCHLD
processor; // stat current (or most recent?) CPU processor; // stat current (or most recent?) CPU
#ifdef OOMEM_ENABLE
int int
oom_score, // oom_score (badness for OOM killer) oom_score, // oom_score (badness for OOM killer)
oom_adj; // oom_adj (adjustment to OOM score) oom_adj; // oom_adj (adjustment to OOM score)
#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 char
*sd_mach, // n/a systemd vm/container name *sd_mach, // n/a systemd vm/container name
*sd_ouid, // n/a systemd session owner uid *sd_ouid, // n/a systemd session owner uid
@ -183,7 +180,6 @@ typedef struct proc_t {
*sd_slice, // n/a systemd slice unit *sd_slice, // n/a systemd slice unit
*sd_unit, // n/a systemd system unit id *sd_unit, // n/a systemd system unit id
*sd_uunit; // n/a systemd user unit id *sd_uunit; // n/a systemd user unit id
#endif
const char const char
*lxcname; // n/a lxc container name *lxcname; // n/a lxc container name
} proc_t; } proc_t;