xref: /aosp_15_r20/external/llvm/test/CodeGen/Mips/align16.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=16
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker@i = global i32 25, align 4
4*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [5 x i8] c"%i \0A\00", align 1
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workerdefine void @p(i32* %i) nounwind {
7*9880d681SAndroid Build Coastguard Workerentry:
8*9880d681SAndroid Build Coastguard Worker  ret void
9*9880d681SAndroid Build Coastguard Worker}
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Workerdefine void @foo() nounwind {
13*9880d681SAndroid Build Coastguard Workerentry:
14*9880d681SAndroid Build Coastguard Worker  %y = alloca [512 x i32], align 4
15*9880d681SAndroid Build Coastguard Worker  %x = alloca i32, align 8
16*9880d681SAndroid Build Coastguard Worker  %zz = alloca i32, align 4
17*9880d681SAndroid Build Coastguard Worker  %z = alloca i32, align 4
18*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* @i, align 4
19*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds [512 x i32], [512 x i32]* %y, i32 0, i32 10
20*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %arrayidx, align 4
21*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* @i, align 4
22*9880d681SAndroid Build Coastguard Worker  store i32 %1, i32* %x, align 8
23*9880d681SAndroid Build Coastguard Worker  call void @p(i32* %x)
24*9880d681SAndroid Build Coastguard Worker  %arrayidx1 = getelementptr inbounds [512 x i32], [512 x i32]* %y, i32 0, i32 10
25*9880d681SAndroid Build Coastguard Worker  call void @p(i32* %arrayidx1)
26*9880d681SAndroid Build Coastguard Worker  ret void
27*9880d681SAndroid Build Coastguard Worker}
28*9880d681SAndroid Build Coastguard Worker; 16:	save	$ra, 2040
29*9880d681SAndroid Build Coastguard Worker; 16:	addiu	$sp, -40 # 16 bit inst
30*9880d681SAndroid Build Coastguard Worker; 16:	addiu	$sp, 40 # 16 bit inst
31*9880d681SAndroid Build Coastguard Worker; 16:	restore	$ra, 2040
32