[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / Hexagon / store1.ll
blobf6329c35f46a6f4985c66c9fff19d5ac3d93d434
1 ; RUN: llc -march=hexagon < %s | FileCheck %s
3 ; Check that the immediate form for the store instructions are generated.
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
9 %s.0 = type { [156 x i8], i8*, i8*, i8, i8*, void (i8*)*, i8 }
11 @g0 = common global %s.0 zeroinitializer, align 4
13 ; Function Attrs: nounwind
14 define void @f0(%s.0* %a0) #0 {
15 b0:
16   %v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 1
17   store i8* null, i8** %v0, align 4
18   ret void
21 ; Function Attrs: nounwind
22 define void @f1(%s.0* %a0) #0 {
23 b0:
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
29 ; Function Attrs: nounwind
30 define void @f2(%s.0* %a0) #0 {
31 b0:
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
37 declare void @f3(i8*)
39 attributes #0 = { nounwind }