mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
e8dd5bcb82
xray_instr_map contains absolute addresses of sleds, which are relocated by `R_*_RELATIVE` when linked in -pie or -shared mode. By making these addresses relative to PC, we can avoid the dynamic relocations and remove the SHF_WRITE flag from xray_instr_map. We can thus save VM pages containg xray_instr_map (because they are not modified). This patch changes x86-64 and bumps the sled version to 2. Subsequent changes will change powerpc64le and AArch64. Reviewed By: dberris, ianlevesque Differential Revision: https://reviews.llvm.org/D78082
62 lines
2.1 KiB
LLVM
62 lines
2.1 KiB
LLVM
; RUN: llc -verify-machineinstrs -filetype=asm -o - -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s
|
|
; RUN: llc -verify-machineinstrs -filetype=asm -o - \
|
|
; RUN: -mtriple=x86_64-unknown-linux-gnu -relocation-model=pic < %s | FileCheck %s
|
|
; RUN: llc -verify-machineinstrs -filetype=asm -o - -mtriple=x86_64-darwin-unknown < %s | FileCheck %s
|
|
|
|
define i32 @foo() nounwind noinline uwtable "function-instrument"="xray-always" {
|
|
; CHECK: .p2align 1, 0x90
|
|
; CHECK-LABEL: Lxray_sled_0:
|
|
; CHECK: .ascii "\353\t"
|
|
; CHECK-NEXT: nopw 512(%rax,%rax)
|
|
ret i32 0
|
|
; CHECK: .p2align 1, 0x90
|
|
; CHECK-LABEL: Lxray_sled_1:
|
|
; CHECK: retq
|
|
; CHECK-NEXT: nopw %cs:512(%rax,%rax)
|
|
}
|
|
; CHECK-LABEL: xray_instr_map
|
|
; CHECK-LABEL: Lxray_sleds_start0:
|
|
; CHECK: .quad {{.*}}xray_sled_0
|
|
; CHECK: .quad {{.*}}xray_sled_1
|
|
; CHECK-LABEL: Lxray_sleds_end0:
|
|
; CHECK-LABEL: xray_fn_idx
|
|
; CHECK: .quad {{.*}}xray_sleds_start0
|
|
; CHECK-NEXT: .quad {{.*}}xray_sleds_end0
|
|
|
|
|
|
; We test multiple returns in a single function to make sure we're getting all
|
|
; of them with XRay instrumentation.
|
|
define i32 @bar(i32 %i) nounwind noinline uwtable "function-instrument"="xray-always" {
|
|
; CHECK: .p2align 1, 0x90
|
|
; CHECK-LABEL: Lxray_sled_2:
|
|
; CHECK: .ascii "\353\t"
|
|
; CHECK-NEXT: nopw 512(%rax,%rax)
|
|
Test:
|
|
%cond = icmp eq i32 %i, 0
|
|
br i1 %cond, label %IsEqual, label %NotEqual
|
|
IsEqual:
|
|
ret i32 0
|
|
; CHECK: .p2align 1, 0x90
|
|
; CHECK-LABEL: Lxray_sled_3:
|
|
; CHECK: retq
|
|
; CHECK-NEXT: nopw %cs:512(%rax,%rax)
|
|
NotEqual:
|
|
ret i32 1
|
|
; CHECK: .p2align 1, 0x90
|
|
; CHECK-LABEL: Lxray_sled_4:
|
|
; CHECK: retq
|
|
; CHECK-NEXT: nopw %cs:512(%rax,%rax)
|
|
}
|
|
; CHECK-LABEL: xray_instr_map
|
|
; CHECK-LABEL: Lxray_sleds_start1:
|
|
; CHECK: Ltmp2:
|
|
; CHECK-NEXT: .quad {{.*}}xray_sled_2-{{\.?}}Ltmp2
|
|
; CHECK: Ltmp3:
|
|
; CHECK-NEXT: .quad {{.*}}xray_sled_3-{{\.?}}Ltmp3
|
|
; CHECK: Ltmp4:
|
|
; CHECK-NEXT: .quad {{.*}}xray_sled_4-{{\.?}}Ltmp4
|
|
; CHECK-LABEL: Lxray_sleds_end1:
|
|
; CHECK-LABEL: xray_fn_idx
|
|
; CHECK: .quad {{.*}}xray_sleds_start1
|
|
; CHECK-NEXT: .quad {{.*}}xray_sleds_end1
|