summaryrefslogtreecommitdiff
path: root/test/CodeGen/Mips/align16.ll
blob: ac6685dd552463010557a0a4acbf9443430b2cd4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
; RUN: llc -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=16

@i = global i32 25, align 4
@.str = private unnamed_addr constant [5 x i8] c"%i \0A\00", align 1

define void @p(i32* %i) nounwind {
entry:
  ret void
}


define void @foo() nounwind {
entry:
  %y = alloca [512 x i32], align 4
  %x = alloca i32, align 8
  %zz = alloca i32, align 4
  %z = alloca i32, align 4
  %0 = load i32, i32* @i, align 4
  %arrayidx = getelementptr inbounds [512 x i32], [512 x i32]* %y, i32 0, i32 10
  store i32 %0, i32* %arrayidx, align 4
  %1 = load i32, i32* @i, align 4
  store i32 %1, i32* %x, align 8
  call void @p(i32* %x)
  %arrayidx1 = getelementptr inbounds [512 x i32], [512 x i32]* %y, i32 0, i32 10
  call void @p(i32* %arrayidx1)
  ret void
}
; 16:	save	$ra, 2040
; 16:	addiu	$sp, -40 # 16 bit inst
; 16:	addiu	$sp, 40 # 16 bit inst
; 16:	restore	$ra, 2040