From a2b0ac40cfe37cfacb8648814cc74f6e8d2c0ed3 Mon Sep 17 00:00:00 2001 From: Filipe Cabecinhas Date: Wed, 4 Nov 2015 14:53:36 +0000 Subject: Error out when faced with value names containing '\0' Bug found with afl-fuzz. llvm-svn: 252048 --- llvm/lib/Bitcode/Reader/BitcodeReader.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'llvm/lib/Bitcode/Reader/BitcodeReader.cpp') diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp index c874a84..522f2aa 100644 --- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1749,7 +1749,10 @@ ErrorOr BitcodeReader::recordValue(SmallVectorImpl &Record, return error("Invalid record"); Value *V = ValueList[ValueID]; - V->setName(StringRef(ValueName.data(), ValueName.size())); + StringRef NameStr(ValueName.data(), ValueName.size()); + if (NameStr.find_first_of(0) != StringRef::npos) + return error("Invalid value name"); + V->setName(NameStr); auto *GO = dyn_cast(V); if (GO) { if (GO->getComdat() == reinterpret_cast(1)) { -- cgit v1.1