From d05c59d5f9449b07e7cc7468c9e5c48b176be0e6 Mon Sep 17 00:00:00 2001 From: Nico Weber Date: Wed, 3 Apr 2019 23:19:39 +0000 Subject: [PATCH] llvm-undname: Fix an assert-on-invalid Found by oss-fuzz, fixes issues 12428 and 12429 on oss-fuzz. Differential Revision: https://reviews.llvm.org/D60204 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@357647 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Demangle/MicrosoftDemangle.cpp | 5 +++++ test/Demangle/invalid-manglings.test | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/lib/Demangle/MicrosoftDemangle.cpp b/lib/Demangle/MicrosoftDemangle.cpp index b8e39c41527..b4e5cef7ac5 100644 --- a/lib/Demangle/MicrosoftDemangle.cpp +++ b/lib/Demangle/MicrosoftDemangle.cpp @@ -466,6 +466,10 @@ IdentifierNode * Demangler::demangleFunctionIdentifierCode(StringView &MangledName) { assert(MangledName.startsWith('?')); MangledName = MangledName.dropFront(); + if (MangledName.empty()) { + Error = true; + return nullptr; + } if (MangledName.consumeFront("__")) return demangleFunctionIdentifierCode( @@ -637,6 +641,7 @@ translateIntrinsicFunctionCode(char CH, FunctionIdentifierCodeGroup Group) { IdentifierNode * Demangler::demangleFunctionIdentifierCode(StringView &MangledName, FunctionIdentifierCodeGroup Group) { + assert(!MangledName.empty()); switch (Group) { case FunctionIdentifierCodeGroup::Basic: switch (char CH = MangledName.popFront()) { diff --git a/test/Demangle/invalid-manglings.test b/test/Demangle/invalid-manglings.test index 6883a46d8d3..af919282bb8 100644 --- a/test/Demangle/invalid-manglings.test +++ b/test/Demangle/invalid-manglings.test @@ -14,3 +14,8 @@ ; CHECK-EMPTY: ; CHECK-NEXT: ?@@8 ; CHECK-NEXT: error: Invalid mangled name + +?? +; CHECK-EMPTY: +; CHECK-NEXT: ?? +; CHECK-NEXT: error: Invalid mangled name -- 2.50.1