blob: 6dded7264c215f732069feff8bde4ef8598a9ea1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
proc genload {} {
# if 'genload' from the ltp exists, use it to create a real load
set genload {/usr/local/ltp/testcases/bin/genload}
if [file executable $genload] {
exec $genload -c 10 -i 10 -m 10 -t 10
# ^^^^^ run for 10 seconds
# ^^^^^ 10 procs spinning on malloc
# ^^^^^ 10 procs spinning on sync
# ^^^^^ 10 procs spinning on sqrt
} else {
# sleep for a bit
after 10000
}
return 0
}
proc probe_ok {probepoint} {
set cmd {exec stap -p2 -e}
lappend cmd "probe $probepoint {}"
return [expr ![catch $cmd]]
}
set systemtap_script {
global stat
probe %s {
stat[probefunc()] <<< 1
}
probe begin { log ("systemtap starting probe") }
probe end {
log ("systemtap ending probe")
foreach (func in stat limit 5) # don't overflow expect buffer
printf("%%d %%s\n", @count(stat[func]), func)
}
}
set letters [split {abcdefghijklmnopqrstuvwxyz_ABCDEFGHIJKLMNOPQRSTUVWXYZ} {}]
set output_string "(\\d+ \\w+\\r\\n)*(WARNING.*skipped.*)?"
# Because this test is known to expose system crashes, it is not enabled
# by default. Change the line below to 'if 1' to enable it.
if 0 {
foreach start $letters {
set probepoint "kernel.function(\"$start*\")"
set prefix "all_kernel_functions:"
if [probe_ok $probepoint] {
set script [format $systemtap_script $probepoint]
stap_run $prefix$probepoint genload $output_string -e $script
} else {
unsupported "$prefix no match for $probepoint"
}
}
} else {
untested "all_kernel_functions is disabled"
}
|