1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-20 19:42:54 +02:00
llvm-mirror/test/CodeGen/Hexagon/packetize-tailcall-arg.ll
Krzysztof Parzyszek 6edea3d184 [Hexagon] Packetize function call arguments with tail call instructions
On Hexagon is it legal to packetize the instructions setting up call
arguments with the call instruction itself. This was already done,
except for tail calls. Make sure tail calls are handled as well.

llvm-svn: 275458
2016-07-14 19:30:55 +00:00

23 lines
447 B
LLVM

; RUN: llc -march=hexagon < %s | FileCheck %s
; There should only be one packet:
; {
; jump free
; r0 = memw(r0 + #-4)
; }
;
; CHECK: {
; CHECK-NOT: {
define void @fred(i8* %p) nounwind {
entry:
%arrayidx = getelementptr inbounds i8, i8* %p, i32 -4
%t0 = bitcast i8* %arrayidx to i8**
%t1 = load i8*, i8** %t0, align 4
tail call void @free(i8* %t1)
ret void
}
; Function Attrs: nounwind
declare void @free(i8* nocapture) nounwind