diff options
| author | Misha Brukman <brukman+llvm@gmail.com> | 2004-06-28 17:57:40 +0000 |
|---|---|---|
| committer | Misha Brukman <brukman+llvm@gmail.com> | 2004-06-28 17:57:40 +0000 |
| commit | 8455e0177b6b4fc5bf66b65ad35164e5d72c8cba (patch) | |
| tree | 06db5ae21684a6d20f11f4d8184d08a35d426d23 /llvm/lib/Target/PowerPC | |
| parent | 3337c8274506235e156c728682339753870fea4b (diff) | |
| download | bcm5719-llvm-8455e0177b6b4fc5bf66b65ad35164e5d72c8cba.tar.gz bcm5719-llvm-8455e0177b6b4fc5bf66b65ad35164e5d72c8cba.zip | |
Do not set the `link' bit when branching to the first BB of a function, as it
will cause an infinite loop. The link bit is only used for calling functions.
llvm-svn: 14466
Diffstat (limited to 'llvm/lib/Target/PowerPC')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPC32AsmPrinter.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PowerPCAsmPrinter.cpp | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/llvm/lib/Target/PowerPC/PPC32AsmPrinter.cpp b/llvm/lib/Target/PowerPC/PPC32AsmPrinter.cpp index c5825a786f0..636b1c413db 100644 --- a/llvm/lib/Target/PowerPC/PPC32AsmPrinter.cpp +++ b/llvm/lib/Target/PowerPC/PPC32AsmPrinter.cpp @@ -423,7 +423,7 @@ void Printer::printOp(const MachineOperand &MO, } case MachineOperand::MO_PCRelativeDisp: std::cerr << "Shouldn't use addPCDisp() when building PPC MachineInstrs"; - abort (); + abort(); return; case MachineOperand::MO_GlobalAddress: if (!elideOffsetKeyword) { @@ -507,7 +507,7 @@ void Printer::printMachineInstruction(const MachineInstr *MI) { if (Opcode == PPC32::MovePCtoLR) { O << "mflr r0\n"; - O << "\tbcl 20,31,L" << CurrentFnName << "$pb\n"; + O << "\tbc 20,31,L" << CurrentFnName << "$pb\n"; O << "L" << CurrentFnName << "$pb:\n"; return; } diff --git a/llvm/lib/Target/PowerPC/PowerPCAsmPrinter.cpp b/llvm/lib/Target/PowerPC/PowerPCAsmPrinter.cpp index c5825a786f0..636b1c413db 100644 --- a/llvm/lib/Target/PowerPC/PowerPCAsmPrinter.cpp +++ b/llvm/lib/Target/PowerPC/PowerPCAsmPrinter.cpp @@ -423,7 +423,7 @@ void Printer::printOp(const MachineOperand &MO, } case MachineOperand::MO_PCRelativeDisp: std::cerr << "Shouldn't use addPCDisp() when building PPC MachineInstrs"; - abort (); + abort(); return; case MachineOperand::MO_GlobalAddress: if (!elideOffsetKeyword) { @@ -507,7 +507,7 @@ void Printer::printMachineInstruction(const MachineInstr *MI) { if (Opcode == PPC32::MovePCtoLR) { O << "mflr r0\n"; - O << "\tbcl 20,31,L" << CurrentFnName << "$pb\n"; + O << "\tbc 20,31,L" << CurrentFnName << "$pb\n"; O << "L" << CurrentFnName << "$pb:\n"; return; } |

