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