Just to add a little more consistency in the calculation...

Greets,
Tobias

---
 components/ram.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git components/ram.c components/ram.c
index 1178837..57081d2 100644
--- components/ram.c
+++ components/ram.c
@@ -60,6 +60,7 @@
        #include <unistd.h>
 
        #define LOG1024         10
+       #define pagetok(size, pageshift) ((size) << (pageshift - LOG1024))
 
        inline int
        load_uvmexp(struct uvmexp *uvmexp)
@@ -81,7 +82,7 @@
 
                if (load_uvmexp(&uvmexp)) {
                        free_pages = uvmexp.npages - uvmexp.active;
-                       free = (float)(free_pages << (uvmexp.pageshift - 
LOG1024)) / 1024 / 1024; 
+                       free = (float)(pagetok(free_pages, uvmexp.pageshift)) / 
1024 / 1024;
                        return bprintf("%f", free);
                }
 
@@ -109,7 +110,7 @@
                float total;
 
                if (load_uvmexp(&uvmexp)) {
-                       total = (float)(uvmexp.npages << (uvmexp.pageshift - 
LOG1024)) / 1024 / 1024; 
+                       total = (float)(pagetok(uvmexp.npages, 
uvmexp.pageshift)) / 1024 / 1024;
                        return bprintf("%f", total);
                }
 
@@ -123,8 +124,7 @@
                float used;
 
                if (load_uvmexp(&uvmexp)) {
-                       used = (double) (uvmexp.active * uvmexp.pagesize) /
-                              1024 / 1024 / 1024;
+                       used = (float)(pagetok(uvmexp.active, 
uvmexp.pageshift)) / 1024 / 1024;
                        return bprintf("%f", used);
                }
 
-- 
2.16.2


Reply via email to