mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-01 18:12:44 +00:00
AsmParser: Require a terminating null character when creating memory buffer.
This commit modifies the memory buffer creation in the AsmParser library so that it requires a terminating null character. The LLLexer in the AsmParser library checks for EOF only when it sees a null character, thus it would be best to require it when creating a memory buffer so that the memory buffer constructor can verify that a terminating null character is indeed present. Reviewers: Duncan P. N. Exon Smith, Matthias Braun Differential Revision: http://reviews.llvm.org/D9883 llvm-svn: 237833
This commit is contained in:
parent
558850ac59
commit
c6277793dd
@ -24,7 +24,7 @@ using namespace llvm;
|
|||||||
|
|
||||||
bool llvm::parseAssemblyInto(MemoryBufferRef F, Module &M, SMDiagnostic &Err) {
|
bool llvm::parseAssemblyInto(MemoryBufferRef F, Module &M, SMDiagnostic &Err) {
|
||||||
SourceMgr SM;
|
SourceMgr SM;
|
||||||
std::unique_ptr<MemoryBuffer> Buf = MemoryBuffer::getMemBuffer(F, false);
|
std::unique_ptr<MemoryBuffer> Buf = MemoryBuffer::getMemBuffer(F);
|
||||||
SM.AddNewSourceBuffer(std::move(Buf), SMLoc());
|
SM.AddNewSourceBuffer(std::move(Buf), SMLoc());
|
||||||
|
|
||||||
return LLParser(F.getBuffer(), SM, Err, &M).Run();
|
return LLParser(F.getBuffer(), SM, Err, &M).Run();
|
||||||
|
47
llvm/unittests/AsmParser/AsmParserTest.cpp
Normal file
47
llvm/unittests/AsmParser/AsmParserTest.cpp
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
//===- llvm/unittest/AsmParser/AsmParserTest.cpp - asm parser unittests ---===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/ADT/StringRef.h"
|
||||||
|
#include "llvm/AsmParser/Parser.h"
|
||||||
|
#include "llvm/IR/LLVMContext.h"
|
||||||
|
#include "llvm/IR/Module.h"
|
||||||
|
#include "llvm/Support/SourceMgr.h"
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
using namespace llvm;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
TEST(AsmParserTest, NullTerminatedInput) {
|
||||||
|
LLVMContext &Ctx = getGlobalContext();
|
||||||
|
StringRef Source = "; Empty module \n";
|
||||||
|
SMDiagnostic Error;
|
||||||
|
auto Mod = parseAssemblyString(Source, Error, Ctx);
|
||||||
|
|
||||||
|
EXPECT_TRUE(Mod != nullptr);
|
||||||
|
EXPECT_TRUE(Error.getMessage().empty());
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef GTEST_HAS_DEATH_TEST
|
||||||
|
#ifndef NDEBUG
|
||||||
|
|
||||||
|
TEST(AsmParserTest, NonNullTerminatedInput) {
|
||||||
|
LLVMContext &Ctx = getGlobalContext();
|
||||||
|
StringRef Source = "; Empty module \n\1\2";
|
||||||
|
SMDiagnostic Error;
|
||||||
|
std::unique_ptr<Module> Mod;
|
||||||
|
EXPECT_DEATH(Mod = parseAssemblyString(Source.substr(0, Source.size() - 2),
|
||||||
|
Error, Ctx),
|
||||||
|
"Buffer is not null terminated!");
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} // end anonymous namespace
|
9
llvm/unittests/AsmParser/CMakeLists.txt
Normal file
9
llvm/unittests/AsmParser/CMakeLists.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
set(LLVM_LINK_COMPONENTS
|
||||||
|
AsmParser
|
||||||
|
Core
|
||||||
|
Support
|
||||||
|
)
|
||||||
|
|
||||||
|
add_llvm_unittest(AsmParserTests
|
||||||
|
AsmParserTest.cpp
|
||||||
|
)
|
15
llvm/unittests/AsmParser/Makefile
Normal file
15
llvm/unittests/AsmParser/Makefile
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
##===- unittests/AsmParser/Makefile ------------------------*- Makefile -*-===##
|
||||||
|
#
|
||||||
|
# The LLVM Compiler Infrastructure
|
||||||
|
#
|
||||||
|
# This file is distributed under the University of Illinois Open Source
|
||||||
|
# License. See LICENSE.TXT for details.
|
||||||
|
#
|
||||||
|
##===----------------------------------------------------------------------===##
|
||||||
|
|
||||||
|
LEVEL = ../..
|
||||||
|
TESTNAME = AsmParser
|
||||||
|
LINK_COMPONENTS := AsmParser Core Support
|
||||||
|
|
||||||
|
include $(LEVEL)/Makefile.config
|
||||||
|
include $(LLVM_SRC_ROOT)/unittests/Makefile.unittest
|
@ -13,6 +13,7 @@ endfunction()
|
|||||||
|
|
||||||
add_subdirectory(ADT)
|
add_subdirectory(ADT)
|
||||||
add_subdirectory(Analysis)
|
add_subdirectory(Analysis)
|
||||||
|
add_subdirectory(AsmParser)
|
||||||
add_subdirectory(Bitcode)
|
add_subdirectory(Bitcode)
|
||||||
add_subdirectory(CodeGen)
|
add_subdirectory(CodeGen)
|
||||||
add_subdirectory(DebugInfo)
|
add_subdirectory(DebugInfo)
|
||||||
|
@ -9,8 +9,9 @@
|
|||||||
|
|
||||||
LEVEL = ..
|
LEVEL = ..
|
||||||
|
|
||||||
PARALLEL_DIRS = ADT Analysis Bitcode CodeGen DebugInfo ExecutionEngine IR \
|
PARALLEL_DIRS = ADT Analysis AsmParser Bitcode CodeGen DebugInfo \
|
||||||
LineEditor Linker MC Option ProfileData Support Transforms
|
ExecutionEngine IR LineEditor Linker MC Option ProfileData \
|
||||||
|
Support Transforms
|
||||||
|
|
||||||
include $(LEVEL)/Makefile.config
|
include $(LEVEL)/Makefile.config
|
||||||
include $(LLVM_SRC_ROOT)/unittests/Makefile.unittest
|
include $(LLVM_SRC_ROOT)/unittests/Makefile.unittest
|
||||||
|
Loading…
Reference in New Issue
Block a user