summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-02-17 18:23:55 +0000
committerChris Lattner <sabre@nondot.org>2004-02-17 18:23:55 +0000
commit30e73e34425926300aba39bfd2b6ec96b3fbcbdb (patch)
tree60a45a63c412689070efeb9896a4a52c93f100a1 /llvm
parent47ea17a852e337ecd5b1fd5c68e47e983f1bc8b2 (diff)
downloadbcm5719-llvm-30e73e34425926300aba39bfd2b6ec96b3fbcbdb.tar.gz
bcm5719-llvm-30e73e34425926300aba39bfd2b6ec96b3fbcbdb.zip
Add support for GlobalAddress's for alkis
llvm-svn: 11560
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Target/X86/X86CodeEmitter.cpp7
-rw-r--r--llvm/lib/Target/X86/X86RegisterInfo.cpp10
2 files changed, 14 insertions, 3 deletions
diff --git a/llvm/lib/Target/X86/X86CodeEmitter.cpp b/llvm/lib/Target/X86/X86CodeEmitter.cpp
index f9de6febb7f..e02fcbf16f5 100644
--- a/llvm/lib/Target/X86/X86CodeEmitter.cpp
+++ b/llvm/lib/Target/X86/X86CodeEmitter.cpp
@@ -602,7 +602,12 @@ void Emitter::emitInstruction(MachineInstr &MI) {
if (MI.getNumOperands() == 5) {
unsigned Size = sizeOfPtr(Desc);
- emitConstant(MI.getOperand(4).getImmedValue(), Size);
+ if (MI.getOperand(4).isImmediate())
+ emitConstant(MI.getOperand(4).getImmedValue(), Size);
+ else if (MI.getOperand(4).isGlobalAddress())
+ emitGlobalAddressForPtr(MI.getOperand(4).getGlobal());
+ else
+ assert(0 && "Unknown operand!");
}
break;
}
diff --git a/llvm/lib/Target/X86/X86RegisterInfo.cpp b/llvm/lib/Target/X86/X86RegisterInfo.cpp
index d94e4ac2661..6479ad56a7e 100644
--- a/llvm/lib/Target/X86/X86RegisterInfo.cpp
+++ b/llvm/lib/Target/X86/X86RegisterInfo.cpp
@@ -100,8 +100,14 @@ static MachineInstr *MakeMRInst(unsigned Opcode, unsigned FrameIndex,
static MachineInstr *MakeMIInst(unsigned Opcode, unsigned FrameIndex,
MachineInstr *MI) {
- return addFrameReference(BuildMI(Opcode, 5), FrameIndex)
- .addZImm(MI->getOperand(1).getImmedValue());
+ if (MI->getOperand(1).isImmediate())
+ return addFrameReference(BuildMI(Opcode, 5), FrameIndex)
+ .addZImm(MI->getOperand(1).getImmedValue());
+ else if (MI->getOperand(1).isGlobalAddress())
+ return addFrameReference(BuildMI(Opcode, 5), FrameIndex)
+ .addGlobalAddress(MI->getOperand(1).getGlobal());
+ assert(0 && "Unknown operand for MakeMI!");
+ return 0;
}
static MachineInstr *MakeRMInst(unsigned Opcode, unsigned FrameIndex,
OpenPOWER on IntegriCloud