aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
diff options
context:
space:
mode:
authorScott Michel <scottm@aero.org>2008-12-10 00:15:19 +0000
committerScott Michel <scottm@aero.org>2008-12-10 00:15:19 +0000
commitaedc637c966b6eaa3ca33e9220efe5ec34517de7 (patch)
tree1345ee8a3819d9eefb4ee01c61d54c7d47995b7d /lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
parent30a64a76492b6a92ccf6d6a6ac907ff8b2b18305 (diff)
downloadexternal_llvm-aedc637c966b6eaa3ca33e9220efe5ec34517de7.tar.gz
external_llvm-aedc637c966b6eaa3ca33e9220efe5ec34517de7.tar.bz2
external_llvm-aedc637c966b6eaa3ca33e9220efe5ec34517de7.zip
CellSPU:
- Fix bug 3185, with misc other cleanups. - Needed to implement SPUInstrInfo::InsertBranch(). CAUTION: Not sure what gets or needs to get passed to InsertBranch() to insert a conditional branch. This will abort for now until a good test case shows up. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60811 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp')
-rw-r--r--lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp b/lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
index 94d8cd5aa3..589a260005 100644
--- a/lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
+++ b/lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
@@ -220,6 +220,18 @@ namespace {
}
void printPCRelativeOperand(const MachineInstr *MI, unsigned OpNo) {
+ // Used to generate a ".-<target>", but it turns out that the assembler
+ // really wants the target.
+ //
+ // N.B.: This operand is used for call targets. Branch hints are another
+ // animal entirely.
+ printOp(MI->getOperand(OpNo));
+ }
+
+ void printHBROperand(const MachineInstr *MI, unsigned OpNo) {
+ // HBR operands are generated in front of branches, hence, the
+ // program counter plus the target.
+ O << ".+";
printOp(MI->getOperand(OpNo));
}