summaryrefslogtreecommitdiff
path: root/test/CodeGen/MSP430/struct_layout.ll
blob: 60ae9f09b4ede844ff2353cfe424714b7934e7e2 (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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
; RUN: llc < %s | FileCheck %s

target triple = "msp430"

%struct.X = type { i8 }

; CHECK-LABEL: @foo
; CHECK: sub.w   #4, r1
; CHECK: mov.b   #1, 3(r1)
define void @foo() {
  %1 = alloca %struct.X
  %2 = alloca %struct.X
  %3 = alloca %struct.X
  %4 = getelementptr inbounds %struct.X, %struct.X* %1, i32 0, i32 0
  store i8 1, i8* %4
  %5 = getelementptr inbounds %struct.X, %struct.X* %2, i32 0, i32 0
  store i8 1, i8* %5
  %6 = getelementptr inbounds %struct.X, %struct.X* %3, i32 0, i32 0
  store i8 1, i8* %6
  ret void
}

; CHECK-LABEL: @bar
; CHECK: sub.w   #4, r1
; CHECK: mov.b   #1, 3(r1)
define void @bar() {
  %1 = alloca [3 x %struct.X]
  %2 = getelementptr inbounds [3 x %struct.X], [3 x %struct.X]* %1, i16 0, i16 0
  %3 = getelementptr inbounds %struct.X, %struct.X* %2, i32 0, i32 0
  store i8 1, i8* %3
  %4 = getelementptr inbounds [3 x %struct.X], [3 x %struct.X]* %1, i16 0, i16 1
  %5 = getelementptr inbounds %struct.X, %struct.X* %4, i32 0, i32 0
  store i8 1, i8* %5
  %6 = getelementptr inbounds [3 x %struct.X], [3 x %struct.X]* %1, i16 0, i16 2
  %7 = getelementptr inbounds %struct.X, %struct.X* %6, i32 0, i32 0
  store i8 1, i8* %7
  ret void
}

%struct.Y = type { i8, i16 }

; CHECK-LABEL: @baz
; CHECK: sub.w   #8, r1
; CHECK: mov.w   #2, 6(r1)
define void @baz() {
  %1 = alloca %struct.Y, align 2
  %2 = alloca %struct.Y, align 2
  %3 = getelementptr inbounds %struct.Y, %struct.Y* %1, i32 0, i32 0
  store i8 1, i8* %3, align 2
  %4 = getelementptr inbounds %struct.Y, %struct.Y* %1, i32 0, i32 1
  store i16 2, i16* %4, align 2
  %5 = getelementptr inbounds %struct.Y, %struct.Y* %2, i32 0, i32 0
  store i8 1, i8* %5, align 2
  %6 = getelementptr inbounds %struct.Y, %struct.Y* %2, i32 0, i32 1
  store i16 2, i16* %6, align 2
  ret void
}