top: exploit those new library task/threads provisions
This patch adapts top to exploit the new <proc/pids.h> interface. And it appears to have reduced top's weight by a considerable margin. Gone were the sort callbacks and manipulation of those library flags. Gosh, all top needs to do now is track some enumerators of interest. [ whoa, wait just a damn minute. it now appears some ] [ that weight loss was solely the result of a theft. ] [ jeeze, we turn our back for just a minute & newlib ] [ up & steals our pids hashing logic for his history ] [ needs. oh well, i guess life's just not that fair. ] Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
7e6a371d8a
commit
77dc22b910
65
top/top.h
65
top/top.h
@ -20,6 +20,8 @@
|
|||||||
#ifndef _Itop
|
#ifndef _Itop
|
||||||
#define _Itop
|
#define _Itop
|
||||||
|
|
||||||
|
#include <proc/pids.h>
|
||||||
|
#include <proc/readstat.h>
|
||||||
#include "../proc/readproc.h"
|
#include "../proc/readproc.h"
|
||||||
|
|
||||||
/* Defines represented in configure.ac ----------------------------- */
|
/* Defines represented in configure.ac ----------------------------- */
|
||||||
@ -31,7 +33,6 @@
|
|||||||
//#define SIGNALS_LESS /* favor reduced signal load over response */
|
//#define SIGNALS_LESS /* favor reduced signal load over response */
|
||||||
|
|
||||||
/* Development/Debugging defines ----------------------------------- */
|
/* Development/Debugging defines ----------------------------------- */
|
||||||
//#define ATEOJ_RPTHSH /* report on hash specifics, at end-of-job */
|
|
||||||
//#define ATEOJ_RPTSTD /* report on misc stuff, at end-of-job */
|
//#define ATEOJ_RPTSTD /* report on misc stuff, at end-of-job */
|
||||||
//#define CASEUP_HEXES /* show any hex values in upper case */
|
//#define CASEUP_HEXES /* show any hex values in upper case */
|
||||||
//#define CASEUP_SUFIX /* show time/mem/cnts suffix in upper case */
|
//#define CASEUP_SUFIX /* show time/mem/cnts suffix in upper case */
|
||||||
@ -41,7 +42,6 @@
|
|||||||
//#define INSP_SAVEBUF /* preserve 'Insp_buf' contents in a file */
|
//#define INSP_SAVEBUF /* preserve 'Insp_buf' contents in a file */
|
||||||
//#define INSP_SLIDE_1 /* when scrolling left/right don't move 8 */
|
//#define INSP_SLIDE_1 /* when scrolling left/right don't move 8 */
|
||||||
//#define MEMGRAPH_OLD /* don't use 'available' when graphing Mem */
|
//#define MEMGRAPH_OLD /* don't use 'available' when graphing Mem */
|
||||||
//#define OFF_HST_HASH /* use BOTH qsort+bsrch vs. hashing scheme */
|
|
||||||
//#define OFF_NUMASKIP /* do NOT skip numa nodes if discontinuous */
|
//#define OFF_NUMASKIP /* do NOT skip numa nodes if discontinuous */
|
||||||
//#define OFF_SCROLLBK /* disable tty emulators scrollback buffer */
|
//#define OFF_SCROLLBK /* disable tty emulators scrollback buffer */
|
||||||
//#define OFF_STDERROR /* disable our stderr buffering (redirect) */
|
//#define OFF_STDERROR /* disable our stderr buffering (redirect) */
|
||||||
@ -223,39 +223,6 @@ typedef long long SIC_t;
|
|||||||
/* Sort support, callback function signature */
|
/* Sort support, callback function signature */
|
||||||
typedef int (*QFP_t)(const void *, const void *);
|
typedef int (*QFP_t)(const void *, const void *);
|
||||||
|
|
||||||
/* This structure consolidates the information that's used
|
|
||||||
in a variety of display roles. */
|
|
||||||
typedef struct FLD_t {
|
|
||||||
int width; // field width, if applicable
|
|
||||||
int scale; // scaled target, if applicable
|
|
||||||
const int align; // the default column alignment flag
|
|
||||||
const QFP_t sort; // sort function
|
|
||||||
const int lflg; // PROC_FILLxxx flag(s) needed by this field
|
|
||||||
} FLD_t;
|
|
||||||
|
|
||||||
#ifdef OFF_HST_HASH
|
|
||||||
/* This structure supports 'history' processing and records the
|
|
||||||
bare minimum of needed information from one frame to the next --
|
|
||||||
we don't calc and save data that goes unused like the old top. */
|
|
||||||
typedef struct HST_t {
|
|
||||||
TIC_t tics; // last frame's tics count
|
|
||||||
unsigned long maj, min; // last frame's maj/min_flt counts
|
|
||||||
int pid; // record 'key'
|
|
||||||
} HST_t;
|
|
||||||
#else
|
|
||||||
/* This structure supports 'history' processing and records the bare
|
|
||||||
minimum of needed information from one frame to the next -- we do
|
|
||||||
not calc and save data that goes unused like the old top nor will
|
|
||||||
we incur the additional overhead of sort to support binary search
|
|
||||||
(or worse, a friggin' for loop) when retrievals become necessary! */
|
|
||||||
typedef struct HST_t {
|
|
||||||
TIC_t tics; // last frame's tics count
|
|
||||||
unsigned long maj, min; // last frame's maj/min_flt counts
|
|
||||||
int pid; // record 'key'
|
|
||||||
int lnk; // next on hash chain
|
|
||||||
} HST_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* /////////////////////////////////////////////////////////////// */
|
/* /////////////////////////////////////////////////////////////// */
|
||||||
/* Special Section: multiple windows/field groups --------------- */
|
/* Special Section: multiple windows/field groups --------------- */
|
||||||
/* ( kind of a header within a header: constants, types & macros ) */
|
/* ( kind of a header within a header: constants, types & macros ) */
|
||||||
@ -397,7 +364,7 @@ typedef struct WIN_t {
|
|||||||
char *osel_prt; // other stuff printable as status line
|
char *osel_prt; // other stuff printable as status line
|
||||||
char *findstr; // window's current/active search string
|
char *findstr; // window's current/active search string
|
||||||
int findlen; // above's strlen, without call overhead
|
int findlen; // above's strlen, without call overhead
|
||||||
proc_t **ppt; // this window's proc_t ptr array
|
struct pids_stack **ppt; // this window's stacks ptr array
|
||||||
struct WIN_t *next, // next window in window stack
|
struct WIN_t *next, // next window in window stack
|
||||||
*prev; // prior window in window stack
|
*prev; // prior window in window stack
|
||||||
} WIN_t;
|
} WIN_t;
|
||||||
@ -606,9 +573,6 @@ typedef struct WIN_t {
|
|||||||
/*###### For Piece of mind #############################################*/
|
/*###### For Piece of mind #############################################*/
|
||||||
|
|
||||||
/* just sanity check(s)... */
|
/* just sanity check(s)... */
|
||||||
#if defined(ATEOJ_RPTHSH) && defined(OFF_HST_HASH)
|
|
||||||
# error 'ATEOJ_RPTHSH' conflicts with 'OFF_HST_HASH'
|
|
||||||
#endif
|
|
||||||
#if defined(RECALL_FIXED) && defined(TERMIOS_ONLY)
|
#if defined(RECALL_FIXED) && defined(TERMIOS_ONLY)
|
||||||
# error 'RECALL_FIXED' conflicts with 'TERMIOS_ONLY'
|
# error 'RECALL_FIXED' conflicts with 'TERMIOS_ONLY'
|
||||||
#endif
|
#endif
|
||||||
@ -633,9 +597,6 @@ typedef struct WIN_t {
|
|||||||
|
|
||||||
/* These 'prototypes' are here exclusively for documentation purposes. */
|
/* These 'prototypes' are here exclusively for documentation purposes. */
|
||||||
/* ( see the find_string function for the one true required protoype ) */
|
/* ( see the find_string function for the one true required protoype ) */
|
||||||
/*------ Sort callbacks ------------------------------------------------*/
|
|
||||||
/* for each possible field, in the form of: */
|
|
||||||
/*atic int sort_EU_XXX (const proc_t **P, const proc_t **Q); */
|
|
||||||
/*------ Tiny useful routine(s) ----------------------------------------*/
|
/*------ Tiny useful routine(s) ----------------------------------------*/
|
||||||
//atic const char *fmtmk (const char *fmts, ...);
|
//atic const char *fmtmk (const char *fmts, ...);
|
||||||
//atic inline char *scat (char *dst, const char *src);
|
//atic inline char *scat (char *dst, const char *src);
|
||||||
@ -672,7 +633,6 @@ typedef struct WIN_t {
|
|||||||
//atic void osel_clear (WIN_t *q);
|
//atic void osel_clear (WIN_t *q);
|
||||||
//atic inline int osel_matched (const WIN_t *q, FLG_t enu, const char *str);
|
//atic inline int osel_matched (const WIN_t *q, FLG_t enu, const char *str);
|
||||||
//atic const char *user_certify (WIN_t *q, const char *str, char typ);
|
//atic const char *user_certify (WIN_t *q, const char *str, char typ);
|
||||||
//atic inline int user_matched (const WIN_t *q, const proc_t *p);
|
|
||||||
/*------ Basic Formatting support --------------------------------------*/
|
/*------ Basic Formatting support --------------------------------------*/
|
||||||
//atic inline const char *justify_pad (const char *str, int width, int justr);
|
//atic inline const char *justify_pad (const char *str, int width, int justr);
|
||||||
//atic inline const char *make_chr (const char ch, int width, int justr);
|
//atic inline const char *make_chr (const char ch, int width, int justr);
|
||||||
@ -693,13 +653,6 @@ typedef struct WIN_t {
|
|||||||
//atic void zap_fieldstab (void);
|
//atic void zap_fieldstab (void);
|
||||||
/*------ Library Interface ---------------------------------------------*/
|
/*------ Library Interface ---------------------------------------------*/
|
||||||
//atic void cpus_refresh (void);
|
//atic void cpus_refresh (void);
|
||||||
#ifdef OFF_HST_HASH
|
|
||||||
//atic inline HST_t *hstbsrch (HST_t *hst, int max, int pid);
|
|
||||||
#else
|
|
||||||
//atic inline HST_t *hstget (int pid);
|
|
||||||
//atic inline void hstput (unsigned idx);
|
|
||||||
#endif
|
|
||||||
//atic void procs_hlp (proc_t *p);
|
|
||||||
//atic void procs_refresh (void);
|
//atic void procs_refresh (void);
|
||||||
//atic void sysinfo_refresh (int forced);
|
//atic void sysinfo_refresh (int forced);
|
||||||
/*------ Inspect Other Output ------------------------------------------*/
|
/*------ Inspect Other Output ------------------------------------------*/
|
||||||
@ -713,7 +666,7 @@ typedef struct WIN_t {
|
|||||||
//atic void insp_find_str (int ch, int *col, int *row);
|
//atic void insp_find_str (int ch, int *col, int *row);
|
||||||
//atic inline void insp_make_row (int col, int row);
|
//atic inline void insp_make_row (int col, int row);
|
||||||
//atic void insp_show_pgs (int col, int row, int max);
|
//atic void insp_show_pgs (int col, int row, int max);
|
||||||
//atic int insp_view_choice (proc_t *obj);
|
//atic int insp_view_choice (struct pids_stack *obj);
|
||||||
//atic void inspection_utility (int pid);
|
//atic void inspection_utility (int pid);
|
||||||
/*------ Startup routines ----------------------------------------------*/
|
/*------ Startup routines ----------------------------------------------*/
|
||||||
//atic void before (char *me);
|
//atic void before (char *me);
|
||||||
@ -731,6 +684,7 @@ typedef struct WIN_t {
|
|||||||
//atic void wins_reflag (int what, int flg);
|
//atic void wins_reflag (int what, int flg);
|
||||||
//atic void wins_stage_1 (void);
|
//atic void wins_stage_1 (void);
|
||||||
//atic void wins_stage_2 (void);
|
//atic void wins_stage_2 (void);
|
||||||
|
//atic inline int wins_usrselect (const WIN_t *q, struct pids_stack *p);
|
||||||
/*------ Interactive Input Tertiary support ----------------------------*/
|
/*------ Interactive Input Tertiary support ----------------------------*/
|
||||||
//atic inline int find_ofs (const WIN_t *q, const char *buf);
|
//atic inline int find_ofs (const WIN_t *q, const char *buf);
|
||||||
//atic void find_string (int ch);
|
//atic void find_string (int ch);
|
||||||
@ -745,16 +699,13 @@ typedef struct WIN_t {
|
|||||||
//atic void keys_xtra (int ch);
|
//atic void keys_xtra (int ch);
|
||||||
/*------ Forest View support -------------------------------------------*/
|
/*------ Forest View support -------------------------------------------*/
|
||||||
//atic void forest_adds (const int self, int level);
|
//atic void forest_adds (const int self, int level);
|
||||||
#ifndef TREE_SCANALL
|
|
||||||
//atic int forest_based (const proc_t **x, const proc_t **y);
|
|
||||||
#endif
|
|
||||||
//atic void forest_create (WIN_t *q);
|
//atic void forest_create (WIN_t *q);
|
||||||
//atic inline const char *forest_display (const WIN_t *q, const proc_t *p);
|
//atic inline const char *forest_display (const WIN_t *q, const int idx);
|
||||||
/*------ Main Screen routines ------------------------------------------*/
|
/*------ Main Screen routines ------------------------------------------*/
|
||||||
//atic void do_key (int ch);
|
//atic void do_key (int ch);
|
||||||
//atic void summary_hlp (CPU_t *cpu, const char *pfx);
|
//atic void summary_hlp (struct procps_jiffs_hist *cpu, const char *pfx);
|
||||||
//atic void summary_show (void);
|
//atic void summary_show (void);
|
||||||
//atic const char *task_show (const WIN_t *q, const proc_t *p);
|
//atic const char *task_show (const WIN_t *q, const int idx);
|
||||||
//atic int window_show (WIN_t *q, int wmax);
|
//atic int window_show (WIN_t *q, int wmax);
|
||||||
/*------ Entry point plus two ------------------------------------------*/
|
/*------ Entry point plus two ------------------------------------------*/
|
||||||
//atic void frame_hlp (int wix, int max);
|
//atic void frame_hlp (int wix, int max);
|
||||||
|
@ -470,8 +470,9 @@ static void build_norm_nlstab (void) {
|
|||||||
. padding with extra spaces as necessary */
|
. padding with extra spaces as necessary */
|
||||||
Norm_nlstab[WORD_abv_mem_txt] = _("Mem ");
|
Norm_nlstab[WORD_abv_mem_txt] = _("Mem ");
|
||||||
Norm_nlstab[WORD_abv_swp_txt] = _("Swap");
|
Norm_nlstab[WORD_abv_swp_txt] = _("Swap");
|
||||||
Norm_nlstab[LIB_errormem_txt] = _("library failed memory statistics");
|
Norm_nlstab[LIB_errormem_fmt] = _("library failed memory statistics, at %d");
|
||||||
Norm_nlstab[LIB_errorcpu_txt] = _("library failed cpu statistics");
|
Norm_nlstab[LIB_errorcpu_fmt] = _("library failed cpu statistics, at %d");
|
||||||
|
Norm_nlstab[LIB_errorpid_fmt] = _("library failed pids statistics, at %d");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -73,18 +73,18 @@ enum norm_nls {
|
|||||||
FAIL_widepid_txt, FIND_no_find_fmt, FIND_no_next_txt, FOREST_modes_fmt,
|
FAIL_widepid_txt, FIND_no_find_fmt, FIND_no_next_txt, FOREST_modes_fmt,
|
||||||
FOREST_views_txt, GET_find_str_txt, GET_max_task_fmt, GET_nice_num_fmt,
|
FOREST_views_txt, GET_find_str_txt, GET_max_task_fmt, GET_nice_num_fmt,
|
||||||
GET_pid2kill_fmt, GET_pid2nice_fmt, GET_sigs_num_fmt, GET_user_ids_txt,
|
GET_pid2kill_fmt, GET_pid2nice_fmt, GET_sigs_num_fmt, GET_user_ids_txt,
|
||||||
HELP_cmdline_fmt, IRIX_curmode_fmt, LIB_errorcpu_txt, LIB_errormem_txt,
|
HELP_cmdline_fmt, IRIX_curmode_fmt, LIB_errorcpu_fmt, LIB_errormem_fmt,
|
||||||
LIMIT_exceed_fmt, MISSING_args_fmt, NAME_windows_fmt, NOT_onsecure_txt,
|
LIB_errorpid_fmt, LIMIT_exceed_fmt, MISSING_args_fmt, NAME_windows_fmt,
|
||||||
NOT_smp_cpus_txt, NUMA_nodebad_txt, NUMA_nodeget_fmt, NUMA_nodenam_fmt,
|
NOT_onsecure_txt, NOT_smp_cpus_txt, NUMA_nodebad_txt, NUMA_nodeget_fmt,
|
||||||
NUMA_nodenot_txt, OFF_one_word_txt, ON_word_only_txt, OSEL_casenot_txt,
|
NUMA_nodenam_fmt, NUMA_nodenot_txt, OFF_one_word_txt, ON_word_only_txt,
|
||||||
OSEL_caseyes_txt, OSEL_errdelm_fmt, OSEL_errdups_txt, OSEL_errvalu_fmt,
|
OSEL_casenot_txt, OSEL_caseyes_txt, OSEL_errdelm_fmt, OSEL_errdups_txt,
|
||||||
OSEL_prompts_fmt, OSEL_statlin_fmt, RC_bad_entry_fmt, RC_bad_files_fmt,
|
OSEL_errvalu_fmt, OSEL_prompts_fmt, OSEL_statlin_fmt, RC_bad_entry_fmt,
|
||||||
SCROLL_coord_fmt, SELECT_clash_txt, THREADS_show_fmt, TIME_accumed_fmt,
|
RC_bad_files_fmt, SCROLL_coord_fmt, SELECT_clash_txt, THREADS_show_fmt,
|
||||||
UNKNOWN_cmds_txt, UNKNOWN_opts_fmt, USAGE_abbrev_txt, WORD_abv_mem_txt,
|
TIME_accumed_fmt, UNKNOWN_cmds_txt, UNKNOWN_opts_fmt, USAGE_abbrev_txt,
|
||||||
WORD_abv_swp_txt, WORD_allcpus_txt, WORD_another_txt, WORD_eachcpu_fmt,
|
WORD_abv_mem_txt, WORD_abv_swp_txt, WORD_allcpus_txt, WORD_another_txt,
|
||||||
WORD_exclude_txt, WORD_include_txt, WORD_noneone_txt, WORD_process_txt,
|
WORD_eachcpu_fmt, WORD_exclude_txt, WORD_include_txt, WORD_noneone_txt,
|
||||||
WORD_threads_txt, WRITE_rcfile_fmt, WRONG_switch_fmt, XTRA_badflds_fmt,
|
WORD_process_txt, WORD_threads_txt, WRITE_rcfile_fmt, WRONG_switch_fmt,
|
||||||
XTRA_fixwide_fmt, XTRA_warncfg_txt, XTRA_winsize_txt,
|
XTRA_badflds_fmt, XTRA_fixwide_fmt, XTRA_warncfg_txt, XTRA_winsize_txt,
|
||||||
#ifndef INSP_OFFDEMO
|
#ifndef INSP_OFFDEMO
|
||||||
YINSP_demo01_txt, YINSP_demo02_txt, YINSP_demo03_txt, YINSP_deqfmt_txt,
|
YINSP_demo01_txt, YINSP_demo02_txt, YINSP_demo03_txt, YINSP_deqfmt_txt,
|
||||||
YINSP_deqtyp_txt, YINSP_dstory_txt,
|
YINSP_deqtyp_txt, YINSP_dstory_txt,
|
||||||
|
Loading…
Reference in New Issue
Block a user