| 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 | |