xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/alloca-align-rounding-32.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -mtriple=i686-apple-darwin | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workerdeclare void @bar(<2 x i64>* %n)
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine void @foo(i32 %h) {
6*9880d681SAndroid Build Coastguard Worker  %p = alloca <2 x i64>, i32 %h
7*9880d681SAndroid Build Coastguard Worker  call void @bar(<2 x i64>* %p)
8*9880d681SAndroid Build Coastguard Worker  ret void
9*9880d681SAndroid Build Coastguard Worker; CHECK: foo
10*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: andl $-32, %eax
11*9880d681SAndroid Build Coastguard Worker}
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Workerdefine void @foo2(i32 %h) {
14*9880d681SAndroid Build Coastguard Worker  %p = alloca <2 x i64>, i32 %h, align 32
15*9880d681SAndroid Build Coastguard Worker  call void @bar(<2 x i64>* %p)
16*9880d681SAndroid Build Coastguard Worker  ret void
17*9880d681SAndroid Build Coastguard Worker; CHECK: foo2
18*9880d681SAndroid Build Coastguard Worker; CHECK: andl $-32, %esp
19*9880d681SAndroid Build Coastguard Worker; CHECK: andl $-32, %e{{..}}
20*9880d681SAndroid Build Coastguard Worker}
21