diff options
author | Frank Ch. Eigler <fche@elastic.org> | 2008-04-24 13:55:34 -0400 |
---|---|---|
committer | Frank Ch. Eigler <fche@elastic.org> | 2008-04-24 13:55:34 -0400 |
commit | fe44e686c32ccb684bd5ec6df57aed00532fc024 (patch) | |
tree | 260953c84c8679572d65bf83a65884050f91d2f7 /testsuite/systemtap.examples/nettop.stp | |
parent | f72154b33e67069cd7c308d24255574b9fbacb1d (diff) | |
parent | 478e10649195945adf7153fe5254932df1e2a902 (diff) | |
download | systemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.tar.gz systemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.tar.xz systemtap-steved-fe44e686c32ccb684bd5ec6df57aed00532fc024.zip |
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap
* 'master' of ssh://sources.redhat.com/git/systemtap:
Made kernel 2.6.25 changes in task_finder.c.
Move examples to testsuite/systemtap.examples
Diffstat (limited to 'testsuite/systemtap.examples/nettop.stp')
-rwxr-xr-x | testsuite/systemtap.examples/nettop.stp | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/testsuite/systemtap.examples/nettop.stp b/testsuite/systemtap.examples/nettop.stp new file mode 100755 index 00000000..96db413a --- /dev/null +++ b/testsuite/systemtap.examples/nettop.stp @@ -0,0 +1,42 @@ +#! /usr/bin/env stap + +global ifxmit, ifrecv + +probe netdev.transmit +{ + ifxmit[pid(), dev_name, execname(), uid()] <<< length +} + +probe netdev.receive +{ + ifrecv[pid(), dev_name, execname(), uid()] <<< length +} + + +function print_activity() +{ + printf("%5s %5s %-7s %7s %7s %7s %7s %-15s\n", + "PID", "UID", "DEV", "XMIT_PK", "RECV_PK", + "XMIT_KB", "RECV_KB", "COMMAND") + + foreach ([pid, dev, exec, uid] in ifrecv-) { + n_xmit = @count(ifxmit[pid, dev, exec, uid]) + n_recv = @count(ifrecv[pid, dev, exec, uid]) + printf("%5d %5d %-7s %7d %7d %7d %7d %-15s\n", + pid, uid, dev, n_xmit, n_recv, + n_xmit ? @sum(ifxmit[pid, dev, exec, uid])/1024 : 0, + n_recv ? @sum(ifrecv[pid, dev, exec, uid])/1024 : 0, + exec) + } + + print("\n") + + delete ifxmit + delete ifrecv +} + +probe timer.ms(5000), end, error +{ + print_activity() +} + |