• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; RUN: llc -march=hexagon < %s | FileCheck %s
2;
3; Check that the immediate form for the store instructions are generated.
4;
5; CHECK: memw(r{{[0-9]+}}+#156) = #0
6; CHECK: memw(r{{[0-9]+}}+#160) = ##g0+144
7; CHECK: memw(r{{[0-9]+}}+#172) = ##f3
8
9%s.0 = type { [156 x i8], i8*, i8*, i8, i8*, void (i8*)*, i8 }
10
11@g0 = common global %s.0 zeroinitializer, align 4
12
13; Function Attrs: nounwind
14define void @f0(%s.0* %a0) #0 {
15b0:
16  %v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 1
17  store i8* null, i8** %v0, align 4
18  ret void
19}
20
21; Function Attrs: nounwind
22define void @f1(%s.0* %a0) #0 {
23b0:
24  %v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 2
25  store i8* getelementptr inbounds (%s.0, %s.0* @g0, i32 0, i32 0, i32 144), i8** %v0, align 4
26  ret void
27}
28
29; Function Attrs: nounwind
30define void @f2(%s.0* %a0) #0 {
31b0:
32  %v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 5
33  store void (i8*)* @f3, void (i8*)** %v0, align 4
34  ret void
35}
36
37declare void @f3(i8*)
38
39attributes #0 = { nounwind }
40