Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARM / stack-protector-bmovpcb_call.ll
blob6f2cb4251b45618222ba172b4dd74a7c45f71c28
1 ; RUN: llc -O3 -mcpu=swift -mtriple=armv7s-apple-ios6.0.0 %s -o /dev/null
2 ; rdar://14811848
4 ; Make sure that we do not emit the BMOVPCB_CALL instruction for now or if we
5 ; fix the assumptions in its implementation that we do not crash when doing it.
7 target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:32:64-v128:32:128-a0:0:32-n32-S32"
8 target triple = "armv7s-apple-ios6.0.0"
10 @main.title = private unnamed_addr constant [15 x i8] c"foo and stuff\0A\00", align 1
11 @.str = private unnamed_addr constant [3 x i8] c"%s\00", align 1
13 ; Function Attrs: nounwind optsize ssp
14 define i32 @main() #0 {
15 entry:
16   %title = alloca [15 x i8], align 1
17   call void @llvm.memcpy.p0.p0.i32(ptr align 1 %title, ptr align 1 @main.title, i32 15, i1 false)
18   %call = call i32 (ptr, ...) @printf(ptr @.str, ptr %title) #3
19   ret i32 0
22 ; Function Attrs: nounwind
23 declare void @llvm.memcpy.p0.p0.i32(ptr nocapture, ptr nocapture readonly, i32, i1) #1
25 ; Function Attrs: nounwind optsize
26 declare i32 @printf(ptr nocapture readonly, ...) #2
28 attributes #0 = { nounwind optsize ssp "less-precise-fpmad"="false" "frame-pointer"="none" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
29 attributes #1 = { nounwind }
30 attributes #2 = { nounwind optsize "less-precise-fpmad"="false" "frame-pointer"="none" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
31 attributes #3 = { nounwind optsize }