xref: /utopia/UTPA2-700.0.x/projects/build/scripts/rt-tester/t4-l2-pi-deboost.tst (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi#
2*53ee8cc1Swenshuai.xi# rt-mutex test
3*53ee8cc1Swenshuai.xi#
4*53ee8cc1Swenshuai.xi# Op: C(ommand)/T(est)/W(ait)
5*53ee8cc1Swenshuai.xi# |  opcode
6*53ee8cc1Swenshuai.xi# |  |     threadid: 0-7
7*53ee8cc1Swenshuai.xi# |  |     |  opcode argument
8*53ee8cc1Swenshuai.xi# |  |     |  |
9*53ee8cc1Swenshuai.xi# C: lock: 0: 0
10*53ee8cc1Swenshuai.xi#
11*53ee8cc1Swenshuai.xi# Commands
12*53ee8cc1Swenshuai.xi#
13*53ee8cc1Swenshuai.xi# opcode	opcode argument
14*53ee8cc1Swenshuai.xi# schedother	nice value
15*53ee8cc1Swenshuai.xi# schedfifo	priority
16*53ee8cc1Swenshuai.xi# lock		lock nr (0-7)
17*53ee8cc1Swenshuai.xi# locknowait	lock nr (0-7)
18*53ee8cc1Swenshuai.xi# lockint	lock nr (0-7)
19*53ee8cc1Swenshuai.xi# lockintnowait	lock nr (0-7)
20*53ee8cc1Swenshuai.xi# lockcont	lock nr (0-7)
21*53ee8cc1Swenshuai.xi# unlock	lock nr (0-7)
22*53ee8cc1Swenshuai.xi# signal	thread to signal (0-7)
23*53ee8cc1Swenshuai.xi# reset		0
24*53ee8cc1Swenshuai.xi# resetevent	0
25*53ee8cc1Swenshuai.xi#
26*53ee8cc1Swenshuai.xi# Tests / Wait
27*53ee8cc1Swenshuai.xi#
28*53ee8cc1Swenshuai.xi# opcode	opcode argument
29*53ee8cc1Swenshuai.xi#
30*53ee8cc1Swenshuai.xi# prioeq	priority
31*53ee8cc1Swenshuai.xi# priolt	priority
32*53ee8cc1Swenshuai.xi# priogt	priority
33*53ee8cc1Swenshuai.xi# nprioeq	normal priority
34*53ee8cc1Swenshuai.xi# npriolt	normal priority
35*53ee8cc1Swenshuai.xi# npriogt	normal priority
36*53ee8cc1Swenshuai.xi# locked	lock nr (0-7)
37*53ee8cc1Swenshuai.xi# blocked	lock nr (0-7)
38*53ee8cc1Swenshuai.xi# blockedwake	lock nr (0-7)
39*53ee8cc1Swenshuai.xi# unlocked	lock nr (0-7)
40*53ee8cc1Swenshuai.xi# opcodeeq	command opcode or number
41*53ee8cc1Swenshuai.xi# opcodelt	number
42*53ee8cc1Swenshuai.xi# opcodegt	number
43*53ee8cc1Swenshuai.xi# eventeq	number
44*53ee8cc1Swenshuai.xi# eventgt	number
45*53ee8cc1Swenshuai.xi# eventlt	number
46*53ee8cc1Swenshuai.xi
47*53ee8cc1Swenshuai.xi#
48*53ee8cc1Swenshuai.xi# 4 threads 2 lock PI
49*53ee8cc1Swenshuai.xi#
50*53ee8cc1Swenshuai.xiC: resetevent:		0: 	0
51*53ee8cc1Swenshuai.xiW: opcodeeq:		0: 	0
52*53ee8cc1Swenshuai.xi
53*53ee8cc1Swenshuai.xi# Set schedulers
54*53ee8cc1Swenshuai.xiC: schedother:		0: 	0
55*53ee8cc1Swenshuai.xiC: schedother:		1: 	0
56*53ee8cc1Swenshuai.xiC: schedfifo:		2: 	82
57*53ee8cc1Swenshuai.xiC: schedfifo:		3: 	83
58*53ee8cc1Swenshuai.xi
59*53ee8cc1Swenshuai.xi# T0 lock L0
60*53ee8cc1Swenshuai.xiC: locknowait:		0: 	0
61*53ee8cc1Swenshuai.xiW: locked:		0: 	0
62*53ee8cc1Swenshuai.xi
63*53ee8cc1Swenshuai.xi# T1 lock L1
64*53ee8cc1Swenshuai.xiC: locknowait:		1: 	1
65*53ee8cc1Swenshuai.xiW: locked:		1: 	1
66*53ee8cc1Swenshuai.xi
67*53ee8cc1Swenshuai.xi# T3 lock L0
68*53ee8cc1Swenshuai.xiC: lockintnowait:	3: 	0
69*53ee8cc1Swenshuai.xiW: blocked:		3: 	0
70*53ee8cc1Swenshuai.xiT: prioeq:		0: 	83
71*53ee8cc1Swenshuai.xi
72*53ee8cc1Swenshuai.xi# T0 lock L1
73*53ee8cc1Swenshuai.xiC: lock:		0: 	1
74*53ee8cc1Swenshuai.xiW: blocked:		0: 	1
75*53ee8cc1Swenshuai.xiT: prioeq:		1: 	83
76*53ee8cc1Swenshuai.xi
77*53ee8cc1Swenshuai.xi# T1 unlock L1
78*53ee8cc1Swenshuai.xiC: unlock:		1:	1
79*53ee8cc1Swenshuai.xi
80*53ee8cc1Swenshuai.xi# Wait until T0 is in the wakeup code
81*53ee8cc1Swenshuai.xiW: blockedwake:		0:	1
82*53ee8cc1Swenshuai.xi
83*53ee8cc1Swenshuai.xi# Verify that T1 is unboosted
84*53ee8cc1Swenshuai.xiW: unlocked:		1: 	1
85*53ee8cc1Swenshuai.xiT: priolt:		1: 	1
86*53ee8cc1Swenshuai.xi
87*53ee8cc1Swenshuai.xi# T2 lock L1 (T0 is boosted and pending owner !)
88*53ee8cc1Swenshuai.xiC: locknowait:		2:	1
89*53ee8cc1Swenshuai.xiW: blocked:		2: 	1
90*53ee8cc1Swenshuai.xiT: prioeq:		0: 	83
91*53ee8cc1Swenshuai.xi
92*53ee8cc1Swenshuai.xi# Interrupt T3 and wait until T3 returned
93*53ee8cc1Swenshuai.xiC: signal:		3:	0
94*53ee8cc1Swenshuai.xiW: unlocked:		3:	0
95*53ee8cc1Swenshuai.xi
96*53ee8cc1Swenshuai.xi# Verify prio of T0 (still pending owner,
97*53ee8cc1Swenshuai.xi# but T2 is enqueued due to the previous boost by T3
98*53ee8cc1Swenshuai.xiT: prioeq:		0:	82
99*53ee8cc1Swenshuai.xi
100*53ee8cc1Swenshuai.xi# Let T0 continue
101*53ee8cc1Swenshuai.xiC: lockcont:		0:	1
102*53ee8cc1Swenshuai.xiW: locked:		0:	1
103*53ee8cc1Swenshuai.xi
104*53ee8cc1Swenshuai.xi# Unlock L1 and let T2 get L1
105*53ee8cc1Swenshuai.xiC: unlock:		0:	1
106*53ee8cc1Swenshuai.xiW: locked:		2:	1
107*53ee8cc1Swenshuai.xi
108*53ee8cc1Swenshuai.xi# Verify that T0 is unboosted
109*53ee8cc1Swenshuai.xiW: unlocked:		0:	1
110*53ee8cc1Swenshuai.xiT: priolt:		0:	1
111*53ee8cc1Swenshuai.xi
112*53ee8cc1Swenshuai.xi# Unlock everything and exit
113*53ee8cc1Swenshuai.xiC: unlock:		2:	1
114*53ee8cc1Swenshuai.xiW: unlocked:		2:	1
115*53ee8cc1Swenshuai.xi
116*53ee8cc1Swenshuai.xiC: unlock:		0:	0
117*53ee8cc1Swenshuai.xiW: unlocked:		0:	0
118*53ee8cc1Swenshuai.xi
119