Home | History | Annotate | Download | only in Hexagon
      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