summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.base/timers.stp
blob: 9f370e74913bf8a9a776c8e2b7bbf73d274f7924 (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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
 * timers.stp
 *
 * Test the functionality of the various timer.* probes.
 */

global p
global j1, j2, jmax
global ms1, ms500, msmax

probe begin
{
	log("systemtap starting probe")
}

probe timer.profile { ++p }

probe timer.jiffies(1) { ++j1 }
probe timer.jiffies(2) { ++j2 }
probe timer.jiffies(1000000) { ++jmax }

/* as long as HZ>2, ms(1) and ms(500) 
 * will produce different counts */
probe timer.ms(1) { ++ms1 }
probe timer.ms(500) { ++ms500 }
probe timer.ms(1000000) { ++msmax }

probe end
{
	log("systemtap ending probe")
	log("p = " . sprint(p))
	log("j1 = " . sprint(j1))
	log("j2 = " . sprint(j2))
	log("jmax = " . sprint(jmax))
	log("ms1 = " . sprint(ms1))
	log("ms500 = " . sprint(ms500))
	log("msmax = " . sprint(msmax))

	/* profile counter should be non-zero, and at
	 * least as many as the jiffies(1) counter */
	if ((p > 0) && (p >= j1)) {
		log("systemtap test success")
	} else {
		log("unexpected profile count")
		log("systemtap test failure");
	}

	/* jiffies(1) should count more than jiffies(2),
	 * and both should be non-zero. */
	if ((j2 > 0) && (j2 < j1)) {
		log("systemtap test success")
	} else {
		log("unexpected jiffies count")
		log("systemtap test failure");
	}

	/* ms(1) should count more than ms(500),
	 * and both should be non-zero. */
	if ((ms500 > 0) && (ms500 < ms1)) {
		log("systemtap test success")
	} else {
		log("unexpected ms count")
		log("systemtap test failure");
	}

	/* both 'infinite' intervals should register zero counts */
	if ((jmax == 0) && (msmax == 0)) {
		log("systemtap test success")
	} else {
		log("unexpected count on 'infinite' interval")
		log("systemtap test failure");
	}
}