top: help the '#define PRETEND48CPU' be more realistic

The previous PRETEND8CPUS #define was recently changed
to PRETEND48CPU to better exercise the new '4' and '!'
toggles. But, the implementation simply duplicated the
/proc/stat summary line for each cpu. Therefore, every
cpu showed the same graph/detail (depending upon 't').

This patch shows the actual individual cpu information
(duplicated, of course, when total cpus are exceeded).

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2020-05-30 00:00:00 -05:00 committed by Craig Small
parent f858e563b7
commit f73d8d180f

View File

@ -96,6 +96,9 @@ static CPU_t *Cpu_tics;
static int Cpu_faux_tot; static int Cpu_faux_tot;
static float Cpu_pmax; static float Cpu_pmax;
static const char *Cpu_States_fmts; static const char *Cpu_States_fmts;
#ifdef PRETEND48CPU
static int Cpu_true_tot;
#endif
/* Specific process id monitoring support */ /* Specific process id monitoring support */
static pid_t Monpids [MONPIDMAX+1] = { 0 }; static pid_t Monpids [MONPIDMAX+1] = { 0 };
@ -2553,7 +2556,9 @@ static void cpus_refresh (void) {
for (i = 0; i < sumSLOT; i++) { for (i = 0; i < sumSLOT; i++) {
CPU_t *cpu_ptr = &Cpu_tics[i]; // avoid gcc subscript bloat CPU_t *cpu_ptr = &Cpu_tics[i]; // avoid gcc subscript bloat
#ifdef PRETEND48CPU #ifdef PRETEND48CPU
bp = buf; int j;
if (i == 0) j = 0; else ++j;
if (j >= Cpu_true_tot) { bp = buf; j = 0; }
#endif #endif
bp = 1 + strchr(bp, '\n'); bp = 1 + strchr(bp, '\n');
// remember from last time around // remember from last time around
@ -3650,6 +3655,7 @@ static void before (char *me) {
// establish cpu particulars // establish cpu particulars
cpuinfo(); cpuinfo();
#ifdef PRETEND48CPU #ifdef PRETEND48CPU
Cpu_true_tot = smp_num_cpus;
smp_num_cpus = 48; smp_num_cpus = 48;
#endif #endif
Cpu_States_fmts = N_unq(STATE_lin2x4_fmt); Cpu_States_fmts = N_unq(STATE_lin2x4_fmt);
@ -5975,7 +5981,11 @@ static void summary_show (void) {
// display the node summary, then the associated cpus (if room) // display the node summary, then the associated cpus (if room)
snprintf(tmp, sizeof(tmp), N_fmt(NUMA_nodenam_fmt), Numa_node_sel); snprintf(tmp, sizeof(tmp), N_fmt(NUMA_nodenam_fmt), Numa_node_sel);
Msg_row += cpu_tics(&Cpu_tics[1 + smp_num_cpus + Numa_node_sel], tmp, 1); Msg_row += cpu_tics(&Cpu_tics[1 + smp_num_cpus + Numa_node_sel], tmp, 1);
#ifdef PRETEND48CPU
for (i = 0; i < Cpu_true_tot; i++) {
#else
for (i = 0; i < Cpu_faux_tot; i++) { for (i = 0; i < Cpu_faux_tot; i++) {
#endif
if (Numa_node_sel == Cpu_tics[i].node) { if (Numa_node_sel == Cpu_tics[i].node) {
if (!isROOM(anyFLG, 1)) break; if (!isROOM(anyFLG, 1)) break;
snprintf(tmp, sizeof(tmp), N_fmt(WORD_eachcpu_fmt), Cpu_tics[i].id); snprintf(tmp, sizeof(tmp), N_fmt(WORD_eachcpu_fmt), Cpu_tics[i].id);