Unsoundness in MemoryBuffer::create_from_memory_range
#516
Labels
Milestone
MemoryBuffer::create_from_memory_range
#516
Describe the Bug
MemoryBuffer::create_from_memory_range
callsLLVMCreateMemoryBufferWithMemoryRange
withRequiresNullTerminator
set tofalse
, while an LLVM memory buffer should always be null-terminated:https://github.com/llvm/llvm-project/blob/adacb5010f5ca6e923b3cf2d8ea47cbaab96099d/llvm/include/llvm/Support/MemoryBuffer.h#L41-L51
Please note that setting
RequiresNullTerminator
totrue
won't solve the issue; LLVM will simply throw an error. Instead, the function signature needs to be changed to require null-terminated buffers. There can be no zero-copy implementation ofMemoryBuffer::create_from_memory_range
for arbitrary&[u8]
.The
RequiresNullTerminator
argument is truly baffling to me. It seems to mean "iftrue
, check if the buffer is null-terminated" and not "I don't need this memory buffer to be null terminated" because it is always assumed to be so (perhaps you want to patch it after construction):https://github.com/llvm/llvm-project/blob/main/llvm/lib/Support/MemoryBuffer.cpp#L49-L57
To Reproduce
Create a memory buffer with
MemoryBuffer::create_from_memory_range
and attempt to use it inContext::create_module_from_ir
for instance. The parser will behave oddly as it tries to read past the buffer.Expected Behavior
MemoryBuffer::create_from_memory_range
should always pass a null-terminated buffer toLLVMCreateMemoryBufferWithMemoryRange
and setRequiresNullTerminator
totrue
.As this requires a copy in the general case, it should take a type that represents a buffer
b
of lengthN
whereb[N - 1] == b'\0'
and set the buffer length toN-1
inLLVMCreateMemoryBufferWithMemoryRange
.Otherwise the documentation should be updated to ask the user to do the the necessary manipulation themselves before calling the function.
LLVM Version (please complete the following information):
Desktop (please complete the following information):
Additional Context
N/A
The text was updated successfully, but these errors were encountered: