mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-20 18:08:24 +08:00
[gdb/testsuite] Fix various issues in gdb.mi/mi-sym-info.exp
I noticed this failure in gdb.mi/mi-sym-info.exp with gcc-4.8: ... FAIL: gdb.mi/mi-sym-info.exp: -symbol-info-functions --max-results 1 \ (unexpected output) ... due to function f2 instead of f3 being listed. AFAICT, this is caused by a difference in debug info: ... $ readelf -wi outputs/gdb.mi/mi-sym-info/mi-sym-info1.o \ | egrep "DW_AT_name.*: f[1-3]" <72> DW_AT_name : f1 <a1> DW_AT_name : f2 <d0> DW_AT_name : f3 ... vs: ... $ readelf -wi outputs/gdb.mi/mi-sym-info/mi-sym-info1.o \ | egrep "DW_AT_name.*: f[1-3]" <f4> DW_AT_name : f3 <123> DW_AT_name : f2 <152> DW_AT_name : f1 ... and the command documentation does not mention an imposed order, so fix this by allowing f2 as well. Doing this fix, it made sense to do a refactoring of adding f2_re and f3_re variables, in order to write (?:$f2_re|$f3_re), and I applied the same pattern overall. Furthermore, I found a silent FAIL due to calling mi_gdb_proc with 2 args, fix by updating the regexp. Then I ran with clang and found another FAIL, fix by updating the regexp. Tested on x86_64-linux with gcc-4.8.5, gcc-7.5.0, gcc-11.2.1, clang-7.0.1 and clang-12.0.1.
This commit is contained in:
@ -189,34 +189,58 @@ with_timeout_factor 4 {
|
||||
}
|
||||
}
|
||||
|
||||
set f2_re \
|
||||
"\{line=\"33\",name=\"f2\",type=\"float \\(another_float_t\\)\",description=\"float f2\\(another_float_t\\);\"\}"
|
||||
set f3_re \
|
||||
"\{line=\"39\",name=\"f3\",type=\"int \\(another_int_t\\)\",description=\"int f3\\(another_int_t\\);\"\}"
|
||||
set f4_re \
|
||||
"\{line=\"36\",name=\"f4\",type=\"void \\(int \\*\\)\",description=\"void f4\\(int \\*\\);\"\}"
|
||||
|
||||
set global_i1_re \
|
||||
"\{line=\"18\",name=\"global_i1\",type=\"int\",description=\"static int global_i1;\"\}"
|
||||
set global_f2_re \
|
||||
"\{line=\"21\",name=\"global_f2\",type=\"int\",description=\"int global_f2;\"\}"
|
||||
set global_i2_re \
|
||||
"\{line=\"20\",name=\"global_i2\",type=\"int\",description=\"int global_i2;\"\}"
|
||||
set global_f1_s1_re \
|
||||
"\{line=\"25\",name=\"global_f1\",type=\"float\",description=\"static float global_f1;\"\}"
|
||||
set global_f1_s2_re \
|
||||
"\{line=\"19\",name=\"global_f1\",type=\"float\",description=\"static float global_f1;\"\}"
|
||||
|
||||
set another_int_re "\{line=\"23\",name=\"another_int_t\"\}"
|
||||
set my_int_re "\{line=\"27\",name=\"my_int_t\"\}"
|
||||
set another_char_re "\{line=\"44\",name=\"another_char_t\"\}"
|
||||
set another_float_re "\{line=\"24\",name=\"another_float_t\"\}"
|
||||
set another_short_re "\{line=\"45\",name=\"another_short_t\"\}"
|
||||
|
||||
# Filter functions by name and type.
|
||||
set lineno [gdb_get_line_number "f3 (another_int_t arg)" ${srcfile2}]
|
||||
mi_gdb_test "116-symbol-info-functions --name ^f3$" \
|
||||
"116\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"39\",name=\"f3\",type=\"int \\(another_int_t\\)\",description=\"int f3\\(another_int_t\\);\"\}\\\]\}\\\]\}" \
|
||||
"116\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$f3_re\\\]\}\\\]\}" \
|
||||
"List all functions matching pattern f3"
|
||||
|
||||
set lineno [gdb_get_line_number "f4 (int *arg)" ${srcfile}]
|
||||
mi_gdb_test "117-symbol-info-functions --type void --name ^f4$" \
|
||||
"117\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[\{line=\"36\",name=\"f4\",type=\"void \\(int \\*\\)\",description=\"void f4\\(int \\*\\);\"\}\\\]\}\\\]\}" \
|
||||
"117\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[$f4_re\\\]\}\\\]\}" \
|
||||
"List all functions matching type void"
|
||||
|
||||
# Filter variables by name and type.
|
||||
set lineno [gdb_get_line_number "int global_f2;" ${srcfile2}]
|
||||
mi_gdb_test "118-symbol-info-variables --name global_f2" \
|
||||
"118\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"21\",name=\"global_f2\",type=\"int\",description=\"int global_f2;\"\}\\\]\}\\\]\}" \
|
||||
"118\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$global_f2_re\\\]\}\\\]\}" \
|
||||
"List all variables matching pattern global_f2"
|
||||
|
||||
set lineno1 [gdb_get_line_number "static float __attribute__ ((used)) global_f1;" ${srcfile}]
|
||||
set lineno2 [gdb_get_line_number "static float __attribute__ ((used)) global_f1;" ${srcfile2}]
|
||||
mi_gdb_test "119-symbol-info-variables --type float --name ^global_" \
|
||||
"119\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[\{line=\"25\",name=\"global_f1\",type=\"float\",description=\"static float global_f1;\"\}\\\]\},\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"19\",name=\"global_f1\",type=\"float\",description=\"static float global_f1;\"\}\\\]\}\\\]\}" \
|
||||
"119\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[$global_f1_s1_re\\\]\},\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$global_f1_s2_re\\\]\}\\\]\}" \
|
||||
"List all variables matching type float"
|
||||
|
||||
# Fetch types, filtering by name.
|
||||
set lineno1 [gdb_get_line_number "typedef int my_int_t;" ${srcfile}]
|
||||
set lineno2 [gdb_get_line_number "typedef int another_int_t;" ${srcfile2}]
|
||||
mi_gdb_test "120-symbol-info-types --name _int_" \
|
||||
"120\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[\{line=\"27\",name=\"my_int_t\"\}\\\]\},\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"23\",name=\"another_int_t\"\}\\\]\}\\\]\}" \
|
||||
"120\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile\",fullname=\"\[^\"\]+$srcfile\",symbols=\\\[$my_int_re\\\]\},\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$another_int_re\\\]\}\\\]\}" \
|
||||
"List all types matching _int_"
|
||||
|
||||
# Test the --max-results parameter.
|
||||
@ -225,20 +249,17 @@ mi_gdb_test "121-symbol-info-functions --max-results 0" \
|
||||
"-symbol-info-functions --max-results 0"
|
||||
|
||||
mi_gdb_test "122-symbol-info-functions --max-results 1 --name ^\[^_\]" \
|
||||
"122\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"39\",name=\"f3\",type=\"int \\(another_int_t\\)\",description=\"int f3\\(another_int_t\\);\"\}\\\]\}\\\]\}" \
|
||||
"122\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[(?:$f2_re|$f3_re)\\\]\}\\\]\}" \
|
||||
"-symbol-info-functions --max-results 1"
|
||||
|
||||
mi_gdb_test "123-symbol-info-functions --max-results 2 --name ^\[^_\]" \
|
||||
"123\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"33\",name=\"f2\",type=\"float \\(another_float_t\\)\",description=\"float f2\\(another_float_t\\);\"\},\{line=\"39\",name=\"f3\",type=\"int \\(another_int_t\\)\",description=\"int f3\\(another_int_t\\);\"\}\\\]\}\\\]\}" \
|
||||
"123\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$f2_re,$f3_re\\\]\}\\\]\}" \
|
||||
"-symbol-info-functions --max-results 2"
|
||||
|
||||
mi_gdb_test "124-symbol-info-variables --max-results 3 --name ^\[^_\]" \
|
||||
"124\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[\{line=\"21\",name=\"global_f2\",type=\"int\",description=\"int global_f2;\"\},\{line=\"20\",name=\"global_i2\",type=\"int\",description=\"int global_i2;\"\},\{line=\"19\",name=\"global_f1\",type=\"float\",description=\"static float global_f1;\"\}\\\]\}\\\]\}" \
|
||||
"124\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$global_f2_re,$global_i2_re,(?:$global_i1_re|$global_f1_s2_re)\\\]\}\\\]\}" \
|
||||
"-symbol-info-types --max-results 3"
|
||||
|
||||
set s1 "\{line=\"44\",name=\"another_char_t\"\}"
|
||||
set s2 "\{line=\"24\",name=\"another_float_t\"\}"
|
||||
set s3 "\{line=\"23\",name=\"another_int_t\"\}"
|
||||
set s4 "\{line=\"45\",name=\"another_short_t\"\}"
|
||||
mi_gdb_test "125-symbol-info-types --max-results 4 --name another_" \
|
||||
"125\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$s1,$s2,$s3,$s4\\\]\}\\\]\}" \
|
||||
"125\\^done,symbols=\{debug=\\\[\{filename=\"\[^\"\]*$srcfile2\",fullname=\"\[^\"\]+$srcfile2\",symbols=\\\[$another_char_re,$another_float_re,$another_int_re,$another_short_re\\\]\}\\\]\}" \
|
||||
"-symbol-info-types --max-results 4"
|
||||
|
Reference in New Issue
Block a user