| Krzysztof Parzyszek | 046090d | 2018-03-12 14:01:28 +0000 | [diff] [blame] | 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 } |