parameters.exp revision 248db7bc5d3e095da23b64f9afb0643ca64977ef
1# This file was written by Steve Fink <sphink@gmail.com>.
2# Based on main.c by Yao Qi <qiyao@cn.ibm.com>.
3
4set testfile "parameters"
5set srcfile ${testfile}.c
6set binfile ${testfile}
7set libfile "parameters-lib"
8set libsrc $srcdir/$subdir/$libfile.c
9set lib_sl $objdir/$subdir/lib$testfile.so
10
11
12if [get_compiler_info $binfile] {
13  return -1
14}
15
16verbose "compiling source file now....."
17if { [ltrace_compile_shlib $libsrc $lib_sl debug ] != ""
18  || [ltrace_compile $srcdir/$subdir/$srcfile $objdir/$subdir/$binfile executable [list debug shlib=$lib_sl] ] != ""} {
19  send_user "Testcase compile failed, so all tests in this file will automatically fail.\n"
20}
21
22# set options for ltrace.
23ltrace_options "-l" "$objdir/$subdir/libparameters.so" "-F" "$srcdir/$subdir/parameters.conf"
24
25# Run PUT for ltarce.
26set exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile]
27
28# Check the output of this program.
29verbose "ltrace runtest output: $exec_output\n"
30if [regexp {ELF from incompatible architecture} $exec_output] {
31	fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!"
32	return
33} elseif [ regexp {Couldn't get .hash data} $exec_output ] {
34	fail "Couldn't get .hash data!"
35	return
36}
37
38set xfail_spec {"arm*-*" }
39set xfail_spec_arm {"arm*-*"}
40
41# Verify the output
42set pattern "func_intptr(17)"
43ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
44set pattern "func_intptr_ret(42)"
45ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
46set pattern "func_strlen(\\\"Hello world\\\") *= *11"
47ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
48set pattern "func_strfixed(\\\"Hell\\\")"
49ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
50set pattern "func_ppp(80)"
51ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
52set pattern "func_stringp(\\\"Dude\\\")"
53ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
54set pattern "func_string(\\\"zero\\\")"
55ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
56set pattern "func_enum(BLUE)"
57ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
58set pattern "func_short(-8, -9)"
59ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
60set pattern "func_ushort(33, 34)"
61ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
62set pattern "func_float(3.40*, -3.40*).*= 3.40*"
63ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
64eval "setup_xfail $xfail_spec"
65set pattern "func_double(3.40*, -3.40*).*= -3.40*"
66ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
67set pattern "func_typedef(BLUE)"
68ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
69set pattern "func_arrayi(. 10, 11, 12, 13\\.\\.\\. ., 8)"
70ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
71set pattern "func_arrayi(. 10, 11 ., 2)"
72ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
73set pattern "func_arrayf(. 10.10*, 11.10*, 12.10*, 13.10*\\.\\.\\. ., 8)"
74ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
75set pattern "func_arrayf(. 10.10*, 11.10* ., 2)"
76ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
77set pattern "exited (status 0)"
78ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
79set pattern "func_struct({ 89, 2, 3, . { 1, 10 }, { 3, 30 } ., . { 4, 40 }, { 5, 50 }, { 6, 60 } ., \\\"123\\\" })"
80ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
81set pattern "func_call( <unfinished ...>"
82ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
83set pattern "func_work(\\\"x\\\")"
84ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
85set pattern "func_struct_2(17, { \\\"ABCDE\\\\\\\\0\\\", 0.250* }, 0.50*).*= { 0.250*, 'B', 'C' }"
86ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
87eval "setup_xfail $xfail_spec_arm"
88set pattern "<... func_call resumed> \\\"x\\\", \\\"y\\\")"
89ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
90
91set pattern "func_struct_large({ 1, 2, 3, 4 }, { 5, 6, 7, 8 }).*= { 6, 8, 10, 12 }"
92ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
93
94set pattern "func_struct_large2({ '0', '1', 3, 4 }, { '2', '3', 7, 8 }).*= { 'b', 'd', 10, 12 }"
95ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
96
97set pattern "func_struct_large3({ 3, 4, '0', '1' }, { 7, 8, '2', '3' }).*= { 10, 12, 'b', 'd' }"
98ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
99
100set pattern "func_many_args(1, 2, 3, 4.00*, '5', 6, 7.00*, '8', 9, 10.00*, 11, 12.00*, 'A', 14, 15, 16, 'B', 18.00*, 19.00*, 20.00*, 21, 22.00*, 23.00*, 24.00*, 25.00*)"
101ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
102
103set pattern "printf(\\\"sotnuh %d %ld %g %c.n\\\", 5, 6, 1.500*, 'X')"
104ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
105
106set pattern "printf(\\\"sotnuh1 %d %ld %hd.n\\\", 5, 6, 7)"
107ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
108
109set pattern "printf(\\\"sotnuh2 %s %10s %10s.n\\\", \\\"a string\\\", \\\"a trimmed \\\", \\\"short\\\")"
110ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
111
112set pattern "printf(\\\"sotnuh3 %.s.n\\\", 4, \\\"a tr\\\")"
113ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
114
115set pattern "printf(\\\"many_args%d %d %ld %g %c %d %g .*, 1, 2, 3, 4.00*, '5', 6, 7.00*, '8', 9, 10.00*, 11, 12.00*, 'A', 14, 15, 16, 'B', 18.00*, 19.00*, 20.00*, 21, 22.00*, 23.00*, 24.00*, 25.00*)"
116ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
117
118set pattern "func_lens(026, 027, 0x18, 0x19)"
119ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
120
121set pattern "func_bool(1, true).*= false"
122ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
123
124set pattern "func_bool(2, false).*= true"
125ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
126
127set pattern "func_hide(1, 4, 6)"
128ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
129
130set pattern "func_short_enums(. A, B, A, A .).*= . A, B, A, A ."
131ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
132
133set pattern "func_negative_enum(A, A, A, A, A, A).*= A"
134ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
135
136set pattern "func_charp_string(\\\"null-terminated string\\\")"
137ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
138
139set pattern "func_dbl_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }"
140ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
141
142set pattern "func_flt_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }"
143ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
144
145set pattern "func_struct_empty({ *}).*= { *}"
146ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
147
148set pattern "func_struct_size1({ '5' }).*= { '5' }"
149ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
150
151set pattern "func_struct_size2({ 5 }).*= { 5 }"
152ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
153
154set pattern "func_struct_size4({ 5 }).*= { 5 }"
155ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
156
157set pattern "func_struct_size8({ 5, 6 }).*= { 5, 6 }"
158ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
159
160set pattern "func_hfa_f2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }"
161ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
162
163set pattern "func_hfa_f3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }"
164ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
165
166set pattern "func_hfa_f4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }"
167ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
168
169set pattern "func_hfa_f5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }"
170ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
171
172set pattern "func_hfa_f6({ 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }).*= { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }"
173ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
174
175set pattern "func_hfa_f7({ 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }).*= { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }"
176ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
177
178set pattern "func_hfa_f8({ 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }).*= { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }"
179ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
180
181set pattern "func_hfa_f9({ 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }).*= { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }"
182ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
183
184set pattern "func_hfa_f10({ 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }).*= { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }"
185ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
186
187set pattern "func_hfa_f11({ 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }).*= { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }"
188ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
189
190set pattern "func_hfa_f12({ 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }).*= { 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }"
191ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
192
193set pattern "func_hfa_d2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }"
194ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
195
196set pattern "func_hfa_d3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }"
197ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
198
199set pattern "func_hfa_d4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }"
200ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
201
202set pattern "func_hfa_d5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }"
203ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
204
205set pattern "func_hfa_d6({ 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }).*= { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }"
206ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
207
208set pattern "func_hfa_d7({ 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }).*= { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }"
209ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
210
211set pattern "func_hfa_d8({ 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }).*= { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }"
212ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
213
214set pattern "func_hfa_d9({ 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }).*= { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }"
215ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
216
217set pattern "func_hfa_d10({ 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }).*= { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }"
218ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
219
220set pattern "func_hfa_d11({ 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }).*= { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }"
221ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
222
223set pattern "func_hfa_d12({ 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }).*= { 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }"
224ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
225