| //===- ProvenanceAnalysis.h - ObjC ARC Optimization -------------*- C++ -*-===// | 
 | // | 
 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
 | // See https://llvm.org/LICENSE.txt for license information. | 
 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 | // | 
 | /// \file | 
 | /// | 
 | /// This file declares a special form of Alias Analysis called ``Provenance | 
 | /// Analysis''. The word ``provenance'' refers to the history of the ownership | 
 | /// of an object. Thus ``Provenance Analysis'' is an analysis which attempts to | 
 | /// use various techniques to determine if locally | 
 | /// | 
 | /// WARNING: This file knows about certain library functions. It recognizes them | 
 | /// by name, and hardwires knowledge of their semantics. | 
 | /// | 
 | /// WARNING: This file knows about how certain Objective-C library functions are | 
 | /// used. Naive LLVM IR transformations which would otherwise be | 
 | /// behavior-preserving may break these assumptions. | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 |  | 
 | #ifndef LLVM_LIB_TRANSFORMS_OBJCARC_PROVENANCEANALYSIS_H | 
 | #define LLVM_LIB_TRANSFORMS_OBJCARC_PROVENANCEANALYSIS_H | 
 |  | 
 | #include "llvm/ADT/DenseMap.h" | 
 | #include "llvm/Analysis/AliasAnalysis.h" | 
 | #include "llvm/IR/ValueHandle.h" | 
 | #include <utility> | 
 |  | 
 | namespace llvm { | 
 |  | 
 | class DataLayout; | 
 | class PHINode; | 
 | class SelectInst; | 
 | class Value; | 
 |  | 
 | namespace objcarc { | 
 |  | 
 | /// This is similar to BasicAliasAnalysis, and it uses many of the same | 
 | /// techniques, except it uses special ObjC-specific reasoning about pointer | 
 | /// relationships. | 
 | /// | 
 | /// In this context ``Provenance'' is defined as the history of an object's | 
 | /// ownership. Thus ``Provenance Analysis'' is defined by using the notion of | 
 | /// an ``independent provenance source'' of a pointer to determine whether or | 
 | /// not two pointers have the same provenance source and thus could | 
 | /// potentially be related. | 
 | class ProvenanceAnalysis { | 
 |   AliasAnalysis *AA; | 
 |  | 
 |   using ValuePairTy = std::pair<const Value *, const Value *>; | 
 |   using CachedResultsTy = DenseMap<ValuePairTy, bool>; | 
 |  | 
 |   CachedResultsTy CachedResults; | 
 |  | 
 |   DenseMap<const Value *, WeakTrackingVH> UnderlyingObjCPtrCache; | 
 |  | 
 |   bool relatedCheck(const Value *A, const Value *B, const DataLayout &DL); | 
 |   bool relatedSelect(const SelectInst *A, const Value *B); | 
 |   bool relatedPHI(const PHINode *A, const Value *B); | 
 |  | 
 | public: | 
 |   ProvenanceAnalysis() = default; | 
 |   ProvenanceAnalysis(const ProvenanceAnalysis &) = delete; | 
 |   ProvenanceAnalysis &operator=(const ProvenanceAnalysis &) = delete; | 
 |  | 
 |   void setAA(AliasAnalysis *aa) { AA = aa; } | 
 |  | 
 |   AliasAnalysis *getAA() const { return AA; } | 
 |  | 
 |   bool related(const Value *A, const Value *B, const DataLayout &DL); | 
 |  | 
 |   void clear() { | 
 |     CachedResults.clear(); | 
 |     UnderlyingObjCPtrCache.clear(); | 
 |   } | 
 | }; | 
 |  | 
 | } // end namespace objcarc | 
 |  | 
 | } // end namespace llvm | 
 |  | 
 | #endif // LLVM_LIB_TRANSFORMS_OBJCARC_PROVENANCEANALYSIS_H |