summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorShoaib Meenai <smeenai@fb.com>2019-04-16 00:18:50 +0000
committerShoaib Meenai <smeenai@fb.com>2019-04-16 00:18:50 +0000
commit1826095a5faa4303c9fb5d3c5aadc46bf66c1cd6 (patch)
tree4544dcf818a516e53203e0a151a313193dacbc4c /llvm/lib
parent0a61be96fc9f10f400497e98f5adb9cc467c98c6 (diff)
downloadbcm5719-llvm-1826095a5faa4303c9fb5d3c5aadc46bf66c1cd6.tar.gz
bcm5719-llvm-1826095a5faa4303c9fb5d3c5aadc46bf66c1cd6.zip
Reapply [Support] Fix recursive response file expansion guard
The test in the dependent revision has been fixed for Windows. Original commit message: Response file expansion limits the amount of expansion to prevent potential infinite recursion. However, the current logic assumes that any argument beginning with @ is a response file, which is not true for e.g. `-Xlinker -rpath -Xlinker @executable_path/../lib` on Darwin. Having too many of these non-response file arguments beginning with @ prevents actual response files from being expanded. Instead, limit based on the number of successful response file expansions, which should still prevent infinite recursion but also avoid false positives. Differential Revision: https://reviews.llvm.org/D60631 > llvm-svn: 358452 llvm-svn: 358466
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Support/CommandLine.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/llvm/lib/Support/CommandLine.cpp b/llvm/lib/Support/CommandLine.cpp
index 98d06f65c79..0050002ff05 100644
--- a/llvm/lib/Support/CommandLine.cpp
+++ b/llvm/lib/Support/CommandLine.cpp
@@ -1040,7 +1040,7 @@ static bool ExpandResponseFile(StringRef FName, StringSaver &Saver,
bool cl::ExpandResponseFiles(StringSaver &Saver, TokenizerCallback Tokenizer,
SmallVectorImpl<const char *> &Argv,
bool MarkEOLs, bool RelativeNames) {
- unsigned RspFiles = 0;
+ unsigned ExpandedRspFiles = 0;
bool AllExpanded = true;
// Don't cache Argv.size() because it can change.
@@ -1058,14 +1058,16 @@ bool cl::ExpandResponseFiles(StringSaver &Saver, TokenizerCallback Tokenizer,
// If we have too many response files, leave some unexpanded. This avoids
// crashing on self-referential response files.
- if (RspFiles++ > 20)
+ if (ExpandedRspFiles > 20)
return false;
// Replace this response file argument with the tokenization of its
// contents. Nested response files are expanded in subsequent iterations.
SmallVector<const char *, 0> ExpandedArgv;
- if (!ExpandResponseFile(Arg + 1, Saver, Tokenizer, ExpandedArgv,
- MarkEOLs, RelativeNames)) {
+ if (ExpandResponseFile(Arg + 1, Saver, Tokenizer, ExpandedArgv, MarkEOLs,
+ RelativeNames)) {
+ ++ExpandedRspFiles;
+ } else {
// We couldn't read this file, so we leave it in the argument stream and
// move on.
AllExpanded = false;
OpenPOWER on IntegriCloud