blob: a1dce7fd4a3cd1883cc23cdc9a0be753c072174d [file] [log] [blame]
Martin Storsjo9a55c1b2018-03-19 20:06:50 +00001; RUN: llc -mtriple thumbv7-windows -filetype asm -o - %s | FileCheck %s
2
3declare arm_aapcs_vfpcc i32 @num_entries()
4
5define arm_aapcs_vfpcc void @test___builtin_alloca() "no-stack-arg-probe" {
6entry:
7 %array = alloca i8*, align 4
8 %call = call arm_aapcs_vfpcc i32 @num_entries()
9 %mul = mul i32 4, %call
10 %0 = alloca i8, i32 %mul
11 store i8* %0, i8** %array, align 4
12 ret void
13}
14
15; CHECK: bl num_entries
16; CHECK: movs [[R1:r[0-9]+]], #7
17; CHECK: add.w [[R0:r[0-9]+]], [[R1]], [[R0]], lsl #2
18; CHECK: bic [[R0]], [[R0]], #7
19; CHECK-NOT: bl __chkstk
20; CHECK: sub.w [[R0]], sp, [[R0]]
21; CHECK: mov sp, [[R0]]