2016-07-14 09:31:20 +08:00
|
|
|
; RUN: llc < %s | FileCheck %s -check-prefix=NOIPRA
|
|
|
|
; RUN: llc -enable-ipra < %s | FileCheck %s
|
|
|
|
|
|
|
|
target triple = "x86_64--"
|
|
|
|
|
|
|
|
define internal void @foo() norecurse {
|
|
|
|
; When IPRA is not enabled R15 will be saved by foo as it is callee saved reg.
|
|
|
|
; NOIPRA-LABEL: foo:
|
|
|
|
; NOIPRA: pushq %r15
|
|
|
|
; When IPRA is enabled none register should be saved as foo() is local function
|
|
|
|
; so we optimize it to save no registers.
|
|
|
|
; CHECK-LABEL: foo:
|
|
|
|
; CHECK-NOT: pushq %r15
|
|
|
|
call void asm sideeffect "movl %r14d, %r15d", "~{r15}"()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @bar(i32 %X) {
|
|
|
|
call void asm sideeffect "movl %r12d, $0", "{r15}~{r12}"(i32 %X)
|
|
|
|
; As R15 is clobbered by foo() when IPRA is enabled value of R15 should be
|
|
|
|
; saved if register containing orignal value is also getting clobbered
|
|
|
|
; and reloaded after foo(), here original value is loaded back into R15D after
|
|
|
|
; call to foo.
|
|
|
|
call void @foo()
|
|
|
|
; CHECK-LABEL: bar:
|
|
|
|
; CHECK: callq foo
|
[MachineCopyPropagation] Extend pass to do COPY source forwarding
Summary:
This change extends MachineCopyPropagation to do COPY source forwarding
and adds an additional run of the pass to the default pass pipeline just
after register allocation.
This version of this patch uses the newly added
MachineOperand::isRenamable bit to avoid forwarding registers is such a
way as to violate constraints that aren't captured in the
Machine IR (e.g. ABI or ISA constraints).
This change is a continuation of the work started in D30751.
Reviewers: qcolombet, javed.absar, MatzeB, jonpa, tstellar
Subscribers: tpr, mgorny, mcrosier, nhaehnle, nemanjai, jyknight, hfinkel, arsenm, inouehrs, eraman, sdardis, guyblank, fedor.sergeev, aheejin, dschuff, jfb, myatsina, llvm-commits
Differential Revision: https://reviews.llvm.org/D41835
llvm-svn: 323991
2018-02-02 02:54:01 +08:00
|
|
|
; CHECK-NEXT: movl %edi, %r15d
|
2016-07-14 09:31:20 +08:00
|
|
|
call void asm sideeffect "movl $0, %r12d", "{r15}~{r12}"(i32 %X)
|
|
|
|
ret void
|
|
|
|
}
|