From 67977ad19cf961f61c35006d9cc5695c4dde6655 Mon Sep 17 00:00:00 2001 From: Nate Begeman Date: Wed, 3 May 2006 04:52:47 +0000 Subject: [PATCH] Teach the x86 jit how to handle jump tables not directly used by a jump instruction. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28080 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/X86CodeEmitter.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lib/Target/X86/X86CodeEmitter.cpp b/lib/Target/X86/X86CodeEmitter.cpp index ca6c78df5ec..9e2c998e3f1 100644 --- a/lib/Target/X86/X86CodeEmitter.cpp +++ b/lib/Target/X86/X86CodeEmitter.cpp @@ -517,6 +517,9 @@ void Emitter::emitInstruction(const MachineInstr &MI) { else if (MI.getOperand(4).isGlobalAddress()) emitGlobalAddressForPtr(MI.getOperand(4).getGlobal(), MI.getOperand(4).getOffset()); + else if (MI.getOperand(4).isJumpTableIndex()) + emitConstant(MCE.getJumpTableEntryAddress(MI.getOperand(4) + .getJumpTableIndex()), 4); else assert(0 && "Unknown operand!"); }