Blame SOURCES/procps-ng-3.3.10-top-strange-mem-val-scaling.patch

ea316c
diff -up ./configure.ac.ori ./configure.ac
ea316c
--- ./configure.ac.ori	2014-09-23 13:40:36.000000000 +0200
ea316c
+++ ./configure.ac	2017-08-02 13:04:25.439881501 +0200
ea316c
@@ -218,11 +218,11 @@ if test "x$enable_wide_percent" = xyes;
ea316c
 fi
ea316c
 
ea316c
 AC_ARG_ENABLE([wide-memory],
ea316c
-  AS_HELP_STRING([--disable-wide-memory], [disable extra precision under memory fields for top]),
ea316c
-  [], [enable_wide_memory=yes]
ea316c
+  AS_HELP_STRING([--enable-wide-memory], [provide extra precision under memory fields for top]),
ea316c
+  [], [enable_wide_memory=no]
ea316c
 )
ea316c
-if test "x$enable_wide_memory" = xno; then
ea316c
-  AC_DEFINE(NOBOOST_MEMS, 1, [disable extra precision under memory fields for top])
ea316c
+if test "x$enable_wide_memory" = xyes; then
ea316c
+  AC_DEFINE(BOOST_MEMORY, 1, [provide extra precision under memory fields for top])
ea316c
 fi
ea316c
 
