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 80e2a7a682 top: eliminate a potential abend when exiting 'A' mode
In that issue cited below, Tyson Nottingham identified
a potential abend which was associated with 'alternate
display mode' plus that troublesome 'mkVIZrow1' macro.
He also offered a perfectly adequate fix for that bug.

I refer to that macro as troublesome since it's now so
widely used and sometimes (by design) causes 'begtask'
to go negative (invalid). And now I found yet one more
place where it should have been used but wasn't ('f').

It's also troublesome as evidenced by some git history
listed below. Heck, there was even a commit addressing
the same symptoms (alternate display mode abend) which
Tyson suffered. Clearly, the current design is flawed.

So, with those two issues in mind, I've refactored the
approach to maintaining a visible task in the 1st row.
Henceforth, a 'mkVIZrow1' macro will be issued in only
two places: once at startup and after most keystrokes.

Such an approach likely results in additional calls to
the 'window_hlp' routine that aren't really necessary.
But, it provides a cleaner design less prone to errors
in the future. Besides, such additional overhead would
only be incurred when interacting with the user. Thus,
new costs are of no concern and will never be noticed.

Reference(s):
. Tyson Nottingham reported problem
https://gitlab.com/procps-ng/procps/-/issues/245
. Jun, 2018 - visible row 1 tasks first addressed
commit 6aedeac667
. Jun, 2018 - adressed edge case, new bugs created
commit 9d59ddc466
. Sep, 2018 - additional edge case addressed
commit 59f02f19c7
. May, 2021 - some abends fixed, new error created
commit 8281ac4f98
. Jun, 2021 - try to prorect against future errors
commit 2ea082b4af
. Sep, 2021 - integrate mkVIZ & 'focused' tasks
commit 69978e3650

Discovered by: Tyson Nottingham
Signed-off-by: Jim Warner <james.warner@comcast.net>
2022-07-27 20:24:54 +10:00
contrib miscellaneous: clean up trailing whitespace once again 2013-04-07 18:05:01 +10:00
doc doc: make the library API pages a little more readable 2022-07-27 20:24:54 +10:00
Documentation library: oh no, failed to right-justify 1 comment line 2021-10-28 07:06:57 +11:00
include c: print strerror() instead of error code. 2021-06-16 20:02:59 +10:00
lib testsuite: shmget returns an int 2022-05-03 19:41:00 +10:00
man-po nls: Update po files 2022-07-18 20:55:01 +10:00
misc build-sys: rename the 'tools' subdirectory to 'misc' 2012-03-02 21:25:38 +11:00
po nls: Update po files 2022-07-18 20:55:01 +10:00
proc library: modify calculation of 'MEMINFO_MEM_USED' item 2022-06-25 11:32:18 +10:00
ps ps: Make STIME entries thread safe 2022-06-30 21:15:37 +10:00
testsuite testsuite shmid can be hex too 2022-05-03 19:37:39 +10:00
top top: eliminate a potential abend when exiting 'A' mode 2022-07-27 20:24:54 +10:00
.gitignore library: Rename to libproc-2 2021-02-20 22:30:31 +11: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 Remove autogen.sh libtool prog check #222. 2021-10-13 20:38:22 +00:00
ChangeLog Changed git site to gitlab 2015-05-10 14:57:50 +10:00
configure.ac build-sys: Give sensible errors if missing pkg-config 2022-05-25 21:08:50 +10:00
COPYING license: update FSF addresses 2012-03-04 08:04:24 +11:00
COPYING.LIB miscellaneous: clean up trailing whitespace once again 2013-04-07 18:05:01 +10:00
create-man-pot.sh misc: Update translations _________________ (catch up) 2018-05-06 07:19:38 +10:00
free.1 doc: Note new Used behavour 2022-06-25 11:42:08 +10:00
free.c free: better error message if meminfo not available 2022-05-31 21:10:18 +10:00
INSTALL.md INSTALL.md: Replace blockquotes with code blocks 2020-04-24 18:56:16 +10:00
kill.1 docs: Minor fix for kill.1 manpage 2022-05-18 21:37:26 +10:00
kill.c kill: use sigqueue to pass value with the signal. 2020-05-11 17:36:12 +10:00
Makefile.am build-sys: Use ncursesw by default 2022-05-21 11:06:57 +10:00
NEWS pgrep: Better warning if pidfd_open not implemented 2022-07-18 20:51:41 +10:00
pgrep.1 pgrep: Better warning if pidfd_open not implemented 2022-07-18 20:51:41 +10:00
pgrep.c pgrep: Better warning if pidfd_open not implemented 2022-07-18 20:51:41 +10:00
pidof.1 Merge branch 'teknoraver/procps-master' 2020-12-22 14:36:09 +11:00
pidof.c Merge branch 'teknoraver/procps-master' 2020-12-22 14:36:09 +11:00
pidwait.1 pidwait: Rename from pwait 2021-02-15 21:55:05 +11:00
pkill.1 procps 010114 2002-02-01 22:47:29 +00:00
pmap.1 docs: some manpage fixes 2020-06-04 22:33:16 +10:00
pmap.c pmap: Don't reopen stdin for reading file 2022-04-26 21:18:03 +10:00
pwdx.1 docs: some manpage fixes 2020-06-04 22:33:16 +10:00
pwdx.c 0021-pwdx: Fix a misleading comment. 2018-06-23 21:59:14 +10:00
README.md misc: Fix typo 2021-10-14 07:57:27 +11:00
skill.1 skill: support namespaces 2013-04-18 13:59:44 -04:00
skill.c all: make buildable again for new 'misc.h' header file 2021-01-21 17:30:25 +11:00
slabtop.1 slabtop: Check for bad d and o option combination 2021-03-11 22:10:37 +11:00
slabtop.c slabtop: Check for bad d and o option combination 2021-03-11 22:10:37 +11:00
snice.1 procps 010114 2002-02-01 22:47:29 +00:00
sysctl.8 sysctl man page update for pattern 2021-05-29 16:20:02 +10:00
sysctl.c sysctl: print dotted keys again 2022-04-09 14:18:28 +10:00
sysctl.conf misc: Add some link examples to sysctl.conf (catch up) 2018-05-06 07:19:38 +10:00
sysctl.conf.5 docs: Add note in sysctl.conf.5 for line length 2021-09-15 21:45:26 +10:00
tload.1 docs: some manpage fixes 2020-06-04 22:33:16 +10:00
tload.c tload: Report on lack of /proc/loadavg 2022-05-31 21:35:40 +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 First cut at subset=pid proc mount handling 2021-12-16 20:36:00 +11:00
vmstat.8 vmstat: use KiB/s for bi/bo instead of blocks/s 2021-11-14 18:48:12 +11:00
vmstat.c First cut at subset=pid proc mount handling 2021-12-16 20:36:00 +11:00
w.1 docs: some manpage fixes 2020-06-04 22:33:16 +10:00
w.c w: responded to those library changes for 'TIME' stuff 2022-02-27 21:27:02 +11:00
watch.1 watch: Add --equexit option 2022-05-18 11:40:25 +00:00
watch.c watch: Add --equexit option 2022-05-18 11:40:25 +00: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 distribution's 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.