aboutsummaryrefslogtreecommitdiffstats
path: root/lib
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
commitcc0d2f586f87a6aef77514ee75dab67cbfc235cb (patch)
treef91f86176227d64c6dc35c721676befe18280124 /lib
parent9b9b7fc28d2e16905cb40bcb3c8691a73ece3a21 (diff)
downloadexternal_llvm-cc0d2f586f87a6aef77514ee75dab67cbfc235cb.tar.gz
external_llvm-cc0d2f586f87a6aef77514ee75dab67cbfc235cb.tar.bz2
external_llvm-cc0d2f586f87a6aef77514ee75dab67cbfc235cb.zip
Add support for GlobalAddress's for alkis
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11560 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Target/X86/X86CodeEmitter.cpp7
-rw-r--r--lib/Target/X86/X86RegisterInfo.cpp10
2 files changed, 14 insertions, 3 deletions
diff --git a/lib/Target/X86/X86CodeEmitter.cpp b/lib/Target/X86/X86CodeEmitter.cpp
index f9de6febb7..e02fcbf16f 100644
--- a/lib/Target/X86/X86CodeEmitter.cpp
+++ b/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/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp
index d94e4ac266..6479ad56a7 100644
--- a/lib/Target/X86/X86RegisterInfo.cpp
+++ b/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,