Command line and full screen utilities for browsing procfs, a "pseudo" file system dynamically generated by Linux to provide information about the status of entries in its process table.
Go to file
Jim Warner 8b64b36bbf library: standardize handling of cgroup, supgid
Some inconsistencies have emerged during development
of support for these relatively new proc_t fields.

For example, a PROC_FILLCGROUP flag (via file2strvec)
could return NULL in cgroup whereas PROC_EDITCGRPCVT
(via fill_cgroup_cvt) *almost* guaranteed a return
address (as is true for PROC_EDITCMDLCVT and cmdline).
But even PROC_EDITCGRPCVT could return NULL if the
kernel version was less than 2.6.24.  Then with NULL
ps would display a "-" while top would show "n/a".

And while unlikely, with the PROC_FILLSTATUS flag (via
status2proc) a NULL supgid address was theoretically
possible and both ps and top would then show "n/a".

This commit standardizes the following usage:
  . PROC_FILLSTATUS         (via status2proc)
      guarantees a valid supgid address
      representing either a true comma
      delimited list or "-"
  . PROC_FILLCGROUP  plus
    PROC_EDITCGRPCVT        (via fill_cgroup_cvt)
      guarantees a cgroup single vector
      representing either a true control
      group hierarchy or "-"

And as was true before, the following remains true:
    PROC_FILLCOM     or
    PROC_FILLARG            (via file2strvec)
      may return a NULL cmdline pointer
  . PROC_FILLCGROUP         (via file2strvec)
      may return a NULL cgroup pointer
  . PROC_FILLCOM     or
    PROC_FILLARG     plus
    PROC_EDITCMDLCVT        (via fill_cmdline_cvt)
      guarantees a cmdline single vector
      representing either a true command
      line or a bracketed program name
  . PROC_FILLSTATUS  plus
    PROC_FILLSUPGRP         (via supgrps_from_supgids)
      guarantees a valid supgrp address
      representing either a true comma
      delimited list or "-"

Signed-off-by: Jim Warner <james.warner@comcast.net>
2012-08-29 17:26:13 +10:00
contrib docs: clarification to license headers in files 2012-03-03 18:41:11 +11:00
Documentation docs: mention linux 3.xx kernels are expected to work 2012-06-02 15:13:18 +10:00
include build-sys: add fileutils.h to dist package 2012-04-18 10:26:20 +02:00
lib lib: add fileutils file with stream error checking facility 2012-03-23 15:57:41 +01:00
misc build-sys: rename the 'tools' subdirectory to 'misc' 2012-03-02 21:25:38 +11:00
po build-sys: use Makevars --add-comments= to limit .pot comments 2011-12-20 17:30:52 +01:00
proc library: standardize handling of cgroup, supgid 2012-08-29 17:26:13 +10:00
ps ps: restore missing space when environment is displayed 2012-08-29 17:24:54 +10:00
testsuite Debian Bug report #526355 2012-08-29 16:47:51 +10:00
top top: ensure /proc is mounted before term is diddled 2012-04-25 15:23:22 +10:00
.gitignore Add -i option to w 2012-05-29 22:20:36 +10:00
AUTHORS other: make AUTHORS file obsolete 2012-01-13 22:42:38 +01:00
autogen.sh Fix a remaining util-linux word in autogen 2012-02-26 08:39:16 +11:00
ChangeLog other: tell in ChangeLog where to see changes 2012-01-13 22:42:38 +01:00
configure.ac build-sys: configure option --enable-skill did not work 2012-05-07 09:01:10 +02:00
COPYING license: update FSF addresses 2012-03-04 08:04:24 +11:00
COPYING.LIB license: update FSF addresses 2012-03-04 08:04:24 +11:00
free.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
free.c Show sizes > 4G correctly in bytes on 32-bit machines. 2012-06-27 06:47:38 +10:00
kill.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
Makefile.am build-sys: earlier patch broke the build 2012-06-24 13:04:03 +02:00
NEWS pkill -u uid fix 2012-06-11 22:30:01 +10:00
pgrep.1 Debian Bug report #526355 2012-08-29 16:47:51 +10:00
pgrep.c Debian Bug report #526355 2012-08-29 16:47:51 +10:00
pkill.1 procps 010114 2002-02-01 22:47:29 +00:00
pmap.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
pmap.c all: check stdout and stderr status at exit 2012-03-23 15:57:53 +01:00
pwdx.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
pwdx.c Fix pwdx argument parsing 2012-06-14 22:33:49 +10:00
README docs: add how to contribute to README 2012-03-03 18:28:52 +11:00
skill.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
skill.c skill: check return value of getline 2012-05-22 20:19:03 +10:00
slabtop.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
slabtop.c all: check stdout and stderr status at exit 2012-03-23 15:57:53 +01:00
snice.1 procps 010114 2002-02-01 22:47:29 +00:00
sysctl.8 sysctl: restore old -p handling 2012-05-07 09:01:10 +02:00
sysctl.c sysctl: avoid crash when -p file has unexpected input 2012-05-07 09:01:10 +02:00
sysctl.conf docs: remove tcp_default_win_scale from sysctl.conf sample 2012-01-24 22:34:12 +01:00
sysctl.conf.5 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
tload.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
tload.c all: check stdout and stderr status at exit 2012-03-23 15:57:53 +01:00
uptime.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
uptime.c all: check stdout and stderr status at exit 2012-03-23 15:57:53 +01:00
vmstat.8 Minor fix with vmstat manpage for r column 2012-05-30 21:41:17 +10:00
vmstat.c vmstat si and so fields zero with -S mM 1 2012-07-28 17:50:00 +10:00
w.1 Add -i option to w 2012-05-29 22:20:36 +10:00
w.c Rework of the -i feature 2012-06-20 22:19:14 +10:00
watch.1 docs: fix manual page warnings 2012-04-16 12:55:53 +02:00
watch.c watch: fix to backporting error, and other wide character issues 2012-05-30 22:03:31 +10:00

COMPATIBILITY

    This code is intended for use with Linux 2.6.xx, 3.x and
    hopefully all future kernels.

INSTALLATION

    If you are using git version of the project you need extra step.

    ./autogen.sh

    After that, and everyone using .tar.xz version of procps-ng, can
    do normal build.  Read './configure --help' to select options for
    your needs.

    ./configure
    make
    make install

    If you have DejaGNU installed you can run optional test suite.

    make check

HOW TO CONTRIBUTE

    See Documentation/BUGS file.

PACKAGING

    If you are a downstream maintainer (packager) for a Linux
    distribution, please avoid causing troubles.  This section
    applies to you.

    Avoid maintaining distribution specific patches.  Send your
    patches to upstream, where they are at least reviewed, if not
    included.

    Please forward bug reports. If your bug database is public and
    busy enough to bother with, please make this known.  Follow
    Debian's lead in making the bug database easy to comment on via
    email without need for an account.

    For normal packages, ensure that you do not add debugging flags
    to the CFLAGS variable.

UPSTREAM & BUG REPORTS

    procps-ng <procps@freelists.org>