1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck --check-prefixes=CHECK,NOVECTOR %s
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z15 | FileCheck --check-prefixes=CHECK,VECTOR %s
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z15 -mattr=+soft-float | FileCheck --check-prefixes=CHECK,NOVECTOR %s
define signext i32 @foo() "function-instrument"="xray-always" {
; CHECK-LABEL: .Lxray_sled_0:
; CHECK: j .Ltmp[[#l:]]
; CHECK: bcr 0, %r0
; CHECK: llilf %r2, 0
; NOVECTOR: brasl %r14, __xray_FunctionEntry@PLT
; VECTOR: brasl %r14, __xray_FunctionEntryVec@PLT
; CHECK: .Ltmp[[#l]]:
ret i32 0
; CHECK-LABEL: .Lxray_sled_1:
; CHECK: br %r14
; CHECK: bc 0, 0
; CHECK: llilf %r2, 0
; NOVECtOR: j __xray_FunctionExit@PLT
; VECTOR: j __xray_FunctionExitVec@PLT
}
; CHECK: .section xray_instr_map,"ao",@progbits,foo
; CHECK: .Lxray_sleds_start0:
; CHECK: [[TMP1:.Ltmp[0-9]+]]:
; CHECK: .quad .Lxray_sled_0-[[TMP1]]
; CHECK: .quad .Lfunc_begin0-([[TMP1]]+8)
; CHECK: .byte 0x00
; CHECK: .byte 0x01
; CHECK: .byte 0x02
; CHECK: .space 13
; CHECK: [[TMP2:.Ltmp[0-9]+]]:
; CHECK: .quad .Lxray_sled_1-[[TMP2]]
; CHECK: .quad .Lfunc_begin0-([[TMP2]]+8)
; CHECK: .byte 0x01
; CHECK: .byte 0x01
; CHECK: .byte 0x02
; CHECK: .space 13
; CHECK: .Lxray_sleds_end0:
; CHECK: .section xray_fn_idx,"ao",@progbits,foo
; CHECK: .p2align 3, 0
; CHECK: .Lxray_fn_idx0:
; CHECK: .quad .Lxray_sleds_start0-.Lxray_fn_idx0
; CHECK: .quad 2
|