forked from OSchip/llvm-project
[Hexagon] Don't mark callee saved registers as clobbered by a tail call
This was causing unnecessary spills/restores of callee saved registers. Fixes PR13572. Patch by Pranav Bhandarkar! llvm-svn: 161778
This commit is contained in:
parent
9746b33e26
commit
0bb7f23cfc
|
@ -2580,22 +2580,16 @@ let isCall = 1, neverHasSideEffects = 1,
|
|||
}
|
||||
|
||||
// Tail Calls.
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1,
|
||||
Defs = [D0, D1, D2, D3, D4, D5, D6, D7, D8, D9, D10,
|
||||
R22, R23, R28, R31, P0, P1, P2, P3, LC0, LC1, SA0, SA1] in {
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1 in {
|
||||
def TCRETURNtg : JInst<(outs), (ins calltarget:$dst),
|
||||
"jump $dst // TAILCALL", []>;
|
||||
}
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1,
|
||||
Defs = [D0, D1, D2, D3, D4, D5, D6, D7, D8, D9, D10,
|
||||
R22, R23, R28, R31, P0, P1, P2, P3, LC0, LC1, SA0, SA1] in {
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1 in {
|
||||
def TCRETURNtext : JInst<(outs), (ins calltarget:$dst),
|
||||
"jump $dst // TAILCALL", []>;
|
||||
}
|
||||
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1,
|
||||
Defs = [D0, D1, D2, D3, D4, D5, D6, D7, D8, D9, D10,
|
||||
R22, R23, R28, R31, P0, P1, P2, P3, LC0, LC1, SA0, SA1] in {
|
||||
let isCall = 1, isBarrier = 1, isReturn = 1, isTerminator = 1 in {
|
||||
def TCRETURNR : JInst<(outs), (ins IntRegs:$dst),
|
||||
"jumpr $dst // TAILCALL", []>;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
; RUN: llc -march=hexagon -mcpu=hexagonv4 < %s | FileCheck %s
|
||||
; CHECK: foo_empty
|
||||
; CHECK-NOT: allocframe
|
||||
; CHECK-NOT: memd(r29
|
||||
; CHECK: jump bar_empty
|
||||
|
||||
define void @foo_empty(i32 %h) nounwind {
|
||||
entry:
|
||||
%add = add nsw i32 %h, 3
|
||||
%call = tail call i32 bitcast (i32 (...)* @bar_empty to i32 (i32)*)(i32 %add) nounwind
|
||||
ret void
|
||||
}
|
||||
|
||||
declare i32 @bar_empty(...)
|
Loading…
Reference in New Issue