summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/Mips/MipsTargetMachine.cpp
diff options
context:
space:
mode:
authorAkira Hatanaka <ahatanaka@mips.com>2012-06-14 01:19:35 +0000
committerAkira Hatanaka <ahatanaka@mips.com>2012-06-14 01:19:35 +0000
commiteb36522a4da83132fcf4c8cae8653dca01a59825 (patch)
tree6eddd96e0610fff090c03f93f0058c7d7f2fe48c /llvm/lib/Target/Mips/MipsTargetMachine.cpp
parent64f8df28ed641e0aecb2dba2e48e2be464906ff3 (diff)
downloadbcm5719-llvm-eb36522a4da83132fcf4c8cae8653dca01a59825.tar.gz
bcm5719-llvm-eb36522a4da83132fcf4c8cae8653dca01a59825.zip
Add long branch expansion pass for MIPS.
llvm-svn: 158433
Diffstat (limited to 'llvm/lib/Target/Mips/MipsTargetMachine.cpp')
-rw-r--r--llvm/lib/Target/Mips/MipsTargetMachine.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/Target/Mips/MipsTargetMachine.cpp b/llvm/lib/Target/Mips/MipsTargetMachine.cpp
index 7ba610e3b1c..b03baa81f2a 100644
--- a/llvm/lib/Target/Mips/MipsTargetMachine.cpp
+++ b/llvm/lib/Target/Mips/MipsTargetMachine.cpp
@@ -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;
}
OpenPOWER on IntegriCloud