mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-28 21:34:23 +00:00
In MemoryBuffer::getOpenFile() don't verify that the mmap'ed
file buffer is null-terminated. If the file is smaller than we thought, mmap will not allow dereferencing past the pages that are enough to cover the actual file size, even though we asked for a larger address range. rdar://11612916 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160075 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f9fa3d8b87
commit
10dedb9421
@ -313,16 +313,6 @@ error_code MemoryBuffer::getOpenFile(int FD, const char *Filename,
|
|||||||
RealMapOffset)) {
|
RealMapOffset)) {
|
||||||
result.reset(GetNamedBuffer<MemoryBufferMMapFile>(
|
result.reset(GetNamedBuffer<MemoryBufferMMapFile>(
|
||||||
StringRef(Pages + Delta, MapSize), Filename, RequiresNullTerminator));
|
StringRef(Pages + Delta, MapSize), Filename, RequiresNullTerminator));
|
||||||
|
|
||||||
if (RequiresNullTerminator && result->getBufferEnd()[0] != '\0') {
|
|
||||||
// There could be a racing issue that resulted in the file being larger
|
|
||||||
// than the FileSize passed by the caller. We already have an assertion
|
|
||||||
// for this in MemoryBuffer::init() but have a runtime guarantee that
|
|
||||||
// the buffer will be null-terminated here, so do a copy that adds a
|
|
||||||
// null-terminator.
|
|
||||||
result.reset(MemoryBuffer::getMemBufferCopy(result->getBuffer(),
|
|
||||||
Filename));
|
|
||||||
}
|
|
||||||
return error_code::success();
|
return error_code::success();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user