diff options
author | Fazlul Shahriar <fshahriar@gmail.com> | 2009-08-08 16:45:27 -0400 |
---|---|---|
committer | Fazlul Shahriar <fshahriar@gmail.com> | 2009-08-08 16:45:27 -0400 |
commit | 3c6ab1854e92467a7309cf244339c6f10c2b0d7d (patch) | |
tree | 8ad262133a440a8751f8f3e2c2ab9846f86a10b8 /src/cmd | |
parent | 0e9f3966da196eee3353154d7da04fafe90e5644 (diff) | |
download | plan9port-3c6ab1854e92467a7309cf244339c6f10c2b0d7d.tar.gz plan9port-3c6ab1854e92467a7309cf244339c6f10c2b0d7d.tar.bz2 plan9port-3c6ab1854e92467a7309cf244339c6f10c2b0d7d.zip |
stats: make more stats work in Linux
http://codereview.appspot.com/96084
Diffstat (limited to 'src/cmd')
-rw-r--r-- | src/cmd/auxstats/Linux.c | 72 | ||||
-rw-r--r-- | src/cmd/draw/stats.c | 7 |
2 files changed, 72 insertions, 7 deletions
diff --git a/src/cmd/auxstats/Linux.c b/src/cmd/auxstats/Linux.c index 2592bc4e..09ca18f3 100644 --- a/src/cmd/auxstats/Linux.c +++ b/src/cmd/auxstats/Linux.c @@ -8,6 +8,8 @@ void xloadavg(int); void xmeminfo(int); void xnet(int); void xstat(int); +void xvmstat(int); +void xwireless(int); void (*statfn[])(int) = { @@ -16,6 +18,8 @@ void (*statfn[])(int) = xmeminfo, xnet, xstat, + xvmstat, + xwireless, 0 }; @@ -77,6 +81,7 @@ xmeminfo(int first) int i; vlong tot, used; vlong mtot, mfree; + vlong stot, sfree; static int fd = -1; if(first){ @@ -86,6 +91,9 @@ xmeminfo(int first) readfile(fd); mtot = 0; + stot = 0; + mfree = 0; + sfree = 0; for(i=0; i<nline; i++){ tokens(i); if(ntok < 3) @@ -98,11 +106,22 @@ xmeminfo(int first) Bprint(&bout, "swap =%lld %lld\n", used/1024, tot/1024); else if(strcmp(tok[0], "MemTotal:") == 0) mtot = atoll(tok[1]); /* kb */ - else if(strcmp(tok[0], "MemFree:") == 0){ - mfree = atoll(tok[1]); + else if(strcmp(tok[0], "MemFree:") == 0) + mfree += atoll(tok[1]); + else if(strcmp(tok[0], "Buffers:") == 0) + mfree += atoll(tok[1]); + else if(strcmp(tok[0], "Cached:") == 0){ + mfree += atoll(tok[1]); if(mtot < mfree) continue; Bprint(&bout, "mem =%lld %lld\n", mtot-mfree, mtot); + }else if(strcmp(tok[0], "SwapTotal:") == 0) + stot = atoll(tok[1]); /* kb */ + else if(strcmp(tok[0], "SwapFree:") == 0){ + sfree = atoll(tok[1]); + if(stot < sfree) + continue; + Bprint(&bout, "swap =%lld %lld\n", stot-sfree, stot); } } } @@ -135,7 +154,7 @@ xnet(int first) tokens(i); if(ntok < 8+8) continue; - if(strncmp(tok[0], "eth", 3) != 0) + if(strncmp(tok[0], "eth", 3) != 0 && strncmp(tok[0], "wlan", 4) != 0) continue; inb = atoll(tok[1]); oub = atoll(tok[9]); @@ -182,7 +201,7 @@ xstat(int first) Bprint(&bout, "user %lld 100\n", atoll(tok[1])); Bprint(&bout, "sys %lld 100\n", atoll(tok[3])); Bprint(&bout, "cpu %lld 100\n", atoll(tok[1])+atoll(tok[3])); - Bprint(&bout, "idle %lld\n", atoll(tok[4])); + Bprint(&bout, "idle %lld 100\n", atoll(tok[4])); } /* if(strcmp(tok[0], "page") == 0 && ntok >= 3){ @@ -197,11 +216,52 @@ xstat(int first) } */ if(strcmp(tok[0], "intr") == 0) - Bprint(&bout, "interrupt %lld 1000\n", atoll(tok[1])); + Bprint(&bout, "intr %lld 1000\n", atoll(tok[1])); if(strcmp(tok[0], "ctxt") == 0) - Bprint(&bout, "context %lld 1000\n", atoll(tok[1])); + Bprint(&bout, "context %lld 10000\n", atoll(tok[1])); if(strcmp(tok[0], "processes") == 0) Bprint(&bout, "fork %lld 1000\n", atoll(tok[1])); } } +void +xvmstat(int first) +{ + static int fd = -1; + int i; + + if(first){ + fd = open("/proc/vmstat", OREAD); + return; + } + + readfile(fd); + for(i=0; i<nline; i++){ + tokens(i); + if(ntok < 2) + continue; + if(strcmp(tok[0], "pgfault") == 0) + Bprint(&bout, "fault %lld 100000\n", atoll(tok[1])); + } +} + +void +xwireless(int first) +{ + static int fd = -1; + int i; + + if(first){ + fd = open("/proc/net/wireless", OREAD); + return; + } + + readfile(fd); + for(i=0; i<nline; i++){ + tokens(i); + if(ntok < 3) + continue; + if(strcmp(tok[0], "wlan0:") == 0) + Bprint(&bout, "802.11 =%lld 100\n", atoll(tok[2])); + } +} diff --git a/src/cmd/draw/stats.c b/src/cmd/draw/stats.c index 75069e2b..74b8b76c 100644 --- a/src/cmd/draw/stats.c +++ b/src/cmd/draw/stats.c @@ -28,6 +28,7 @@ enum enum { + V80211, Vbattery, Vcontext, Vcpu, @@ -51,6 +52,7 @@ enum char* labels[Nvalue] = { + "802.11", "battery", "context", "cpu", @@ -109,7 +111,7 @@ Machine *mach; Font *mediumfont; char *fontname; char *mysysname; -char argchars[] = "bcCeEfiIlmnsw"; +char argchars[] = "8bcCeEfiIlmnsw"; int pids[1024]; int parity; /* toggled to avoid patterns in textured background */ int nmach; @@ -748,6 +750,9 @@ threadmain(int argc, char *argv[]) default: fprint(2, "stats: internal error: unknown arg %c\n", args[i]); usage(); + case '8': + addgraph(V80211); + break; case 'b': addgraph(Vbattery); break; |