ea316c
 AC_ARG_ENABLE([modern-top],
ea316c
diff -up ./top/top.c.ori ./top/top.c
ea316c
--- ./top/top.c.ori	2017-08-02 12:56:41.681326790 +0200
ea316c
+++ ./top/top.c	2017-08-02 13:50:24.953331241 +0200
ea316c
@@ -1542,11 +1542,11 @@ static inline const char *make_str (cons
ea316c
          * We'll interpret 'num' as a kibibytes quantity and try to
ea316c
          * format it to reach 'target' while also fitting 'width'. */
ea316c
 static const char *scale_mem (int target, unsigned long num, int width, int justr) {
ea316c
-#ifndef NOBOOST_MEMS
ea316c
    //                               SK_Kb   SK_Mb      SK_Gb      SK_Tb      SK_Pb      SK_Eb
ea316c
+#ifdef BOOST_MEMORY
ea316c
    static const char *fmttab[] =  { "%.0f", "%#.1f%c", "%#.3f%c", "%#.3f%c", "%#.3f%c", NULL };
ea316c
 #else
ea316c
-   static const char *fmttab[] =  { "%.0f", "%.0f%c",  "%.0f%c",  "%.0f%c",  "%.0f%c",  NULL };
ea316c
+   static const char *fmttab[] =  { "%.0f", "%.1f%c",  "%.1f%c",  "%.1f%c",  "%.1f%c",  NULL };
ea316c
 #endif
ea316c
    static char buf[SMLBUFSIZ];
ea316c
    float scaled_num;
ea316c
@@ -1750,21 +1750,12 @@ static FLD_t Fieldstab[] = {
ea316c
 #else
ea316c
    {     4,     -1,  A_right,  SF(RES),  L_statm   }, // EU_MEM slot
ea316c
 #endif
ea316c
-#ifndef NOBOOST_MEMS
ea316c
    {     7,  SK_Kb,  A_right,  SF(VRT),  L_statm   },
ea316c
    {     6,  SK_Kb,  A_right,  SF(SWP),  L_status  },
ea316c
    {     6,  SK_Kb,  A_right,  SF(RES),  L_statm   },
ea316c
    {     6,  SK_Kb,  A_right,  SF(COD),  L_statm   },
ea316c
    {     7,  SK_Kb,  A_right,  SF(DAT),  L_statm   },
ea316c
    {     6,  SK_Kb,  A_right,  SF(SHR),  L_statm   },
ea316c
-#else
ea316c
-   {     5,  SK_Kb,  A_right,  SF(VRT),  L_statm   },
ea316c
-   {     4,  SK_Kb,  A_right,  SF(SWP),  L_status  },
ea316c
-   {     4,  SK_Kb,  A_right,  SF(RES),  L_statm   },
ea316c
-   {     4,  SK_Kb,  A_right,  SF(COD),  L_statm   },
ea316c
-   {     5,  SK_Kb,  A_right,  SF(DAT),  L_statm   },
ea316c
-   {     4,  SK_Kb,  A_right,  SF(SHR),  L_statm   },
ea316c
-#endif
ea316c
    {     4,     -1,  A_right,  SF(FL1),  L_stat    },
ea316c
    {     4,     -1,  A_right,  SF(FL2),  L_stat    },
ea316c
    {     4,     -1,  A_right,  SF(DRT),  L_statm   },
ea316c
@@ -1785,11 +1776,7 @@ static FLD_t Fieldstab[] = {
ea316c
    {    -1,     -1,  A_left,   SF(ENV),  L_ENVIRON },
ea316c
    {     3,     -1,  A_right,  SF(FV1),  L_stat    },
ea316c
    {     3,     -1,  A_right,  SF(FV2),  L_stat    },
ea316c
-#ifndef NOBOOST_MEMS
ea316c
    {     6,  SK_Kb,  A_right,  SF(USE),  L_USED    },
ea316c
-#else
ea316c
-   {     4,  SK_Kb,  A_right,  SF(USE),  L_USED    },
ea316c
-#endif
ea316c
    {    10,     -1,  A_right,  SF(NS1),  L_NS      }, // IPCNS
ea316c
    {    10,     -1,  A_right,  SF(NS2),  L_NS      }, // MNTNS
ea316c
    {    10,     -1,  A_right,  SF(NS3),  L_NS      }, // NETNS
ea316c
@@ -5208,12 +5195,20 @@ numa_nope:
ea316c
          const char *fmts;
ea316c
          const char *label;
ea316c
       } scaletab[] = {
ea316c
-         { 1, "%1.0f ", NULL },                            // kibibytes
ea316c
-         { 1024.0, "%#4.3f ", NULL },                      // mebibytes
ea316c
-         { 1024.0*1024, "%#4.3f ", NULL },                 // gibibytes
ea316c
-         { 1024.0*1024*1024, "%#4.3f ", NULL },            // tebibytes
ea316c
-         { 1024.0*1024*1024*1024, "%#4.3f ", NULL },       // pebibytes
ea316c
-         { 1024.0*1024*1024*1024*1024, "%#4.3f ", NULL }   // exbibytes
ea316c
+         { 1, "%.0f ", NULL },                             // kibibytes
ea316c
+#ifdef BOOST_MEMORY
ea316c
+         { 1024.0, "%#.3f ", NULL },                       // mebibytes
ea316c
+         { 1024.0*1024, "%#.3f ", NULL },                  // gibibytes
ea316c
+         { 1024.0*1024*1024, "%#.3f ", NULL },             // tebibytes
ea316c
+         { 1024.0*1024*1024*1024, "%#.3f ", NULL },        // pebibytes
ea316c
+         { 1024.0*1024*1024*1024*1024, "%#.3f ", NULL }    // exbibytes
ea316c
+#else
ea316c
+         { 1024.0, "%#.1f ", NULL },                       // mebibytes
ea316c
+         { 1024.0*1024, "%#.1f ", NULL },                  // gibibytes
ea316c
+         { 1024.0*1024*1024, "%#.1f ", NULL },             // tebibytes
ea316c
+         { 1024.0*1024*1024*1024, "%#.1f ", NULL },        // pebibytes
ea316c
+         { 1024.0*1024*1024*1024*1024, "%#.1f ", NULL }    // exbibytes
ea316c
+#endif
ea316c
       };
ea316c
       struct { //                                            0123456789
ea316c
       // snprintf contents of each buf (after SK_Kb):       'nnnn.nnn 0'
ea316c
diff -up ./top/top.h.ori ./top/top.h
ea316c
--- ./top/top.h.ori	2017-08-02 12:56:41.681326790 +0200
ea316c
+++ ./top/top.h	2017-08-02 13:04:25.446881464 +0200
ea316c
@@ -23,8 +23,8 @@
ea316c
 #include "../proc/readproc.h"
ea316c
 
ea316c
         /* Defines represented in configure.ac ----------------------------- */
ea316c
-//#define BOOST_PERCNT            /* enable extra precision for two % fields */
ea316c
-//#define NOBOOST_MEMS            /* disable extra precision for mem fields  */
ea316c
+//#define BOOST_MEMORY            /* enable extra precision for mem fields   */
ea316c
+//#define BOOST_PERCNT            /* enable extra precision for 2 % fields   */
ea316c
 //#define NUMA_DISABLE            /* disable summary area NUMA/Nodes display */
ea316c
 //#define OOMEM_ENABLE            /* enable the SuSE out-of-memory additions */
ea316c
 //#define ORIG_TOPDEFS            /* with no rcfile retain original defaults */