clang 23.0.0git
FactsGenerator.h
Go to the documentation of this file.
1//===- FactsGenerator.h - Lifetime Facts Generation -------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the FactsGenerator, which traverses the AST to generate
10// lifetime-relevant facts (such as loan issuance, expiration, origin flow,
11// and use) from CFG statements. These facts are used by the dataflow analyses
12// to track pointer lifetimes and detect use-after-free errors.
13//
14//===----------------------------------------------------------------------===//
15#ifndef LLVM_CLANG_ANALYSIS_ANALYSES_LIFETIMESAFETY_FACTSGENERATOR_H
16#define LLVM_CLANG_ANALYSIS_ANALYSES_LIFETIMESAFETY_FACTSGENERATOR_H
17
22#include "clang/Analysis/CFG.h"
23#include "llvm/ADT/SmallVector.h"
24
26
27class FactsGenerator : public ConstStmtVisitor<FactsGenerator> {
29
30public:
32 : FactMgr(FactMgr), AC(AC),
33 IsCMode(!AC.getASTContext().getLangOpts().CPlusPlus &&
34 !AC.getASTContext().getLangOpts().ObjC) {}
35
36 void run();
37
38 void VisitDeclStmt(const DeclStmt *DS);
39 void VisitDeclRefExpr(const DeclRefExpr *DRE);
43 void VisitMemberExpr(const MemberExpr *ME);
44 void VisitCallExpr(const CallExpr *CE);
46 void VisitCastExpr(const CastExpr *CE);
47 void VisitUnaryOperator(const UnaryOperator *UO);
48 void VisitReturnStmt(const ReturnStmt *RS);
49 void VisitBinaryOperator(const BinaryOperator *BO);
53 void VisitInitListExpr(const InitListExpr *ILE);
56 void VisitLambdaExpr(const LambdaExpr *LE);
58 void VisitCXXNewExpr(const CXXNewExpr *NE);
59 void VisitCXXDeleteExpr(const CXXDeleteExpr *DE);
60
61private:
62 OriginList *getOriginsList(const ValueDecl &D);
63 OriginList *getOriginsList(const Expr &E);
64
65 bool hasOrigins(QualType QT) const;
66 bool hasOrigins(const Expr *E) const;
67
68 void flow(OriginList *Dst, OriginList *Src, bool Kill);
69
70 /// Handles assignment for both BinaryOperator and CXXOperatorCallExpr.
71 ///
72 /// LHSExpr is the destination whose stored loans are replaced by RHSExpr's
73 /// loans. TargetExpr is the assignment expression itself; it receives
74 /// LHSExpr's origins so chained assignments like `a = b = c` can propagate
75 /// through the result of `b = c`.
76 void handleAssignment(const Expr *TargetExpr, const Expr *LHSExpr,
77 const Expr *RHSExpr);
78
79 void handlePointerArithmetic(const BinaryOperator *BO);
80
81 bool handlePlacementNew(const CXXNewExpr *NE, OriginList *NewList);
82
83 void handleCXXCtorInitializer(const CXXCtorInitializer *CII);
84
85 void handleLifetimeEnds(const CFGLifetimeEnds &LifetimeEnds);
86
87 void handleFullExprCleanup(const CFGFullExprCleanup &FullExprCleanup);
88
89 void handleExitBlock();
90
91 /// Mark all fields of the implicit object as used for an instance method
92 /// call, since the callee may access any part of the object.
93 void handleImplicitObjectFieldUses(const Expr *Call, const FunctionDecl *FD);
94
95 void handleGSLPointerConstruction(const CXXConstructExpr *CCE);
96
97 /// Detects arguments passed to rvalue reference parameters and creates
98 /// MovedOriginFact for them. The MovedLoansAnalysis then uses these facts
99 /// to track in a flow-sensitive manner which loans have been moved at each
100 /// program point, allowing warnings to distinguish potentially moved storage
101 /// from other use-after-free errors.
102 void handleMovedArgsInCall(const FunctionDecl *FD,
104
105 // Handles [[clang::lifetime_capture_by(X)]] annotations on a function call to
106 // create flow facts from captured arguments to the capturer
107 void handleLifetimeCaptureBy(const FunctionDecl *FD,
109
110 /// Checks if a call-like expression creates a borrow by passing a value to a
111 /// reference parameter, creating an IssueFact if it does.
112 /// \param IsGslConstruction True if this is a GSL construction where all
113 /// argument origins should flow to the returned origin.
114 void handleFunctionCall(const Expr *Call, const FunctionDecl *FD,
116 bool IsGslConstruction = false);
117
118 // Detect methods that invalidate iterators/references/pointees.
119 // For instance methods, Args[0] is the implicit 'this' pointer.
120 void handleInvalidatingCall(const Expr *Call, const FunctionDecl *FD,
122
123 // Detect explicit destructor calls/`std::destroy_at`
124 void handleDestructiveCall(const Expr *Call, const FunctionDecl *FD,
126
127 template <typename Destination, typename Source>
128 void flowOrigin(const Destination &D, const Source &S) {
129 flow(getOriginsList(D), getOriginsList(S), /*Kill=*/false);
130 }
131
132 template <typename Destination, typename Source>
133 void killAndFlowOrigin(const Destination &D, const Source &S) {
134 flow(getOriginsList(D), getOriginsList(S), /*Kill=*/true);
135 }
136
137 /// Checks if the expression is a `void("__lifetime_test_point_...")` cast.
138 /// If so, creates a `TestPointFact` and returns true.
139 bool handleTestPoint(const CXXFunctionalCastExpr *FCE);
140
141 // Treats an expression as a use of the referenced object. It will be
142 // checked for use-after-free unless it is later marked as being written to
143 // (e.g. on the left-hand side of an assignment in the case of a DeclRefExpr).
144 void handleUse(const Expr *E);
145
146 void markUseAsWrite(const DeclRefExpr *DRE);
147
148 bool escapesViaReturn(OriginID OID) const;
149
150 llvm::SmallVector<Fact *> issuePlaceholderLoans();
151 FactManager &FactMgr;
153 llvm::SmallVector<Fact *> CurrentBlockFacts;
154 // Collect origins that escape the function in this block (OriginEscapesFact),
155 // appended at the end of CurrentBlockFacts to ensure they appear after
156 // ExpireFact entries.
157 llvm::SmallVector<Fact *> EscapesInCurrentBlock;
158 // To distinguish between reads and writes for use-after-free checks, this map
159 // stores the `UseFact` for each `DeclRefExpr`. We initially identify all
160 // `DeclRefExpr`s as "read" uses. When an assignment is processed, the use
161 // corresponding to the left-hand side is updated to be a "write", thereby
162 // exempting it from the check.
163 llvm::DenseMap<const Expr *, UseFact *> UseFacts;
164 const CFGBlock *CurrentBlock;
165 bool IsCMode = false;
166};
167
168} // namespace clang::lifetimes::internal
169
170#endif // LLVM_CLANG_ANALYSIS_ANALYSES_LIFETIMESAFETY_FACTSGENERATOR_H
This file defines AnalysisDeclContext, a class that manages the analysis context data for context sen...
static bool handleAssignment(EvalInfo &Info, const Expr *E, const LValue &LVal, QualType LValType, APValue &Val)
Perform an assignment of Val to LVal. Takes ownership of Val.
AbstractConditionalOperator - An abstract base class for ConditionalOperator and BinaryConditionalOpe...
Definition Expr.h:4359
AnalysisDeclContext contains the context data for the function, method or block under analysis.
ArraySubscriptExpr - [C99 6.5.2.1] Array Subscripting.
Definition Expr.h:2727
A builtin binary operation expression such as "x + y" or "x <= y".
Definition Expr.h:4044
Represents a single basic block in a source-level CFG.
Definition CFG.h:652
Represents the point where the lifetime of an automatic object ends.
Definition CFG.h:321
Represents binding an expression to a temporary.
Definition ExprCXX.h:1497
Represents a call to a C++ constructor.
Definition ExprCXX.h:1552
Represents a C++ base or member initializer.
Definition DeclCXX.h:2398
A use of a default initializer in a constructor or in aggregate initialization.
Definition ExprCXX.h:1381
Represents a delete expression for memory deallocation and destructor calls, e.g.
Definition ExprCXX.h:2630
Represents an explicit C++ type conversion that uses "functional" notation (C++ [expr....
Definition ExprCXX.h:1835
Represents a call to a member function that may be written either with member call syntax (e....
Definition ExprCXX.h:183
Represents a new-expression for memory allocation and constructor calls, e.g: "new CXXNewExpr(foo)".
Definition ExprCXX.h:2359
The null pointer literal (C++11 [lex.nullptr])
Definition ExprCXX.h:772
A call to an overloaded operator written using operator syntax.
Definition ExprCXX.h:85
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
Definition Expr.h:2949
CastExpr - Base class for type casts, including both implicit casts (ImplicitCastExpr) and explicit c...
Definition Expr.h:3682
ConstStmtVisitor - This class implements a simple visitor for Stmt subclasses.
A reference to a declared variable, function, enum, etc.
Definition Expr.h:1276
DeclStmt - Adaptor class for mixing declarations with statements and expressions.
Definition Stmt.h:1641
This represents one expression.
Definition Expr.h:112
Represents a function declaration or definition.
Definition Decl.h:2018
Describes an C or C++ initializer list.
Definition Expr.h:5305
A C++ lambda expression, which produces a function object (of unspecified type) that can be invoked l...
Definition ExprCXX.h:1972
Represents a prvalue temporary that is written into memory so that a reference can bind to it.
Definition ExprCXX.h:4920
MemberExpr - [C99 6.5.2.3] Structure and Union Members.
Definition Expr.h:3370
A (possibly-)qualified type.
Definition TypeBase.h:937
ReturnStmt - This represents a return, optionally of an expression: return; return 4;.
Definition Stmt.h:3170
UnaryOperator - This represents the unary-expression's (except sizeof and alignof),...
Definition Expr.h:2250
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
Definition Decl.h:712
void VisitDeclRefExpr(const DeclRefExpr *DRE)
void VisitBinaryOperator(const BinaryOperator *BO)
void VisitMaterializeTemporaryExpr(const MaterializeTemporaryExpr *MTE)
FactsGenerator(FactManager &FactMgr, AnalysisDeclContext &AC)
void VisitCXXConstructExpr(const CXXConstructExpr *CCE)
void VisitAbstractConditionalOperator(const AbstractConditionalOperator *CO)
void VisitCXXDeleteExpr(const CXXDeleteExpr *DE)
void VisitCXXFunctionalCastExpr(const CXXFunctionalCastExpr *FCE)
void VisitCXXDefaultInitExpr(const CXXDefaultInitExpr *DIE)
void VisitInitListExpr(const InitListExpr *ILE)
void VisitCXXNullPtrLiteralExpr(const CXXNullPtrLiteralExpr *N)
void VisitCXXOperatorCallExpr(const CXXOperatorCallExpr *OCE)
void VisitArraySubscriptExpr(const ArraySubscriptExpr *ASE)
void VisitUnaryOperator(const UnaryOperator *UO)
void VisitCXXMemberCallExpr(const CXXMemberCallExpr *MCE)
void VisitCXXBindTemporaryExpr(const CXXBindTemporaryExpr *BTE)
A list of origins representing levels of indirection for pointer-like types.
Definition Origins.h:95
utils::ID< struct OriginTag > OriginID
Definition Origins.h:28
@ CPlusPlus