diff options
| author | Kai Nacke <kai.nacke@redstar.de> | 2019-10-08 08:21:20 +0000 |
|---|---|---|
| committer | Kai Nacke <kai.nacke@redstar.de> | 2019-10-08 08:21:20 +0000 |
| commit | c9ddda84052659698b921e6c3a5bf7df9df599ce (patch) | |
| tree | 4953dbeb6c12adf8534e0313b1cac53ffeb15ac7 /llvm/tools/llvm-mc/llvm-mc.cpp | |
| parent | d2e9dd3877e903812ed5568e3a59e9e124ca4f85 (diff) | |
| download | bcm5719-llvm-c9ddda84052659698b921e6c3a5bf7df9df599ce.tar.gz bcm5719-llvm-c9ddda84052659698b921e6c3a5bf7df9df599ce.zip | |
[Tools] Mark output of tools as text if it is text
Several LLVM tools write text files/streams without using OF_Text.
This can cause problems on platforms which distinguish between
text and binary output. This PR adds the OF_Text flag for the
following tools:
- llvm-dis
- llvm-dwarfdump
- llvm-mca
- llvm-mc (assembler files only)
- opt (assembler files only)
- RemarkStreamer (used e.g. by opt)
Reviewers: rnk, vivekvpandya, Bigcheese, andreadb
Differential Revision: https://reviews.llvm.org/D67696
llvm-svn: 374024
Diffstat (limited to 'llvm/tools/llvm-mc/llvm-mc.cpp')
| -rw-r--r-- | llvm/tools/llvm-mc/llvm-mc.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/llvm/tools/llvm-mc/llvm-mc.cpp b/llvm/tools/llvm-mc/llvm-mc.cpp index 832c46683b8..97d507028c1 100644 --- a/llvm/tools/llvm-mc/llvm-mc.cpp +++ b/llvm/tools/llvm-mc/llvm-mc.cpp @@ -209,9 +209,10 @@ static const Target *GetTarget(const char *ProgName) { return TheTarget; } -static std::unique_ptr<ToolOutputFile> GetOutputStream(StringRef Path) { +static std::unique_ptr<ToolOutputFile> GetOutputStream(StringRef Path, + sys::fs::OpenFlags Flags) { std::error_code EC; - auto Out = std::make_unique<ToolOutputFile>(Path, EC, sys::fs::OF_None); + auto Out = std::make_unique<ToolOutputFile>(Path, EC, Flags); if (EC) { WithColor::error() << EC.message() << '\n'; return nullptr; @@ -413,7 +414,9 @@ int main(int argc, char **argv) { FeaturesStr = Features.getString(); } - std::unique_ptr<ToolOutputFile> Out = GetOutputStream(OutputFilename); + sys::fs::OpenFlags Flags = (FileType == OFT_AssemblyFile) ? sys::fs::OF_Text + : sys::fs::OF_None; + std::unique_ptr<ToolOutputFile> Out = GetOutputStream(OutputFilename, Flags); if (!Out) return 1; @@ -423,7 +426,7 @@ int main(int argc, char **argv) { WithColor::error() << "dwo output only supported with object files\n"; return 1; } - DwoOut = GetOutputStream(SplitDwarfFile); + DwoOut = GetOutputStream(SplitDwarfFile, sys::fs::OF_None); if (!DwoOut) return 1; } |

