library: play catchup with a new proc_t 'cgname' field
Since we're about to break the ABI/API anyway, why not go ahead and add yet another field to our proc_t which the newlib branch has had for awhile. This then allows the top program to offer 'control group name' and will also permit a few reductions in that ps program logic. And let's also clean up some unrelated warnings below. Clang warnings: proc/readproc.c:1178:50: warning: address of array 'ent->d_name' will always evaluate to 'true' [-Wpointer-bool-conversion] if(unlikely(unlikely(!ent) || unlikely(!ent->d_name))) return 0; ~~~~~~^~~~~~ proc/readproc.c:1205:50: warning: address of array 'ent->d_name' will always evaluate to 'true' [-Wpointer-bool-conversion] if(unlikely(unlikely(!ent) || unlikely(!ent->d_name))) return 0; ~~~~~~^~~~~~ Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
c15aea9d08
commit
5d54dc0d2e
@ -93,6 +93,7 @@ static inline void free_acquired (proc_t *p, int reuse) {
|
|||||||
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->cgname) free(p->cgname);
|
||||||
if (p->supgid) free(p->supgid);
|
if (p->supgid) free(p->supgid);
|
||||||
if (p->supgrp) free(p->supgrp);
|
if (p->supgrp) free(p->supgrp);
|
||||||
if (p->sd_mach) free(p->sd_mach);
|
if (p->sd_mach) free(p->sd_mach);
|
||||||
@ -773,7 +774,7 @@ static char** vectorize_this_str (const char* src) {
|
|||||||
// the data into a single string represented as a single vector.
|
// the data into a single string represented as a single vector.
|
||||||
static void fill_cgroup_cvt (const char* directory, proc_t *restrict p) {
|
static void fill_cgroup_cvt (const char* directory, proc_t *restrict p) {
|
||||||
#define vMAX ( MAX_BUFSZ - (int)(dst - dst_buffer) )
|
#define vMAX ( MAX_BUFSZ - (int)(dst - dst_buffer) )
|
||||||
char *src, *dst, *grp, *eob;
|
char *src, *dst, *grp, *eob, *name;
|
||||||
int tot, x, whackable_int = MAX_BUFSZ;
|
int tot, x, whackable_int = MAX_BUFSZ;
|
||||||
|
|
||||||
*(dst = dst_buffer) = '\0'; // empty destination
|
*(dst = dst_buffer) = '\0'; // empty destination
|
||||||
@ -790,6 +791,10 @@ static void fill_cgroup_cvt (const char* directory, proc_t *restrict p) {
|
|||||||
dst += escape_str(dst, grp, vMAX, &whackable_int);
|
dst += escape_str(dst, grp, vMAX, &whackable_int);
|
||||||
}
|
}
|
||||||
p->cgroup = vectorize_this_str(dst_buffer[0] ? dst_buffer : "-");
|
p->cgroup = vectorize_this_str(dst_buffer[0] ? dst_buffer : "-");
|
||||||
|
|
||||||
|
name = strstr(p->cgroup[0], ":name=");
|
||||||
|
if (name && *(name+6)) name += 6; else name = p->cgroup[0];
|
||||||
|
p->cgname = strdup(name);
|
||||||
#undef vMAX
|
#undef vMAX
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -973,24 +978,21 @@ static proc_t* simple_readproc(PROCTAB *restrict const PT, proc_t *restrict cons
|
|||||||
fill_environ_cvt(path, p);
|
fill_environ_cvt(path, p);
|
||||||
else
|
else
|
||||||
p->environ = file2strvec(path, "environ");
|
p->environ = file2strvec(path, "environ");
|
||||||
} else
|
}
|
||||||
p->environ = NULL;
|
|
||||||
|
|
||||||
if (flags & (PROC_FILLCOM|PROC_FILLARG)) { // read /proc/#/cmdline
|
if (flags & (PROC_FILLCOM|PROC_FILLARG)) { // read /proc/#/cmdline
|
||||||
if (flags & PROC_EDITCMDLCVT)
|
if (flags & PROC_EDITCMDLCVT)
|
||||||
fill_cmdline_cvt(path, p);
|
fill_cmdline_cvt(path, p);
|
||||||
else
|
else
|
||||||
p->cmdline = file2strvec(path, "cmdline");
|
p->cmdline = file2strvec(path, "cmdline");
|
||||||
} else
|
}
|
||||||
p->cmdline = NULL;
|
|
||||||
|
|
||||||
if ((flags & PROC_FILLCGROUP)) { // read /proc/#/cgroup
|
if ((flags & PROC_FILLCGROUP)) { // read /proc/#/cgroup
|
||||||
if (flags & PROC_EDITCGRPCVT)
|
if (flags & PROC_EDITCGRPCVT)
|
||||||
fill_cgroup_cvt(path, p);
|
fill_cgroup_cvt(path, p);
|
||||||
else
|
else
|
||||||
p->cgroup = file2strvec(path, "cgroup");
|
p->cgroup = file2strvec(path, "cgroup");
|
||||||
} else
|
}
|
||||||
p->cgroup = NULL;
|
|
||||||
|
|
||||||
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))
|
||||||
@ -1092,24 +1094,21 @@ static proc_t* simple_readtask(PROCTAB *restrict const PT, const proc_t *restric
|
|||||||
fill_environ_cvt(path, t);
|
fill_environ_cvt(path, t);
|
||||||
else
|
else
|
||||||
t->environ = file2strvec(path, "environ");
|
t->environ = file2strvec(path, "environ");
|
||||||
} else
|
}
|
||||||
t->environ = NULL;
|
|
||||||
|
|
||||||
if (flags & (PROC_FILLCOM|PROC_FILLARG)) { // read /proc/#/task/#/cmdline
|
if (flags & (PROC_FILLCOM|PROC_FILLARG)) { // read /proc/#/task/#/cmdline
|
||||||
if (flags & PROC_EDITCMDLCVT)
|
if (flags & PROC_EDITCMDLCVT)
|
||||||
fill_cmdline_cvt(path, t);
|
fill_cmdline_cvt(path, t);
|
||||||
else
|
else
|
||||||
t->cmdline = file2strvec(path, "cmdline");
|
t->cmdline = file2strvec(path, "cmdline");
|
||||||
} else
|
}
|
||||||
t->cmdline = NULL;
|
|
||||||
|
|
||||||
if ((flags & PROC_FILLCGROUP)) { // read /proc/#/task/#/cgroup
|
if ((flags & PROC_FILLCGROUP)) { // read /proc/#/task/#/cgroup
|
||||||
if (flags & PROC_EDITCGRPCVT)
|
if (flags & PROC_EDITCGRPCVT)
|
||||||
fill_cgroup_cvt(path, t);
|
fill_cgroup_cvt(path, t);
|
||||||
else
|
else
|
||||||
t->cgroup = file2strvec(path, "cgroup");
|
t->cgroup = file2strvec(path, "cgroup");
|
||||||
} else
|
}
|
||||||
t->cgroup = NULL;
|
|
||||||
|
|
||||||
if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
|
if (unlikely(flags & PROC_FILLSYSTEMD)) // get sd-login.h stuff
|
||||||
sd2proc(t);
|
sd2proc(t);
|
||||||
@ -1128,6 +1127,7 @@ static proc_t* simple_readtask(PROCTAB *restrict const PT, const proc_t *restric
|
|||||||
t->dt = p->dt;
|
t->dt = p->dt;
|
||||||
t->cmdline = p->cmdline; // better not free these until done with all threads!
|
t->cmdline = p->cmdline; // better not free these until done with all threads!
|
||||||
t->environ = p->environ;
|
t->environ = p->environ;
|
||||||
|
t->cgname = p->cgname;
|
||||||
t->cgroup = p->cgroup;
|
t->cgroup = p->cgroup;
|
||||||
if (t->supgid) free(t->supgid);
|
if (t->supgid) free(t->supgid);
|
||||||
t->supgid = p->supgid;
|
t->supgid = p->supgid;
|
||||||
@ -1170,7 +1170,7 @@ static int simple_nextpid(PROCTAB *restrict const PT, proc_t *restrict const p)
|
|||||||
char *restrict const path = PT->path;
|
char *restrict const path = PT->path;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
ent = readdir(PT->procfs);
|
ent = readdir(PT->procfs);
|
||||||
if(unlikely(unlikely(!ent) || unlikely(!ent->d_name))) return 0;
|
if(unlikely(unlikely(!ent) || unlikely(!ent->d_name[0]))) return 0;
|
||||||
if(likely(likely(*ent->d_name > '0') && likely(*ent->d_name <= '9'))) break;
|
if(likely(likely(*ent->d_name > '0') && likely(*ent->d_name <= '9'))) break;
|
||||||
}
|
}
|
||||||
p->tgid = strtoul(ent->d_name, NULL, 10);
|
p->tgid = strtoul(ent->d_name, NULL, 10);
|
||||||
@ -1197,7 +1197,7 @@ static int simple_nexttid(PROCTAB *restrict const PT, const proc_t *restrict con
|
|||||||
}
|
}
|
||||||
for (;;) {
|
for (;;) {
|
||||||
ent = readdir(PT->taskdir);
|
ent = readdir(PT->taskdir);
|
||||||
if(unlikely(unlikely(!ent) || unlikely(!ent->d_name))) return 0;
|
if(unlikely(unlikely(!ent) || unlikely(!ent->d_name[0]))) return 0;
|
||||||
if(likely(likely(*ent->d_name > '0') && likely(*ent->d_name <= '9'))) break;
|
if(likely(likely(*ent->d_name > '0') && likely(*ent->d_name <= '9'))) break;
|
||||||
}
|
}
|
||||||
t->tid = strtoul(ent->d_name, NULL, 10);
|
t->tid = strtoul(ent->d_name, NULL, 10);
|
||||||
|
@ -137,6 +137,7 @@ typedef struct proc_t {
|
|||||||
**environ, // (special) environment string vector (/proc/#/environ)
|
**environ, // (special) environment string vector (/proc/#/environ)
|
||||||
**cmdline, // (special) command line string vector (/proc/#/cmdline)
|
**cmdline, // (special) command line string vector (/proc/#/cmdline)
|
||||||
**cgroup, // (special) cgroup string vector (/proc/#/cgroup)
|
**cgroup, // (special) cgroup string vector (/proc/#/cgroup)
|
||||||
|
*cgname, // (special) name portion of above (if possible)
|
||||||
*supgid, // status supplementary gids as comma delimited str
|
*supgid, // status supplementary gids as comma delimited str
|
||||||
*supgrp; // supp grp names as comma delimited str, derived from supgid
|
*supgrp; // supp grp names as comma delimited str, derived from supgid
|
||||||
char
|
char
|
||||||
|
Loading…
Reference in New Issue
Block a user