From: Chris Lattner Date: Fri, 6 Oct 2006 22:50:56 +0000 (+0000) Subject: If a target uses a GOT, put it in the jt data section, not the text X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=0336fdba858830d515bf53ac29b8e5ff24dfa823;p=oota-llvm.git If a target uses a GOT, put it in the jt data section, not the text section. This will fix alpha when Andrew implements AlphaTargetMachine::getTargetLowering(). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30779 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter.cpp index 96a481fc846..33b6b979d0d 100644 --- a/lib/CodeGen/AsmPrinter.cpp +++ b/lib/CodeGen/AsmPrinter.cpp @@ -22,6 +22,7 @@ #include "llvm/Support/MathExtras.h" #include "llvm/Target/TargetAsmInfo.h" #include "llvm/Target/TargetData.h" +#include "llvm/Target/TargetLowering.h" #include "llvm/Target/TargetMachine.h" #include #include @@ -200,10 +201,17 @@ void AsmPrinter::EmitJumpTableInfo(MachineJumpTableInfo *MJTI, // Pick the directive to use to print the jump table entries, and switch to // the appropriate section. if (TM.getRelocationModel() == Reloc::PIC_) { - // In PIC mode, we need to emit the jump table to the same section as the - // function body itself, otherwise the label differences won't make sense. - const Function *F = MF.getFunction(); - SwitchToTextSection(getSectionForFunction(*F).c_str(), F); + TargetLowering *LoweringInfo = TM.getTargetLowering(); + if (LoweringInfo && LoweringInfo->usesGlobalOffsetTable()) { + SwitchToDataSection(TAI->getJumpTableDataSection(), 0); + if (TD->getPointerSize() == 8) + JTEntryDirective = TAI->getData64bitsDirective(); + } else { + // In PIC mode, we need to emit the jump table to the same section as the + // function body itself, otherwise the label differences won't make sense. + const Function *F = MF.getFunction(); + SwitchToTextSection(getSectionForFunction(*F).c_str(), F); + } } else { SwitchToDataSection(TAI->getJumpTableDataSection(), 0); if (TD->getPointerSize() == 8)