From: Nikita Popov Date: Sat, 5 Dec 2020 09:39:31 +0000 (+0100) Subject: [AA] Add statistics for alias results (NFC) X-Git-Tag: llvmorg-13-init~4284 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f8afba5f7a25a69c12191d979d78d40fa6e5b684;p=platform%2Fupstream%2Fllvm.git [AA] Add statistics for alias results (NFC) Count how many NoAlias/MustAlias/MayAlias we get from top-level queries. --- diff --git a/llvm/include/llvm/Analysis/AliasAnalysis.h b/llvm/include/llvm/Analysis/AliasAnalysis.h index 7a43389..05c0193 100644 --- a/llvm/include/llvm/Analysis/AliasAnalysis.h +++ b/llvm/include/llvm/Analysis/AliasAnalysis.h @@ -814,6 +814,9 @@ private: std::vector AADeps; + /// Query depth used to distinguish recursive queries. + unsigned Depth; + friend class BatchAAResults; }; diff --git a/llvm/lib/Analysis/AliasAnalysis.cpp b/llvm/lib/Analysis/AliasAnalysis.cpp index 3d094a6..6635e53 100644 --- a/llvm/lib/Analysis/AliasAnalysis.cpp +++ b/llvm/lib/Analysis/AliasAnalysis.cpp @@ -24,6 +24,7 @@ //===----------------------------------------------------------------------===// #include "llvm/Analysis/AliasAnalysis.h" +#include "llvm/ADT/Statistic.h" #include "llvm/Analysis/BasicAliasAnalysis.h" #include "llvm/Analysis/CFLAndersAliasAnalysis.h" #include "llvm/Analysis/CFLSteensAliasAnalysis.h" @@ -54,8 +55,14 @@ #include #include +#define DEBUG_TYPE "aa" + using namespace llvm; +STATISTIC(NumNoAlias, "Number of NoAlias results"); +STATISTIC(NumMayAlias, "Number of MayAlias results"); +STATISTIC(NumMustAlias, "Number of MustAlias results"); + /// Allow disabling BasicAA from the AA results. This is particularly useful /// when testing to isolate a single AA implementation. cl::opt DisableBasicAA("disable-basic-aa", cl::Hidden, cl::init(false)); @@ -109,12 +116,25 @@ AliasResult AAResults::alias(const MemoryLocation &LocA, AliasResult AAResults::alias(const MemoryLocation &LocA, const MemoryLocation &LocB, AAQueryInfo &AAQI) { + AliasResult Result = MayAlias; + + Depth++; for (const auto &AA : AAs) { - auto Result = AA->alias(LocA, LocB, AAQI); + Result = AA->alias(LocA, LocB, AAQI); if (Result != MayAlias) - return Result; + break; + } + Depth--; + + if (Depth == 0) { + if (Result == NoAlias) + ++NumNoAlias; + else if (Result == MustAlias) + ++NumMustAlias; + else + ++NumMayAlias; } - return MayAlias; + return Result; } bool AAResults::pointsToConstantMemory(const MemoryLocation &Loc,