summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.base/timers.stp
blob: fb590edc225db07c50f7719067397e2666a5af96 (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
74
/*
 * timers.stp
 *
 * Test the functionality of the various timer.* probes.
 */

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

probe begin
{
	printf("systemtap starting probe\n")
}

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
{
	printf("systemtap ending probe\n")
	printf("p = %d\n", p)
	printf("j1 = %d\n", j1)
	printf("j2 = %d\n", j2)
	printf("jmax = %d\n", jmax)
	printf("ms1 = %d\n", ms1)
	printf("ms500 = %d\n", ms500)
	printf("msmax = %d\n", msmax)

	/* profile counter should be non-zero, and at
	 * least as many as the jiffies(1) counter */
	/* (fudge comparison by ~1% since start & end aren't synchronized) */
	if ((p > 0) && (p*100 >= j1*99)) {
		printf("systemtap test success\n")
	} else {
		printf("unexpected profile count: %d profiles and %d jiffies\n", p, j1)
		printf("systemtap test failure\n");
	}

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

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

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