diff options
author | Timm Baeder <tbaeder@redhat.com> | 2025-08-05 07:54:25 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-08-05 07:54:25 +0200 |
commit | df3f6297354b3ea5fa53cc6a9d5464b54aae6f15 (patch) | |
tree | c86dbb171b71d605fc4bc1cefabc21779294ade7 /clang/lib/AST/ByteCode/Compiler.cpp | |
parent | e4d3dc6359f568a9b0ac2e1010bbc7d13f4982b6 (diff) | |
download | llvm-df3f6297354b3ea5fa53cc6a9d5464b54aae6f15.zip llvm-df3f6297354b3ea5fa53cc6a9d5464b54aae6f15.tar.gz llvm-df3f6297354b3ea5fa53cc6a9d5464b54aae6f15.tar.bz2 |
[clang][bytecode][NFC] Only collect non-null args if we have to (#152074)
Only do this if the function really has a NonNullArg.
Diffstat (limited to 'clang/lib/AST/ByteCode/Compiler.cpp')
-rw-r--r-- | clang/lib/AST/ByteCode/Compiler.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/AST/ByteCode/Compiler.cpp b/clang/lib/AST/ByteCode/Compiler.cpp index 5bcac39..6b74b5e 100644 --- a/clang/lib/AST/ByteCode/Compiler.cpp +++ b/clang/lib/AST/ByteCode/Compiler.cpp @@ -2038,7 +2038,12 @@ bool Compiler<Emitter>::visitCallArgs(ArrayRef<const Expr *> Args, const FunctionDecl *FuncDecl, bool Activate) { assert(VarScope->getKind() == ScopeKind::Call); - llvm::BitVector NonNullArgs = collectNonNullArgs(FuncDecl, Args); + bool HasNonNullAttr = false; + llvm::BitVector NonNullArgs; + if (FuncDecl && FuncDecl->hasAttr<NonNullAttr>()) { + HasNonNullAttr = true; + NonNullArgs = collectNonNullArgs(FuncDecl, Args); + } unsigned ArgIndex = 0; for (const Expr *Arg : Args) { @@ -2064,7 +2069,7 @@ bool Compiler<Emitter>::visitCallArgs(ArrayRef<const Expr *> Args, return false; } - if (FuncDecl && NonNullArgs[ArgIndex]) { + if (HasNonNullAttr && NonNullArgs[ArgIndex]) { PrimType ArgT = classify(Arg).value_or(PT_Ptr); if (ArgT == PT_Ptr) { if (!this->emitCheckNonNullArg(ArgT, Arg)) |