[llvm-commits] CVS: llvm/lib/Target/ARM/ARMInstrInfo.td

Rafael Espindola rafael.espindola at gmail.com
Mon Oct 16 11:32:50 PDT 2006



Changes in directory llvm/lib/Target/ARM:

ARMInstrInfo.td updated: 1.54 -> 1.55
---
Log message:

add the FPBinOp class


---
Diffs of the changes:  (+8 -9)

 ARMInstrInfo.td |   17 ++++++++---------
 1 files changed, 8 insertions(+), 9 deletions(-)


Index: llvm/lib/Target/ARM/ARMInstrInfo.td
diff -u llvm/lib/Target/ARM/ARMInstrInfo.td:1.54 llvm/lib/Target/ARM/ARMInstrInfo.td:1.55
--- llvm/lib/Target/ARM/ARMInstrInfo.td:1.54	Mon Oct 16 13:18:14 2006
+++ llvm/lib/Target/ARM/ARMInstrInfo.td	Mon Oct 16 13:32:36 2006
@@ -51,6 +51,11 @@
                  !strconcat(OpcStr, " $dst, $a, $b"),
                  [(set IntRegs:$dst, (OpNode IntRegs:$a, IntRegs:$b))]>;
 
+class FPBinOp<string OpcStr, SDNode OpNode> :
+        InstARM<(ops FPRegs:$dst, FPRegs:$a, FPRegs:$b),
+                 !strconcat(OpcStr, " $dst, $a, $b"),
+                 [(set FPRegs:$dst, (OpNode FPRegs:$a, FPRegs:$b))]>;
+
 class Addr1BinOp<string OpcStr, SDNode OpNode> :
         InstARM<(ops IntRegs:$dst, IntRegs:$a, op_addr_mode1:$b),
                  !strconcat(OpcStr, " $dst, $a, $b"),
@@ -251,17 +256,13 @@
 def FMSTAT  : InstARM<(ops ), "fmstat", [(armfmstat)]>;
 
 // Floating Point Arithmetic
-def FADDS   : InstARM<(ops FPRegs:$dst, FPRegs:$a, FPRegs:$b),
-                       "fadds $dst, $a, $b",
-		       [(set FPRegs:$dst, (fadd FPRegs:$a, FPRegs:$b))]>;
+def FADDS   : FPBinOp<"fadds", fadd>;
 
 def FADDD   : InstARM<(ops DFPRegs:$dst, DFPRegs:$a, DFPRegs:$b),
                        "faddd $dst, $a, $b",
 		       [(set DFPRegs:$dst, (fadd DFPRegs:$a, DFPRegs:$b))]>;
 
-def FSUBS   : InstARM<(ops FPRegs:$dst, FPRegs:$a, FPRegs:$b),
-                       "fsubs $dst, $a, $b",
-		       [(set FPRegs:$dst, (fsub FPRegs:$a, FPRegs:$b))]>;
+def FSUBS   : FPBinOp<"fsubs", fsub>;
 
 def FSUBD   : InstARM<(ops DFPRegs:$dst, DFPRegs:$a, DFPRegs:$b),
                        "fsubd $dst, $a, $b",
@@ -275,9 +276,7 @@
                        "fnegd $dst, $src",
 		       [(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
 
-def FMULS   : InstARM<(ops FPRegs:$dst, FPRegs:$a, FPRegs:$b),
-                       "fmuls $dst, $a, $b",
-		       [(set FPRegs:$dst, (fmul FPRegs:$a, FPRegs:$b))]>;
+def FMULS   : FPBinOp<"fmuls", fmul>;
 
 def FMULD   : InstARM<(ops DFPRegs:$dst, DFPRegs:$a, DFPRegs:$b),
                        "fmuld $dst, $a, $b",






More information about the llvm-commits mailing list