From: Jim Warner Date: Fri, 31 Jul 2015 05:00:00 +0000 (-0500) Subject: top: avoid an unnecessary conversion for 'USED' column X-Git-Tag: v3.3.11~11 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8226ca983856d2d023dc52e5d56ec92552b5bf18;p=procps-ng top: avoid an unnecessary conversion for 'USED' column When the USED column was introduced the proc_t.vm_swap & proc_t.resident values were added together. However, using 'resident' required an additional PROC_FILL flag not to mention extra conversion of pages to kibibytes. So now we'll use an already present vm_rss value which removes any special handling for top's derived column. And while we're at it we'll trade some more 'resident' field uses with that more immediately usable 'vm_rss'. Reference(s): commit 709785e20bd19dc28546d19c45bb7444a56f88b9 Signed-off-by: Jim Warner --- diff --git a/top/top.c b/top/top.c index 3c4f3f2c..5686c136 100644 --- a/top/top.c +++ b/top/top.c @@ -283,7 +283,7 @@ SCB_NUMx(PGD, pgrp) SCB_NUMx(PID, tid) SCB_NUMx(PPD, ppid) SCB_NUMx(PRI, priority) -SCB_NUM1(RES, resident) // also serves MEM ! +SCB_NUM1(RES, vm_rss) // also serves MEM ! SCB_STRX(SGD, supgid) SCB_STRS(SGN, supgrp) SCB_NUM1(SHR, share) @@ -316,7 +316,7 @@ SCB_STRS(UEN, euser) SCB_NUMx(URD, ruid) SCB_STRS(URN, ruser) SCB_NUMx(USD, suid) -SCB_NUM2(USE, resident, vm_swap) +SCB_NUM2(USE, vm_rss, vm_swap) SCB_STRS(USN, suser) SCB_NUM1(VRT, size) SCB_NUM1(WCH, wchan) @@ -1689,7 +1689,6 @@ end_justifies: #define L_OUSER PROC_FILLSTATUS | PROC_FILLUSR #define L_EGROUP PROC_FILLSTATUS | PROC_FILLGRP #define L_SUPGRP PROC_FILLSTATUS | PROC_FILLSUPGRP -#define L_USED PROC_FILLSTATUS | PROC_FILLMEM #define L_NS PROC_FILLNS #define L_LXC PROC_FILL_LXC // make 'none' non-zero (used to be important to Frames_libflags) @@ -1742,21 +1741,21 @@ static FLD_t Fieldstab[] = { { 6, -1, A_right, SF(TME), L_stat }, { 9, -1, A_right, SF(TME), L_stat }, // EU_TM2 slot #ifdef BOOST_PERCNT - { 5, -1, A_right, SF(RES), L_statm }, // EU_MEM slot + { 5, -1, A_right, SF(RES), L_status }, // EU_MEM slot #else - { 4, -1, A_right, SF(RES), L_statm }, // EU_MEM slot + { 4, -1, A_right, SF(RES), L_status }, // EU_MEM slot #endif #ifndef NOBOOST_MEMS { 7, SK_Kb, A_right, SF(VRT), L_statm }, { 6, SK_Kb, A_right, SF(SWP), L_status }, - { 6, SK_Kb, A_right, SF(RES), L_statm }, + { 6, SK_Kb, A_right, SF(RES), L_status }, { 6, SK_Kb, A_right, SF(COD), L_statm }, { 7, SK_Kb, A_right, SF(DAT), L_statm }, { 6, SK_Kb, A_right, SF(SHR), L_statm }, #else { 5, SK_Kb, A_right, SF(VRT), L_statm }, { 4, SK_Kb, A_right, SF(SWP), L_status }, - { 4, SK_Kb, A_right, SF(RES), L_statm }, + { 4, SK_Kb, A_right, SF(RES), L_status }, { 4, SK_Kb, A_right, SF(COD), L_statm }, { 5, SK_Kb, A_right, SF(DAT), L_statm }, { 4, SK_Kb, A_right, SF(SHR), L_statm }, @@ -1782,9 +1781,9 @@ static FLD_t Fieldstab[] = { { 3, -1, A_right, SF(FV1), L_stat }, { 3, -1, A_right, SF(FV2), L_stat }, #ifndef NOBOOST_MEMS - { 6, SK_Kb, A_right, SF(USE), L_USED }, + { 6, SK_Kb, A_right, SF(USE), L_status }, #else - { 4, SK_Kb, A_right, SF(USE), L_USED }, + { 4, SK_Kb, A_right, SF(USE), L_status }, #endif { 10, -1, A_right, SF(NS1), L_NS }, // IPCNS { 10, -1, A_right, SF(NS2), L_NS }, // MNTNS @@ -5393,7 +5392,7 @@ static const char *task_show (const WIN_t *q, const proc_t *p) { cp = make_str(p->lxcname, W, Js, EU_LXC); break; case EU_MEM: - cp = scale_pcnt((float)pages2K(p->resident) * 100 / kb_main_total, W, Jn); + cp = scale_pcnt((float)p->vm_rss * 100 / kb_main_total, W, Jn); break; case EU_NCE: cp = make_num(p->nice, W, Jn, AUTOX_NO); @@ -5433,7 +5432,7 @@ static const char *task_show (const WIN_t *q, const proc_t *p) { cp = make_num(p->priority, W, Jn, AUTOX_NO); break; case EU_RES: - cp = scale_mem(S, pages2K(p->resident), W, Jn); + cp = scale_mem(S, p->vm_rss, W, Jn); break; case EU_SGD: makeVAR(p->supgid); @@ -5491,7 +5490,7 @@ static const char *task_show (const WIN_t *q, const proc_t *p) { cp = make_num(p->suid, W, Jn, EU_USD); break; case EU_USE: - cp = scale_mem(S, (p->vm_swap + pages2K(p->resident)), W, Jn); + cp = scale_mem(S, (p->vm_swap + p->vm_rss), W, Jn); break; case EU_USN: cp = make_str(p->suser, W, Js, EU_USN);