summaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
authorOleg Ranevskyy <oranevskyy@accesssoftek.com>2016-01-05 19:54:39 +0000
committerOleg Ranevskyy <oranevskyy@accesssoftek.com>2016-01-05 19:54:39 +0000
commitce9707f0de5ef749500a627f42657ebb92627a04 (patch)
treef2950bfedd43d5ab47696429a63921a7f2642c2e /cmake
parentaae4a6f9eb70f0f59dd322cd993962115d424d71 (diff)
[Clang/Support/Windows/Unix] Command lines created by clang may exceed the command length limit set by the OS
Summary: LLVM part of the patch is D15831. When clang runs an external tool such as a linker it may create a command line that exceeds the length limit. Clang uses the llvm::sys::argumentsFitWithinSystemLimits function to check if command line length fits the OS limitation. There are two problems in this function that may cause exceeding of the limit: 1. It ignores the length of the program path in its calculations. On the other hand, clang adds the program path to the command line when it runs the program. 2. It assumes no space character is inserted after the last argument, which is not true for Windows. The flattenArgs function adds the trailing space for *each* argument. The result of this is that the terminating NULL character is not counted and may be placed beyond the length limit if the command line is exactly 32768 characters long. The WinAPI's CreateProcess does not find the NULL character and fails. Reviewers: rafael, asl Subscribers: asl, llvm-commits Differential Revision: http://reviews.llvm.org/D15832 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@256865 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'cmake')
0 files changed, 0 insertions, 0 deletions