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 3da7318683 top: parent total cpu includes collapsed children, pgm
Now, when a parent's children have been collapsed, the
cpu used by those unseen tasks will disappear no more.
Instead such tics will be added to the parent's total.

[ if one wished a return to the 'land of lost tics', ]
[ the '#define TREE_VCPUOFF' directive is available. ]

------------------------------------------------------
Note: With collapsible parents now displaying children
cpu usage, it will eventually be noticed the cpu stats
for the summary area and task areas often vary widely.

It's worth a reminder that for top's summary area each
individual cpu and the cpu summary is limited to 100%,
regardless of how many tics a linux kernel may export.

An individual task is limited to 100% times the number
of threads. But, in no case will cpu usage ever exceed
100% times total number of processors. Such limits are
further reduced under 'Solaris' mode ('I' toggle off).
In this mode, a task cpu usage will never exceed 100%.
These limits will now also apply to collapsed parents.

In addition to those influences, results are subjected
to kernel timer sampling anomalies and the distortions
inherent in a small sample size, made worse by smaller
delay intervals. Often there is just 1 or 2 tics for a
few tasks at smaller intervals such as: 1/10th second.

Anyway, should questions on this subject arise, a good
starting point, beyond the reminders above, is the 1st
link listed below. Those other links were derivatives.

Reference(s):
. from the kernel documentation
https://www.kernel.org/doc/Documentation/cpu-load.txt
. as mentioned in the above kernel documentation
https://lkml.org/lkml/2007/2/12/6
. from above, with many more links on the subject
https://www.boblycat.org/~malc/apc/

Signed-off-by: Jim Warner <james.warner@comcast.net>

top: parent total cpu includes collapsed children, pgm
2018-07-17 21:00:51 +10:00
contrib
Documentation miscellaneous: remove some trailing whitespace buildup 2015-06-20 07:46:23 +10:00
include misc: fix strtod_nol_err tests 2016-07-13 20:08:51 +10:00
lib misc: fix strtod_nol_err tests 2016-07-13 20:08:51 +10:00
man-po misc: Tell po4a to handle email macros 2018-06-07 21:52:46 +10:00
misc
po update translations 2018-04-10 21:37:39 +10:00
proc library: tweak that change to 'supgrps_from_supgids()' 2018-06-07 21:35:59 +10:00
ps docs: Tidying of ps,kill and skill manpages 2018-05-31 21:18:27 +10:00
testsuite testsuite: Remove pgrep ?15 char test 2018-05-19 21:50:21 +10:00
top top: parent total cpu includes collapsed children, pgm 2018-07-17 21:00:51 +10:00
.gitignore misc: add asc sign files to ignore 2018-05-31 20:28:20 +10:00
.gitlab-ci.yml added gettext to dependency 2016-04-20 22:15:27 +10:00
AUTHORS
autogen.sh
ChangeLog
configure.ac Add support for elogind 2017-12-29 15:57:14 +11:00
COPYING
COPYING.LIB
create-man-pot.sh misc: Update translations 2018-03-12 14:24:49 +11:00
free.1 docs: use correct units in free.1 2018-05-31 20:34:13 +10:00
free.c free: fix scaling on 32-bit systems 2018-04-10 21:20:25 +10:00
INSTALL.md
kill.1 docs: Tidying of ps,kill and skill manpages 2018-05-31 21:18:27 +10:00
Makefile.am library: Bump API to 8:0:1 2018-05-20 07:35:37 +10:00
NEWS top: allow collapsible forest view children, documents 2018-06-23 22:03:57 +10:00
pgrep.1 docs: Update pgrep.1 example to more modern browser 2017-12-22 14:56:08 +11:00
pgrep.c pgrep: Remove >15 warning 2018-05-19 08:14:06 +10:00
pidof.1 docs: Note limitation of finding scripts in pidof.1 2018-03-03 18:47:22 +11:00
pidof.c pidof: Prevent integer overflows with grow_size(). 2018-05-19 07:32:21 +10:00
pkill.1
pmap.1
pmap.c pmap: Fix extended mode in one_proc(). 2018-05-19 07:32:22 +10:00
procio.c library: build on non-glibc systems 2018-04-10 21:28:11 +10:00
pwdx.1
pwdx.c pwdx: Fix a misleading comment. 2018-05-19 07:32:21 +10:00
README.md misc: Remove build badge 2018-06-23 22:51:12 +10:00
skill.1 docs: Tidying of ps,kill and skill manpages 2018-05-31 21:18:27 +10:00
skill.c skill: Do not scan past the null-terminator in check_proc(). 2018-05-19 07:32:21 +10:00
slabtop.1
slabtop.c slabtop: Reset slab_list if get_slabinfo() fails. 2018-05-19 07:32:21 +10:00
snice.1
sysctl.8 docs: sysctl.8 clarify when w flag is required 2018-02-19 21:05:42 +11:00
sysctl.c sysctl: fixup build system 2018-03-12 13:06:08 +11:00
sysctl.conf misc: Add link protection examples to sysctl.conf 2018-03-03 18:56:20 +11:00
sysctl.conf.5 misc: remove some newly introduced trailing whitespace 2016-09-26 07:41:04 +10:00
tload.1
tload.c tload: Prevent integer overflows of ncols, nrows, and scr_size. 2018-05-19 07:32:21 +10:00
translate-man.sh
uptime.1
uptime.c uptime: Check the return value of various functions. 2018-05-19 07:32:21 +10:00
vmstat.8 Fix error in vmstat documentation. 2018-06-23 22:15:33 +10:00
vmstat.c vmstat: Prevent out-of-bounds writes in new_header() and diskheader(). 2018-06-13 22:06:51 +10:00
w.1
w.c w: Clamp maxcmd to the MIN/MAX_CMD_WIDTH range. 2018-06-13 22:05:18 +10:00
watch.1 docs: Reword --exec option in watch.1 2018-03-03 18:26:47 +11:00
watch.c watch: use sysconf() for hostname length 2018-03-03 18:36:44 +11:00

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.