forked from OSchip/llvm-project
eliminate the std::ostream forms of the bitcode writing APIs.
llvm-svn: 79840
This commit is contained in:
parent
91922253c5
commit
6973395cc7
|
@ -32,11 +32,12 @@
|
||||||
#include "llvm/Bitcode/ReaderWriter.h"
|
#include "llvm/Bitcode/ReaderWriter.h"
|
||||||
#include "llvm/ExecutionEngine/GenericValue.h"
|
#include "llvm/ExecutionEngine/GenericValue.h"
|
||||||
#include "llvm/ExecutionEngine/JIT.h"
|
#include "llvm/ExecutionEngine/JIT.h"
|
||||||
|
#include "llvm/Target/TargetSelect.h"
|
||||||
#include "llvm/Support/CommandLine.h"
|
#include "llvm/Support/CommandLine.h"
|
||||||
#include "llvm/Support/ManagedStatic.h"
|
#include "llvm/Support/ManagedStatic.h"
|
||||||
#include "llvm/Target/TargetSelect.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#include <fstream>
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include <fstream>
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
//Command line options
|
//Command line options
|
||||||
|
@ -91,50 +92,49 @@ int main(int argc, char **argv) {
|
||||||
LLVMContext &Context = getGlobalContext();
|
LLVMContext &Context = getGlobalContext();
|
||||||
|
|
||||||
if (InputFilename == "") {
|
if (InputFilename == "") {
|
||||||
std::cerr<<"Error: You must specify the filename of the program to "
|
errs() << "Error: You must specify the filename of the program to "
|
||||||
"be compiled. Use --help to see the options.\n";
|
"be compiled. Use --help to see the options.\n";
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
//Get the output stream
|
//Get the output stream
|
||||||
std::ostream *out = &std::cout;
|
raw_ostream *out = &outs();
|
||||||
if (!JIT) {
|
if (!JIT) {
|
||||||
if (OutputFilename == "") {
|
if (OutputFilename == "") {
|
||||||
std::string base = InputFilename;
|
std::string base = InputFilename;
|
||||||
if (InputFilename == "-") { base = "a"; }
|
if (InputFilename == "-") { base = "a"; }
|
||||||
|
|
||||||
//Use default filename
|
// Use default filename.
|
||||||
const char *suffix = ".bc";
|
OutputFilename = base+".bc";
|
||||||
OutputFilename = base+suffix;
|
|
||||||
}
|
}
|
||||||
if (OutputFilename != "-") {
|
if (OutputFilename != "-") {
|
||||||
out = new std::
|
std::string ErrInfo;
|
||||||
ofstream(OutputFilename.c_str(),
|
out = new raw_fd_ostream(OutputFilename.c_str(), ErrInfo,
|
||||||
std::ios::out | std::ios::trunc | std::ios::binary);
|
raw_fd_ostream::F_Force|
|
||||||
|
raw_fd_ostream::F_Binary);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Get the input stream
|
//Get the input stream
|
||||||
std::istream *in = &std::cin;
|
std::istream *in = &std::cin;
|
||||||
if (InputFilename != "-") {
|
if (InputFilename != "-")
|
||||||
in = new std::ifstream(InputFilename.c_str());
|
in = new std::ifstream(InputFilename.c_str());
|
||||||
}
|
|
||||||
|
|
||||||
//Gather the compile flags
|
//Gather the compile flags
|
||||||
BrainF::CompileFlags cf = BrainF::flag_off;
|
BrainF::CompileFlags cf = BrainF::flag_off;
|
||||||
if (ArrayBoundsChecking) {
|
if (ArrayBoundsChecking)
|
||||||
cf = BrainF::CompileFlags(cf | BrainF::flag_arraybounds);
|
cf = BrainF::CompileFlags(cf | BrainF::flag_arraybounds);
|
||||||
}
|
|
||||||
|
|
||||||
//Read the BrainF program
|
//Read the BrainF program
|
||||||
BrainF bf;
|
BrainF bf;
|
||||||
Module *mod = bf.parse(in, 65536, cf, Context); //64 KiB
|
Module *mod = bf.parse(in, 65536, cf, Context); //64 KiB
|
||||||
if (in != &std::cin) {delete in;}
|
if (in != &std::cin)
|
||||||
|
delete in;
|
||||||
addMainFunction(mod);
|
addMainFunction(mod);
|
||||||
|
|
||||||
//Verify generated code
|
//Verify generated code
|
||||||
if (verifyModule(*mod)) {
|
if (verifyModule(*mod)) {
|
||||||
std::cerr<<"Error: module failed verification. This shouldn't happen.\n";
|
errs() << "Error: module failed verification. This shouldn't happen.\n";
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ int main(int argc, char **argv) {
|
||||||
if (JIT) {
|
if (JIT) {
|
||||||
InitializeNativeTarget();
|
InitializeNativeTarget();
|
||||||
|
|
||||||
std::cout << "------- Running JIT -------\n";
|
outs() << "------- Running JIT -------\n";
|
||||||
ExecutionEngine *ee = EngineBuilder(mod).create();
|
ExecutionEngine *ee = EngineBuilder(mod).create();
|
||||||
std::vector<GenericValue> args;
|
std::vector<GenericValue> args;
|
||||||
Function *brainf_func = mod->getFunction("brainf");
|
Function *brainf_func = mod->getFunction("brainf");
|
||||||
|
@ -152,7 +152,8 @@ int main(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
|
|
||||||
//Clean up
|
//Clean up
|
||||||
if (out != &std::cout) {delete out;}
|
if (out != &outs())
|
||||||
|
delete out;
|
||||||
delete mod;
|
delete mod;
|
||||||
|
|
||||||
llvm_shutdown();
|
llvm_shutdown();
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
#include "llvm/Constants.h"
|
#include "llvm/Constants.h"
|
||||||
#include "llvm/Instructions.h"
|
#include "llvm/Instructions.h"
|
||||||
#include "llvm/Bitcode/ReaderWriter.h"
|
#include "llvm/Bitcode/ReaderWriter.h"
|
||||||
#include <iostream>
|
#include "llvm/Support/raw_ostream.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
@ -56,7 +56,7 @@ int main() {
|
||||||
BB->getInstList().push_back(ReturnInst::Create(Context, Add));
|
BB->getInstList().push_back(ReturnInst::Create(Context, Add));
|
||||||
|
|
||||||
// Output the bitcode file to stdout
|
// Output the bitcode file to stdout
|
||||||
WriteBitcodeToFile(M, std::cout);
|
WriteBitcodeToFile(M, outs());
|
||||||
|
|
||||||
// Delete the module and all of its contents.
|
// Delete the module and all of its contents.
|
||||||
delete M;
|
delete M;
|
||||||
|
|
|
@ -14,7 +14,6 @@
|
||||||
#ifndef LLVM_BITCODE_H
|
#ifndef LLVM_BITCODE_H
|
||||||
#define LLVM_BITCODE_H
|
#define LLVM_BITCODE_H
|
||||||
|
|
||||||
#include <iosfwd>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
@ -41,10 +40,6 @@ namespace llvm {
|
||||||
Module *ParseBitcodeFile(MemoryBuffer *Buffer, LLVMContext& Context,
|
Module *ParseBitcodeFile(MemoryBuffer *Buffer, LLVMContext& Context,
|
||||||
std::string *ErrMsg = 0);
|
std::string *ErrMsg = 0);
|
||||||
|
|
||||||
/// WriteBitcodeToFile - Write the specified module to the specified output
|
|
||||||
/// stream.
|
|
||||||
void WriteBitcodeToFile(const Module *M, std::ostream &Out);
|
|
||||||
|
|
||||||
/// WriteBitcodeToFile - Write the specified module to the specified
|
/// WriteBitcodeToFile - Write the specified module to the specified
|
||||||
/// raw output stream.
|
/// raw output stream.
|
||||||
void WriteBitcodeToFile(const Module *M, raw_ostream &Out);
|
void WriteBitcodeToFile(const Module *M, raw_ostream &Out);
|
||||||
|
@ -53,10 +48,6 @@ namespace llvm {
|
||||||
/// raw output stream.
|
/// raw output stream.
|
||||||
void WriteBitcodeToStream(const Module *M, BitstreamWriter &Stream);
|
void WriteBitcodeToStream(const Module *M, BitstreamWriter &Stream);
|
||||||
|
|
||||||
/// CreateBitcodeWriterPass - Create and return a pass that writes the module
|
|
||||||
/// to the specified ostream.
|
|
||||||
ModulePass *CreateBitcodeWriterPass(std::ostream &Str);
|
|
||||||
|
|
||||||
/// createBitcodeWriterPass - Create and return a pass that writes the module
|
/// createBitcodeWriterPass - Create and return a pass that writes the module
|
||||||
/// to the specified ostream.
|
/// to the specified ostream.
|
||||||
ModulePass *createBitcodeWriterPass(raw_ostream &Str);
|
ModulePass *createBitcodeWriterPass(raw_ostream &Str);
|
||||||
|
|
|
@ -12,11 +12,7 @@
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/Bitcode/Deserialize.h"
|
#include "llvm/Bitcode/Deserialize.h"
|
||||||
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#ifdef DEBUG_BACKPATCH
|
|
||||||
#include "llvm/Support/Streams.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
Deserializer::Deserializer(BitstreamReader& stream)
|
Deserializer::Deserializer(BitstreamReader& stream)
|
||||||
|
@ -357,7 +353,7 @@ void Deserializer::RegisterPtr(const SerializedPtrID& PtrId,
|
||||||
assert (!HasFinalPtr(E) && "Pointer already registered.");
|
assert (!HasFinalPtr(E) && "Pointer already registered.");
|
||||||
|
|
||||||
#ifdef DEBUG_BACKPATCH
|
#ifdef DEBUG_BACKPATCH
|
||||||
llvm::cerr << "RegisterPtr: " << PtrId << " => " << Ptr << "\n";
|
errs() << "RegisterPtr: " << PtrId << " => " << Ptr << "\n";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SetPtr(E,Ptr);
|
SetPtr(E,Ptr);
|
||||||
|
@ -377,7 +373,7 @@ void Deserializer::ReadUIntPtr(uintptr_t& PtrRef,
|
||||||
PtrRef = GetFinalPtr(E);
|
PtrRef = GetFinalPtr(E);
|
||||||
|
|
||||||
#ifdef DEBUG_BACKPATCH
|
#ifdef DEBUG_BACKPATCH
|
||||||
llvm::cerr << "ReadUintPtr: " << PtrId
|
errs() << "ReadUintPtr: " << PtrId
|
||||||
<< " <-- " << (void*) GetFinalPtr(E) << '\n';
|
<< " <-- " << (void*) GetFinalPtr(E) << '\n';
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -386,7 +382,7 @@ void Deserializer::ReadUIntPtr(uintptr_t& PtrRef,
|
||||||
"Client forbids backpatching for this pointer.");
|
"Client forbids backpatching for this pointer.");
|
||||||
|
|
||||||
#ifdef DEBUG_BACKPATCH
|
#ifdef DEBUG_BACKPATCH
|
||||||
llvm::cerr << "ReadUintPtr: " << PtrId << " (NO PTR YET)\n";
|
errs() << "ReadUintPtr: " << PtrId << " (NO PTR YET)\n";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Register backpatch. Check the freelist for a BPNode.
|
// Register backpatch. Check the freelist for a BPNode.
|
||||||
|
|
|
@ -9,43 +9,31 @@
|
||||||
|
|
||||||
#include "llvm-c/BitWriter.h"
|
#include "llvm-c/BitWriter.h"
|
||||||
#include "llvm/Bitcode/ReaderWriter.h"
|
#include "llvm/Bitcode/ReaderWriter.h"
|
||||||
#include <fstream>
|
#include "llvm/Support/raw_ostream.h"
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
|
|
||||||
/*===-- Operations on modules ---------------------------------------------===*/
|
/*===-- Operations on modules ---------------------------------------------===*/
|
||||||
|
|
||||||
int LLVMWriteBitcodeToFile(LLVMModuleRef M, const char *Path) {
|
int LLVMWriteBitcodeToFile(LLVMModuleRef M, const char *Path) {
|
||||||
std::ofstream OS(Path, std::ios_base::out|std::ios::trunc|std::ios::binary);
|
std::string ErrorInfo;
|
||||||
|
raw_fd_ostream OS(Path, ErrorInfo,
|
||||||
|
raw_fd_ostream::F_Force|raw_fd_ostream::F_Binary);
|
||||||
|
|
||||||
if (!OS.fail())
|
if (!ErrorInfo.empty())
|
||||||
WriteBitcodeToFile(unwrap(M), OS);
|
|
||||||
|
|
||||||
if (OS.fail())
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
WriteBitcodeToFile(unwrap(M), OS);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(__GNUC__) && (__GNUC__ > 3 || __GNUC__ == 3 && __GNUC_MINOR >= 4)
|
#if defined(__GNUC__) && (__GNUC__ > 3 || __GNUC__ == 3 && __GNUC_MINOR >= 4)
|
||||||
#include <ext/stdio_filebuf.h>
|
#include <ext/stdio_filebuf.h>
|
||||||
|
|
||||||
// FIXME: Control this with configure? Provide some portable abstraction in
|
|
||||||
// libSystem? As is, the user will just get a linker error if they use this on
|
|
||||||
// non-GCC. Some C++ stdlibs even have ofstream::ofstream(int fd).
|
|
||||||
int LLVMWriteBitcodeToFileHandle(LLVMModuleRef M, int FileHandle) {
|
int LLVMWriteBitcodeToFileHandle(LLVMModuleRef M, int FileHandle) {
|
||||||
__gnu_cxx::stdio_filebuf<char> Buffer(FileHandle, std::ios_base::out |
|
raw_fd_ostream OS(FileHandle, false);
|
||||||
std::ios::trunc |
|
|
||||||
std::ios::binary);
|
|
||||||
std::ostream OS(&Buffer);
|
|
||||||
|
|
||||||
if (!OS.fail())
|
|
||||||
WriteBitcodeToFile(unwrap(M), OS);
|
WriteBitcodeToFile(unwrap(M), OS);
|
||||||
|
|
||||||
if (OS.fail())
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@
|
||||||
#include "llvm/ValueSymbolTable.h"
|
#include "llvm/ValueSymbolTable.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
#include "llvm/Support/MathExtras.h"
|
#include "llvm/Support/MathExtras.h"
|
||||||
#include "llvm/Support/Streams.h"
|
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#include "llvm/System/Program.h"
|
#include "llvm/System/Program.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
@ -1466,16 +1465,6 @@ static void EmitDarwinBCTrailer(BitstreamWriter &Stream, unsigned BufferSize) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// WriteBitcodeToFile - Write the specified module to the specified output
|
|
||||||
/// stream.
|
|
||||||
void llvm::WriteBitcodeToFile(const Module *M, std::ostream &Out) {
|
|
||||||
raw_os_ostream RawOut(Out);
|
|
||||||
// If writing to stdout, set binary mode.
|
|
||||||
if (llvm::cout == Out)
|
|
||||||
sys::Program::ChangeStdoutToBinary();
|
|
||||||
WriteBitcodeToFile(M, RawOut);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// WriteBitcodeToFile - Write the specified module to the specified output
|
/// WriteBitcodeToFile - Write the specified module to the specified output
|
||||||
/// stream.
|
/// stream.
|
||||||
void llvm::WriteBitcodeToFile(const Module *M, raw_ostream &Out) {
|
void llvm::WriteBitcodeToFile(const Module *M, raw_ostream &Out) {
|
||||||
|
|
|
@ -17,24 +17,16 @@ using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
class WriteBitcodePass : public ModulePass {
|
class WriteBitcodePass : public ModulePass {
|
||||||
// FIXME: Kill off std::ostream
|
raw_ostream &OS; // raw_ostream to print on
|
||||||
std::ostream *Out;
|
|
||||||
raw_ostream *RawOut; // raw_ostream to print on
|
|
||||||
public:
|
public:
|
||||||
static char ID; // Pass identification, replacement for typeid
|
static char ID; // Pass identification, replacement for typeid
|
||||||
explicit WriteBitcodePass(std::ostream &o)
|
|
||||||
: ModulePass(&ID), Out(&o), RawOut(0) {}
|
|
||||||
explicit WriteBitcodePass(raw_ostream &o)
|
explicit WriteBitcodePass(raw_ostream &o)
|
||||||
: ModulePass(&ID), Out(0), RawOut(&o) {}
|
: ModulePass(&ID), OS(o) {}
|
||||||
|
|
||||||
const char *getPassName() const { return "Bitcode Writer"; }
|
const char *getPassName() const { return "Bitcode Writer"; }
|
||||||
|
|
||||||
bool runOnModule(Module &M) {
|
bool runOnModule(Module &M) {
|
||||||
if (Out) {
|
WriteBitcodeToFile(&M, OS);
|
||||||
WriteBitcodeToFile(&M, *Out);
|
|
||||||
} else {
|
|
||||||
WriteBitcodeToFile(&M, *RawOut);
|
|
||||||
}
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -42,13 +34,6 @@ namespace {
|
||||||
|
|
||||||
char WriteBitcodePass::ID = 0;
|
char WriteBitcodePass::ID = 0;
|
||||||
|
|
||||||
/// CreateBitcodeWriterPass - Create and return a pass that writes the module
|
|
||||||
/// to the specified ostream.
|
|
||||||
ModulePass *llvm::CreateBitcodeWriterPass(std::ostream &Str) {
|
|
||||||
return new WriteBitcodePass(Str);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// createBitcodeWriterPass - Create and return a pass that writes the module
|
/// createBitcodeWriterPass - Create and return a pass that writes the module
|
||||||
/// to the specified ostream.
|
/// to the specified ostream.
|
||||||
ModulePass *llvm::createBitcodeWriterPass(raw_ostream &Str) {
|
ModulePass *llvm::createBitcodeWriterPass(raw_ostream &Str) {
|
||||||
|
|
|
@ -51,10 +51,10 @@ namespace {
|
||||||
///
|
///
|
||||||
bool BugDriver::writeProgramToFile(const std::string &Filename,
|
bool BugDriver::writeProgramToFile(const std::string &Filename,
|
||||||
Module *M) const {
|
Module *M) const {
|
||||||
std::ios::openmode io_mode = std::ios::out | std::ios::trunc |
|
std::string ErrInfo;
|
||||||
std::ios::binary;
|
raw_fd_ostream Out(Filename.c_str(), ErrInfo,
|
||||||
std::ofstream Out(Filename.c_str(), io_mode);
|
raw_fd_ostream::F_Force|raw_fd_ostream::F_Binary);
|
||||||
if (!Out.good()) return true;
|
if (!ErrInfo.empty()) return true;
|
||||||
|
|
||||||
WriteBitcodeToFile(M ? M : Program, Out);
|
WriteBitcodeToFile(M ? M : Program, Out);
|
||||||
return false;
|
return false;
|
||||||
|
@ -83,11 +83,10 @@ void BugDriver::EmitProgressBitcode(const std::string &ID, bool NoFlyer) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int BugDriver::runPassesAsChild(const std::vector<const PassInfo*> &Passes) {
|
int BugDriver::runPassesAsChild(const std::vector<const PassInfo*> &Passes) {
|
||||||
|
std::string ErrInfo;
|
||||||
std::ios::openmode io_mode = std::ios::out | std::ios::trunc |
|
raw_fd_ostream OutFile(ChildOutput.c_str(), ErrInfo,
|
||||||
std::ios::binary;
|
raw_fd_ostream::F_Force|raw_fd_ostream::F_Binary);
|
||||||
std::ofstream OutFile(ChildOutput.c_str(), io_mode);
|
if (!ErrInfo.empty()) {
|
||||||
if (!OutFile.good()) {
|
|
||||||
errs() << "Error opening bitcode file: " << ChildOutput << "\n";
|
errs() << "Error opening bitcode file: " << ChildOutput << "\n";
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -106,7 +105,7 @@ int BugDriver::runPassesAsChild(const std::vector<const PassInfo*> &Passes) {
|
||||||
PM.add(createVerifierPass());
|
PM.add(createVerifierPass());
|
||||||
|
|
||||||
// Write bitcode out to disk as the last step...
|
// Write bitcode out to disk as the last step...
|
||||||
PM.add(CreateBitcodeWriterPass(OutFile));
|
PM.add(createBitcodeWriterPass(OutFile));
|
||||||
|
|
||||||
// Run all queued passes.
|
// Run all queued passes.
|
||||||
PM.run(*Program);
|
PM.run(*Program);
|
||||||
|
@ -146,12 +145,15 @@ bool BugDriver::runPasses(const std::vector<const PassInfo*> &Passes,
|
||||||
<< ErrMsg << "\n";
|
<< ErrMsg << "\n";
|
||||||
return(1);
|
return(1);
|
||||||
}
|
}
|
||||||
std::ios::openmode io_mode = std::ios::out | std::ios::trunc |
|
|
||||||
std::ios::binary;
|
std::string ErrInfo;
|
||||||
std::ofstream InFile(inputFilename.c_str(), io_mode);
|
raw_fd_ostream InFile(inputFilename.c_str(), ErrInfo,
|
||||||
if (!InFile.good()) {
|
raw_fd_ostream::F_Force|raw_fd_ostream::F_Binary);
|
||||||
|
|
||||||
|
|
||||||
|
if (!ErrInfo.empty()) {
|
||||||
errs() << "Error opening bitcode file: " << inputFilename << "\n";
|
errs() << "Error opening bitcode file: " << inputFilename << "\n";
|
||||||
return(1);
|
return 1;
|
||||||
}
|
}
|
||||||
WriteBitcodeToFile(Program, InFile);
|
WriteBitcodeToFile(Program, InFile);
|
||||||
InFile.close();
|
InFile.close();
|
||||||
|
|
|
@ -47,10 +47,7 @@
|
||||||
#include "llvm/Transforms/IPO.h"
|
#include "llvm/Transforms/IPO.h"
|
||||||
#include "llvm/Transforms/Scalar.h"
|
#include "llvm/Transforms/Scalar.h"
|
||||||
#include "llvm/Config/config.h"
|
#include "llvm/Config/config.h"
|
||||||
|
|
||||||
|
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <fstream>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
@ -139,25 +136,28 @@ void LTOCodeGenerator::addMustPreserveSymbol(const char* sym)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool LTOCodeGenerator::writeMergedModules(const char* path, std::string& errMsg)
|
bool LTOCodeGenerator::writeMergedModules(const char *path,
|
||||||
{
|
std::string &errMsg) {
|
||||||
if ( this->determineTarget(errMsg) )
|
if (determineTarget(errMsg))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// mark which symbols can not be internalized
|
// mark which symbols can not be internalized
|
||||||
this->applyScopeRestrictions();
|
applyScopeRestrictions();
|
||||||
|
|
||||||
// create output file
|
// create output file
|
||||||
std::ofstream out(path, std::ios_base::out|std::ios::trunc|std::ios::binary);
|
std::string ErrInfo;
|
||||||
if ( out.fail() ) {
|
raw_fd_ostream Out(path, ErrInfo,
|
||||||
|
raw_fd_ostream::F_Force|raw_fd_ostream::F_Binary);
|
||||||
|
if (!ErrInfo.empty()) {
|
||||||
errMsg = "could not open bitcode file for writing: ";
|
errMsg = "could not open bitcode file for writing: ";
|
||||||
errMsg += path;
|
errMsg += path;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// write bitcode to it
|
// write bitcode to it
|
||||||
WriteBitcodeToFile(_linker.getModule(), out);
|
WriteBitcodeToFile(_linker.getModule(), Out);
|
||||||
if ( out.fail() ) {
|
|
||||||
|
if (Out.has_error()) {
|
||||||
errMsg = "could not write bitcode file: ";
|
errMsg = "could not write bitcode file: ";
|
||||||
errMsg += path;
|
errMsg += path;
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in New Issue