Kill off StripMetaData.

This commit is contained in:
Benjamin Kramer 2009-08-25 21:35:43 +02:00
parent a54bf33d4b
commit 8b6f11938a
4 changed files with 1 additions and 114 deletions

View file

@ -938,13 +938,6 @@ LDC_TARGETS
std::string errormsg; std::string errormsg;
for (int i = 0; i < llvmModules.size(); i++) for (int i = 0; i < llvmModules.size(); i++)
{ {
#if USE_METADATA
//FIXME: workaround for llvm metadata bug:
// the LinkInModule call asserts with metadata unstripped
llvm::ModulePass* stripMD = createStripMetaData();
stripMD->runOnModule(*llvmModules[i]);
delete stripMD;
#endif // USE_METADATA
if(linker.LinkInModule(llvmModules[i], &errormsg)) if(linker.LinkInModule(llvmModules[i], &errormsg))
error("%s", errormsg.c_str()); error("%s", errormsg.c_str());
delete llvmModules[i]; delete llvmModules[i];

View file

@ -58,12 +58,6 @@ disableGCToStack("disable-gc2stack",
cl::desc("Disable promotion of GC allocations to stack memory in -O<N>"), cl::desc("Disable promotion of GC allocations to stack memory in -O<N>"),
cl::ZeroOrMore); cl::ZeroOrMore);
// Not recommended; metadata currently triggers an assert in the backend...
static cl::opt<bool>
disableStripMetaData("disable-strip-metadata",
cl::desc("Disable default metadata stripping (not recommended)"),
cl::ZeroOrMore);
static cl::opt<opts::BoolOrDefaultAdapter, false, opts::FlagParser> static cl::opt<opts::BoolOrDefaultAdapter, false, opts::FlagParser>
enableInlining("inlining", enableInlining("inlining",
cl::desc("(*) Enable function inlining in -O<N>"), cl::desc("(*) Enable function inlining in -O<N>"),
@ -222,18 +216,8 @@ static void addPassesForOptLevel(PassManager& pm) {
// Returns true if any optimization passes were invoked. // Returns true if any optimization passes were invoked.
bool ldc_optimize_module(llvm::Module* m) bool ldc_optimize_module(llvm::Module* m)
{ {
if (!optimize()) { if (!optimize())
#if USE_METADATA
if (!disableStripMetaData) {
// This one always needs to run if metadata is generated, because
// the code generator will assert if it's not used.
ModulePass* stripMD = createStripMetaData();
stripMD->runOnModule(*m);
delete stripMD;
}
#endif
return false; return false;
}
PassManager pm; PassManager pm;
@ -270,14 +254,6 @@ bool ldc_optimize_module(llvm::Module* m)
if (optimize) if (optimize)
addPassesForOptLevel(pm); addPassesForOptLevel(pm);
#if USE_METADATA
if (!disableStripMetaData) {
// This one is purposely not disabled by disableLangSpecificPasses
// because the code generator will assert if it's not used.
addPass(pm, createStripMetaData());
}
#endif // USE_METADATA
pm.run(*m); pm.run(*m);
return true; return true;
} }

View file

@ -12,7 +12,6 @@ llvm::FunctionPass* createSimplifyDRuntimeCalls();
#if USE_METADATA #if USE_METADATA
llvm::FunctionPass* createGarbageCollect2Stack(); llvm::FunctionPass* createGarbageCollect2Stack();
llvm::ModulePass* createStripMetaData();
#endif // USE_METADATA #endif // USE_METADATA
llvm::ModulePass* createStripExternalsPass(); llvm::ModulePass* createStripExternalsPass();

View file

@ -1,81 +0,0 @@
#if USE_METADATA
//===- StripMetaData - Strips D-specific metadata -------------------------===//
//
// The LLVM D Compiler
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// There's an issue with the new LLVM metadata support; an assertion fires when
// trying to generate asm for metadata globals.
//
// This pass is a workaround; it deletes the metadata LDC generates so the code
// generator doesn't see it.
// Obviously, this should only run after all passes that make use of that
// metadata or they won't work.
//
//===----------------------------------------------------------------------===//
#include "gen/metadata.h"
#define DEBUG_TYPE "strip-metadata"
#include "Passes.h"
#include "llvm/Pass.h"
#include "llvm/Module.h"
#include "llvm/ADT/Statistic.h"
#include "llvm/Support/Compiler.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/raw_ostream.h"
using namespace llvm;
STATISTIC(NumDeleted, "Number of metadata globals deleted");
//===----------------------------------------------------------------------===//
// StripMetaData Pass Implementation
//===----------------------------------------------------------------------===//
namespace {
/// This pass optimizes library functions from the D runtime as used by LDC.
///
class VISIBILITY_HIDDEN StripMetaData : public ModulePass {
public:
static char ID; // Pass identification
StripMetaData() : ModulePass(&ID) {}
bool runOnModule(Module &M);
};
char StripMetaData::ID = 0;
} // end anonymous namespace.
static RegisterPass<StripMetaData>
X("strip-metadata", "Delete D-specific metadata");
// Public interface to the pass.
ModulePass *createStripMetaData() {
return new StripMetaData();
}
/// runOnFunction - Top level algorithm.
///
bool StripMetaData::runOnModule(Module &M) {
bool Changed = false;
for (Module::global_iterator I = M.global_begin(), E = M.global_end(); I != E;) {
GlobalVariable* G = I++;
if (G->getName().startswith("llvm.ldc.")) {
assert(G->hasInitializer() && isa<MDNode>(G->getInitializer())
&& "Not a metadata global?");
Changed = true;
NumDeleted++;
DEBUG(errs() << "Deleting " << *G << '\n');
G->eraseFromParent();
}
}
return Changed;
}
#endif // USE_METADATA