1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-24 03:33:20 +01:00
llvm-mirror/test/CodeGen/Hexagon/store1.ll
Krzysztof Parzyszek 66abdd815e [Hexagon] Add more lit tests
llvm-svn: 327271
2018-03-12 14:01:28 +00:00

40 lines
1007 B
LLVM

; RUN: llc -march=hexagon < %s | FileCheck %s
;
; Check that the immediate form for the store instructions are generated.
;
; CHECK: memw(r{{[0-9]+}}+#156) = #0
; CHECK: memw(r{{[0-9]+}}+#160) = ##g0+144
; CHECK: memw(r{{[0-9]+}}+#172) = ##f3
%s.0 = type { [156 x i8], i8*, i8*, i8, i8*, void (i8*)*, i8 }
@g0 = common global %s.0 zeroinitializer, align 4
; Function Attrs: nounwind
define void @f0(%s.0* %a0) #0 {
b0:
%v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 1
store i8* null, i8** %v0, align 4
ret void
}
; Function Attrs: nounwind
define void @f1(%s.0* %a0) #0 {
b0:
%v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 2
store i8* getelementptr inbounds (%s.0, %s.0* @g0, i32 0, i32 0, i32 144), i8** %v0, align 4
ret void
}
; Function Attrs: nounwind
define void @f2(%s.0* %a0) #0 {
b0:
%v0 = getelementptr inbounds %s.0, %s.0* %a0, i32 0, i32 5
store void (i8*)* @f3, void (i8*)** %v0, align 4
ret void
}
declare void @f3(i8*)
attributes #0 = { nounwind }