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,434 @@
|
|
|
1
|
+
//===- Andersen.h -- Field-sensitive Andersen's pointer analysis-------------//
|
|
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
|
+
* Andersen.h
|
|
25
|
+
*
|
|
26
|
+
* Created on: Nov 12, 2013
|
|
27
|
+
* Author: Yulei Sui
|
|
28
|
+
*
|
|
29
|
+
* The field-sensitive implementation is improved based on
|
|
30
|
+
*
|
|
31
|
+
* Yuxiang Lei and Yulei Sui. "Fast and Precise Handling of Positive Weight Cycles for Field-sensitive Pointer Analysis".
|
|
32
|
+
* 26th International Static Analysis Symposium (SAS'19)
|
|
33
|
+
*/
|
|
34
|
+
|
|
35
|
+
#ifndef INCLUDE_WPA_ANDERSEN_H_
|
|
36
|
+
#define INCLUDE_WPA_ANDERSEN_H_
|
|
37
|
+
|
|
38
|
+
#include "MemoryModel/PointerAnalysisImpl.h"
|
|
39
|
+
#include "WPA/WPAStat.h"
|
|
40
|
+
#include "WPA/WPASolver.h"
|
|
41
|
+
#include "SVFIR/SVFIR.h"
|
|
42
|
+
#include "Graphs/ConsG.h"
|
|
43
|
+
#include "Util/Options.h"
|
|
44
|
+
|
|
45
|
+
namespace SVF
|
|
46
|
+
{
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
class ThreadCallGraph;
|
|
50
|
+
|
|
51
|
+
/*!
|
|
52
|
+
* Abstract class of inclusion-based Pointer Analysis
|
|
53
|
+
*/
|
|
54
|
+
typedef WPASolver<ConstraintGraph*> WPAConstraintSolver;
|
|
55
|
+
|
|
56
|
+
class AndersenBase: public WPAConstraintSolver, public BVDataPTAImpl
|
|
57
|
+
{
|
|
58
|
+
public:
|
|
59
|
+
typedef OrderedMap<const CallICFGNode*, NodeID> CallSite2DummyValPN;
|
|
60
|
+
|
|
61
|
+
public:
|
|
62
|
+
|
|
63
|
+
/// Constructor
|
|
64
|
+
AndersenBase(SVFIR* _pag, PTATY type = Andersen_BASE, bool alias_check = true)
|
|
65
|
+
: BVDataPTAImpl(_pag, type, alias_check), consCG(nullptr)
|
|
66
|
+
{
|
|
67
|
+
iterationForPrintStat = OnTheFlyIterBudgetForStat;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/// Destructor
|
|
71
|
+
~AndersenBase() override;
|
|
72
|
+
|
|
73
|
+
/// Andersen analysis
|
|
74
|
+
virtual void analyze() override;
|
|
75
|
+
|
|
76
|
+
virtual void solveAndwritePtsToFile(const std::string& filename);
|
|
77
|
+
|
|
78
|
+
virtual void readPtsFromFile(const std::string& filename);
|
|
79
|
+
|
|
80
|
+
virtual void solveConstraints();
|
|
81
|
+
|
|
82
|
+
/// Initialize analysis
|
|
83
|
+
virtual void initialize() override;
|
|
84
|
+
|
|
85
|
+
/// Finalize analysis
|
|
86
|
+
virtual void finalize() override;
|
|
87
|
+
|
|
88
|
+
/// Update call graph
|
|
89
|
+
virtual bool updateCallGraph(const CallSiteToFunPtrMap&) override;
|
|
90
|
+
|
|
91
|
+
/// Update thread call graph
|
|
92
|
+
virtual bool updateThreadCallGraph(const CallSiteToFunPtrMap&, NodePairSet&);
|
|
93
|
+
|
|
94
|
+
/// Connect formal and actual parameters for indirect forksites
|
|
95
|
+
virtual void connectCaller2ForkedFunParams(const CallICFGNode* cs, const FunObjVar* F,
|
|
96
|
+
NodePairSet& cpySrcNodes);
|
|
97
|
+
|
|
98
|
+
/// Connect formal and actual parameters for indirect callsites
|
|
99
|
+
virtual void connectCaller2CalleeParams(const CallICFGNode* cs, const FunObjVar* F,
|
|
100
|
+
NodePairSet& cpySrcNodes);
|
|
101
|
+
|
|
102
|
+
/// Methods for support type inquiry through isa, cast, and dyn_cast:
|
|
103
|
+
//@{
|
|
104
|
+
static inline bool classof(const AndersenBase *)
|
|
105
|
+
{
|
|
106
|
+
return true;
|
|
107
|
+
}
|
|
108
|
+
static inline bool classof(const PointerAnalysis *pta)
|
|
109
|
+
{
|
|
110
|
+
return ( pta->getAnalysisTy() == Andersen_BASE
|
|
111
|
+
|| pta->getAnalysisTy() == Andersen_WPA
|
|
112
|
+
|| pta->getAnalysisTy() == AndersenWaveDiff_WPA
|
|
113
|
+
|| pta->getAnalysisTy() == AndersenSCD_WPA
|
|
114
|
+
|| pta->getAnalysisTy() == AndersenSFR_WPA
|
|
115
|
+
|| pta->getAnalysisTy() == TypeCPP_WPA
|
|
116
|
+
|| pta->getAnalysisTy() == Steensgaard_WPA);
|
|
117
|
+
}
|
|
118
|
+
//@}
|
|
119
|
+
|
|
120
|
+
/// Get constraint graph
|
|
121
|
+
ConstraintGraph* getConstraintGraph()
|
|
122
|
+
{
|
|
123
|
+
return consCG;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
/// SCC methods
|
|
127
|
+
//@{
|
|
128
|
+
inline NodeID sccRepNode(NodeID id) const override
|
|
129
|
+
{
|
|
130
|
+
return consCG->sccRepNode(id);
|
|
131
|
+
}
|
|
132
|
+
inline NodeBS& sccSubNodes(NodeID repId)
|
|
133
|
+
{
|
|
134
|
+
return consCG->sccSubNodes(repId);
|
|
135
|
+
}
|
|
136
|
+
//@}
|
|
137
|
+
|
|
138
|
+
/// Add copy edge on constraint graph
|
|
139
|
+
virtual bool addCopyEdge(NodeID src, NodeID dst) = 0;
|
|
140
|
+
|
|
141
|
+
/// dump statistics
|
|
142
|
+
inline void printStat()
|
|
143
|
+
{
|
|
144
|
+
PointerAnalysis::dumpStat();
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
virtual void normalizePointsTo() override;
|
|
148
|
+
|
|
149
|
+
/// remove redundant gepnodes in constraint graph
|
|
150
|
+
void cleanConsCG(NodeID id);
|
|
151
|
+
|
|
152
|
+
NodeBS redundantGepNodes;
|
|
153
|
+
|
|
154
|
+
/// Statistics
|
|
155
|
+
//@{
|
|
156
|
+
static u32_t numOfProcessedAddr; /// Number of processed Addr edge
|
|
157
|
+
static u32_t numOfProcessedCopy; /// Number of processed Copy edge
|
|
158
|
+
static u32_t numOfProcessedGep; /// Number of processed Gep edge
|
|
159
|
+
static u32_t numOfProcessedLoad; /// Number of processed Load edge
|
|
160
|
+
static u32_t numOfProcessedStore; /// Number of processed Store edge
|
|
161
|
+
static u32_t numOfSfrs;
|
|
162
|
+
static u32_t numOfFieldExpand;
|
|
163
|
+
|
|
164
|
+
static u32_t numOfSCCDetection;
|
|
165
|
+
static double timeOfSCCDetection;
|
|
166
|
+
static double timeOfSCCMerges;
|
|
167
|
+
static double timeOfCollapse;
|
|
168
|
+
static u32_t AveragePointsToSetSize;
|
|
169
|
+
static u32_t MaxPointsToSetSize;
|
|
170
|
+
static double timeOfProcessCopyGep;
|
|
171
|
+
static double timeOfProcessLoadStore;
|
|
172
|
+
static double timeOfUpdateCallGraph;
|
|
173
|
+
//@}
|
|
174
|
+
|
|
175
|
+
protected:
|
|
176
|
+
/// Constraint Graph
|
|
177
|
+
ConstraintGraph* consCG;
|
|
178
|
+
CallSite2DummyValPN
|
|
179
|
+
callsite2DummyValPN; ///< Map an instruction to a dummy obj which
|
|
180
|
+
///< created at an indirect callsite, which invokes
|
|
181
|
+
///< a heap allocator
|
|
182
|
+
void heapAllocatorViaIndCall(const CallICFGNode* cs, NodePairSet& cpySrcNodes);
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
/*!
|
|
186
|
+
* Inclusion-based Pointer Analysis
|
|
187
|
+
*/
|
|
188
|
+
class Andersen: public AndersenBase
|
|
189
|
+
{
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
public:
|
|
193
|
+
typedef SCCDetection<ConstraintGraph*> CGSCC;
|
|
194
|
+
|
|
195
|
+
/// Constructor
|
|
196
|
+
Andersen(SVFIR* _pag, PTATY type = Andersen_WPA, bool alias_check = true)
|
|
197
|
+
: AndersenBase(_pag, type, alias_check)
|
|
198
|
+
{
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/// Destructor
|
|
202
|
+
virtual ~Andersen()
|
|
203
|
+
{
|
|
204
|
+
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/// Initialize analysis
|
|
208
|
+
virtual void initialize();
|
|
209
|
+
|
|
210
|
+
/// Finalize analysis
|
|
211
|
+
virtual void finalize();
|
|
212
|
+
|
|
213
|
+
/// Reset data
|
|
214
|
+
inline void resetData()
|
|
215
|
+
{
|
|
216
|
+
AveragePointsToSetSize = 0;
|
|
217
|
+
MaxPointsToSetSize = 0;
|
|
218
|
+
timeOfProcessCopyGep = 0;
|
|
219
|
+
timeOfProcessLoadStore = 0;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
/// Methods for support type inquiry through isa, cast, and dyn_cast:
|
|
223
|
+
//@{
|
|
224
|
+
static inline bool classof(const Andersen *)
|
|
225
|
+
{
|
|
226
|
+
return true;
|
|
227
|
+
}
|
|
228
|
+
static inline bool classof(const PointerAnalysis *pta)
|
|
229
|
+
{
|
|
230
|
+
return (pta->getAnalysisTy() == Andersen_WPA
|
|
231
|
+
|| pta->getAnalysisTy() == AndersenWaveDiff_WPA
|
|
232
|
+
|| pta->getAnalysisTy() == AndersenSCD_WPA
|
|
233
|
+
|| pta->getAnalysisTy() == AndersenSFR_WPA);
|
|
234
|
+
}
|
|
235
|
+
//@}
|
|
236
|
+
|
|
237
|
+
/// Operation of points-to set
|
|
238
|
+
virtual inline const PointsTo& getPts(NodeID id)
|
|
239
|
+
{
|
|
240
|
+
return getPTDataTy()->getPts(sccRepNode(id));
|
|
241
|
+
}
|
|
242
|
+
virtual inline bool unionPts(NodeID id, const PointsTo& target)
|
|
243
|
+
{
|
|
244
|
+
id = sccRepNode(id);
|
|
245
|
+
return getPTDataTy()->unionPts(id, target);
|
|
246
|
+
}
|
|
247
|
+
virtual inline bool unionPts(NodeID id, NodeID ptd)
|
|
248
|
+
{
|
|
249
|
+
id = sccRepNode(id);
|
|
250
|
+
ptd = sccRepNode(ptd);
|
|
251
|
+
return getPTDataTy()->unionPts(id,ptd);
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
void dumpTopLevelPtsTo();
|
|
256
|
+
|
|
257
|
+
void setDetectPWC(bool flag)
|
|
258
|
+
{
|
|
259
|
+
Options::DetectPWC.setValue(flag);
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
protected:
|
|
263
|
+
|
|
264
|
+
CallSite2DummyValPN callsite2DummyValPN; ///< Map an instruction to a dummy obj which created at an indirect callsite, which invokes a heap allocator
|
|
265
|
+
|
|
266
|
+
/// Handle diff points-to set.
|
|
267
|
+
virtual inline void computeDiffPts(NodeID id)
|
|
268
|
+
{
|
|
269
|
+
if (Options::DiffPts())
|
|
270
|
+
{
|
|
271
|
+
NodeID rep = sccRepNode(id);
|
|
272
|
+
getDiffPTDataTy()->computeDiffPts(rep, getDiffPTDataTy()->getPts(rep));
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
virtual inline const PointsTo& getDiffPts(NodeID id)
|
|
276
|
+
{
|
|
277
|
+
NodeID rep = sccRepNode(id);
|
|
278
|
+
if (Options::DiffPts())
|
|
279
|
+
return getDiffPTDataTy()->getDiffPts(rep);
|
|
280
|
+
else
|
|
281
|
+
return getPTDataTy()->getPts(rep);
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
/// Handle propagated points-to set.
|
|
285
|
+
inline void updatePropaPts(NodeID dstId, NodeID srcId)
|
|
286
|
+
{
|
|
287
|
+
if (!Options::DiffPts())
|
|
288
|
+
return;
|
|
289
|
+
NodeID srcRep = sccRepNode(srcId);
|
|
290
|
+
NodeID dstRep = sccRepNode(dstId);
|
|
291
|
+
getDiffPTDataTy()->updatePropaPtsMap(srcRep, dstRep);
|
|
292
|
+
}
|
|
293
|
+
inline void clearPropaPts(NodeID src)
|
|
294
|
+
{
|
|
295
|
+
if (Options::DiffPts())
|
|
296
|
+
{
|
|
297
|
+
NodeID rep = sccRepNode(src);
|
|
298
|
+
getDiffPTDataTy()->clearPropaPts(rep);
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
virtual void initWorklist() {}
|
|
303
|
+
|
|
304
|
+
/// Override WPASolver function in order to use the default solver
|
|
305
|
+
virtual void processNode(NodeID nodeId);
|
|
306
|
+
|
|
307
|
+
/// handling various constraints
|
|
308
|
+
//@{
|
|
309
|
+
void processAllAddr();
|
|
310
|
+
|
|
311
|
+
virtual bool processLoad(NodeID node, const ConstraintEdge* load);
|
|
312
|
+
virtual bool processStore(NodeID node, const ConstraintEdge* load);
|
|
313
|
+
virtual bool processCopy(NodeID node, const ConstraintEdge* edge);
|
|
314
|
+
virtual bool processGep(NodeID node, const GepCGEdge* edge);
|
|
315
|
+
virtual void handleCopyGep(ConstraintNode* node);
|
|
316
|
+
virtual void handleLoadStore(ConstraintNode* node);
|
|
317
|
+
virtual void processAddr(const AddrCGEdge* addr);
|
|
318
|
+
virtual bool processGepPts(const PointsTo& pts, const GepCGEdge* edge);
|
|
319
|
+
//@}
|
|
320
|
+
|
|
321
|
+
/// Add copy edge on constraint graph
|
|
322
|
+
virtual inline bool addCopyEdge(NodeID src, NodeID dst)
|
|
323
|
+
{
|
|
324
|
+
if (consCG->addCopyCGEdge(src, dst))
|
|
325
|
+
{
|
|
326
|
+
updatePropaPts(src, dst);
|
|
327
|
+
return true;
|
|
328
|
+
}
|
|
329
|
+
return false;
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
/// Merge sub node to its rep
|
|
333
|
+
virtual void mergeNodeToRep(NodeID nodeId,NodeID newRepId);
|
|
334
|
+
|
|
335
|
+
virtual bool mergeSrcToTgt(NodeID srcId,NodeID tgtId);
|
|
336
|
+
|
|
337
|
+
/// Merge sub node in a SCC cycle to their rep node
|
|
338
|
+
//@{
|
|
339
|
+
void mergeSccNodes(NodeID repNodeId, const NodeBS& subNodes);
|
|
340
|
+
void mergeSccCycle();
|
|
341
|
+
//@}
|
|
342
|
+
/// Collapse a field object into its base for field insensitive analysis
|
|
343
|
+
//@{
|
|
344
|
+
virtual void collapsePWCNode(NodeID nodeId);
|
|
345
|
+
void collapseFields();
|
|
346
|
+
bool collapseNodePts(NodeID nodeId);
|
|
347
|
+
bool collapseField(NodeID nodeId);
|
|
348
|
+
//@}
|
|
349
|
+
|
|
350
|
+
/// Updates subnodes of its rep, and rep node of its subs
|
|
351
|
+
void updateNodeRepAndSubs(NodeID nodeId,NodeID newRepId);
|
|
352
|
+
|
|
353
|
+
/// SCC detection
|
|
354
|
+
virtual NodeStack& SCCDetect();
|
|
355
|
+
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
/// Sanitize pts for field insensitive objects
|
|
359
|
+
void sanitizePts()
|
|
360
|
+
{
|
|
361
|
+
for(ConstraintGraph::iterator it = consCG->begin(), eit = consCG->end(); it!=eit; ++it)
|
|
362
|
+
{
|
|
363
|
+
const PointsTo& pts = getPts(it->first);
|
|
364
|
+
NodeBS fldInsenObjs;
|
|
365
|
+
|
|
366
|
+
for (NodeID o : pts)
|
|
367
|
+
{
|
|
368
|
+
if(isFieldInsensitive(o))
|
|
369
|
+
fldInsenObjs.set(o);
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
for (NodeID o : fldInsenObjs)
|
|
373
|
+
{
|
|
374
|
+
const NodeBS &allFields = consCG->getAllFieldsObjVars(o);
|
|
375
|
+
for (NodeID f : allFields) addPts(it->first, f);
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
/// Get PTA name
|
|
381
|
+
virtual const std::string PTAName() const
|
|
382
|
+
{
|
|
383
|
+
return "AndersenWPA";
|
|
384
|
+
}
|
|
385
|
+
|
|
386
|
+
/// Runs a Steensgaard analysis and performs clustering based on those
|
|
387
|
+
/// results set the global best mapping.
|
|
388
|
+
virtual void cluster(void) const;
|
|
389
|
+
};
|
|
390
|
+
|
|
391
|
+
|
|
392
|
+
|
|
393
|
+
/**
|
|
394
|
+
* Wave propagation with diff points-to set.
|
|
395
|
+
*/
|
|
396
|
+
class AndersenWaveDiff : public Andersen
|
|
397
|
+
{
|
|
398
|
+
|
|
399
|
+
private:
|
|
400
|
+
|
|
401
|
+
static AndersenWaveDiff* diffWave; // static instance
|
|
402
|
+
|
|
403
|
+
public:
|
|
404
|
+
AndersenWaveDiff(SVFIR* _pag, PTATY type = AndersenWaveDiff_WPA, bool alias_check = true): Andersen(_pag, type, alias_check) {}
|
|
405
|
+
|
|
406
|
+
/// Create an singleton instance directly instead of invoking llvm pass manager
|
|
407
|
+
static AndersenWaveDiff* createAndersenWaveDiff(SVFIR* _pag)
|
|
408
|
+
{
|
|
409
|
+
if(diffWave==nullptr)
|
|
410
|
+
{
|
|
411
|
+
diffWave = new AndersenWaveDiff(_pag, AndersenWaveDiff_WPA, false);
|
|
412
|
+
diffWave->analyze();
|
|
413
|
+
return diffWave;
|
|
414
|
+
}
|
|
415
|
+
return diffWave;
|
|
416
|
+
}
|
|
417
|
+
static void releaseAndersenWaveDiff()
|
|
418
|
+
{
|
|
419
|
+
if (diffWave)
|
|
420
|
+
delete diffWave;
|
|
421
|
+
diffWave = nullptr;
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
virtual void initialize();
|
|
425
|
+
virtual void solveWorklist();
|
|
426
|
+
virtual void processNode(NodeID nodeId);
|
|
427
|
+
virtual void postProcessNode(NodeID nodeId);
|
|
428
|
+
virtual bool handleLoad(NodeID id, const ConstraintEdge* load);
|
|
429
|
+
virtual bool handleStore(NodeID id, const ConstraintEdge* store);
|
|
430
|
+
};
|
|
431
|
+
|
|
432
|
+
} // End namespace SVF
|
|
433
|
+
|
|
434
|
+
#endif /* INCLUDE_WPA_ANDERSEN_H_ */
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
//===- AndersenSFR.h -- SFR based field-sensitive Andersen's analysis-------------//
|
|
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
|
+
* AndersenSFR.h
|
|
25
|
+
*
|
|
26
|
+
* Created on: 09, Feb, 2019
|
|
27
|
+
* Author: Yuxiang Lei
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
#ifndef PROJECT_ANDERSENSFR_H
|
|
31
|
+
#define PROJECT_ANDERSENSFR_H
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
#include "WPA/Andersen.h"
|
|
35
|
+
#include "WPA/CSC.h"
|
|
36
|
+
#include "MemoryModel/PointsTo.h"
|
|
37
|
+
|
|
38
|
+
namespace SVF
|
|
39
|
+
{
|
|
40
|
+
|
|
41
|
+
/*!
|
|
42
|
+
* Selective Cycle Detection Based Andersen Analysis
|
|
43
|
+
*/
|
|
44
|
+
class AndersenSCD : public Andersen
|
|
45
|
+
{
|
|
46
|
+
public:
|
|
47
|
+
typedef Map<NodeID, NodeID> NodeToNodeMap;
|
|
48
|
+
|
|
49
|
+
protected:
|
|
50
|
+
static AndersenSCD* scdAndersen;
|
|
51
|
+
NodeSet sccCandidates;
|
|
52
|
+
NodeToNodeMap pwcReps;
|
|
53
|
+
|
|
54
|
+
public:
|
|
55
|
+
AndersenSCD(SVFIR* _pag, PTATY type = AndersenSCD_WPA) :
|
|
56
|
+
Andersen(_pag,type)
|
|
57
|
+
{
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/// Create an singleton instance directly instead of invoking llvm pass manager
|
|
61
|
+
static AndersenSCD *createAndersenSCD(SVFIR* _pag)
|
|
62
|
+
{
|
|
63
|
+
if (scdAndersen == nullptr)
|
|
64
|
+
{
|
|
65
|
+
scdAndersen = new AndersenSCD(_pag);
|
|
66
|
+
scdAndersen->analyze();
|
|
67
|
+
return scdAndersen;
|
|
68
|
+
}
|
|
69
|
+
return scdAndersen;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
static void releaseAndersenSCD()
|
|
73
|
+
{
|
|
74
|
+
if (scdAndersen)
|
|
75
|
+
delete scdAndersen;
|
|
76
|
+
scdAndersen = nullptr;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
protected:
|
|
80
|
+
inline void addSccCandidate(NodeID nodeId)
|
|
81
|
+
{
|
|
82
|
+
sccCandidates.insert(sccRepNode(nodeId));
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
virtual NodeStack& SCCDetect();
|
|
86
|
+
virtual void PWCDetect();
|
|
87
|
+
virtual void solveWorklist();
|
|
88
|
+
virtual void handleLoadStore(ConstraintNode* node);
|
|
89
|
+
virtual void processAddr(const AddrCGEdge* addr);
|
|
90
|
+
virtual bool addCopyEdge(NodeID src, NodeID dst);
|
|
91
|
+
virtual bool updateCallGraph(const CallSiteToFunPtrMap& callsites);
|
|
92
|
+
virtual void processPWC(ConstraintNode* rep);
|
|
93
|
+
virtual void handleCopyGep(ConstraintNode* node);
|
|
94
|
+
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
/*!
|
|
100
|
+
* Selective Cycle Detection with Stride-based Field Representation
|
|
101
|
+
*/
|
|
102
|
+
class AndersenSFR : public AndersenSCD
|
|
103
|
+
{
|
|
104
|
+
public:
|
|
105
|
+
typedef Map<NodeID, NodeBS> NodeStrides;
|
|
106
|
+
typedef Map<NodeID, NodeSet> FieldReps;
|
|
107
|
+
typedef Map<NodeID, std::pair<NodeID, NodeSet>> SFRTrait;
|
|
108
|
+
|
|
109
|
+
private:
|
|
110
|
+
static AndersenSFR* sfrAndersen;
|
|
111
|
+
|
|
112
|
+
CSC* csc;
|
|
113
|
+
NodeSet sfrObjNodes;
|
|
114
|
+
FieldReps fieldReps;
|
|
115
|
+
|
|
116
|
+
public:
|
|
117
|
+
AndersenSFR(SVFIR* _pag, PTATY type = AndersenSFR_WPA) :
|
|
118
|
+
AndersenSCD(_pag, type), csc(nullptr)
|
|
119
|
+
{
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/// Create an singleton instance directly instead of invoking llvm pass manager
|
|
123
|
+
static AndersenSFR *createAndersenSFR(SVFIR* _pag)
|
|
124
|
+
{
|
|
125
|
+
if (sfrAndersen == nullptr)
|
|
126
|
+
{
|
|
127
|
+
sfrAndersen = new AndersenSFR(_pag);
|
|
128
|
+
sfrAndersen->analyze();
|
|
129
|
+
return sfrAndersen;
|
|
130
|
+
}
|
|
131
|
+
return sfrAndersen;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
static void releaseAndersenSFR()
|
|
135
|
+
{
|
|
136
|
+
if (sfrAndersen)
|
|
137
|
+
delete sfrAndersen;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
~AndersenSFR()
|
|
141
|
+
{
|
|
142
|
+
if (csc != nullptr)
|
|
143
|
+
{
|
|
144
|
+
delete(csc);
|
|
145
|
+
csc = nullptr;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
protected:
|
|
150
|
+
void initialize();
|
|
151
|
+
void PWCDetect();
|
|
152
|
+
void fieldExpand(NodeSet& initials, APOffset offset, NodeBS& strides, PointsTo& expandPts);
|
|
153
|
+
bool processGepPts(const PointsTo& pts, const GepCGEdge* edge);
|
|
154
|
+
bool mergeSrcToTgt(NodeID nodeId, NodeID newRepId);
|
|
155
|
+
|
|
156
|
+
};
|
|
157
|
+
|
|
158
|
+
} // End namespace SVF
|
|
159
|
+
|
|
160
|
+
#endif //PROJECT_ANDERSENSFR_H
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
//===- CSC.h -- Cycle Stride Calculation algorithm---------------------------------------//
|
|
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
|
+
* CSC.h
|
|
25
|
+
*
|
|
26
|
+
* Created on: 09, Feb, 2019
|
|
27
|
+
* Author: Yuxiang Lei
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
#ifndef PROJECT_CSC_H
|
|
31
|
+
#define PROJECT_CSC_H
|
|
32
|
+
|
|
33
|
+
#include "Graphs/ConsG.h"
|
|
34
|
+
#include "Graphs/SCC.h"
|
|
35
|
+
#include "SVFIR/SVFValue.h" // for NodeBS
|
|
36
|
+
#include "Util/WorkList.h"
|
|
37
|
+
#include <limits.h>
|
|
38
|
+
#include <map>
|
|
39
|
+
#include <stack>
|
|
40
|
+
|
|
41
|
+
namespace SVF
|
|
42
|
+
{
|
|
43
|
+
|
|
44
|
+
typedef SCCDetection<ConstraintGraph *> CGSCC;
|
|
45
|
+
|
|
46
|
+
/*!
|
|
47
|
+
* class CSC: cycle stride calculation
|
|
48
|
+
*/
|
|
49
|
+
class CSC
|
|
50
|
+
{
|
|
51
|
+
public:
|
|
52
|
+
typedef Map<NodeID, NodeID> IdToIdMap;
|
|
53
|
+
typedef FILOWorkList<NodeID> WorkStack;
|
|
54
|
+
typedef typename IdToIdMap::iterator iterator;
|
|
55
|
+
|
|
56
|
+
private:
|
|
57
|
+
ConstraintGraph* _consG;
|
|
58
|
+
CGSCC* _scc;
|
|
59
|
+
|
|
60
|
+
NodeID _I;
|
|
61
|
+
IdToIdMap _D; // the sum of weight of a path relevant to a certain node, while accessing the node via DFS
|
|
62
|
+
NodeStack _S; // a stack holding a DFS branch
|
|
63
|
+
NodeSet _visited; // a set holding visited nodes
|
|
64
|
+
// NodeStrides nodeStrides;
|
|
65
|
+
// IdToIdMap pwcReps;
|
|
66
|
+
|
|
67
|
+
public:
|
|
68
|
+
CSC(ConstraintGraph* g, CGSCC* c)
|
|
69
|
+
: _consG(g), _scc(c), _I(0) {}
|
|
70
|
+
|
|
71
|
+
void find(NodeStack& candidates);
|
|
72
|
+
void visit(NodeID nodeId, s32_t _w);
|
|
73
|
+
void clear();
|
|
74
|
+
|
|
75
|
+
bool isVisited(NodeID nId)
|
|
76
|
+
{
|
|
77
|
+
return _visited.find(nId) != _visited.end();
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
void setVisited(NodeID nId)
|
|
81
|
+
{
|
|
82
|
+
_visited.insert(nId);
|
|
83
|
+
}
|
|
84
|
+
// inline iterator begin() { return pwcReps.begin(); }
|
|
85
|
+
//
|
|
86
|
+
// inline iterator end() { return pwcReps.end(); }
|
|
87
|
+
|
|
88
|
+
// NodeStrides &getNodeStrides() { return nodeStrides; }
|
|
89
|
+
|
|
90
|
+
// const NodeSet& getPWCReps() const { return _pwcReps; }
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
} // End namespace SVF
|
|
94
|
+
|
|
95
|
+
#endif //PROJECT_CSC_H
|