eddyz87 updated this revision to Diff 468611. eddyz87 added a comment. Comment fixed.
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D136041/new/ https://reviews.llvm.org/D136041 Files: clang/lib/CodeGen/CGDebugInfo.cpp clang/test/CodeGen/debug-info-extern-call.c llvm/lib/IR/Verifier.cpp llvm/test/Verifier/callsite-dbgloc.ll Index: llvm/test/Verifier/callsite-dbgloc.ll =================================================================== --- llvm/test/Verifier/callsite-dbgloc.ll +++ llvm/test/Verifier/callsite-dbgloc.ll @@ -45,6 +45,9 @@ call void @j() ; CHECK: inlinable function call in a function with debug info must have a !dbg location call void @k() +; CHECK-NOT: inlinable function call in a function with debug info must have a !dbg location +; CHECK-NOT: @i + call void (...) @i() ret void, !dbg !13 } Index: llvm/lib/IR/Verifier.cpp =================================================================== --- llvm/lib/IR/Verifier.cpp +++ llvm/lib/IR/Verifier.cpp @@ -3466,9 +3466,11 @@ // Verify that each inlinable callsite of a debug-info-bearing function in a // debug-info-bearing function has a debug location attached to it. Failure to // do so causes assertion failures when the inliner sets up inline scope info - // (Interposable functions are not inlinable). + // (Interposable functions are not inlinable, neither are functions without + // definitions.) if (Call.getFunction()->getSubprogram() && Call.getCalledFunction() && !Call.getCalledFunction()->isInterposable() && + !Call.getCalledFunction()->isDeclaration() && Call.getCalledFunction()->getSubprogram()) CheckDI(Call.getDebugLoc(), "inlinable function call in a function with " Index: clang/test/CodeGen/debug-info-extern-call.c =================================================================== --- clang/test/CodeGen/debug-info-extern-call.c +++ clang/test/CodeGen/debug-info-extern-call.c @@ -29,8 +29,8 @@ // DECLS-FOR-EXTERN: [[FN1_TYPES]] = !{[[X_TYPE:![0-9]+]], // DECLS-FOR-EXTERN: [[X_TYPE]] = !DIDerivedType(tag: DW_TAG_typedef, name: "x", // DECLS-FOR-EXTERN-SAME: baseType: [[INT_TYPE]]) -// DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "memcmp" -// DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "__some_reserved_name" +// DECLS-FOR-EXTERN: !DISubprogram(name: "memcmp" +// DECLS-FOR-EXTERN: !DISubprogram(name: "__some_reserved_name" // NO-DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "fn1" // NO-DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "memcmp" Index: clang/lib/CodeGen/CGDebugInfo.cpp =================================================================== --- clang/lib/CodeGen/CGDebugInfo.cpp +++ clang/lib/CodeGen/CGDebugInfo.cpp @@ -4228,17 +4228,11 @@ if (Func->getSubprogram()) return; - // Do not emit a declaration subprogram for a builtin, a function with nodebug - // attribute, or if call site info isn't required. Also, elide declarations - // for functions with reserved names, as call site-related features aren't - // interesting in this case (& also, the compiler may emit calls to these - // functions without debug locations, which makes the verifier complain). - if (CalleeDecl->getBuiltinID() != 0 || CalleeDecl->hasAttr<NoDebugAttr>() || + // Do not emit a declaration subprogram for a function with nodebug + // attribute, or if call site info isn't required. + if (CalleeDecl->hasAttr<NoDebugAttr>() || getCallSiteRelatedAttrs() == llvm::DINode::FlagZero) return; - if (CalleeDecl->isReserved(CGM.getLangOpts()) != - ReservedIdentifierStatus::NotReserved) - return; // If there is no DISubprogram attached to the function being called, // create the one describing the function in order to have complete
Index: llvm/test/Verifier/callsite-dbgloc.ll =================================================================== --- llvm/test/Verifier/callsite-dbgloc.ll +++ llvm/test/Verifier/callsite-dbgloc.ll @@ -45,6 +45,9 @@ call void @j() ; CHECK: inlinable function call in a function with debug info must have a !dbg location call void @k() +; CHECK-NOT: inlinable function call in a function with debug info must have a !dbg location +; CHECK-NOT: @i + call void (...) @i() ret void, !dbg !13 } Index: llvm/lib/IR/Verifier.cpp =================================================================== --- llvm/lib/IR/Verifier.cpp +++ llvm/lib/IR/Verifier.cpp @@ -3466,9 +3466,11 @@ // Verify that each inlinable callsite of a debug-info-bearing function in a // debug-info-bearing function has a debug location attached to it. Failure to // do so causes assertion failures when the inliner sets up inline scope info - // (Interposable functions are not inlinable). + // (Interposable functions are not inlinable, neither are functions without + // definitions.) if (Call.getFunction()->getSubprogram() && Call.getCalledFunction() && !Call.getCalledFunction()->isInterposable() && + !Call.getCalledFunction()->isDeclaration() && Call.getCalledFunction()->getSubprogram()) CheckDI(Call.getDebugLoc(), "inlinable function call in a function with " Index: clang/test/CodeGen/debug-info-extern-call.c =================================================================== --- clang/test/CodeGen/debug-info-extern-call.c +++ clang/test/CodeGen/debug-info-extern-call.c @@ -29,8 +29,8 @@ // DECLS-FOR-EXTERN: [[FN1_TYPES]] = !{[[X_TYPE:![0-9]+]], // DECLS-FOR-EXTERN: [[X_TYPE]] = !DIDerivedType(tag: DW_TAG_typedef, name: "x", // DECLS-FOR-EXTERN-SAME: baseType: [[INT_TYPE]]) -// DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "memcmp" -// DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "__some_reserved_name" +// DECLS-FOR-EXTERN: !DISubprogram(name: "memcmp" +// DECLS-FOR-EXTERN: !DISubprogram(name: "__some_reserved_name" // NO-DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "fn1" // NO-DECLS-FOR-EXTERN-NOT: !DISubprogram(name: "memcmp" Index: clang/lib/CodeGen/CGDebugInfo.cpp =================================================================== --- clang/lib/CodeGen/CGDebugInfo.cpp +++ clang/lib/CodeGen/CGDebugInfo.cpp @@ -4228,17 +4228,11 @@ if (Func->getSubprogram()) return; - // Do not emit a declaration subprogram for a builtin, a function with nodebug - // attribute, or if call site info isn't required. Also, elide declarations - // for functions with reserved names, as call site-related features aren't - // interesting in this case (& also, the compiler may emit calls to these - // functions without debug locations, which makes the verifier complain). - if (CalleeDecl->getBuiltinID() != 0 || CalleeDecl->hasAttr<NoDebugAttr>() || + // Do not emit a declaration subprogram for a function with nodebug + // attribute, or if call site info isn't required. + if (CalleeDecl->hasAttr<NoDebugAttr>() || getCallSiteRelatedAttrs() == llvm::DINode::FlagZero) return; - if (CalleeDecl->isReserved(CGM.getLangOpts()) != - ReservedIdentifierStatus::NotReserved) - return; // If there is no DISubprogram attached to the function being called, // create the one describing the function in order to have complete
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits