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 e9c101edcb library: prefer /proc/stat before /proc/status, <pids>
Long ago, in a galaxy far away (when top was in charge
of library FILL flgs) /proc/status was to be preferred
over /proc/stat if a field could be satisfied by both.

This was done to avoid costly 64-bit math emulation in
a 32-bit application due to 'unsigned long long' data.

Well it's time to acknowledge the prevalence of 64-bit
platforms. And in such an environment the cost picture
has shifted significantly. It now costs 14 times (wow)
as much to access /proc/status compared to /proc/stat.

In other words, even with '%llu' variables, a sscanf()
call in stat2proc() beats the pants off that home brew
gperf based hashing employed by the status2proc() guy.
In fact, status2proc incurs higher costs than found in
the most expensive aspect of top's forest view option.

Here's a gprof extract to illustrate the costs. It was
produced with an rcfile requiring fields from both the
/proc/stat & /proc/status pseudo files (among others).
There were 5000 iterations in each of 4 separate gprof
runs subsequently merged into 1 gmon.sum for analysis.

  %      self              self
 time   seconds    calls  us/call  name
 -----  -------  -------  -------  -----------
 28.65     4.10  4689423     0.87  status2proc
 26.14     3.74    40000    93.50  forest_adds
 ...
 01.96     0.28  4689427     0.06  stat2proc

[ since forest_adds is recursive, the calls value is ]
[ the non-recursive #, its 'call graph' shows totals ]

Anyway, now that such cost is known this patch becomes
what is euphemistically known as the usual no-brainer.

[ jeeze, was it really this long between profilings? ]

Signed-off-by: Jim Warner <james.warner@comcast.net>
2016-08-23 21:11:09 +10:00
contrib
doc misc: eliminated every instance of trailing whitespace 2016-07-09 12:48:28 +10:00
Documentation miscellaneous: remove some trailing whitespace buildup 2015-06-20 07:46:23 +10:00
include tests: update template and add pids 2016-04-19 21:33:02 +10:00
lib misc: Few more resource leak fixes 2016-05-03 21:58:13 +10:00
man-po misc: add simplified chinese manpo to ignore 2016-07-28 20:48:02 +10:00
misc
po free: french translation alignment 2016-08-23 20:46:17 +10:00
proc library: prefer /proc/stat before /proc/status, <pids> 2016-08-23 21:11:09 +10:00
ps ps/output.c: include <dlfcn.h> only when necessary 2016-08-15 21:10:30 +10:00
testsuite testsuite: kill test fails on signal names 2016-04-11 22:12:58 +10:00
top top: minimized default fields requested of our library 2016-08-23 21:11:09 +10:00
.gitignore pgrep: some coverity fixes 2016-04-27 22:50:25 +10:00
.gitlab-ci.yml test: Update gitlab CI YAML to use shared runner 2016-04-20 22:20:55 +10:00
AUTHORS Changed git site to gitlab 2015-05-10 14:57:50 +10:00
autogen.sh
ChangeLog Changed git site to gitlab 2015-05-10 14:57:50 +10:00
configure.ac build sys: update configure.ac for the latest autoscan 2016-07-09 12:48:28 +10:00
COPYING
COPYING.LIB
create-man-pot.sh docs: with systemd now in library, remember openproc.3 2014-07-18 20:49:57 +02:00
free.1 watch,free: interpet intervals in non-locale way 2016-07-03 16:20:48 +10:00
free.c related: change for lost 'PROCPS_' enumerator prefixes 2016-07-26 20:49:44 +10:00
INSTALL.md docs: Updated documentation 2015-05-10 17:23:54 +10:00
kill.1
kill.c kill: Correct pid type 2016-07-02 15:04:22 +10:00
Makefile.am library: provide for validating result type references 2016-08-07 21:40:48 +10:00
NEWS watch,free: interpet intervals in non-locale way 2016-07-03 16:20:48 +10:00
pgrep.1 misc: eliminate accumulated trailing whitespace, again 2016-03-12 14:53:53 +11:00
pgrep.c pgrep: fixup inconsistencies in result type references 2016-08-11 07:56:00 +10:00
pidof.1 pidof: support for omitted %PPID and additional separators 2013-10-14 15:38:33 +02:00
pidof.c related: respond to VAL macro addition of context parm 2016-08-07 21:40:48 +10:00
pkill.1
pmap.1 pmap: Including -p in the man page 2013-11-26 13:45:22 +01:00
pmap.c related: respond to VAL macro addition of context parm 2016-08-07 21:40:48 +10:00
pwdx.1
pwdx.c Handle out of memory conditions. 2015-07-11 21:28:47 +02:00
README.md misc: eliminate accumulated trailing whitespace, again 2016-03-12 14:53:53 +11:00
skill.1
skill.c skill: fixup inconsistencies in result type references 2016-08-11 07:57:55 +10:00
slabtop.1 procps: Add a zero-width break point in slabtop.1 2015-06-01 22:04:40 +10:00
slabtop.c misc: use 'VAL' macros to benefit from type validation 2016-08-16 21:06:18 +10:00
snice.1
sysctl.8 docs: Fix typos in slabtop.1, sysctl.8 and uptime.1 2014-09-16 19:35:28 +02:00
sysctl.c sysctl.c: use strchr() instead of index() 2016-08-15 21:14:23 +10:00
sysctl.conf
sysctl.conf.5 docs: Fix typos in sysctl.8 and sysctl.conf.5 2014-09-15 16:24:59 +02:00
tload.1
tload.c library: cleanup of library includes 2016-04-16 17:03:57 +10:00
translate-man.sh Fixed translate-man.sh for no top ps 2014-05-28 20:12:33 +10:00
uptime.1 docs: Fix typos in slabtop.1, sysctl.8 and uptime.1 2014-09-16 19:35:28 +02:00
uptime.c library: cleanup of library includes 2016-04-16 17:03:57 +10:00
vmstat.8 library: reverting tmpfs subtraction from cached (18-FEB-2014) 2014-04-30 13:59:34 +02:00
vmstat.c misc: use 'VAL' macros to benefit from type validation 2016-08-16 21:06:18 +10:00
w.1 w: correct program help & man page regarding arguments 2015-09-07 18:11:48 +10:00
w.c related: fix inconsistencies in result type references 2016-08-07 21:40:48 +10:00
watch.1 documentation: Update watch man page 2016-07-03 16:20:58 +10:00
watch.c watch: fix process_ansi typo 2016-07-10 07:45:56 +10:00

build status procps

procps is a set of command line and full-screen utilities that provide information out of the pseudo-filesystem most commonly located at /proc. This filesystem provides a simple interface to the kernel data structures. The programs of procps generally concentrate on the structures that describe the processess running on the system.

The following programs are found in procps:

  • free - Report the amount of free and used memory in the system
  • kill - Send a signal to a process based on PID
  • pgrep - List processes based on name or other attributes
  • pkill - Send a signal to a process based on name or other attributes
  • pmap - Report memory map of a process
  • ps - Report information of processes
  • pwdx - Report current directory of a process
  • skill - Obsolete version of pgrep/pkill
  • slabtop - Display kernel slab cache information in real time
  • snice - Renice a process
  • sysctl - Read or Write kernel parameters at run-time
  • tload - Graphical representation of system load average
  • top - Dynamic real-time view of running processes
  • uptime - Display how long the system has been running
  • vmstat - Report virtual memory statistics
  • w - Report logged in users and what they are doing
  • watch - Execute a program periodically, showing output fullscreen

Reporting Bugs

There are a few ways of reporting bugs or feature requests:

  1. Your distributions bug reporter. If you are using a distribution your first port of call is their bug tracker. This is because each distribution has their own patches and way of dealing with bugs. Also bug reporting often does not need any subscription to websites.
  2. GitLab Issues - To the left of this page is the issue tracker. You can report bugs here.
  3. Email list - We have an email list (see below) where you can report bugs. The problem with this method is bug reports often get lost and cannot be tracked. This is especially a big problem when its something that will take time to resolve.

If you need to report bugs, there is more details on the Bug Reporting page.

Email List

The email list for the developers and users of procps is found at http://www.freelists.org/archive/procps/ This email list discusses the development of procps and is used by distributions to also forward or discuss bugs.