eliminate the std::ostream forms of the bitcode writing APIs.

llvm-svn: 79840
This commit is contained in:
Chris Lattner 2009-08-23 07:49:08 +00:00
parent 91922253c5
commit 6973395cc7
9 changed files with 80 additions and 128 deletions

View File

@ -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();

View File

@ -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;

View File

@ -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);

View File

@ -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.

View File

@ -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;
} }

View File

@ -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) {

View File

@ -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) {

View File

@ -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();

View File

@ -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;