forked from OSchip/llvm-project
raw_ostream::operator<<(StringRef): Avoid potential overflow in pointer arithmetic.
(OutBufCur + Size) might overflow if Size were large. For example on i686-linux, OutBufCur: 0xFFFDF27D OutBufEnd: 0xFFFDF370 Size: 0x0002BF20 (180,000) It caused flaky error in MC/COFF/section-name-encoding.s. llvm-svn: 207621
This commit is contained in:
parent
41cec5c3cb
commit
d112b82066
|
@ -162,7 +162,7 @@ public:
|
|||
size_t Size = Str.size();
|
||||
|
||||
// Make sure we can use the fast path.
|
||||
if (OutBufCur+Size > OutBufEnd)
|
||||
if (Size > (size_t)(OutBufEnd - OutBufCur))
|
||||
return write(Str.data(), Size);
|
||||
|
||||
memcpy(OutBufCur, Str.data(), Size);
|
||||
|
|
Loading…
Reference in New Issue