diff options
author | Akira Hatanaka <ahatanaka@mips.com> | 2012-06-14 01:19:35 +0000 |
---|---|---|
committer | Akira Hatanaka <ahatanaka@mips.com> | 2012-06-14 01:19:35 +0000 |
commit | eb36522a4da83132fcf4c8cae8653dca01a59825 (patch) | |
tree | 6eddd96e0610fff090c03f93f0058c7d7f2fe48c /llvm/lib/Target/Mips/MipsTargetMachine.cpp | |
parent | 64f8df28ed641e0aecb2dba2e48e2be464906ff3 (diff) | |
download | bcm5719-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.cpp | 8 |
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; } |