Codegen ADD X, IMM -> addis/addi if needed.
authorChris Lattner <sabre@nondot.org>
Wed, 28 Sep 2005 23:07:13 +0000 (23:07 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 28 Sep 2005 23:07:13 +0000 (23:07 +0000)
This implements PowerPC/fold-li.ll

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23514 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/PowerPC/PPCInstrInfo.td

index a39aaaa6051a1176c70553fc625ea4d844a58832..4f3715eaf7a602e9f03e2e343da29fe6284e40ce 100644 (file)
@@ -218,6 +218,13 @@ def HI16 : SDNodeXForm<imm, [{
   return getI32Imm((unsigned)N->getValue() >> 16);
 }]>;
 
+def HA16 : SDNodeXForm<imm, [{
+  // Transformation function: shift the immediate value down into the low bits.
+  signed int Val = N->getValue();
+  return getI32Imm((Val - (signed short)Val) >> 16);
+}]>;
+
+
 def immSExt16  : PatLeaf<(imm), [{
   // immSExt16 predicate - True if the immediate fits in a 16-bit sign extended
   // field.  Used by instructions like 'addi'.
@@ -801,10 +808,13 @@ def EQV1 : Pat<(xor (not GPRC:$in1), GPRC:$in2),
 def EQV2 : Pat<(xor GPRC:$in1, (not GPRC:$in2)),
                (EQV GPRC:$in1, GPRC:$in2)>;
 
-// or by an arbitrary immediate.
+// ADD an arbitrary immediate.
+def : Pat<(add GPRC:$in, imm:$imm),
+          (ADDIS (ADDI GPRC:$in, (LO16 imm:$imm)), (HA16 imm:$imm))>;
+// OR an arbitrary immediate.
 def : Pat<(or GPRC:$in, imm:$imm),
           (ORIS (ORI GPRC:$in, (LO16 imm:$imm)), (HI16 imm:$imm))>;
-// xor by an arbitrary immediate.
+// XOR an arbitrary immediate.
 def : Pat<(xor GPRC:$in, imm:$imm),
           (XORIS (XORI GPRC:$in, (LO16 imm:$imm)), (HI16 imm:$imm))>;