| OLD | NEW |
| 1 //===- subzero/src/IceCompileServer.cpp - Compile server ------------------===// | 1 //===- subzero/src/IceCompileServer.cpp - Compile server ------------------===// |
| 2 // | 2 // |
| 3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
| 4 // | 4 // |
| 5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
| 7 // | 7 // |
| 8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
| 9 // | 9 // |
| 10 // This file defines the basic commandline-based compile server. | 10 // This file defines the basic commandline-based compile server. |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 #include "IceClFlags.h" | 23 #include "IceClFlags.h" |
| 24 #include "IceClFlagsExtra.h" | 24 #include "IceClFlagsExtra.h" |
| 25 #include "IceCompileServer.h" | 25 #include "IceCompileServer.h" |
| 26 #include "IceELFStreamer.h" | 26 #include "IceELFStreamer.h" |
| 27 #include "IceGlobalContext.h" | 27 #include "IceGlobalContext.h" |
| 28 | 28 |
| 29 namespace Ice { | 29 namespace Ice { |
| 30 | 30 |
| 31 namespace { | 31 namespace { |
| 32 | 32 |
| 33 std::unique_ptr<Ostream> getStream(const IceString &Filename) { | 33 std::unique_ptr<Ostream> makeStream(const IceString &Filename, |
| 34 std::ofstream Ofs; | 34 std::error_code &EC) { |
| 35 if (Filename != "-") { | 35 if (Filename == "-") { |
| 36 Ofs.open(Filename.c_str(), std::ofstream::out); | 36 return std::unique_ptr<Ostream>(new llvm::raw_os_ostream(std::cout)); |
| 37 return std::unique_ptr<Ostream>(new llvm::raw_os_ostream(Ofs)); | |
| 38 } else { | 37 } else { |
| 39 return std::unique_ptr<Ostream>(new llvm::raw_os_ostream(std::cout)); | 38 return std::unique_ptr<Ostream>( |
| 39 new llvm::raw_fd_ostream(Filename, EC, llvm::sys::fs::F_None)); |
| 40 } | 40 } |
| 41 } | 41 } |
| 42 | 42 |
| 43 ErrorCodes getReturnValue(const Ice::ClFlagsExtra &Flags, ErrorCodes Val) { | 43 ErrorCodes getReturnValue(const Ice::ClFlagsExtra &Flags, ErrorCodes Val) { |
| 44 if (Flags.getAlwaysExitSuccess()) | 44 if (Flags.getAlwaysExitSuccess()) |
| 45 return EC_None; | 45 return EC_None; |
| 46 return Val; | 46 return Val; |
| 47 } | 47 } |
| 48 | 48 |
| 49 } // end of anonymous namespace | 49 } // end of anonymous namespace |
| 50 | 50 |
| 51 void CLCompileServer::run() { | 51 void CLCompileServer::run() { |
| 52 ClFlags::parseFlags(argc, argv); | 52 ClFlags::parseFlags(argc, argv); |
| 53 ClFlags Flags; | 53 ClFlags Flags; |
| 54 ClFlagsExtra ExtraFlags; | 54 ClFlagsExtra ExtraFlags; |
| 55 ClFlags::getParsedClFlags(Flags); | 55 ClFlags::getParsedClFlags(Flags); |
| 56 ClFlags::getParsedClFlagsExtra(ExtraFlags); | 56 ClFlags::getParsedClFlagsExtra(ExtraFlags); |
| 57 | 57 |
| 58 std::unique_ptr<Ostream> Ls = getStream(ExtraFlags.getLogFilename()); | 58 std::error_code EC; |
| 59 std::unique_ptr<Ostream> Ls = makeStream(ExtraFlags.getLogFilename(), EC); |
| 60 if (EC) { |
| 61 llvm::report_fatal_error("Unable to open log file"); |
| 62 } |
| 59 Ls->SetUnbuffered(); | 63 Ls->SetUnbuffered(); |
| 60 std::unique_ptr<Ostream> Os; | 64 std::unique_ptr<Ostream> Os; |
| 61 std::unique_ptr<ELFStreamer> ELFStr; | 65 std::unique_ptr<ELFStreamer> ELFStr; |
| 62 switch (Flags.getOutFileType()) { | 66 switch (Flags.getOutFileType()) { |
| 63 case FT_Elf: { | 67 case FT_Elf: { |
| 64 if (ExtraFlags.getOutputFilename() == "-") { | 68 if (ExtraFlags.getOutputFilename() == "-") { |
| 65 *Ls << "Error: writing binary ELF to stdout is unsupported\n"; | 69 *Ls << "Error: writing binary ELF to stdout is unsupported\n"; |
| 66 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Args)); | 70 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Args)); |
| 67 } | 71 } |
| 68 std::error_code EC; | |
| 69 std::unique_ptr<llvm::raw_fd_ostream> FdOs(new llvm::raw_fd_ostream( | 72 std::unique_ptr<llvm::raw_fd_ostream> FdOs(new llvm::raw_fd_ostream( |
| 70 ExtraFlags.getOutputFilename(), EC, llvm::sys::fs::F_None)); | 73 ExtraFlags.getOutputFilename(), EC, llvm::sys::fs::F_None)); |
| 71 if (EC) { | 74 if (EC) { |
| 72 *Ls << "Failed to open output file: " << ExtraFlags.getOutputFilename() | 75 *Ls << "Failed to open output file: " << ExtraFlags.getOutputFilename() |
| 73 << ":\n" << EC.message() << "\n"; | 76 << ":\n" << EC.message() << "\n"; |
| 74 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Args)); | 77 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Args)); |
| 75 } | 78 } |
| 76 ELFStr.reset(new ELFStreamer(*FdOs.get())); | 79 ELFStr.reset(new ELFStreamer(*FdOs.get())); |
| 77 Os.reset(FdOs.release()); | 80 Os.reset(FdOs.release()); |
| 78 // NaCl sets st_blksize to 0, and LLVM uses that to pick the | 81 // NaCl sets st_blksize to 0, and LLVM uses that to pick the |
| 79 // default preferred buffer size. Set to something non-zero. | 82 // default preferred buffer size. Set to something non-zero. |
| 80 Os->SetBufferSize(1 << 14); | 83 Os->SetBufferSize(1 << 14); |
| 81 } break; | 84 } break; |
| 82 case FT_Asm: | 85 case FT_Asm: |
| 83 case FT_Iasm: { | 86 case FT_Iasm: { |
| 84 Os = getStream(ExtraFlags.getOutputFilename()); | 87 Os = makeStream(ExtraFlags.getOutputFilename(), EC); |
| 88 if (EC) { |
| 89 *Ls << "Failed to open output file: " << ExtraFlags.getOutputFilename() |
| 90 << ":\n" << EC.message() << "\n"; |
| 91 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Args)); |
| 92 } |
| 85 Os->SetUnbuffered(); | 93 Os->SetUnbuffered(); |
| 86 } break; | 94 } break; |
| 87 } | 95 } |
| 88 | 96 |
| 89 IceString StrError; | 97 IceString StrError; |
| 90 std::unique_ptr<llvm::DataStreamer> InputStream( | 98 std::unique_ptr<llvm::DataStreamer> InputStream( |
| 91 llvm::getDataFileStreamer(ExtraFlags.getIRFilename(), &StrError)); | 99 llvm::getDataFileStreamer(ExtraFlags.getIRFilename(), &StrError)); |
| 92 if (!StrError.empty() || !InputStream) { | 100 if (!StrError.empty() || !InputStream) { |
| 93 llvm::SMDiagnostic Err(ExtraFlags.getIRFilename(), | 101 llvm::SMDiagnostic Err(ExtraFlags.getIRFilename(), |
| 94 llvm::SourceMgr::DK_Error, StrError); | 102 llvm::SourceMgr::DK_Error, StrError); |
| 95 Err.print(ExtraFlags.getAppName().c_str(), *Ls); | 103 Err.print(ExtraFlags.getAppName().c_str(), *Ls); |
| 96 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Bitcode)); | 104 return transferErrorCode(getReturnValue(ExtraFlags, Ice::EC_Bitcode)); |
| 97 } | 105 } |
| 98 | 106 |
| 99 Ctx.reset(new GlobalContext(Ls.get(), Os.get(), Ls.get(), ELFStr.get(), | 107 Ctx.reset( |
| 100 Flags)); | 108 new GlobalContext(Ls.get(), Os.get(), Ls.get(), ELFStr.get(), Flags)); |
| 101 if (Ctx->getFlags().getNumTranslationThreads() != 0) { | 109 if (Ctx->getFlags().getNumTranslationThreads() != 0) { |
| 102 std::thread CompileThread([this, &ExtraFlags, &InputStream]() { | 110 std::thread CompileThread([this, &ExtraFlags, &InputStream]() { |
| 103 Ctx->initParserThread(); | 111 Ctx->initParserThread(); |
| 104 getCompiler().run(ExtraFlags, *Ctx.get(), std::move(InputStream)); | 112 getCompiler().run(ExtraFlags, *Ctx.get(), std::move(InputStream)); |
| 105 }); | 113 }); |
| 106 CompileThread.join(); | 114 CompileThread.join(); |
| 107 } else { | 115 } else { |
| 108 getCompiler().run(ExtraFlags, *Ctx.get(), std::move(InputStream)); | 116 getCompiler().run(ExtraFlags, *Ctx.get(), std::move(InputStream)); |
| 109 } | 117 } |
| 110 transferErrorCode(getReturnValue( | 118 transferErrorCode(getReturnValue( |
| 111 ExtraFlags, static_cast<ErrorCodes>(Ctx->getErrorStatus()->value()))); | 119 ExtraFlags, static_cast<ErrorCodes>(Ctx->getErrorStatus()->value()))); |
| 112 } | 120 } |
| 113 | 121 |
| 114 } // end of namespace Ice | 122 } // end of namespace Ice |
| OLD | NEW |