diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 27f69adff56b6..1f2cf7bc9f18d 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -10426,7 +10426,7 @@ Decl *Sema::ActOnFinishFunctionBody(Decl *dcl, Stmt *Body, if (FD && FD->hasAttr()) { for (const Stmt *S : Body->children()) { - if (!isa(S)) { + if (!isa(S) && !isa(S)) { Diag(S->getLocStart(), diag::err_non_asm_stmt_in_naked_function); Diag(FD->getAttr()->getLocation(), diag::note_attribute); FD->setInvalidDecl(); diff --git a/clang/test/Sema/attr-naked.c b/clang/test/Sema/attr-naked.c index f6c26b29fc3a2..fcae842775e0d 100644 --- a/clang/test/Sema/attr-naked.c +++ b/clang/test/Sema/attr-naked.c @@ -23,3 +23,12 @@ __attribute__((naked)) int t5(int x) { asm("movl x, %eax"); asm("retl"); } + +__attribute__((naked)) void t6() { + ; +} + +__attribute__((naked)) void t7() { + asm("movl $42, %eax"); + ; +}