2006-03-04 21:16:49 +03:00
|
|
|
#ifndef HEADER_ProcessList
|
|
|
|
#define HEADER_ProcessList
|
|
|
|
/*
|
2006-06-07 00:28:42 +04:00
|
|
|
htop - ProcessList.h
|
2006-03-24 06:39:04 +03:00
|
|
|
(C) 2004,2005 Hisham H. Muhammad
|
2021-09-22 12:33:00 +03:00
|
|
|
Released under the GNU GPLv2+, see the COPYING file
|
2006-03-04 21:16:49 +03:00
|
|
|
in the source distribution for its full text.
|
|
|
|
*/
|
|
|
|
|
2020-09-19 14:55:23 +03:00
|
|
|
#include "config.h" // IWYU pragma: keep
|
|
|
|
|
2021-08-24 18:27:43 +03:00
|
|
|
#include <limits.h>
|
2020-09-19 14:55:23 +03:00
|
|
|
#include <stdbool.h>
|
2021-04-29 18:12:43 +03:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/time.h>
|
2020-09-19 14:55:23 +03:00
|
|
|
#include <sys/types.h>
|
|
|
|
|
2006-03-04 21:16:49 +03:00
|
|
|
#include "Hashtable.h"
|
2020-09-19 14:55:23 +03:00
|
|
|
#include "Object.h"
|
2011-12-01 16:31:57 +04:00
|
|
|
#include "Panel.h"
|
2011-12-27 01:35:57 +04:00
|
|
|
#include "Process.h"
|
2020-09-19 14:55:23 +03:00
|
|
|
#include "RichString.h"
|
2015-01-22 04:27:31 +03:00
|
|
|
#include "Settings.h"
|
2020-09-18 20:23:04 +03:00
|
|
|
#include "UsersTable.h"
|
|
|
|
#include "Vector.h"
|
2010-08-25 03:20:38 +04:00
|
|
|
|
2016-02-15 00:57:29 +03:00
|
|
|
#ifdef HAVE_LIBHWLOC
|
|
|
|
#include <hwloc.h>
|
|
|
|
#endif
|
|
|
|
|
2020-09-19 14:55:23 +03:00
|
|
|
|
2006-03-04 21:16:49 +03:00
|
|
|
#ifndef MAX_NAME
|
|
|
|
#define MAX_NAME 128
|
|
|
|
#endif
|
|
|
|
|
2006-03-24 06:39:04 +03:00
|
|
|
#ifndef MAX_READ
|
2006-07-11 10:13:32 +04:00
|
|
|
#define MAX_READ 2048
|
2006-03-24 06:39:04 +03:00
|
|
|
#endif
|
|
|
|
|
2021-01-06 20:11:24 +03:00
|
|
|
typedef unsigned long long int memory_t;
|
|
|
|
#define MEMORY_MAX ULLONG_MAX
|
|
|
|
|
2006-03-04 21:16:49 +03:00
|
|
|
typedef struct ProcessList_ {
|
2020-10-21 22:26:09 +03:00
|
|
|
const Settings* settings;
|
2015-01-22 04:27:31 +03:00
|
|
|
|
2021-12-16 19:09:03 +03:00
|
|
|
Vector* processes; /* all known processes; sort order can vary and differ from display order */
|
2021-12-19 14:07:55 +03:00
|
|
|
Vector* displayList; /* process tree flattened in display order (borrowed);
|
|
|
|
updated in ProcessList_updateDisplayList when rebuilding panel */
|
2021-12-16 19:09:03 +03:00
|
|
|
Hashtable* processTable; /* fast known process lookup by PID */
|
2006-03-04 21:16:49 +03:00
|
|
|
UsersTable* usersTable;
|
|
|
|
|
2021-12-16 01:33:32 +03:00
|
|
|
bool needsSort;
|
2020-11-18 14:19:42 +03:00
|
|
|
|
2021-06-23 10:44:56 +03:00
|
|
|
Hashtable* dynamicMeters; /* runtime-discovered meters */
|
PCP: support for 'dynamic columns' added at runtime
Implements support for arbitrary Performance Co-Pilot
metrics with per-process instance domains to form new
htop columns. The column-to-metric mappings are setup
using configuration files which will be documented via
man pages as part of a follow-up commit.
We provide an initial set of column configurations so
as to provide new capabilities to pcp-htop: including
configs for containers, open fd counts, scheduler run
queue time, tcp/udp bytes/calls sent/recv, delay acct,
virtual machine guests, detailed virtual memory, swap.
Note there is a change to the configuration file path
resolution algorithm introduced for 'dynamic meters'.
First, look in any custom PCP_HTOP_DIR location. Then
iterate, in priority order, users home directory, then
local sysadmins files in /etc/pcp/htop, then readonly
configuration files below /usr/share/pcp/htop. This
final location becomes the preferred place for our own
shipped meter and column files.
The Settings file (htoprc) writing code is updated to
not using the numeric identifier for dynamic columns.
The same strategy used for dynamic meters is used here
where we write Dynamic(name) so the name can be setup
once more at start. Regular (static) columns writing
to htoprc - i.e. numerically indexed - is unchanged.
2021-07-11 04:11:29 +03:00
|
|
|
Hashtable* dynamicColumns; /* runtime-discovered Columns */
|
2021-06-23 10:44:56 +03:00
|
|
|
|
2021-03-30 07:55:48 +03:00
|
|
|
struct timeval realtime; /* time of the current sample */
|
|
|
|
uint64_t realtimeMs; /* current time in milliseconds */
|
|
|
|
uint64_t monotonicMs; /* same, but from monotonic clock */
|
2021-03-23 09:27:05 +03:00
|
|
|
|
2011-12-01 16:31:57 +04:00
|
|
|
Panel* panel;
|
2012-02-03 03:45:40 +04:00
|
|
|
int following;
|
2011-12-01 16:31:57 +04:00
|
|
|
uid_t userId;
|
|
|
|
const char* incFilter;
|
2020-09-09 12:38:15 +03:00
|
|
|
Hashtable* pidMatchList;
|
2011-12-01 16:31:57 +04:00
|
|
|
|
2011-11-21 06:52:41 +04:00
|
|
|
#ifdef HAVE_LIBHWLOC
|
2011-09-24 04:30:47 +04:00
|
|
|
hwloc_topology_t topology;
|
|
|
|
bool topologyOk;
|
|
|
|
#endif
|
2015-01-22 04:27:31 +03:00
|
|
|
|
2021-02-17 19:38:35 +03:00
|
|
|
unsigned int totalTasks;
|
|
|
|
unsigned int runningTasks;
|
|
|
|
unsigned int userlandThreads;
|
|
|
|
unsigned int kernelThreads;
|
2015-03-17 05:01:48 +03:00
|
|
|
|
2021-01-06 20:11:24 +03:00
|
|
|
memory_t totalMem;
|
|
|
|
memory_t usedMem;
|
|
|
|
memory_t buffersMem;
|
|
|
|
memory_t cachedMem;
|
2021-03-03 21:48:30 +03:00
|
|
|
memory_t sharedMem;
|
2021-01-06 20:11:24 +03:00
|
|
|
memory_t availableMem;
|
2021-01-07 16:38:18 +03:00
|
|
|
|
2021-01-06 20:11:24 +03:00
|
|
|
memory_t totalSwap;
|
|
|
|
memory_t usedSwap;
|
|
|
|
memory_t cachedSwap;
|
2015-03-16 09:13:42 +03:00
|
|
|
|
2021-06-12 19:17:28 +03:00
|
|
|
unsigned int activeCPUs;
|
|
|
|
unsigned int existingCPUs;
|
2006-03-04 21:16:49 +03:00
|
|
|
} ProcessList;
|
|
|
|
|
2021-06-12 23:04:37 +03:00
|
|
|
/* Implemented by platforms */
|
PCP: support for 'dynamic columns' added at runtime
Implements support for arbitrary Performance Co-Pilot
metrics with per-process instance domains to form new
htop columns. The column-to-metric mappings are setup
using configuration files which will be documented via
man pages as part of a follow-up commit.
We provide an initial set of column configurations so
as to provide new capabilities to pcp-htop: including
configs for containers, open fd counts, scheduler run
queue time, tcp/udp bytes/calls sent/recv, delay acct,
virtual machine guests, detailed virtual memory, swap.
Note there is a change to the configuration file path
resolution algorithm introduced for 'dynamic meters'.
First, look in any custom PCP_HTOP_DIR location. Then
iterate, in priority order, users home directory, then
local sysadmins files in /etc/pcp/htop, then readonly
configuration files below /usr/share/pcp/htop. This
final location becomes the preferred place for our own
shipped meter and column files.
The Settings file (htoprc) writing code is updated to
not using the numeric identifier for dynamic columns.
The same strategy used for dynamic meters is used here
where we write Dynamic(name) so the name can be setup
once more at start. Regular (static) columns writing
to htoprc - i.e. numerically indexed - is unchanged.
2021-07-11 04:11:29 +03:00
|
|
|
ProcessList* ProcessList_new(UsersTable* usersTable, Hashtable* dynamicMeters, Hashtable* dynamicColumns, Hashtable* pidMatchList, uid_t userId);
|
2014-11-27 22:48:38 +03:00
|
|
|
void ProcessList_delete(ProcessList* pl);
|
2020-10-27 23:26:28 +03:00
|
|
|
void ProcessList_goThroughEntries(ProcessList* super, bool pauseProcessUpdate);
|
2021-06-12 23:04:37 +03:00
|
|
|
bool ProcessList_isCPUonline(const ProcessList* super, unsigned int id);
|
2014-11-24 23:55:03 +03:00
|
|
|
|
2011-11-04 02:12:12 +04:00
|
|
|
|
PCP: support for 'dynamic columns' added at runtime
Implements support for arbitrary Performance Co-Pilot
metrics with per-process instance domains to form new
htop columns. The column-to-metric mappings are setup
using configuration files which will be documented via
man pages as part of a follow-up commit.
We provide an initial set of column configurations so
as to provide new capabilities to pcp-htop: including
configs for containers, open fd counts, scheduler run
queue time, tcp/udp bytes/calls sent/recv, delay acct,
virtual machine guests, detailed virtual memory, swap.
Note there is a change to the configuration file path
resolution algorithm introduced for 'dynamic meters'.
First, look in any custom PCP_HTOP_DIR location. Then
iterate, in priority order, users home directory, then
local sysadmins files in /etc/pcp/htop, then readonly
configuration files below /usr/share/pcp/htop. This
final location becomes the preferred place for our own
shipped meter and column files.
The Settings file (htoprc) writing code is updated to
not using the numeric identifier for dynamic columns.
The same strategy used for dynamic meters is used here
where we write Dynamic(name) so the name can be setup
once more at start. Regular (static) columns writing
to htoprc - i.e. numerically indexed - is unchanged.
2021-07-11 04:11:29 +03:00
|
|
|
ProcessList* ProcessList_init(ProcessList* this, const ObjectClass* klass, UsersTable* usersTable, Hashtable* dynamicMeters, Hashtable* dynamicColumns, Hashtable* pidMatchList, uid_t userId);
|
2006-03-04 21:16:49 +03:00
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
void ProcessList_done(ProcessList* this);
|
2006-03-04 21:16:49 +03:00
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
void ProcessList_setPanel(ProcessList* this, Panel* panel);
|
2011-12-01 16:31:57 +04:00
|
|
|
|
2021-01-06 01:42:55 +03:00
|
|
|
void ProcessList_printHeader(const ProcessList* this, RichString* header);
|
2006-03-04 21:16:49 +03:00
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
void ProcessList_add(ProcessList* this, Process* p);
|
2014-11-24 23:55:03 +03:00
|
|
|
|
2021-12-16 19:09:03 +03:00
|
|
|
void ProcessList_updateDisplayList(ProcessList* this);
|
2006-03-04 21:16:49 +03:00
|
|
|
|
2020-11-04 19:46:11 +03:00
|
|
|
ProcessField ProcessList_keyAt(const ProcessList* this, int at);
|
2008-03-14 21:50:49 +03:00
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
void ProcessList_expandTree(ProcessList* this);
|
2010-08-25 03:20:38 +04:00
|
|
|
|
2021-02-12 20:48:09 +03:00
|
|
|
void ProcessList_collapseAllBranches(ProcessList* this);
|
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
void ProcessList_rebuildPanel(ProcessList* this);
|
2011-12-01 16:31:57 +04:00
|
|
|
|
2020-09-02 10:38:44 +03:00
|
|
|
Process* ProcessList_getProcess(ProcessList* this, pid_t pid, bool* preExisting, Process_New constructor);
|
2015-03-17 05:01:48 +03:00
|
|
|
|
2020-10-13 17:03:37 +03:00
|
|
|
void ProcessList_scan(ProcessList* this, bool pauseProcessUpdate);
|
2014-11-24 23:55:03 +03:00
|
|
|
|
2021-03-19 19:34:12 +03:00
|
|
|
static inline Process* ProcessList_findProcess(ProcessList* this, pid_t pid) {
|
|
|
|
return (Process*) Hashtable_get(this->processTable, pid);
|
|
|
|
}
|
|
|
|
|
2006-03-04 21:16:49 +03:00
|
|
|
#endif
|