diff options
| author | James Henderson <jh7370@my.bristol.ac.uk> | 2019-01-23 17:27:48 +0000 |
|---|---|---|
| committer | James Henderson <jh7370@my.bristol.ac.uk> | 2019-01-23 17:27:48 +0000 |
| commit | 25ce596cd111ba93777338412ff9731b16f45cc6 (patch) | |
| tree | 29574ce3db13dfe4bda309b9a28bf2c249e6c42f /llvm/test/tools/llvm-symbolizer | |
| parent | 15a77418a9cbf24efb1f6a6a2d5c776e31d5c2d2 (diff) | |
| download | bcm5719-llvm-25ce596cd111ba93777338412ff9731b16f45cc6.tar.gz bcm5719-llvm-25ce596cd111ba93777338412ff9731b16f45cc6.zip | |
[llvm-symbolizer] Improve compatibility of --functions with GNU addr2line
This fixes https://bugs.llvm.org/show_bug.cgi?id=40072.
GNU addr2line's --functions switch is off by default, has a short alias
of -f, and does not take an argument. This patch changes llvm-symbolizer
to allow the second and third point (changing the default behaviour may
have negative impacts on users). If the option is missing a value, it
now treats it as "linkage".
This change does cause one previously valid command-line to behave
differently. Before --functions <value> was accepted, but now only
--functions=<value> is allowed (as well as --functions). The old
behaviour will result in the value being treated as a positional
argument.
The previous testing for --functions=short has been pulled out into a
new test that also tests the other accepted values and option formats.
Reviewed by: ruiu
Differential Revision: https://reviews.llvm.org/D57049
llvm-svn: 351968
Diffstat (limited to 'llvm/test/tools/llvm-symbolizer')
| -rw-r--r-- | llvm/test/tools/llvm-symbolizer/flag-grouping.test | 2 | ||||
| -rw-r--r-- | llvm/test/tools/llvm-symbolizer/functions.s | 109 |
2 files changed, 110 insertions, 1 deletions
diff --git a/llvm/test/tools/llvm-symbolizer/flag-grouping.test b/llvm/test/tools/llvm-symbolizer/flag-grouping.test index ec032689e15..c8ae547a5fc 100644 --- a/llvm/test/tools/llvm-symbolizer/flag-grouping.test +++ b/llvm/test/tools/llvm-symbolizer/flag-grouping.test @@ -1,4 +1,4 @@ -RUN: llvm-symbolizer -inlining -apC -obj=%p/Inputs/addr.exe < %p/Inputs/addr.inp | FileCheck %s +RUN: llvm-symbolizer -inlining -apfC -obj=%p/Inputs/addr.exe < %p/Inputs/addr.inp | FileCheck %s CHECK: some text CHECK: 0x40054d: inctwo diff --git a/llvm/test/tools/llvm-symbolizer/functions.s b/llvm/test/tools/llvm-symbolizer/functions.s new file mode 100644 index 00000000000..93cca51a0c1 --- /dev/null +++ b/llvm/test/tools/llvm-symbolizer/functions.s @@ -0,0 +1,109 @@ +# REQUIRES: x86-registered-target + +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o + +# RUN: llvm-symbolizer 0 --obj=%t.o | FileCheck %s --check-prefix=LINKAGE +# RUN: llvm-symbolizer 0 --functions --obj=%t.o | FileCheck %s --check-prefix=LINKAGE +# RUN: llvm-symbolizer 0 --functions=linkage --obj=%t.o | FileCheck %s --check-prefix=LINKAGE +# RUN: llvm-symbolizer 0 --functions=short --obj=%t.o | FileCheck %s --check-prefix=SHORT +# RUN: llvm-symbolizer 0 --functions=none --obj=%t.o | FileCheck %s --check-prefix=NONE + +## Characterise behaviour for no '=' sign. llvm-symbolizer treats the next option as an +## input address, and just prints it. +# RUN: llvm-symbolizer 0 --functions none --obj=%t.o | FileCheck %s --check-prefixes=LINKAGE,ERR + +# LINKAGE: {{^}}foo(int){{$}} +# LINKAGE-NEXT: functions.cpp:2:0 + +# SHORT: {{^}}foo{{$}} +# SHORT-NEXT: functions.cpp:2:0 + +# NONE-NOT: foo +# NONE: functions.cpp:2:0 + +# ERR: none + +# The assembly below is a stripped down version of the output of: +# clang -S -g --target=x86_64-pc-linux +# for the following C++ source: +# void foo(int bar) {} + .type _Z3fooi,@function +_Z3fooi: +.Lfunc_begin0: + .file 1 "/llvm-symbolizer/Inputs" "functions.cpp" + .loc 1 2 0 # functions.cpp:2:0 + nop + .loc 1 2 20 prologue_end # functions.cpp:2:20 +.Lfunc_end0: + + .section .debug_str,"MS",@progbits,1 +.Linfo_string1: + .asciz "functions.cpp" +.Linfo_string2: + .asciz "/llvm-symbolizer/Inputs" +.Linfo_string3: + .asciz "_Z3fooi" +.Linfo_string4: + .asciz "foo" + + .section .debug_abbrev,"",@progbits + .byte 1 # Abbreviation Code + .byte 17 # DW_TAG_compile_unit + .byte 1 # DW_CHILDREN_yes + .byte 3 # DW_AT_name + .byte 14 # DW_FORM_strp + .byte 16 # DW_AT_stmt_list + .byte 23 # DW_FORM_sec_offset + .byte 27 # DW_AT_comp_dir + .byte 14 # DW_FORM_strp + .byte 17 # DW_AT_low_pc + .byte 1 # DW_FORM_addr + .byte 18 # DW_AT_high_pc + .byte 6 # DW_FORM_data4 + .byte 0 # EOM(1) + .byte 0 # EOM(2) + .byte 2 # Abbreviation Code + .byte 46 # DW_TAG_subprogram + .byte 0 # DW_CHILDREN_no + .byte 17 # DW_AT_low_pc + .byte 1 # DW_FORM_addr + .byte 18 # DW_AT_high_pc + .byte 6 # DW_FORM_data4 + .byte 110 # DW_AT_linkage_name + .byte 14 # DW_FORM_strp + .byte 3 # DW_AT_name + .byte 14 # DW_FORM_strp + .byte 58 # DW_AT_decl_file + .byte 11 # DW_FORM_data1 + .byte 59 # DW_AT_decl_line + .byte 11 # DW_FORM_data1 + .byte 0 # EOM(1) + .byte 0 # EOM(2) + .byte 0 # EOM(3) + + .section .debug_info,"",@progbits +.Lcu_begin0: + .long .Ldebug_info_end0-.Ldebug_info_start0 # Length of Unit +.Ldebug_info_start0: + .short 4 # DWARF version number + .long .debug_abbrev # Offset Into Abbrev. Section + .byte 8 # Address Size (in bytes) + .byte 1 # Abbrev [1] 0xb:0x4f DW_TAG_compile_unit + .long .Linfo_string1 # DW_AT_name + .long .Lline_table_start0 # DW_AT_stmt_list + .long .Linfo_string2 # DW_AT_comp_dir + .quad .Lfunc_begin0 # DW_AT_low_pc + .long .Lfunc_end0-.Lfunc_begin0 # DW_AT_high_pc + .byte 2 # Abbrev [2] 0x2a:0x28 DW_TAG_subprogram + .quad .Lfunc_begin0 # DW_AT_low_pc + .long .Lfunc_end0-.Lfunc_begin0 # DW_AT_high_pc + .long .Linfo_string3 # DW_AT_linkage_name + .long .Linfo_string4 # DW_AT_name + .byte 1 # DW_AT_decl_file + .byte 2 # DW_AT_decl_line + .byte 0 # End Of Children Mark + .byte 0 # End Of Children Mark +.Ldebug_info_end0: + + .section .debug_line,"",@progbits +.Lline_table_start0: |

