Add long branch expansion pass for MIPS.
authorAkira Hatanaka <ahatanaka@mips.com>
Thu, 14 Jun 2012 01:19:35 +0000 (01:19 +0000)
committerAkira Hatanaka <ahatanaka@mips.com>
Thu, 14 Jun 2012 01:19:35 +0000 (01:19 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158433 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/Mips/Mips.h
lib/Target/Mips/MipsTargetMachine.cpp

index 5ce2347144880aeb3270e6d5527ba8b8b55d4d27..2963f7e7fa4204b012bcf7244fa3cf9e66cd9957 100644 (file)
@@ -24,6 +24,7 @@ namespace llvm {
 
   FunctionPass *createMipsISelDag(MipsTargetMachine &TM);
   FunctionPass *createMipsDelaySlotFillerPass(MipsTargetMachine &TM);
+  FunctionPass *createMipsLongBranchPass(MipsTargetMachine &TM);
   FunctionPass *createMipsJITCodeEmitterPass(MipsTargetMachine &TM,
                                              JITCodeEmitter &JCE);
 
index 7ba610e3b1cab807fae7be3eccb37684daaec6c6..b03baa81f2ac91b4baad7c03209ed48158d40d49 100644 (file)
@@ -124,7 +124,13 @@ bool MipsPassConfig::addInstSelector() {
 // machine code is emitted. return true if -print-machineinstrs should
 // print out the code after the passes.
 bool MipsPassConfig::addPreEmitPass() {
-  PM->add(createMipsDelaySlotFillerPass(getMipsTargetMachine()));
+  MipsTargetMachine &TM = getMipsTargetMachine();
+  PM->add(createMipsDelaySlotFillerPass(TM));
+
+  // NOTE: long branch has not been implemented for mips16.
+  if (TM.getSubtarget<MipsSubtarget>().hasStandardEncoding())
+    PM->add(createMipsLongBranchPass(TM));
+
   return true;
 }