1b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# This file was written by Steve Fink <sphink@gmail.com>. 2b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# Based on main.c by Yao Qi <qiyao@cn.ibm.com>. 3b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 4b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset testfile "parameters" 5b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset srcfile ${testfile}.c 6b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset binfile ${testfile} 7b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset libfile "parameters-lib" 8b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset libsrc $srcdir/$subdir/$libfile.c 94627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchset lib_sl $objdir/$subdir/lib$testfile.so 10b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 11b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 12b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkif [get_compiler_info $binfile] { 13b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink return -1 14b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink} 15b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 16b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkverbose "compiling source file now....." 17b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkif { [ltrace_compile_shlib $libsrc $lib_sl debug ] != "" 184627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welch || [ltrace_compile $srcdir/$subdir/$srcfile $objdir/$subdir/$binfile executable [list debug shlib=$lib_sl] ] != ""} { 19b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink send_user "Testcase compile failed, so all tests in this file will automatically fail.\n" 20b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink} 21b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 22b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# set options for ltrace. 2351e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataltrace_options "-l" "libparameters.so" "-F" "$srcdir/$subdir/parameters.conf" 24b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 25b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# Run PUT for ltarce. 264627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchset exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile] 27b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 28b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# Check the output of this program. 29b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkverbose "ltrace runtest output: $exec_output\n" 30b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkif [regexp {ELF from incompatible architecture} $exec_output] { 31b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!" 32b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink return 33b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink} elseif [ regexp {Couldn't get .hash data} $exec_output ] { 34b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink fail "Couldn't get .hash data!" 35b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink return 36b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink} 37b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink 38b2c254573fbf30189293be6b7f2ef307c499704cSteve Fink# Verify the output 39b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_intptr(17)" 404627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 41b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_intptr_ret(42)" 424627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 43b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_strlen(\\\"Hello world\\\") *= *11" 444627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 4583b3189516cab1e42854308f151b2ce5d2dd2364Petr Machataset pattern "func_arg0(\\\"Hello another world!\\\") *= *20" 4683b3189516cab1e42854308f151b2ce5d2dd2364Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 47b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_strfixed(\\\"Hell\\\")" 484627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 49b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_ppp(80)" 504627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 51b2c254573fbf30189293be6b7f2ef307c499704cSteve Finkset pattern "func_stringp(\\\"Dude\\\")" 524627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 53b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset pattern "func_string(\\\"zero\\\")" 54b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 556a3e24dc1709530e59dd6ae3e91ced1c221fe1b9Steve Finkset pattern "func_enum(BLUE)" 564627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 576fa27c330f9e07c5be553614b9c6e2f08461780fSteve Finkset pattern "func_short(-8, -9)" 584627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 596fa27c330f9e07c5be553614b9c6e2f08461780fSteve Finkset pattern "func_ushort(33, 34)" 604627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 611607793a00298f9d5a857dac73de2dd6a6510725Petr Machataset pattern "func_float(3.40*, -3.40*).*= 3.40*" 621607793a00298f9d5a857dac73de2dd6a6510725Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 631607793a00298f9d5a857dac73de2dd6a6510725Petr Machataset pattern "func_double(3.40*, -3.40*).*= -3.40*" 644627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 65e22411dd33d2d55fd5c6510390954f13fd502d3aSteve Finkset pattern "func_typedef(BLUE)" 664627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 6794078ecce3a103c28457e6f90f1e5b0dacc61146Petr Machataset pattern "func_arrayi(. 10, 11, 12, 13\\.\\.\\. ., 8)" 684627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 6994078ecce3a103c28457e6f90f1e5b0dacc61146Petr Machataset pattern "func_arrayi(. 10, 11 ., 2)" 704627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 7194078ecce3a103c28457e6f90f1e5b0dacc61146Petr Machataset pattern "func_arrayf(. 10.10*, 11.10*, 12.10*, 13.10*\\.\\.\\. ., 8)" 724627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 7394078ecce3a103c28457e6f90f1e5b0dacc61146Petr Machataset pattern "func_arrayf(. 10.10*, 11.10* ., 2)" 744627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 756fa27c330f9e07c5be553614b9c6e2f08461780fSteve Finkset pattern "exited (status 0)" 764627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 77e4b3263fb2b32eb5ee0f693fc223ed8c363fbd69Steve Finkset pattern "func_struct({ 89, 2, 3, . { 1, 10 }, { 3, 30 } ., . { 4, 40 }, { 5, 50 }, { 6, 60 } ., \\\"123\\\" })" 784627fc493db8459e6ef0597a4155a06b7d120d20Zachary T Welchltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 79280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataset pattern "func_call( <unfinished ...>" 80280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 81280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataset pattern "func_work(\\\"x\\\")" 82280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 83b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset pattern "func_struct_2(17, { \\\"ABCDE\\\\\\\\0\\\", 0.250* }, 0.50*).*= { 0.250*, 'B', 'C' }" 84b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 85280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataset pattern "<... func_call resumed> \\\"x\\\", \\\"y\\\")" 86280f829ca87ff6b6c3a242a97fcef01d4488d2c8Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 87b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 88b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset pattern "func_struct_large({ 1, 2, 3, 4 }, { 5, 6, 7, 8 }).*= { 6, 8, 10, 12 }" 89b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 90b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 91b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset pattern "func_struct_large2({ '0', '1', 3, 4 }, { '2', '3', 7, 8 }).*= { 'b', 'd', 10, 12 }" 92b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 93b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 94b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset pattern "func_struct_large3({ 3, 4, '0', '1' }, { 7, 8, '2', '3' }).*= { 10, 12, 'b', 'd' }" 95b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 96b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 97b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataset 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*)" 98b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 99b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 10051e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataset pattern "func_printf(\\\"sotnuh %d %ld %g %c.n\\\", 5, 6, 1.500*, 'X')" 101b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 102b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 10351e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataset pattern "func_printf(\\\"sotnuh1 %d %ld %hd.n\\\", 5, 6, 7)" 104b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 105b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 10651e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataset pattern "func_printf(\\\"sotnuh2 %s %10s %10s.n\\\", \\\"a string\\\", \\\"a trimmed \\\", \\\"short\\\")" 107b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 108b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 10951e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataset pattern "func_printf(\\\"sotnuh3 %.s.n\\\", 4, \\\"a tr\\\")" 110b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 111b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machata 11251e74aca71ff7e8be91c074afd4f2264f46294e9Petr Machataset pattern "func_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*)" 113b77f778eda200e0dc1c481e2f7dc5ff322147bd7Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 114ce034981e2880eecb8a196c78182dfb4ae67850fPetr Machata 11526c0c9413c2558c3f95cb466b3734ea5ba57444dPetr Machataset pattern "func_sprintf(nil, \\\"test %d %d %d %d.n\\\", 1, 2, 3, 4)" 1163a8a91ca57f66d664b3fbd19882e6d163c7ad496Edgar E. Iglesiasltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1173a8a91ca57f66d664b3fbd19882e6d163c7ad496Edgar E. Iglesias 118ce034981e2880eecb8a196c78182dfb4ae67850fPetr Machataset pattern "func_lens(026, 027, 0x18, 0x19)" 119ce034981e2880eecb8a196c78182dfb4ae67850fPetr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 120e3f4a984db115979e09414b7281da98399dd8949Petr Machata 121e3f4a984db115979e09414b7281da98399dd8949Petr Machataset pattern "func_bool(1, true).*= false" 122e3f4a984db115979e09414b7281da98399dd8949Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 123e3f4a984db115979e09414b7281da98399dd8949Petr Machata 124e3f4a984db115979e09414b7281da98399dd8949Petr Machataset pattern "func_bool(2, false).*= true" 125e3f4a984db115979e09414b7281da98399dd8949Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 126e3f4a984db115979e09414b7281da98399dd8949Petr Machata 1270ceae2a763aee33e23808edc7bece9888c583411Petr Machataset pattern "func_hide(2, 5, 7)" 1280ceae2a763aee33e23808edc7bece9888c583411Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1290ceae2a763aee33e23808edc7bece9888c583411Petr Machata 1300ceae2a763aee33e23808edc7bece9888c583411Petr Machataset pattern "func_hide_struct({ 2, 5, 7 })" 131e3f4a984db115979e09414b7281da98399dd8949Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 132e3f4a984db115979e09414b7281da98399dd8949Petr Machata 133c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machataset pattern "func_short_enums(. A, B, A, A .).*= . A, B, A, A ." 134c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 135c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machata 136c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machataset pattern "func_negative_enum(A, A, A, A, A, A).*= A" 137c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 138c07a26a8d0f86bc4137eb7b7fea8bbf9021275f1Petr Machata 139e3f4a984db115979e09414b7281da98399dd8949Petr Machataset pattern "func_charp_string(\\\"null-terminated string\\\")" 140e3f4a984db115979e09414b7281da98399dd8949Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 141df3e3ce40c5dd3459bb365b684b78d8b1b94c1ecPetr Machata 1421ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataset pattern "func_struct_empty({ *}).*= { *}" 1431ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1441ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machata 1451ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataset pattern "func_struct_size1({ '5' }).*= { '5' }" 1461ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1471ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machata 1481ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataset pattern "func_struct_size2({ 5 }).*= { 5 }" 1491ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1501ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machata 1511ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataset pattern "func_struct_size4({ 5 }).*= { 5 }" 1521ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 1531ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machata 1541ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataset pattern "func_struct_size8({ 5, 6 }).*= { 5, 6 }" 1551ac91188e53f5b880bfb7d103a56b51a2f0ebb52Petr Machataltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 156