xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/patchable-prologue.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -filetype=obj -o - -mtriple=x86_64-apple-macosx < %s | llvm-objdump -triple x86_64-apple-macosx -disassemble - | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=x86_64-apple-macosx < %s | FileCheck %s --check-prefix=CHECK-ALIGN
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdeclare void @callee(i64*)
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workerdefine void @f0() "patchable-function"="prologue-short-redirect" {
7*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: _f0:
8*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  66 90 	nop
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: 	.p2align	4, 0x90
11*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: _f0:
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Worker  ret void
14*9880d681SAndroid Build Coastguard Worker}
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Workerdefine void @f1() "patchable-function"="prologue-short-redirect" "no-frame-pointer-elim"="true" {
17*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: _f1
18*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ff f5 	pushq	%rbp
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: 	.p2align	4, 0x90
21*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: _f1:
22*9880d681SAndroid Build Coastguard Worker  ret void
23*9880d681SAndroid Build Coastguard Worker}
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerdefine void @f2() "patchable-function"="prologue-short-redirect" {
26*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: _f2
27*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: 48 81 ec a8 00 00 00 	subq	$168, %rsp
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: 	.p2align	4, 0x90
30*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: _f2:
31*9880d681SAndroid Build Coastguard Worker  %ptr = alloca i64, i32 20
32*9880d681SAndroid Build Coastguard Worker  call void @callee(i64* %ptr)
33*9880d681SAndroid Build Coastguard Worker  ret void
34*9880d681SAndroid Build Coastguard Worker}
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Workerdefine void @f3() "patchable-function"="prologue-short-redirect" optsize {
37*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: _f3
38*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: 66 90 	nop
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: 	.p2align	4, 0x90
41*9880d681SAndroid Build Coastguard Worker; CHECK-ALIGN: _f3:
42*9880d681SAndroid Build Coastguard Worker  ret void
43*9880d681SAndroid Build Coastguard Worker}
44*9880d681SAndroid Build Coastguard Worker
45*9880d681SAndroid Build Coastguard Worker; This testcase happens to produce a KILL instruction at the beginning of the
46*9880d681SAndroid Build Coastguard Worker; first basic block. In this case the 2nd instruction should be turned into a
47*9880d681SAndroid Build Coastguard Worker; patchable one.
48*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f4:
49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: 8b 0c 37  movl  (%rdi,%rsi), %ecx
50*9880d681SAndroid Build Coastguard Workerdefine i32 @f4(i8* %arg1, i64 %arg2, i32 %arg3) "patchable-function"="prologue-short-redirect" {
51*9880d681SAndroid Build Coastguard Workerbb:
52*9880d681SAndroid Build Coastguard Worker  %tmp10 = getelementptr i8, i8* %arg1, i64 %arg2
53*9880d681SAndroid Build Coastguard Worker  %tmp11 = bitcast i8* %tmp10 to i32*
54*9880d681SAndroid Build Coastguard Worker  %tmp12 = load i32, i32* %tmp11, align 4
55*9880d681SAndroid Build Coastguard Worker  fence acquire
56*9880d681SAndroid Build Coastguard Worker  %tmp13 = add i32 %tmp12, %arg3
57*9880d681SAndroid Build Coastguard Worker  %tmp14 = cmpxchg i32* %tmp11, i32 %tmp12, i32 %tmp13 seq_cst monotonic
58*9880d681SAndroid Build Coastguard Worker  %tmp15 = extractvalue { i32, i1 } %tmp14, 1
59*9880d681SAndroid Build Coastguard Worker  br i1 %tmp15, label %bb21, label %bb16
60*9880d681SAndroid Build Coastguard Worker
61*9880d681SAndroid Build Coastguard Workerbb16:
62*9880d681SAndroid Build Coastguard Worker  br label %bb21
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Workerbb21:
65*9880d681SAndroid Build Coastguard Worker  %tmp22 = phi i32 [ %tmp12, %bb ], [ %arg3, %bb16 ]
66*9880d681SAndroid Build Coastguard Worker  ret i32 %tmp22
67*9880d681SAndroid Build Coastguard Worker}
68