1# REQUIRES: system-linux 2 3# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-subprogram-multiple-ranges-main.s -o %t1.o 4# RUN: llvm-mc -dwarf-version=5 -filetype=obj -triple x86_64-unknown-linux %p/Inputs/dwarf5-subprogram-multiple-ranges-other.s -o %t2.o 5# RUN: %clang %cflags %t1.o %t2.o -o %t.exe -Wl,-q 6# RUN: llvm-bolt %t.exe -o %t.bolt --update-debug-sections --debug-thread-count=4 --cu-processing-batch-size=4 7# RUN: llvm-objdump %t.bolt --disassemble > %t1.txt 8# RUN: llvm-dwarfdump --show-form --verbose --debug-info %t.bolt >> %t1.txt 9# RUN: cat %t1.txt | FileCheck --check-prefix=POSTCHECK %s 10 11## This test checks that BOLT correctly handles DW_TAG_subprogram with Ranges with multiple entries and handles multiple CUs with ranges. 12 13# POSTCHECK: _Z7doStuffi>: 14# POSTCHECK: [[#%.6x,ADDR:]] 15# POSTCHECK: _Z7doStuffi.__part.1>: 16# POSTCHECK-NEXT: [[#%.6x,ADDR1:]] 17# POSTCHECK: _Z7doStuffi.__part.2>: 18# POSTCHECK-NEXT: [[#%.6x,ADDR2:]] 19 20# POSTCHECK: _Z12doStuffOtheri>: 21# POSTCHECK: [[#%.6x,ADDR3:]] 22# POSTCHECK: _Z12doStuffOtheri.__part.1>: 23# POSTCHECK-NEXT: [[#%.6x,ADDR4:]] 24# POSTCHECK: _Z12doStuffOtheri.__part.2>: 25# POSTCHECK-NEXT: [[#%.6x,ADDR5:]] 26 27# POSTCHECK: DW_TAG_subprogram 28# POSTCHECK-NEXT: DW_AT_ranges 29# POSTCHECK-NEXT: [0x0000000000[[#ADDR]], 0x0000000000[[#ADDR + 0xf]]) 30# POSTCHECK-NEXT: [0x0000000000[[#ADDR1]], 0x0000000000[[#ADDR1 + 0xb]]) 31# POSTCHECK-NEXT: [0x0000000000[[#ADDR2]], 0x0000000000[[#ADDR2 + 0x5]])) 32 33# POSTCHECK: DW_TAG_subprogram 34# POSTCHECK: DW_TAG_subprogram 35# POSTCHECK-NEXT: DW_AT_ranges 36# POSTCHECK-NEXT: [0x0000000000[[#ADDR3]], 0x0000000000[[#ADDR3 + 0xf]]) 37# POSTCHECK-NEXT: [0x0000000000[[#ADDR4]], 0x0000000000[[#ADDR4 + 0xb]]) 38# POSTCHECK-NEXT: [0x0000000000[[#ADDR5]], 0x0000000000[[#ADDR5 + 0x5]])) 39