library: removed that 'calloc/free' cruft where doable

Under newlib, the only caller of the readproc routines
is that pids module. And in every case, the address of
some static proc_t structure has always been provided.

As a result, there is no need for the logic supporting
calloc() for a possible NULL pointer which was present
in both of those readproc() and readeither() routines.

Additionally, that pids module takes ownership of most
dynamically acquired 'str' plus 'strv' memory whenever
assigning to a results structure. So, henceforth under
the free_acquired() guy we will only free those string
fields which might exist when not explicitly selected.

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2019-09-30 00:00:00 -05:00 committed by Craig Small
parent 281c37d1cd
commit 11cf6cc005

View File

@ -73,28 +73,24 @@ static int task_dir_missing;
// free any additional dynamically acquired storage associated with a proc_t // free any additional dynamically acquired storage associated with a proc_t
// ( and if it's to be reused, refresh it otherwise destroy it ) static inline void free_acquired (proc_t *p) {
static inline void free_acquired (proc_t *p, int reuse) { /*
if (p->cgname) free((void*)p->cgname); * here we free those items that might exist even when not explicitly |
if (p->cgroup) free((void*)p->cgroup); * requested by our caller. it is expected that pid.c will then free |
if (p->cgroup_v) free((void*)*p->cgroup_v); * any remaining dynamic memory which might be dangling off a proc_t. | */
if (p->cmd) free(p->cmd); if (p->cgname) free(p->cgname);
if (p->cmdline) free((void*)p->cmdline); if (p->cgroup) free(p->cgroup);
if (p->cmdline_v) free((void*)*p->cmdline_v); if (p->cmd) free(p->cmd);
if (p->environ) free((void*)p->environ); if (p->sd_mach) free(p->sd_mach);
if (p->environ_v) free((void*)*p->environ_v); if (p->sd_ouid) free(p->sd_ouid);
if (p->exe) free(p->exe); if (p->sd_seat) free(p->sd_seat);
if (p->sd_mach) free(p->sd_mach); if (p->sd_sess) free(p->sd_sess);
if (p->sd_ouid) free(p->sd_ouid); if (p->sd_slice) free(p->sd_slice);
if (p->sd_seat) free(p->sd_seat); if (p->sd_unit) free(p->sd_unit);
if (p->sd_sess) free(p->sd_sess); if (p->sd_uunit) free(p->sd_uunit);
if (p->sd_slice) free(p->sd_slice); if (p->supgid) free(p->supgid);
if (p->sd_unit) free(p->sd_unit);
if (p->sd_uunit) free(p->sd_uunit);
if (p->supgid) free(p->supgid);
if (p->supgrp) free(p->supgrp);
memset(p, reuse ? '\0' : '\xff', sizeof(*p)); memset(p, '\0', sizeof(proc_t));
} }
@ -1315,14 +1311,9 @@ static int listed_nextpid(PROCTAB *restrict const PT, proc_t *restrict const p)
*/ */
proc_t* readproc(PROCTAB *restrict const PT, proc_t *restrict p) { proc_t* readproc(PROCTAB *restrict const PT, proc_t *restrict p) {
proc_t *ret; proc_t *ret;
proc_t *saved_p;
saved_p = p; free_acquired(p);
if (p) free_acquired(p, 1);
else {
p = calloc(1, sizeof *p);
if (!p) goto out;
}
for(;;){ for(;;){
if (errno == ENOMEM) goto out; if (errno == ENOMEM) goto out;
// fills in the path, plus p->tid and p->tgid // fills in the path, plus p->tid and p->tgid
@ -1334,8 +1325,6 @@ proc_t* readproc(PROCTAB *restrict const PT, proc_t *restrict p) {
} }
out: out:
if(!saved_p) free(p);
// FIXME: maybe set tid to -1 here, for "-" in display?
return NULL; return NULL;
} }
@ -1350,14 +1339,10 @@ proc_t* readeither (PROCTAB *restrict const PT, proc_t *restrict x) {
static proc_t *new_p; // for process/task transitions static proc_t *new_p; // for process/task transitions
static int canary; static int canary;
char path[PROCPATHLEN]; char path[PROCPATHLEN];
proc_t *saved_x, *ret; proc_t *ret;
free_acquired(x);
saved_x = x;
if (x) free_acquired(x,1);
else {
x = calloc(1, sizeof(*x));
if (!x) goto end_procs;
}
if (new_p) { if (new_p) {
if (new_p->tid != canary) new_p = NULL; if (new_p->tid != canary) new_p = NULL;
goto next_task; goto next_task;
@ -1386,7 +1371,6 @@ next_task:
return ret; return ret;
end_procs: end_procs:
if (!saved_x) free(x);
return NULL; return NULL;
} }