forked from OSchip/llvm-project
57 lines
2.3 KiB
Plaintext
57 lines
2.3 KiB
Plaintext
# REQUIRES: system-linux
|
|
|
|
# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-loclist-offset-form-main.s -o %tmain.o
|
|
# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-loclist-offset-form-helper.s -o %thelper.o
|
|
# RUN: %clang %cflags -dwarf-5 %tmain.o %thelper.o -o %t.exe -Wl,-q
|
|
# RUN: llvm-bolt %t.exe -o %t.bolt --update-debug-sections
|
|
# RUN: llvm-dwarfdump --show-form --verbose --debug-info %t.exe | FileCheck --check-prefix=PRECHECK %s
|
|
# RUN: llvm-dwarfdump --show-form --verbose --debug-addr %t.bolt > %t.txt
|
|
# RUN: llvm-dwarfdump --show-form --verbose --debug-info %t.bolt >> %t.txt
|
|
# RUN: cat %t.txt | FileCheck --check-prefix=POSTCHECK %s
|
|
|
|
# Checks we can handle DWARF5 CU with DWARF4 DW_AT_location access pattern.
|
|
|
|
# PRECHECK: DW_TAG_compile_unit
|
|
# PRECHECK: DW_TAG_variable [5]
|
|
# PRECHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
|
|
# PRECHECK: DW_TAG_variable [5]
|
|
# PRECHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
|
|
# PRECHECK: DW_TAG_compile_unit
|
|
# PRECHECK: DW_TAG_variable [11]
|
|
# PRECHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]
|
|
|
|
# POSTCHECK: Addrs: [
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR1:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR2:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR3:]]
|
|
# For second CU.
|
|
# POSTCHECK: Addrs: [
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR4:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR5:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR6:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR7:]]
|
|
# POSTCHECK-NEXT: 0x[[#%.16x,ADDR8:]]
|
|
|
|
# POSTCHECK: DW_TAG_compile_unit
|
|
# POSTCHECK: DW_AT_loclists_base [DW_FORM_sec_offset] (0x0000000c)
|
|
# POSTCHECK: DW_TAG_variable [5]
|
|
# POSTCHECK-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x0)
|
|
# POSTCHECK-NEXT: [0x[[#ADDR1]]
|
|
# POSTCHECK-SAME: 0x[[#ADDR1 + 9]]
|
|
# POSTCHECK-NEXT: [0x[[#ADDR3]]
|
|
# POSTCHECK-SAME: 0x[[#ADDR3 + 6]]
|
|
# POSTCHECK: DW_TAG_variable [5]
|
|
# POSTCHECK-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x1)
|
|
# POSTCHECK-NEXT: [0x[[#ADDR3]]
|
|
# POSTCHECK-SAME: 0x[[#ADDR3 + 2]]
|
|
|
|
# POSTCHECK: DW_TAG_compile_unit
|
|
# POSTCHECK: DW_AT_loclists_base [DW_FORM_sec_offset] (0x00000043)
|
|
# POSTCHECK: DW_TAG_variable [11]
|
|
# POSTCHECK-NEXT: DW_AT_location [DW_FORM_loclistx] (indexed (0x0)
|
|
# POSTCHECK-NEXT: [0x[[#ADDR5]]
|
|
# POSTCHECK-SAME: 0x[[#ADDR5 + 3]]
|
|
# POSTCHECK-NEXT: [0x[[#ADDR8]]
|
|
# POSTCHECK-SAME: 0x[[#ADDR8 + 1]]
|