Skip to content

Process Widget

The process widget displays a table containing information regarding a running process, along with sorting, searching, and process control features.

A picture of an expanded process widget by default.

Features

The process widget has three main components:

  • The main process table
  • The search sub-widget (opened with Ctrl+f or /)
  • The sort menu sub-widget (opened with s or F6)

By default, the main process table displays the following information for each process:

  • PID
  • Name of the process
  • CPU use percentage (note this is averaged out per available thread by default)
  • Memory use percentage
  • Disk reads per second
  • Disk writes per second
  • Total amount read from disk
  • Total amount written from disk
  • User
  • Process state
  • Process uptime

    Info

    On Windows, the I/O counters will report all reads/writes, not just disk. See here for more details.

With the feature flag (--enable_gpu on Linux/Windows) and gpu process columns enabled in the configuration:

  • GPU memory use percentage
  • GPU core utilization percentage

See the processes configuration page on how to customize which columns are shown.

Sorting

The table can be sorted by clicking on the table headers, which will either sort the table by that column, or if already sorting by that column, reverse the sorting order.

Alternatively, one can sort using the sort menu sub-widget, which is brought up using s or F6, and can be controlled by arrow keys or the mouse.

A picture of an expanded process widget with the sort menu open.

Grouping

Pressing Tab in the table will group entries with the same name together. The PID column will be replaced with the number of entries in each group, and usage is added together when displayed.

A picture of grouped mode in a process widget.

Note that the process state and user columns are disabled in this mode.

Process termination

Pressing d+d or F9 will allow you to terminate the currently selected process/process group. On Unix-like operating systems, you are also able to control which specific signals to send (e.g. SIGKILL, SIGTERM).

A picture of the process kill menu on Linux.
The process termination menu on Linux

If you're on Windows, or if the disable_advanced_kill flag is set in the options or command-line, then a simpler termination screen will be shown to confirm whether you want to kill that process/process group.

A picture of the process kill menu on Windows.
The process termination menu on Windows

Tree mode

Pressing t or F5 in the table toggles tree mode in the process widget, displaying processes in regard to their parent-child process relationships.

A picture of tree mode in a process widget.

A process in tree mode can also be "collapsed", hiding its children and any descendants, using either the - or + keys, or double-clicking on an entry.

Lastly, note that in tree mode, processes cannot be grouped together due to the behaviour of the two modes somewhat clashing.

Full command

You can show the full command instead of just the process name by pressing P.

A picture of a process widget using full commands.

Pressing / or Ctrl+f will open up the search sub-widget. By default, just typing in something will search by the process name.

A picture of searching for a process with a simple search.

This search can be further enhanced by matching by case, matching the entire word, or by regex.

A picture of searching for a process with a search condition that uses regex.

We are able to also search for multiple things/conditions.

A picture of searching for a process with a search condition that uses the or operator.

And if our search uses a keyword, we need to use quotation marks around the term to properly search it.

A picture of searching for a process with a search condition that needs quotation marks.

Lastly, we can refine our search even further based on the other columns, like PID, CPU usage, etc., as well as grouping together conditions.

A picture of searching for a process with a search condition that uses the CPU keyword.

You can also paste search queries (e.g. Shift+Ins, Ctrl+Shift+v).

Keywords

Note all keywords are case-insensitive. To search for a process/command that collides with a keyword, surround the term with quotes (e.x. "cpu").

Keywords Example Description
btm Matches by process or command name; supports regex
pid pid=1044 Matches by PID; supports regex
cpu
cpu%
cpu > 0.5 Matches the CPU column; supports comparison operators
memb memb > 1000 b Matches the memory column in terms of bytes; supports comparison operators
mem
mem%
mem < 0.5 Matches the memory column in terms of percent; supports comparison operators
read
r/s
rps
read = 1 mb Matches the read/s column in terms of bytes; supports comparison operators
write
w/s
wps
write >= 1 kb Matches the write/s column in terms of bytes; supports comparison operators
tread
t.read
tread <= 1024 gb Matches he total read column in terms of bytes; supports comparison operators
twrite
t.write
twrite > 1024 tb Matches the total write column in terms of bytes; supports comparison operators
user user=root Matches by user; supports regex
state state=running Matches by state; supports regex
() (<COND 1> AND <COND 2>) OR <COND 3> Group together a condition
gmem gmem > 1000 b Matches the gpu memory column in terms of bytes; supports comparison operators
gmem% gmem% < 0.5 Matches the gpu memory column in terms of percent; supports comparison operators
gpu% gpu% > 0 Matches the gpu usage column in terms of percent; supports comparison operators

Comparison operators

Keywords Description
= Checks if the values are equal
> Checks if the left value is strictly greater than the right
< Checks if the left value is strictly less than the right
>= Checks if the left value is greater than or equal to the right
<= Checks if the left value is less than or equal to the right

Logical operators

Note all operators are case-insensitive, and the and operator takes precedence over the or operator.

Keywords Usage Description
and
&&
<Space>
<COND 1> and <COND 2>
<COND 1> && <COND 2>
<COND 1> <COND 2>
Requires both conditions to be true to match
or
||
<COND 1> or <COND 2>
<COND 1> &#124;&#124; <COND 2>
Requires at least one condition to be true to match

Units

All units are case-insensitive.

Keywords Description
B Bytes
KB Kilobytes
MB Megabytes
GB Gigabytes
TB Terabytes
KiB Kibibytes
MiB Mebibytes
GiB Gibibytes
TiB Tebibytes

Key bindings

Note that key bindings are generally case-sensitive.

Process table

Binding Action
Up , k Move up within a widget
Down , j Move down within a widget
g+g , Home Jump to the first entry in the table
G , End Jump to the last entry in the table
d+d , F9 Send a kill signal to the selected process
c Sort by CPU usage, press again to reverse sorting order
m Sort by memory usage, press again to reverse sorting order
p Sort by PID name, press again to reverse sorting order
n Sort by process name, press again to reverse sorting order
Tab Toggle grouping processes with the same name
P Toggle between showing the full command or just the process name
Ctrl+f , / Toggle showing the search sub-widget
s , F6 Toggle showing the sort sub-widget
I Invert the current sort
% Toggle between values and percentages for memory usage
t , F5 Toggle tree mode
M Sort by gpu memory usage, press again to reverse sorting order
C Sort by gpu usage, press again to reverse sorting order

Sort sub-widget

Binding Action
Up , k Move up within a widget
Down , j Move down within a widget
g+g , Home Jump to the first entry in the table
G , End Jump to the last entry in the table
Esc Close the sort sub-widget
Enter Sorts the corresponding process table

Search sub-widget

Binding Action
Left
h
Alt+h
Moves the cursor left
Right
l
Alt+l
Moves the cursor right
Esc Close the search widget (retains the filter)
Ctrl+a Skip to the start of the search query
Ctrl+e Skip to the end of the search query
Ctrl+u Clear the current search query
Ctrl+w Delete a word behind the cursor
Ctrl+h Delete the character behind the cursor
Backspace Delete the character behind the cursor
Del Delete the character at the cursor
Alt+c , F1 Toggle matching case
Alt+w , F2 Toggle matching the entire word
Alt+r , F3 Toggle using regex

Mouse bindings

Process table

Binding Action
Scroll Selects a CPU thread/average to show in the graph
Left Button Table header: Sorts/reverse sorts the table by the column
Table entry: Selects an entry in the table, if in tree mode, collapses/expands the entry's children

Sort sub-widget

Binding Action
Left Button Selects an entry in the table