340a94
diff -up ./proc/sysinfo.c.ori ./proc/sysinfo.c
340a94
--- ./proc/sysinfo.c.ori	2021-02-09 11:11:25.000000000 +0100
340a94
+++ ./proc/sysinfo.c	2022-07-29 14:08:42.093322509 +0200
340a94
@@ -786,10 +786,8 @@ nextline:
340a94
      where such values will be dramatically distorted over those of the host. */
340a94
   if (kb_main_available > kb_main_total)
340a94
     kb_main_available = kb_main_free;
340a94
-  mem_used = kb_main_total - kb_main_free - kb_main_cached - kb_main_buffers;
340a94
-  if (mem_used < 0)
340a94
-    mem_used = kb_main_total - kb_main_free;
340a94
-  kb_main_used = (unsigned long)mem_used;
340a94
+  mem_used = kb_main_total - kb_main_available;
340a94
+  kb_main_used = mem_used < 0 ? 0 : (unsigned long) mem_used;
340a94
 
340a94
   /* zero? might need fallback for 2.6.27 <= kernel 
340a94
   if (!kb_main_available) {
340a94
diff -up ./top/top.c.ori ./top/top.c
340a94
--- ./top/top.c.ori	2021-02-09 11:11:25.000000000 +0100
340a94
+++ ./top/top.c	2022-07-29 13:59:04.681966019 +0200
340a94
@@ -6076,12 +6076,16 @@ numa_nope:
340a94
          char used[SMLBUFSIZ], util[SMLBUFSIZ], dual[MEDBUFSIZ];
340a94
          float pct_used, pct_misc, pct_swap;
340a94
          int ix, num_used, num_misc;
340a94
+         unsigned long my_used;
340a94
 
340a94
-         pct_used = (float)kb_main_used * (100.0 / (float)kb_main_total);
340a94
+         // upstream kept old calculation of 'used' here for some reason
340a94
+         // https://gitlab.com/procps-ng/procps/-/commit/047d16ccfda6638eda78f56b67def196a2002b6f
340a94
+         my_used = kb_main_total - kb_main_free - kb_main_cached - kb_main_buffers;
340a94
+         pct_used = (float)my_used * (100.0 / (float)kb_main_total);
340a94
 #ifdef MEMGRAPH_OLD
340a94
          pct_misc = (float)(kb_main_buffers + kb_main_cached) * (100.0 / (float)kb_main_total);
340a94
 #else
340a94
-         pct_misc = (float)(kb_main_total - kb_main_available - kb_main_used) * (100.0 / (float)kb_main_total);
340a94
+         pct_misc = (float)(kb_main_total - kb_main_available - my_used) * (100.0 / (float)kb_main_total);
340a94
 #endif
340a94
          if (pct_used + pct_misc > 100.0 || pct_misc < 0) pct_misc = 0;
340a94
          pct_swap = kb_swap_total ? (float)kb_swap_used * (100.0 / (float)kb_swap_total) : 0;