1 | //===- DependencyAnalysis.h - ObjC ARC Optimization ---*- 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 | /// \file |
9 | /// |
10 | /// This file declares special dependency analysis routines used in Objective C |
11 | /// ARC Optimizations. |
12 | /// |
13 | /// WARNING: This file knows about certain library functions. It recognizes them |
14 | /// by name, and hardwires knowledge of their semantics. |
15 | /// |
16 | /// WARNING: This file knows about how certain Objective-C library functions are |
17 | /// used. Naive LLVM IR transformations which would otherwise be |
18 | /// behavior-preserving may break these assumptions. |
19 | /// |
20 | //===----------------------------------------------------------------------===// |
21 | |
22 | #ifndef LLVM_LIB_TRANSFORMS_OBJCARC_DEPENDENCYANALYSIS_H |
23 | #define LLVM_LIB_TRANSFORMS_OBJCARC_DEPENDENCYANALYSIS_H |
24 | |
25 | #include "llvm/Analysis/ObjCARCInstKind.h" |
26 | |
27 | namespace llvm { |
28 | class BasicBlock; |
29 | class Instruction; |
30 | class Value; |
31 | } |
32 | |
33 | namespace llvm { |
34 | namespace objcarc { |
35 | |
36 | class ProvenanceAnalysis; |
37 | |
38 | /// \enum DependenceKind |
39 | /// Defines different dependence kinds among various ARC constructs. |
40 | /// |
41 | /// There are several kinds of dependence-like concepts in use here. |
42 | /// |
43 | enum DependenceKind { |
44 | NeedsPositiveRetainCount, |
45 | AutoreleasePoolBoundary, |
46 | CanChangeRetainCount, |
47 | RetainAutoreleaseDep, ///< Blocks objc_retainAutorelease. |
48 | RetainAutoreleaseRVDep ///< Blocks objc_retainAutoreleaseReturnValue. |
49 | }; |
50 | |
51 | /// Find dependent instructions. If there is exactly one dependent instruction, |
52 | /// return it. Otherwise, return null. |
53 | llvm::Instruction *findSingleDependency(DependenceKind Flavor, const Value *Arg, |
54 | BasicBlock *StartBB, |
55 | Instruction *StartInst, |
56 | ProvenanceAnalysis &PA); |
57 | |
58 | bool |
59 | Depends(DependenceKind Flavor, Instruction *Inst, const Value *Arg, |
60 | ProvenanceAnalysis &PA); |
61 | |
62 | /// Test whether the given instruction can "use" the given pointer's object in a |
63 | /// way that requires the reference count to be positive. |
64 | bool CanUse(const Instruction *Inst, const Value *Ptr, ProvenanceAnalysis &PA, |
65 | ARCInstKind Class); |
66 | |
67 | /// Test whether the given instruction can result in a reference count |
68 | /// modification (positive or negative) for the pointer's object. |
69 | bool CanAlterRefCount(const Instruction *Inst, const Value *Ptr, |
70 | ProvenanceAnalysis &PA, ARCInstKind Class); |
71 | |
72 | /// Returns true if we can not conservatively prove that Inst can not decrement |
73 | /// the reference count of Ptr. Returns false if we can. |
74 | bool CanDecrementRefCount(const Instruction *Inst, const Value *Ptr, |
75 | ProvenanceAnalysis &PA, ARCInstKind Class); |
76 | |
77 | static inline bool CanDecrementRefCount(const Instruction *Inst, |
78 | const Value *Ptr, |
79 | ProvenanceAnalysis &PA) { |
80 | return CanDecrementRefCount(Inst, Ptr, PA, Class: GetARCInstKind(V: Inst)); |
81 | } |
82 | |
83 | } // namespace objcarc |
84 | } // namespace llvm |
85 | |
86 | #endif |
87 | |