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 |