diff options
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstr64Bit.td | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstrInfo.td | 2 | 
2 files changed, 3 insertions, 1 deletions
| diff --git a/llvm/lib/Target/PowerPC/PPCInstr64Bit.td b/llvm/lib/Target/PowerPC/PPCInstr64Bit.td index c2351ecfe23..94d709dee1e 100644 --- a/llvm/lib/Target/PowerPC/PPCInstr64Bit.td +++ b/llvm/lib/Target/PowerPC/PPCInstr64Bit.td @@ -296,12 +296,14 @@ def MFLR8  : XFXForm_1_ext<31, 339, 8, (outs G8RC:$rT), (ins),  let PPC970_Unit = 1 in {  // FXU Operations. +let isReMaterializable = 1, isAsCheapAsAMove = 1, isMoveImm = 1 in {  def LI8  : DForm_2_r0<14, (outs G8RC:$rD), (ins symbolLo64:$imm),                        "li $rD, $imm", IntSimple,                        [(set G8RC:$rD, immSExt16:$imm)]>;  def LIS8 : DForm_2_r0<15, (outs G8RC:$rD), (ins symbolHi64:$imm),                        "lis $rD, $imm", IntSimple,                        [(set G8RC:$rD, imm16ShiftedSExt:$imm)]>; +}  // Logical ops.  def NAND8: XForm_6<31, 476, (outs G8RC:$rA), (ins G8RC:$rS, G8RC:$rB), diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.td b/llvm/lib/Target/PowerPC/PPCInstrInfo.td index 0230b4e7954..864b13afc2c 100644 --- a/llvm/lib/Target/PowerPC/PPCInstrInfo.td +++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.td @@ -972,7 +972,7 @@ def SUBFIC : DForm_2< 8, (outs GPRC:$rD), (ins GPRC:$rA, s16imm:$imm),                       [(set GPRC:$rD, (subc immSExt16:$imm, GPRC:$rA))]>;  } -let isReMaterializable = 1 in { +let isReMaterializable = 1, isAsCheapAsAMove = 1, isMoveImm = 1 in {    def LI  : DForm_2_r0<14, (outs GPRC:$rD), (ins symbolLo:$imm),                         "li $rD, $imm", IntSimple,                         [(set GPRC:$rD, immSExt16:$imm)]>; | 

