summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorReid Kleckner <rnk@google.com>2016-12-29 17:07:10 +0000
committerReid Kleckner <rnk@google.com>2016-12-29 17:07:10 +0000
commitcd46c1df809836ebd9a862ee6be2ea68214e3bf8 (patch)
tree35c7afc359392034aa42030dd7d57c50b29f16db /llvm/lib
parent00d76a57542307c8225324683559075b7f212c65 (diff)
downloadbcm5719-llvm-cd46c1df809836ebd9a862ee6be2ea68214e3bf8.tar.gz
bcm5719-llvm-cd46c1df809836ebd9a862ee6be2ea68214e3bf8.zip
Revert "[COFF] Use 32-bit jump table entries in .rdata for Win64"
This reverts commit r290694. It broke sanitizer tests on Win64. I'll probably bring this back, but the jump tables will just live in .text like they do for MSVC. llvm-svn: 290714
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp7
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp25
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.h1
3 files changed, 0 insertions, 33 deletions
diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
index d19ca47ec1a..eb2a28f574a 100644
--- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
+++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
@@ -1055,13 +1055,6 @@ MCSection *TargetLoweringObjectFileCOFF::getSectionForJumpTable(
COFF::IMAGE_COMDAT_SELECT_ASSOCIATIVE, UniqueID);
}
-bool TargetLoweringObjectFileCOFF::shouldPutJumpTableInFunctionSection(
- bool UsesLabelDifference, const Function &F) const {
- // We can always create relative relocations, so use another section
- // that can be marked non-executable.
- return false;
-}
-
void TargetLoweringObjectFileCOFF::emitModuleFlags(
MCStreamer &Streamer, ArrayRef<Module::ModuleFlagEntry> ModuleFlags,
const TargetMachine &TM) const {
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index d0c77030acd..b293dfa98f8 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -1926,20 +1926,10 @@ unsigned X86TargetLowering::getJumpTableEncoding() const {
if (isPositionIndependent() && Subtarget.isPICStyleGOT())
return MachineJumpTableInfo::EK_Custom32;
- // On Win64, we want to use both label differences and a separate section.
- if (Subtarget.isTargetWin64())
- return MachineJumpTableInfo::EK_LabelDifference32;
-
// Otherwise, use the normal jump table encoding heuristics.
return TargetLowering::getJumpTableEncoding();
}
-bool X86TargetLowering::isJumpTableRelative() const {
- if (Subtarget.isTargetWin64())
- return true;
- return TargetLowering::isJumpTableRelative();
-}
-
bool X86TargetLowering::useSoftFloat() const {
return Subtarget.useSoftFloat();
}
@@ -1958,19 +1948,11 @@ X86TargetLowering::LowerCustomJumpTableEntry(const MachineJumpTableInfo *MJTI,
/// Returns relocation base for the given PIC jumptable.
SDValue X86TargetLowering::getPICJumpTableRelocBase(SDValue Table,
SelectionDAG &DAG) const {
- // COFF doesn't have relocations to take the difference between two arbitrary
- // symbols. The assembler, however, can resolve a fixup between the function
- // entry and a basic block label, so use the function entry as the base.
- if (Subtarget.isTargetWin64())
- return DAG.getGlobalAddress(DAG.getMachineFunction().getFunction(), SDLoc(),
- getPointerTy(DAG.getDataLayout()));
-
if (!Subtarget.is64Bit())
// This doesn't have SDLoc associated with it, but is not really the
// same as a Register.
return DAG.getNode(X86ISD::GlobalBaseReg, SDLoc(),
getPointerTy(DAG.getDataLayout()));
-
return Table;
}
@@ -1979,13 +1961,6 @@ SDValue X86TargetLowering::getPICJumpTableRelocBase(SDValue Table,
const MCExpr *X86TargetLowering::
getPICJumpTableRelocBaseExpr(const MachineFunction *MF, unsigned JTI,
MCContext &Ctx) const {
- // COFF doesn't have relocations to take the difference between two arbitrary
- // symbols. The assembler, however, can resolve a fixup between the function
- // entry and a basic block label, so use the function entry as the base.
- if (Subtarget.isTargetWin64())
- return MCSymbolRefExpr::create(
- getTargetMachine().getSymbol(MF->getFunction()), Ctx);
-
// X86-64 uses RIP relative addressing based on the jump table label.
if (Subtarget.isPICStyleRIPRel())
return TargetLowering::getPICJumpTableRelocBaseExpr(MF, JTI, Ctx);
diff --git a/llvm/lib/Target/X86/X86ISelLowering.h b/llvm/lib/Target/X86/X86ISelLowering.h
index 643727d7aed..37f9353042b 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.h
+++ b/llvm/lib/Target/X86/X86ISelLowering.h
@@ -684,7 +684,6 @@ namespace llvm {
const X86Subtarget &STI);
unsigned getJumpTableEncoding() const override;
- bool isJumpTableRelative() const override;
bool useSoftFloat() const override;
MVT getScalarShiftAmountTy(const DataLayout &, EVT) const override {
OpenPOWER on IntegriCloud