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 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 19 } 20 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 27 } 28 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 35 } 36 37 declare void @f3(i8*) 38 39 attributes #0 = { nounwind } 40