mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
ea195a382e
At the same time, fixes InstructionsTest::CastInst unittest: yes you can leave the IR in an invalid state and exit when you don't destroy the context (like the global one), no longer now. This is the first part of http://reviews.llvm.org/D19094 From: Mehdi Amini <mehdi.amini@apple.com> llvm-svn: 266379
55 lines
1.8 KiB
C++
55 lines
1.8 KiB
C++
//===----- LinkAllIR.h - Reference All VMCore Code --------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This header file pulls in all the object modules of the VMCore library so
|
|
// that tools like llc, opt, and lli can ensure they are linked with all symbols
|
|
// from libVMCore.a It should only be used from a tool's main program.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_LINKALLIR_H
|
|
#define LLVM_LINKALLIR_H
|
|
|
|
#include "llvm/IR/InlineAsm.h"
|
|
#include "llvm/IR/Instructions.h"
|
|
#include "llvm/IR/IntrinsicInst.h"
|
|
#include "llvm/IR/LLVMContext.h"
|
|
#include "llvm/IR/Module.h"
|
|
#include "llvm/IR/Verifier.h"
|
|
#include "llvm/Support/Dwarf.h"
|
|
#include "llvm/Support/DynamicLibrary.h"
|
|
#include "llvm/Support/MathExtras.h"
|
|
#include "llvm/Support/Memory.h"
|
|
#include "llvm/Support/Mutex.h"
|
|
#include "llvm/Support/Path.h"
|
|
#include "llvm/Support/Process.h"
|
|
#include "llvm/Support/Program.h"
|
|
#include "llvm/Support/Signals.h"
|
|
#include "llvm/Support/TimeValue.h"
|
|
#include <cstdlib>
|
|
|
|
namespace {
|
|
struct ForceVMCoreLinking {
|
|
ForceVMCoreLinking() {
|
|
// We must reference VMCore in such a way that compilers will not
|
|
// delete it all as dead code, even with whole program optimization,
|
|
// yet is effectively a NO-OP. As the compiler isn't smart enough
|
|
// to know that getenv() never returns -1, this will do the job.
|
|
if (std::getenv("bar") != (char*) -1)
|
|
return;
|
|
llvm::LLVMContext Context;
|
|
(void)new llvm::Module("", Context);
|
|
(void)new llvm::UnreachableInst(Context);
|
|
(void) llvm::createVerifierPass();
|
|
}
|
|
} ForceVMCoreLinking;
|
|
}
|
|
|
|
#endif
|