aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/ARM/alloca-align.ll
blob: 6f5eb9d012da32f9384bde4055b029b1a3759a0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
; RUN: llc -o - %s | FileCheck %s
target triple="arm--"

@glob = external global ptr

declare void @bar(ptr, ptr byval([20000 x i8]))

; CHECK-LABEL: foo:
; We should see the stack getting additional alignment
; CHECK: sub sp, sp, #16
; CHECK: bic sp, sp, #31
; And a base pointer getting used.
; CHECK: mov r6, sp
; Which is passed to the call
; CHECK: mov r0, r6
; CHECK: bl bar
define void @foo(ptr %addr) {
  %tmp = alloca [4 x i32], align 32
  call void @bar(ptr %tmp, ptr byval([20000 x i8]) %addr)
  ret void
}