svf-lib 1.0.2319 → 1.0.2321
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/WorkList.h +0 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
- package/SVF-linux-aarch64/Release-build/lib/libSvfCore.so.3.1 +0 -0
- package/SVF-linux-aarch64/Release-build/lib/libSvfLLVM.so.3.1 +0 -0
- package/SVF-linux-aarch64/Release-build/lib/pkgconfig/SVF.pc +12 -0
- package/SVF-osx/Release-build/bin/ae +0 -0
- package/SVF-osx/Release-build/bin/cfl +0 -0
- package/SVF-osx/Release-build/bin/dvf +0 -0
- package/SVF-osx/Release-build/bin/llvm2svf +0 -0
- package/SVF-osx/Release-build/bin/mta +0 -0
- package/SVF-osx/Release-build/bin/saber +0 -0
- package/SVF-osx/Release-build/bin/svf-ex +0 -0
- package/SVF-osx/Release-build/bin/wpa +0 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractState.h +425 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractValue.h +157 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AddressValue.h +225 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/ICFGWTO.h +135 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/IntervalValue.h +1055 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/NumericValue.h +1292 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/RelExeState.h +226 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/RelationSolver.h +91 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AEDetector.h +439 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbsExtAPI.h +138 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbstractInterpretation.h +384 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFGNormalizer.h +84 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFGrammar.h +468 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLAlias.h +168 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLBase.h +118 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLGramGraphChecker.h +74 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLGraphBuilder.h +168 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLSVFGBuilder.h +58 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLSolver.h +374 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLStat.h +67 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLVF.h +68 -0
- package/SVF-osx/Release-build/include/SVF/CFL/GrammarBuilder.h +100 -0
- package/SVF-osx/Release-build/include/SVF/DDA/ContextDDA.h +230 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAClient.h +163 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAPass.h +102 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAStat.h +121 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAVFSolver.h +794 -0
- package/SVF-osx/Release-build/include/SVF/DDA/FlowDDA.h +178 -0
- package/SVF-osx/Release-build/include/SVF/FastCluster/fastcluster.h +80 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/BasicBlockG.h +318 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CDG.h +482 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CFLGraph.h +232 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CHG.h +368 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CallGraph.h +497 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsG.h +402 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsGEdge.h +355 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsGNode.h +418 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/DOTGraphTraits.h +188 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GenericGraph.h +628 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphPrinter.h +111 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphTraits.h +150 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphWriter.h +380 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFG.h +331 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGEdge.h +281 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGNode.h +669 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGStat.h +164 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/IRGraph.h +398 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SCC.h +375 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFG.h +491 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGEdge.h +237 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGNode.h +501 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGOPT.h +372 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGStat.h +273 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ThreadCallGraph.h +399 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFG.h +726 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFGEdge.h +295 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFGNode.h +1266 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/WTO.h +872 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MSSAMuChi.h +722 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemPartition.h +169 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemRegion.h +489 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemSSA.h +452 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/SVFGBuilder.h +104 -0
- package/SVF-osx/Release-build/include/SVF/MTA/LockAnalysis.h +533 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MHP.h +546 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MTA.h +97 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MTAStat.h +73 -0
- package/SVF-osx/Release-build/include/SVF/MTA/TCT.h +620 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/AbstractPointsToDS.h +316 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/AccessPath.h +194 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/ConditionalPT.h +878 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/MutablePointsToDS.h +1025 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToCache.h +463 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToDS.h +955 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysis.h +428 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysisImpl.h +602 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointsTo.h +255 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/SVFLoop.h +167 -0
- package/SVF-osx/Release-build/include/SVF/SABER/DoubleFreeChecker.h +76 -0
- package/SVF-osx/Release-build/include/SVF/SABER/FileChecker.h +80 -0
- package/SVF-osx/Release-build/include/SVF/SABER/LeakChecker.h +122 -0
- package/SVF-osx/Release-build/include/SVF/SABER/ProgSlice.h +327 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberCheckerAPI.h +151 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberCondAllocator.h +317 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberSVFGBuilder.h +114 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkDDA.h +327 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkSolver.h +186 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BasicTypes.h +280 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BreakConstantExpr.h +93 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CHGBuilder.h +78 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CppUtil.h +184 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/DCHG.h +474 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/GEPTypeBridgeIterator.h +183 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ICFGBuilder.h +160 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMLoopAnalysis.h +60 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMModule.h +527 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMUtil.h +433 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ObjTypeInference.h +129 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SVFIRBuilder.h +523 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SymbolTableBuilder.h +132 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/ObjTypeInfo.h +224 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/PAGBuilderFromFile.h +80 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFIR.h +856 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFStatements.h +1330 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFType.h +606 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFValue.h +338 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFVariables.h +2212 -0
- package/SVF-osx/Release-build/include/SVF/Util/Annotator.h +180 -0
- package/SVF-osx/Release-build/include/SVF/Util/BitVector.h +55 -0
- package/SVF-osx/Release-build/include/SVF/Util/CDGBuilder.h +107 -0
- package/SVF-osx/Release-build/include/SVF/Util/CallGraphBuilder.h +61 -0
- package/SVF-osx/Release-build/include/SVF/Util/Casting.h +426 -0
- package/SVF-osx/Release-build/include/SVF/Util/CommandLine.h +530 -0
- package/SVF-osx/Release-build/include/SVF/Util/CoreBitVector.h +214 -0
- package/SVF-osx/Release-build/include/SVF/Util/CxtStmt.h +502 -0
- package/SVF-osx/Release-build/include/SVF/Util/DPItem.h +618 -0
- package/SVF-osx/Release-build/include/SVF/Util/ExtAPI.h +117 -0
- package/SVF-osx/Release-build/include/SVF/Util/GeneralType.h +127 -0
- package/SVF-osx/Release-build/include/SVF/Util/GraphReachSolver.h +186 -0
- package/SVF-osx/Release-build/include/SVF/Util/NodeIDAllocator.h +203 -0
- package/SVF-osx/Release-build/include/SVF/Util/Options.h +273 -0
- package/SVF-osx/Release-build/include/SVF/Util/PTAStat.h +83 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFBugReport.h +427 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFLoopAndDomInfo.h +169 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFStat.h +103 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFUtil.h +478 -0
- package/SVF-osx/Release-build/include/SVF/Util/SparseBitVector.h +1252 -0
- package/SVF-osx/Release-build/include/SVF/Util/ThreadAPI.h +188 -0
- package/SVF-osx/Release-build/include/SVF/Util/WorkList.h +317 -0
- package/SVF-osx/Release-build/include/SVF/Util/Z3Expr.h +325 -0
- package/SVF-osx/Release-build/include/SVF/Util/cJSON.h +300 -0
- package/SVF-osx/Release-build/include/SVF/Util/config.h +46 -0
- package/SVF-osx/Release-build/include/SVF/Util/iterator.h +407 -0
- package/SVF-osx/Release-build/include/SVF/Util/iterator_range.h +76 -0
- package/SVF-osx/Release-build/include/SVF/WPA/Andersen.h +434 -0
- package/SVF-osx/Release-build/include/SVF/WPA/AndersenPWC.h +160 -0
- package/SVF-osx/Release-build/include/SVF/WPA/CSC.h +95 -0
- package/SVF-osx/Release-build/include/SVF/WPA/FlowSensitive.h +322 -0
- package/SVF-osx/Release-build/include/SVF/WPA/Steensgaard.h +131 -0
- package/SVF-osx/Release-build/include/SVF/WPA/TypeAnalysis.h +90 -0
- package/SVF-osx/Release-build/include/SVF/WPA/VersionedFlowSensitive.h +295 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAFSSolver.h +246 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAPass.h +115 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPASolver.h +205 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAStat.h +222 -0
- package/SVF-osx/Release-build/include/SVF/extapi.bc +2384 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
- package/SVF-osx/Release-build/lib/libSvfCore.3.1.dylib +0 -0
- package/SVF-osx/Release-build/lib/libSvfLLVM.3.1.dylib +0 -0
- package/SVF-osx/Release-build/lib/pkgconfig/SVF.pc +12 -0
- package/package.json +1 -1
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PAGGrammar.txt +0 -15
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PEGGrammar.txt +0 -11
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/VFGGrammar.txt +0 -7
- package/SVF-linux-aarch64/Release-build/include/FastCluster/LICENSE.TXT +0 -13
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractState.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AddressValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/ICFGWTO.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/IntervalValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/NumericValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelExeState.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelationSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AEDetector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbsExtAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbstractInterpretation.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGNormalizer.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGrammar.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLAlias.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLBase.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGramGraphChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGraphBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLVF.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/GrammarBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/ContextDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAClient.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAPass.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAVFSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/FlowDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{FastCluster → SVF/FastCluster}/fastcluster.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/BasicBlockG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CDG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CFLGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CHG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CallGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/DOTGraphTraits.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GenericGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphPrinter.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphTraits.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphWriter.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/IRGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SCC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGOPT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ThreadCallGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/WTO.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MSSAMuChi.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemPartition.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemRegion.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemSSA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/SVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/LockAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MHP.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/TCT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AbstractPointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AccessPath.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/ConditionalPT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/MutablePointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToCache.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysisImpl.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointsTo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/SVFLoop.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/DoubleFreeChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/FileChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/LeakChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/ProgSlice.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCheckerAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCondAllocator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberSVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BasicTypes.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BreakConstantExpr.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CHGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CppUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/DCHG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/GEPTypeBridgeIterator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ICFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMLoopAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMModule.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ObjTypeInference.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SVFIRBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SymbolTableBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/ObjTypeInfo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/PAGBuilderFromFile.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFIR.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFStatements.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFType.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFVariables.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Annotator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/BitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CDGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CallGraphBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Casting.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CommandLine.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CoreBitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CxtStmt.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/DPItem.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ExtAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GeneralType.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GraphReachSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/NodeIDAllocator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Options.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/PTAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFBugReport.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFLoopAndDomInfo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SparseBitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ThreadAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Z3Expr.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/cJSON.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator_range.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Andersen.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/AndersenPWC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/CSC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/FlowSensitive.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Steensgaard.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/TypeAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/VersionedFlowSensitive.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAFSSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAPass.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPASolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/{lib → include/SVF}/extapi.bc +0 -0
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
//===- WPASolver.h -- Generic WPA solver--------------------------------------//
|
|
2
|
+
//
|
|
3
|
+
// SVF: Static Value-Flow Analysis
|
|
4
|
+
//
|
|
5
|
+
// Copyright (C) <2013-2017> <Yulei Sui>
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
// This program is free software: you can redistribute it and/or modify
|
|
9
|
+
// it under the terms of the GNU Affero General Public License as published by
|
|
10
|
+
// the Free Software Foundation, either version 3 of the License, or
|
|
11
|
+
// (at your option) any later version.
|
|
12
|
+
|
|
13
|
+
// This program is distributed in the hope that it will be useful,
|
|
14
|
+
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
15
|
+
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
16
|
+
// GNU Affero General Public License for more details.
|
|
17
|
+
|
|
18
|
+
// You should have received a copy of the GNU Affero General Public License
|
|
19
|
+
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
20
|
+
//
|
|
21
|
+
//===----------------------------------------------------------------------===//
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
/*
|
|
25
|
+
* WPASolver.h
|
|
26
|
+
*
|
|
27
|
+
* Created on: Oct 25, 2013
|
|
28
|
+
* Author: Yulei Sui
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
#ifndef GRAPHSOLVER_H_
|
|
32
|
+
#define GRAPHSOLVER_H_
|
|
33
|
+
|
|
34
|
+
#include "Util/WorkList.h"
|
|
35
|
+
|
|
36
|
+
namespace SVF
|
|
37
|
+
{
|
|
38
|
+
|
|
39
|
+
/*
|
|
40
|
+
* Generic graph solver for whole program pointer analysis
|
|
41
|
+
*/
|
|
42
|
+
template<class GraphType>
|
|
43
|
+
class WPASolver
|
|
44
|
+
{
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
///Define the GTraits and node iterator for printing
|
|
48
|
+
typedef SVF::GenericGraphTraits<GraphType> GTraits;
|
|
49
|
+
typedef typename GTraits::NodeRef GNODE;
|
|
50
|
+
typedef typename GTraits::EdgeType GEDGE;
|
|
51
|
+
typedef typename GTraits::ChildIteratorType child_iterator;
|
|
52
|
+
|
|
53
|
+
typedef SCCDetection<GraphType> SCC;
|
|
54
|
+
|
|
55
|
+
typedef FIFOWorkList<NodeID> WorkList;
|
|
56
|
+
|
|
57
|
+
protected:
|
|
58
|
+
|
|
59
|
+
/// Constructor
|
|
60
|
+
WPASolver(): reanalyze(false), iterationForPrintStat(1000), _graph(nullptr), numOfIteration(0)
|
|
61
|
+
{
|
|
62
|
+
}
|
|
63
|
+
/// Destructor
|
|
64
|
+
virtual ~WPASolver() = default;
|
|
65
|
+
|
|
66
|
+
/// Get SCC detector
|
|
67
|
+
inline SCC* getSCCDetector() const
|
|
68
|
+
{
|
|
69
|
+
return scc.get();
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/// Get/Set graph methods
|
|
73
|
+
//@{
|
|
74
|
+
const inline GraphType graph()
|
|
75
|
+
{
|
|
76
|
+
return _graph;
|
|
77
|
+
}
|
|
78
|
+
inline void setGraph(GraphType g)
|
|
79
|
+
{
|
|
80
|
+
_graph = g;
|
|
81
|
+
scc = std::make_unique<SCC>(_graph);
|
|
82
|
+
}
|
|
83
|
+
//@}
|
|
84
|
+
|
|
85
|
+
/// SCC detection
|
|
86
|
+
virtual inline NodeStack& SCCDetect()
|
|
87
|
+
{
|
|
88
|
+
getSCCDetector()->find();
|
|
89
|
+
return getSCCDetector()->topoNodeStack();
|
|
90
|
+
}
|
|
91
|
+
virtual inline NodeStack& SCCDetect(NodeSet& candidates)
|
|
92
|
+
{
|
|
93
|
+
getSCCDetector()->find(candidates);
|
|
94
|
+
return getSCCDetector()->topoNodeStack();
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
virtual inline void initWorklist()
|
|
98
|
+
{
|
|
99
|
+
NodeStack& nodeStack = SCCDetect();
|
|
100
|
+
while (!nodeStack.empty())
|
|
101
|
+
{
|
|
102
|
+
NodeID nodeId = nodeStack.top();
|
|
103
|
+
nodeStack.pop();
|
|
104
|
+
pushIntoWorklist(nodeId);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
virtual inline void solveWorklist()
|
|
109
|
+
{
|
|
110
|
+
while (!isWorklistEmpty())
|
|
111
|
+
{
|
|
112
|
+
NodeID nodeId = popFromWorklist();
|
|
113
|
+
// Keep solving until workList is empty.
|
|
114
|
+
processNode(nodeId);
|
|
115
|
+
collapseFields();
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/// Following methods are to be implemented in child class, in order to achieve a fully worked PTA
|
|
120
|
+
//@{
|
|
121
|
+
/// Process each node on the graph, to be implemented in the child class
|
|
122
|
+
virtual inline void processNode(NodeID) {}
|
|
123
|
+
/// collapse positive weight cycles of a graph
|
|
124
|
+
virtual void collapseFields() {}
|
|
125
|
+
/// dump statistics
|
|
126
|
+
/// Propagation for the solving, to be implemented in the child class
|
|
127
|
+
virtual void propagate(GNODE* v)
|
|
128
|
+
{
|
|
129
|
+
child_iterator EI = GTraits::direct_child_begin(*v);
|
|
130
|
+
child_iterator EE = GTraits::direct_child_end(*v);
|
|
131
|
+
for (; EI != EE; ++EI)
|
|
132
|
+
{
|
|
133
|
+
if (propFromSrcToDst(*(EI.getCurrent())))
|
|
134
|
+
pushIntoWorklist(Node_Index(*EI));
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
/// Propagate information from source to destination node, to be implemented in the child class
|
|
138
|
+
virtual bool propFromSrcToDst(GEDGE*)
|
|
139
|
+
{
|
|
140
|
+
return false;
|
|
141
|
+
}
|
|
142
|
+
//@}
|
|
143
|
+
|
|
144
|
+
virtual NodeID sccRepNode(NodeID id) const
|
|
145
|
+
{
|
|
146
|
+
return getSCCDetector()->repNode(id);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
/// Worklist operations
|
|
150
|
+
//@{
|
|
151
|
+
inline NodeID popFromWorklist()
|
|
152
|
+
{
|
|
153
|
+
return sccRepNode(worklist.pop());
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
virtual inline void pushIntoWorklist(NodeID id)
|
|
157
|
+
{
|
|
158
|
+
worklist.push(sccRepNode(id));
|
|
159
|
+
}
|
|
160
|
+
inline bool isWorklistEmpty()
|
|
161
|
+
{
|
|
162
|
+
return worklist.empty();
|
|
163
|
+
}
|
|
164
|
+
inline bool isInWorklist(NodeID id)
|
|
165
|
+
{
|
|
166
|
+
return worklist.find(id);
|
|
167
|
+
}
|
|
168
|
+
//@}
|
|
169
|
+
|
|
170
|
+
/// Reanalyze if any constraint value changed
|
|
171
|
+
bool reanalyze;
|
|
172
|
+
/// print out statistics for i-th iteration
|
|
173
|
+
u32_t iterationForPrintStat;
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
/// Get node on the graph
|
|
177
|
+
inline GNODE* Node(NodeID id)
|
|
178
|
+
{
|
|
179
|
+
return GTraits::getNode(_graph, id);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
/// Get node ID
|
|
183
|
+
inline NodeID Node_Index(GNODE node)
|
|
184
|
+
{
|
|
185
|
+
return GTraits::getNodeID(node);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
protected:
|
|
189
|
+
/// Graph
|
|
190
|
+
GraphType _graph;
|
|
191
|
+
|
|
192
|
+
/// SCC
|
|
193
|
+
std::unique_ptr<SCC> scc;
|
|
194
|
+
|
|
195
|
+
/// Worklist for resolution
|
|
196
|
+
WorkList worklist;
|
|
197
|
+
|
|
198
|
+
public:
|
|
199
|
+
/// num of iterations during constraint solving
|
|
200
|
+
u32_t numOfIteration;
|
|
201
|
+
};
|
|
202
|
+
|
|
203
|
+
} // End namespace SVF
|
|
204
|
+
|
|
205
|
+
#endif /* GRAPHSOLVER_H_ */
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
//===- WPAStat.h -- WPA statistics--------------------------------------------//
|
|
2
|
+
//
|
|
3
|
+
// SVF: Static Value-Flow Analysis
|
|
4
|
+
//
|
|
5
|
+
// Copyright (C) <2013-2017> <Yulei Sui>
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
// This program is free software: you can redistribute it and/or modify
|
|
9
|
+
// it under the terms of the GNU Affero General Public License as published by
|
|
10
|
+
// the Free Software Foundation, either version 3 of the License, or
|
|
11
|
+
// (at your option) any later version.
|
|
12
|
+
|
|
13
|
+
// This program is distributed in the hope that it will be useful,
|
|
14
|
+
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
15
|
+
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
16
|
+
// GNU Affero General Public License for more details.
|
|
17
|
+
|
|
18
|
+
// You should have received a copy of the GNU Affero General Public License
|
|
19
|
+
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
20
|
+
//
|
|
21
|
+
//===----------------------------------------------------------------------===//
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
/*
|
|
25
|
+
* FlowSensitiveStat.h
|
|
26
|
+
*
|
|
27
|
+
* Created on: 27/11/2013
|
|
28
|
+
* Author: yesen
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
#ifndef FLOWSENSITIVESTAT_H_
|
|
32
|
+
#define FLOWSENSITIVESTAT_H_
|
|
33
|
+
|
|
34
|
+
#include "Util/PTAStat.h"
|
|
35
|
+
#include "WPA/FlowSensitive.h"
|
|
36
|
+
#include "WPA/VersionedFlowSensitive.h"
|
|
37
|
+
|
|
38
|
+
namespace SVF
|
|
39
|
+
{
|
|
40
|
+
|
|
41
|
+
class AndersenBase;
|
|
42
|
+
class SVFIR;
|
|
43
|
+
class ConstraintGraph;
|
|
44
|
+
|
|
45
|
+
/*!
|
|
46
|
+
* Statistics of Andersen's analysis
|
|
47
|
+
*/
|
|
48
|
+
class AndersenStat : public PTAStat
|
|
49
|
+
{
|
|
50
|
+
|
|
51
|
+
private:
|
|
52
|
+
AndersenBase* pta;
|
|
53
|
+
|
|
54
|
+
public:
|
|
55
|
+
static const char* CollapseTime;
|
|
56
|
+
|
|
57
|
+
static u32_t _MaxPtsSize;
|
|
58
|
+
static u32_t _NumOfCycles;
|
|
59
|
+
static u32_t _NumOfPWCCycles;
|
|
60
|
+
static u32_t _NumOfNodesInCycles;
|
|
61
|
+
static u32_t _MaxNumOfNodesInSCC;
|
|
62
|
+
u32_t _NumOfNullPtr;
|
|
63
|
+
u32_t _NumOfConstantPtr;
|
|
64
|
+
u32_t _NumOfBlackholePtr;
|
|
65
|
+
|
|
66
|
+
AndersenStat(AndersenBase* p);
|
|
67
|
+
|
|
68
|
+
virtual ~AndersenStat()
|
|
69
|
+
{
|
|
70
|
+
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
virtual void performStat();
|
|
74
|
+
|
|
75
|
+
void collectCycleInfo(ConstraintGraph* consCG);
|
|
76
|
+
|
|
77
|
+
void statNullPtr();
|
|
78
|
+
|
|
79
|
+
void constraintGraphStat();
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
/*!
|
|
83
|
+
* Statistics of flow-sensitive analysis
|
|
84
|
+
*/
|
|
85
|
+
class FlowSensitiveStat : public PTAStat
|
|
86
|
+
{
|
|
87
|
+
public:
|
|
88
|
+
typedef FlowSensitive::DFInOutMap DFInOutMap;
|
|
89
|
+
typedef FlowSensitive::PtsMap PtsMap;
|
|
90
|
+
|
|
91
|
+
FlowSensitive * fspta;
|
|
92
|
+
|
|
93
|
+
FlowSensitiveStat(FlowSensitive* pta): PTAStat(pta)
|
|
94
|
+
{
|
|
95
|
+
fspta = pta;
|
|
96
|
+
clearStat();
|
|
97
|
+
startClk();
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
virtual ~FlowSensitiveStat() {}
|
|
101
|
+
|
|
102
|
+
virtual void performStat();
|
|
103
|
+
|
|
104
|
+
private:
|
|
105
|
+
enum ENUM_INOUT
|
|
106
|
+
{
|
|
107
|
+
IN,
|
|
108
|
+
OUT
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
void clearStat();
|
|
112
|
+
|
|
113
|
+
void statNullPtr();
|
|
114
|
+
|
|
115
|
+
void statPtsSize();
|
|
116
|
+
|
|
117
|
+
void statAddrVarPtsSize();
|
|
118
|
+
|
|
119
|
+
void calculateAddrVarPts(NodeID pointer, const SVFGNode* node);
|
|
120
|
+
|
|
121
|
+
void statInOutPtsSize(const DFInOutMap& data, ENUM_INOUT inOrOut);
|
|
122
|
+
|
|
123
|
+
u32_t _NumOfNullPtr;
|
|
124
|
+
u32_t _NumOfConstantPtr;
|
|
125
|
+
u32_t _NumOfBlackholePtr;
|
|
126
|
+
|
|
127
|
+
/// number of SVFG nodes which have IN/OUT set.
|
|
128
|
+
u32_t _NumOfSVFGNodesHaveInOut[2];
|
|
129
|
+
u32_t _NumOfFormalInSVFGNodesHaveInOut[2];
|
|
130
|
+
u32_t _NumOfFormalOutSVFGNodesHaveInOut[2];
|
|
131
|
+
u32_t _NumOfActualInSVFGNodesHaveInOut[2];
|
|
132
|
+
u32_t _NumOfActualOutSVFGNodesHaveInOut[2];
|
|
133
|
+
u32_t _NumOfLoadSVFGNodesHaveInOut[2];
|
|
134
|
+
u32_t _NumOfStoreSVFGNodesHaveInOut[2];
|
|
135
|
+
u32_t _NumOfMSSAPhiSVFGNodesHaveInOut[2];
|
|
136
|
+
|
|
137
|
+
/// number of pag nodes which have points-to set in IN/OUT set.
|
|
138
|
+
u32_t _NumOfVarHaveINOUTPts[2];
|
|
139
|
+
u32_t _NumOfVarHaveEmptyINOUTPts[2];
|
|
140
|
+
u32_t _NumOfVarHaveINOUTPtsInFormalIn[2];
|
|
141
|
+
u32_t _NumOfVarHaveINOUTPtsInFormalOut[2];
|
|
142
|
+
u32_t _NumOfVarHaveINOUTPtsInActualIn[2];
|
|
143
|
+
u32_t _NumOfVarHaveINOUTPtsInActualOut[2];
|
|
144
|
+
u32_t _NumOfVarHaveINOUTPtsInLoad[2];
|
|
145
|
+
u32_t _NumOfVarHaveINOUTPtsInStore[2];
|
|
146
|
+
u32_t _NumOfVarHaveINOUTPtsInMSSAPhi[2];
|
|
147
|
+
u32_t _PotentialNumOfVarHaveINOUTPts[2];
|
|
148
|
+
|
|
149
|
+
/// sizes of points-to set
|
|
150
|
+
u32_t _MaxPtsSize; ///< max points-to set size.
|
|
151
|
+
u32_t _MaxTopLvlPtsSize; ///< max points-to set size in top-level pointers.
|
|
152
|
+
u32_t _MaxInOutPtsSize[2]; ///< max points-to set size in IN/OUT set.
|
|
153
|
+
|
|
154
|
+
u32_t _TotalPtsSize; ///< total points-to set size.
|
|
155
|
+
|
|
156
|
+
double _AvgPtsSize; ///< average points-to set size.
|
|
157
|
+
double _AvgTopLvlPtsSize; ///< average points-to set size in top-level pointers.
|
|
158
|
+
double _AvgInOutPtsSize[2]; ///< average points-to set size in IN set.
|
|
159
|
+
double _AvgAddrTakenVarPtsSize; ///< average points-to set size of addr-taken variables.
|
|
160
|
+
|
|
161
|
+
u32_t _MaxAddrTakenVarPts; ///< max points-to set size of addr-taken variables.
|
|
162
|
+
u32_t _NumOfAddrTakeVar; ///< number of occurrences of addr-taken variables in load/store.
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
class VersionedFlowSensitiveStat : public PTAStat
|
|
166
|
+
{
|
|
167
|
+
public:
|
|
168
|
+
VersionedFlowSensitive *vfspta;
|
|
169
|
+
|
|
170
|
+
VersionedFlowSensitiveStat(VersionedFlowSensitive* pta): PTAStat(pta)
|
|
171
|
+
{
|
|
172
|
+
vfspta = pta;
|
|
173
|
+
clearStat();
|
|
174
|
+
startClk();
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
virtual ~VersionedFlowSensitiveStat() { }
|
|
178
|
+
|
|
179
|
+
virtual void performStat();
|
|
180
|
+
|
|
181
|
+
private:
|
|
182
|
+
void clearStat();
|
|
183
|
+
|
|
184
|
+
/// For all version-related statistics.
|
|
185
|
+
void versionStat(void);
|
|
186
|
+
|
|
187
|
+
/// For all PTS size related statistics not handled by versionStat.
|
|
188
|
+
void ptsSizeStat(void);
|
|
189
|
+
|
|
190
|
+
/// Total number of versions across all objects.
|
|
191
|
+
u32_t _NumVersions;
|
|
192
|
+
/// Most versions for a single object.
|
|
193
|
+
u32_t _MaxVersions;
|
|
194
|
+
/// Number of version PTSs actually used (sum of next two fields).
|
|
195
|
+
u32_t _NumUsedVersions;
|
|
196
|
+
/// Number of versions with non-empty points-to sets (since versioning is over-approximate).
|
|
197
|
+
u32_t _NumNonEmptyVersions;
|
|
198
|
+
/// Number of versions with empty points-to sets (actually empty, not never-accessed).
|
|
199
|
+
u32_t _NumEmptyVersions;
|
|
200
|
+
/// Number of objects which have a single version.
|
|
201
|
+
u32_t _NumSingleVersion;
|
|
202
|
+
|
|
203
|
+
/// Largest PTS size.
|
|
204
|
+
u32_t _MaxPtsSize;
|
|
205
|
+
/// Max points-to set size in top-level pointers.
|
|
206
|
+
u32_t _MaxTopLvlPtsSize;
|
|
207
|
+
/// Max address-taken points-to set size.
|
|
208
|
+
u32_t _MaxVersionPtsSize;
|
|
209
|
+
|
|
210
|
+
/// Total of points-to set sizes for calculating averages.
|
|
211
|
+
u32_t _TotalPtsSize;
|
|
212
|
+
|
|
213
|
+
/// Average size across all points-to sets.
|
|
214
|
+
double _AvgPtsSize;
|
|
215
|
+
/// Average points-to set size for top-level pointers.
|
|
216
|
+
double _AvgTopLvlPtsSize;
|
|
217
|
+
/// Average points-to set size for address-taken objects.
|
|
218
|
+
double _AvgVersionPtsSize;
|
|
219
|
+
};
|
|
220
|
+
} // End namespace SVF
|
|
221
|
+
|
|
222
|
+
#endif /* FLOWSENSITIVESTAT_H_ */
|