mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-26 10:29:36 +00:00
[inline asm] Add a check in InlineAsm::ConstraintInfo::Parse to make sure '{'
follows '~' in a clobber constraint string. Previously llc would hit an llvm_unreachable when compiling an inline-asm instruction with malformed constraint string "~x{21}". This commit enables LLParser to catch the error earlier and print a more helpful diagnostic. rdar://problem/14206559 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@217288 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
52af82df95
commit
cbbae7f41d
@ -91,6 +91,10 @@ bool InlineAsm::ConstraintInfo::Parse(StringRef Str,
|
||||
if (*I == '~') {
|
||||
Type = isClobber;
|
||||
++I;
|
||||
|
||||
// '{' must immediately follow '~'.
|
||||
if (I != E && *I != '{')
|
||||
return true;
|
||||
} else if (*I == '=') {
|
||||
++I;
|
||||
Type = isOutput;
|
||||
|
10
test/Assembler/inline-asm-clobber.ll
Normal file
10
test/Assembler/inline-asm-clobber.ll
Normal file
@ -0,0 +1,10 @@
|
||||
; RUN: not llvm-as <%s 2>&1 | FileCheck %s
|
||||
|
||||
; "~x{21}" is not a valid clobber constraint.
|
||||
|
||||
; CHECK: invalid type for inline asm constraint string
|
||||
|
||||
define void @foo() nounwind {
|
||||
call void asm sideeffect "mov x0, #42", "~{x0},~{x19},~x{21}"() nounwind
|
||||
ret void
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user