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,316 @@
|
|
|
1
|
+
//===- AbstractPointsToDS.h -- Abstract points-to data structure-------------//
|
|
2
|
+
//
|
|
3
|
+
// SVF: Static Value-Flow Analysis
|
|
4
|
+
//
|
|
5
|
+
// Copyright (C) <2013-> <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
|
+
/// Contains abstract classes for:
|
|
25
|
+
/// PTData: basic points-to data structure derived by all others.
|
|
26
|
+
/// DiffPTData: PTData which only propagates new changes, not entire points-to sets.
|
|
27
|
+
/// DFPTData: flow-sensitive PTData as defined by Hardekopf and Lin (CGO '11).
|
|
28
|
+
///
|
|
29
|
+
/// Hierarchy (square brackets indicate abstract class):
|
|
30
|
+
///
|
|
31
|
+
/// +------------> [PTData] <----------------+---------------------+
|
|
32
|
+
/// | ^ | |
|
|
33
|
+
/// | | | |
|
|
34
|
+
/// MutablePTData [DiffPTData] [DFPTData] [VersionedPTData]
|
|
35
|
+
/// ^ ^ ^
|
|
36
|
+
/// | | |
|
|
37
|
+
/// MutableDiffPTData MutableDFPTData MutableVersionedPTData
|
|
38
|
+
/// ^
|
|
39
|
+
/// |
|
|
40
|
+
/// MutableIncDFPTData
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
/*
|
|
44
|
+
* AbstractPointsToDS.h
|
|
45
|
+
*
|
|
46
|
+
* Authors: Mohamad Barbar and Yulei Sui
|
|
47
|
+
*
|
|
48
|
+
* The implementation is based on
|
|
49
|
+
* Mohamad Barbar and Yulei Sui. Hash Consed Points-To Sets.
|
|
50
|
+
* 28th Static Analysis Symposium (SAS'21)
|
|
51
|
+
*/
|
|
52
|
+
|
|
53
|
+
#ifndef ABSTRACT_POINTSTO_H_
|
|
54
|
+
#define ABSTRACT_POINTSTO_H_
|
|
55
|
+
|
|
56
|
+
#include "SVFIR/SVFType.h"
|
|
57
|
+
|
|
58
|
+
namespace SVF
|
|
59
|
+
{
|
|
60
|
+
/// Basic points-to data structure
|
|
61
|
+
/// Given a key (variable/condition variable), return its points-to data (pts/condition pts)
|
|
62
|
+
/// It is designed flexible for different context, heap and path sensitive analysis
|
|
63
|
+
/// Context Insensitive Key --> Variable, DataSet --> PointsTo
|
|
64
|
+
/// Context sensitive: Key --> CondVar, DataSet --> PointsTo
|
|
65
|
+
/// Heap sensitive: Key --> Variable DataSet --> CondPointsToSet
|
|
66
|
+
/// Context and heap sensitive: Key --> CondVar, DataSet --> CondPointsToSet
|
|
67
|
+
///
|
|
68
|
+
/// This class is abstract to allow for multiple methods of actually storing points-to sets.
|
|
69
|
+
/// Key: "owning" variable of a points-to set.
|
|
70
|
+
/// KeySet: collection of keys.
|
|
71
|
+
/// Data: elements in points-to sets.
|
|
72
|
+
/// DataSet: the points-to set; a collection of Data.
|
|
73
|
+
template <typename Key, typename KeySet, typename Data, typename DataSet>
|
|
74
|
+
class PTData
|
|
75
|
+
{
|
|
76
|
+
public:
|
|
77
|
+
/// Types of a points-to data structures.
|
|
78
|
+
enum PTDataTy
|
|
79
|
+
{
|
|
80
|
+
Base,
|
|
81
|
+
MutBase,
|
|
82
|
+
Diff,
|
|
83
|
+
MutDiff,
|
|
84
|
+
DataFlow,
|
|
85
|
+
MutDataFlow,
|
|
86
|
+
MutIncDataFlow,
|
|
87
|
+
Versioned,
|
|
88
|
+
MutVersioned,
|
|
89
|
+
PersBase,
|
|
90
|
+
PersDiff,
|
|
91
|
+
PersDataFlow,
|
|
92
|
+
PersIncDataFlow,
|
|
93
|
+
PersVersioned,
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
PTData(bool reversePT = true, PTDataTy ty = PTDataTy::Base) : rev(reversePT), ptdTy(ty) { }
|
|
97
|
+
|
|
98
|
+
virtual ~PTData() { }
|
|
99
|
+
|
|
100
|
+
/// Get the type of points-to data structure that this is.
|
|
101
|
+
inline PTDataTy getPTDTY() const
|
|
102
|
+
{
|
|
103
|
+
return ptdTy;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/// Clears all points-to sets as if nothing is stored.
|
|
107
|
+
virtual void clear() = 0;
|
|
108
|
+
|
|
109
|
+
/// Get points-to set of var.
|
|
110
|
+
virtual const DataSet& getPts(const Key& var) = 0;
|
|
111
|
+
/// Get reverse points-to set of a datum.
|
|
112
|
+
virtual const KeySet& getRevPts(const Data& datum) = 0;
|
|
113
|
+
|
|
114
|
+
/// Adds element to the points-to set associated with var.
|
|
115
|
+
virtual bool addPts(const Key& var, const Data& element) = 0;
|
|
116
|
+
|
|
117
|
+
/// Performs pts(dstVar) = pts(dstVar) U pts(srcVar).
|
|
118
|
+
virtual bool unionPts(const Key& dstVar, const Key& srcVar) = 0;
|
|
119
|
+
/// Performs pts(dstVar) = pts(dstVar) U srcDataSet.
|
|
120
|
+
virtual bool unionPts(const Key& dstVar, const DataSet& srcDataSet) = 0;
|
|
121
|
+
|
|
122
|
+
/// Clears element from the points-to set of var.
|
|
123
|
+
virtual void clearPts(const Key& var, const Data& element) = 0;
|
|
124
|
+
/// Fully clears the points-to set of var.
|
|
125
|
+
virtual void clearFullPts(const Key& var) = 0;
|
|
126
|
+
|
|
127
|
+
/// Remaps all points-to sets to use the current mapping.
|
|
128
|
+
virtual void remapAllPts(void) = 0;
|
|
129
|
+
|
|
130
|
+
/// Dump stored keys and points-to sets.
|
|
131
|
+
virtual void dumpPTData() = 0;
|
|
132
|
+
|
|
133
|
+
/// Returns a mapping of points-to sets to the number of times
|
|
134
|
+
/// they are stored. liveOnly indicates whether to include only
|
|
135
|
+
/// points-to sets which correspond to a variable (matters when
|
|
136
|
+
/// dealing with non-GC persistent PT).
|
|
137
|
+
virtual Map<DataSet, unsigned> getAllPts(bool liveOnly) const = 0;
|
|
138
|
+
|
|
139
|
+
protected:
|
|
140
|
+
/// Whether we maintain reverse points-to sets or not.
|
|
141
|
+
bool rev;
|
|
142
|
+
PTDataTy ptdTy;
|
|
143
|
+
};
|
|
144
|
+
|
|
145
|
+
/// Abstract diff points-to data with cached information.
|
|
146
|
+
/// This is an optimisation on top of the base points-to data structure.
|
|
147
|
+
/// The points-to information is propagated incrementally only for the different parts.
|
|
148
|
+
template <typename Key, typename KeySet, typename Data, typename DataSet>
|
|
149
|
+
class DiffPTData : public PTData<Key, KeySet, Data, DataSet>
|
|
150
|
+
{
|
|
151
|
+
public:
|
|
152
|
+
typedef PTData<Key, KeySet, Data, DataSet> BasePTData;
|
|
153
|
+
typedef typename BasePTData::PTDataTy PTDataTy;
|
|
154
|
+
|
|
155
|
+
DiffPTData(bool reversePT = true, PTDataTy ty = PTDataTy::Diff) : BasePTData(reversePT, ty) { }
|
|
156
|
+
|
|
157
|
+
virtual ~DiffPTData() { }
|
|
158
|
+
|
|
159
|
+
/// Get diff points to.
|
|
160
|
+
virtual const DataSet& getDiffPts(Key& var) = 0;
|
|
161
|
+
|
|
162
|
+
/// Compute diff points to. Return TRUE if diff is not empty.
|
|
163
|
+
/// 1. calculate diff: diff = all - propa.
|
|
164
|
+
/// 2. update propagated pts: propa = all.
|
|
165
|
+
virtual bool computeDiffPts(Key& var, const DataSet& all) = 0;
|
|
166
|
+
|
|
167
|
+
/// Update dst's propagated points-to set with src's.
|
|
168
|
+
/// The final result is the intersection of these two sets.
|
|
169
|
+
virtual void updatePropaPtsMap(Key& src, Key& dst) = 0;
|
|
170
|
+
|
|
171
|
+
/// Clear propagated points-to set of var.
|
|
172
|
+
virtual void clearPropaPts(Key& var) = 0;
|
|
173
|
+
|
|
174
|
+
/// Methods to support type inquiry through isa, cast, and dyn_cast:
|
|
175
|
+
///@{
|
|
176
|
+
static inline bool classof(const DiffPTData<Key, KeySet, Data, DataSet> *)
|
|
177
|
+
{
|
|
178
|
+
return true;
|
|
179
|
+
}
|
|
180
|
+
static inline bool classof(const PTData<Key, KeySet, Data, DataSet>* ptd)
|
|
181
|
+
{
|
|
182
|
+
return ptd->getPTDTY() == PTDataTy::Diff
|
|
183
|
+
|| ptd->getPTDTY() == PTDataTy::MutDiff
|
|
184
|
+
|| ptd->getPTDTY() == PTDataTy::PersDiff;
|
|
185
|
+
}
|
|
186
|
+
///@}
|
|
187
|
+
};
|
|
188
|
+
|
|
189
|
+
/// Data-flow points-to data structure for flow-sensitive analysis as defined by Hardekopf and Lin (CGO 11).
|
|
190
|
+
/// Points-to information is maintained at each program point (statement).
|
|
191
|
+
/// For address-taken variables, every program point has two sets: IN and OUT points-to sets.
|
|
192
|
+
/// For top-level variables, points-to sets are maintained flow-insensitively via getPts(var).
|
|
193
|
+
template <typename Key, typename KeySet, typename Data, typename DataSet>
|
|
194
|
+
class DFPTData : public PTData<Key, KeySet, Data, DataSet>
|
|
195
|
+
{
|
|
196
|
+
public:
|
|
197
|
+
typedef PTData<Key, KeySet, Data, DataSet> BasePTData;
|
|
198
|
+
typedef typename BasePTData::PTDataTy PTDataTy;
|
|
199
|
+
|
|
200
|
+
typedef NodeID LocID;
|
|
201
|
+
|
|
202
|
+
/// Constructor
|
|
203
|
+
DFPTData(bool reversePT = true, PTDataTy ty = BasePTData::DataFlow) : BasePTData(reversePT, ty) { }
|
|
204
|
+
|
|
205
|
+
virtual ~DFPTData() { }
|
|
206
|
+
|
|
207
|
+
/// Determine whether the DF IN/OUT sets have points-to sets.
|
|
208
|
+
///@{
|
|
209
|
+
virtual bool hasDFInSet(LocID loc) const = 0;
|
|
210
|
+
virtual bool hasDFOutSet(LocID loc) const = 0;
|
|
211
|
+
///@}
|
|
212
|
+
|
|
213
|
+
/// Access points-to set from data-flow IN/OUT set.
|
|
214
|
+
///@{
|
|
215
|
+
virtual bool hasDFOutSet(LocID loc, const Key& var) const = 0;
|
|
216
|
+
virtual bool hasDFInSet(LocID loc, const Key& var) const = 0;
|
|
217
|
+
virtual const DataSet& getDFInPtsSet(LocID loc, const Key& var) = 0;
|
|
218
|
+
virtual const DataSet& getDFOutPtsSet(LocID loc, const Key& var) = 0;
|
|
219
|
+
///@}
|
|
220
|
+
|
|
221
|
+
/// Update points-to for IN/OUT set
|
|
222
|
+
/// IN[loc:var] represents the points-to of variable var in the IN set of location loc.
|
|
223
|
+
/// union(ptsDst, ptsSrc) represents ptsDst = ptsDst U ptsSrc.
|
|
224
|
+
///@{
|
|
225
|
+
/// Union (IN[dstLoc:dstVar], IN[srcLoc:srcVar]).
|
|
226
|
+
virtual bool updateDFInFromIn(LocID srcLoc, const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
227
|
+
/// Union (IN[dstLoc::dstVar], IN[srcLoc:srcVar]. There is no flag check, unlike the above.
|
|
228
|
+
virtual bool updateAllDFInFromIn(LocID srcLoc, const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
229
|
+
/// Union (IN[dstLoc:dstVar], OUT[srcLoc:srcVar]).
|
|
230
|
+
virtual bool updateDFInFromOut(LocID srcLoc, const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
231
|
+
/// Union (IN[dstLoc::dstVar], OUT[srcLoc:srcVar]. There is no flag check, unlike the above.
|
|
232
|
+
virtual bool updateAllDFInFromOut(LocID srcLoc, const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
233
|
+
|
|
234
|
+
/// Union (OUT[dstLoc:dstVar], IN[srcLoc:srcVar]).
|
|
235
|
+
virtual bool updateDFOutFromIn(LocID srcLoc, const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
236
|
+
/// For each variable var in IN at loc, do updateDFOutFromIn(loc, var, loc, var).
|
|
237
|
+
virtual bool updateAllDFOutFromIn(LocID loc, const Key& singleton, bool strongUpdates) = 0;
|
|
238
|
+
|
|
239
|
+
virtual void clearAllDFOutUpdatedVar(LocID) = 0;
|
|
240
|
+
|
|
241
|
+
/// Update points-to set of top-level pointers with IN[srcLoc:srcVar].
|
|
242
|
+
virtual bool updateTLVPts(LocID srcLoc, const Key& srcVar, const Key& dstVar) = 0;
|
|
243
|
+
/// Update address-taken variables OUT[dstLoc:dstVar] with points-to of top-level pointers
|
|
244
|
+
virtual bool updateATVPts(const Key& srcVar, LocID dstLoc, const Key& dstVar) = 0;
|
|
245
|
+
///@}
|
|
246
|
+
|
|
247
|
+
/// Methods to support type inquiry through isa, cast, and dyn_cast:
|
|
248
|
+
///@{
|
|
249
|
+
static inline bool classof(const DFPTData<Key, KeySet, Data, DataSet> *)
|
|
250
|
+
{
|
|
251
|
+
return true;
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
static inline bool classof(const PTData<Key, KeySet, Data, DataSet>* ptd)
|
|
255
|
+
{
|
|
256
|
+
return ptd->getPTDTY() == BasePTData::DataFlow
|
|
257
|
+
|| ptd->getPTDTY() == BasePTData::MutDataFlow
|
|
258
|
+
|| ptd->getPTDTY() == BasePTData::MutIncDataFlow
|
|
259
|
+
|| ptd->getPTDTY() == BasePTData::PersDataFlow
|
|
260
|
+
|| ptd->getPTDTY() == BasePTData::PersIncDataFlow;
|
|
261
|
+
}
|
|
262
|
+
///@}
|
|
263
|
+
};
|
|
264
|
+
|
|
265
|
+
/// PTData with normal keys and versioned keys. Replicates the PTData interface for
|
|
266
|
+
/// versioned keys too. Intended to be used for versioned flow-sensitive PTA--hence the
|
|
267
|
+
/// name--but can be used anywhere where there are two types of keys at play.
|
|
268
|
+
template <typename Key, typename KeySet, typename Data, typename DataSet, typename VersionedKey, typename VersionedKeySet>
|
|
269
|
+
class VersionedPTData : public PTData<Key, KeySet, Data, DataSet>
|
|
270
|
+
{
|
|
271
|
+
public:
|
|
272
|
+
typedef PTData<Key, KeySet, Data, DataSet> BasePTData;
|
|
273
|
+
typedef typename BasePTData::PTDataTy PTDataTy;
|
|
274
|
+
|
|
275
|
+
VersionedPTData(bool reversePT = true, PTDataTy ty = PTDataTy::Versioned) : BasePTData(reversePT, ty) { }
|
|
276
|
+
|
|
277
|
+
virtual ~VersionedPTData() { }
|
|
278
|
+
|
|
279
|
+
virtual const DataSet& getPts(const VersionedKey& vk) = 0;
|
|
280
|
+
virtual const VersionedKeySet& getVersionedKeyRevPts(const Data& datum) = 0;
|
|
281
|
+
|
|
282
|
+
virtual bool addPts(const VersionedKey& vk, const Data& element) = 0;
|
|
283
|
+
|
|
284
|
+
virtual bool unionPts(const VersionedKey& dstVar, const VersionedKey& srcVar) = 0;
|
|
285
|
+
virtual bool unionPts(const VersionedKey& dstVar, const Key& srcVar) = 0;
|
|
286
|
+
virtual bool unionPts(const Key& dstVar, const VersionedKey& srcVar) = 0;
|
|
287
|
+
virtual bool unionPts(const VersionedKey& dstVar, const DataSet& srcDataSet) = 0;
|
|
288
|
+
|
|
289
|
+
virtual void clearPts(const VersionedKey& vk, const Data& element) = 0;
|
|
290
|
+
virtual void clearFullPts(const VersionedKey& vk) = 0;
|
|
291
|
+
|
|
292
|
+
/// Methods to support type inquiry through isa, cast, and dyn_cast:
|
|
293
|
+
///@{
|
|
294
|
+
static inline bool classof(const VersionedPTData<Key, KeySet, Data, DataSet, VersionedKey, VersionedKeySet> *)
|
|
295
|
+
{
|
|
296
|
+
return true;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
static inline bool classof(const PTData<Key, KeySet, Data, DataSet>* ptd)
|
|
300
|
+
{
|
|
301
|
+
return ptd->getPTDTY() == PTDataTy::Versioned
|
|
302
|
+
|| ptd->getPTDTY() == PTDataTy::MutVersioned
|
|
303
|
+
|| ptd->getPTDTY() == PTDataTy::PersVersioned;
|
|
304
|
+
}
|
|
305
|
+
private:
|
|
306
|
+
using BasePTData::getPts;
|
|
307
|
+
using BasePTData::addPts;
|
|
308
|
+
using BasePTData::unionPts;
|
|
309
|
+
using BasePTData::clearPts;
|
|
310
|
+
using BasePTData::clearFullPts;
|
|
311
|
+
///@}
|
|
312
|
+
};
|
|
313
|
+
|
|
314
|
+
} // End namespace SVF
|
|
315
|
+
|
|
316
|
+
#endif // ABSTRACT_POINTSTO_H_
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
//===- AccessPath.h -- Location set of abstract object-----------------------//
|
|
2
|
+
//
|
|
3
|
+
// SVF: Static Value-Flow Analysis
|
|
4
|
+
//
|
|
5
|
+
// Copyright (C) <2013-> <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
|
+
* @file: AccessPath.h
|
|
25
|
+
* @author: yesen
|
|
26
|
+
* @date: 26 Sep 2014
|
|
27
|
+
*
|
|
28
|
+
* LICENSE
|
|
29
|
+
*
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
#ifndef AccessPath_H_
|
|
34
|
+
#define AccessPath_H_
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
#include "SVFIR/SVFValue.h"
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
namespace SVF
|
|
41
|
+
{
|
|
42
|
+
|
|
43
|
+
class SVFVar;
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
/*
|
|
47
|
+
* Location set represents a set of locations in a memory block with following offsets:
|
|
48
|
+
* { offset + \sum_{i=0}^N (stride_i * j_i) | 0 \leq j_i < M_i }
|
|
49
|
+
* where N is the size of number-stride pair vector, M_i (stride_i) is i-th number (stride)
|
|
50
|
+
* in the number-stride pair vector.
|
|
51
|
+
*/
|
|
52
|
+
class AccessPath
|
|
53
|
+
{
|
|
54
|
+
friend class SVFIRWriter;
|
|
55
|
+
friend class SVFIRReader;
|
|
56
|
+
|
|
57
|
+
public:
|
|
58
|
+
enum LSRelation
|
|
59
|
+
{
|
|
60
|
+
NonOverlap, Overlap, Subset, Superset, Same
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
typedef std::pair<const SVFVar*, const SVFType*> IdxOperandPair;
|
|
64
|
+
typedef std::vector<IdxOperandPair> IdxOperandPairs;
|
|
65
|
+
|
|
66
|
+
/// Constructor
|
|
67
|
+
AccessPath(APOffset o = 0, const SVFType* srcTy = nullptr) : fldIdx(o), gepPointeeType(srcTy) {}
|
|
68
|
+
|
|
69
|
+
/// Copy Constructor
|
|
70
|
+
AccessPath(const AccessPath& ap)
|
|
71
|
+
: fldIdx(ap.fldIdx),
|
|
72
|
+
idxOperandPairs(ap.getIdxOperandPairVec()),
|
|
73
|
+
gepPointeeType(ap.gepSrcPointeeType())
|
|
74
|
+
{
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
~AccessPath() {}
|
|
78
|
+
|
|
79
|
+
/// Overload operators
|
|
80
|
+
//@{
|
|
81
|
+
AccessPath operator+(const AccessPath& rhs) const;
|
|
82
|
+
bool operator<(const AccessPath& rhs) const;
|
|
83
|
+
inline const AccessPath& operator=(const AccessPath& rhs)
|
|
84
|
+
{
|
|
85
|
+
fldIdx = rhs.fldIdx;
|
|
86
|
+
idxOperandPairs = rhs.getIdxOperandPairVec();
|
|
87
|
+
gepPointeeType = rhs.gepPointeeType;
|
|
88
|
+
return *this;
|
|
89
|
+
}
|
|
90
|
+
inline bool operator==(const AccessPath& rhs) const
|
|
91
|
+
{
|
|
92
|
+
return this->fldIdx == rhs.fldIdx &&
|
|
93
|
+
this->idxOperandPairs == rhs.idxOperandPairs && this->gepPointeeType == rhs.gepPointeeType;
|
|
94
|
+
}
|
|
95
|
+
//@}
|
|
96
|
+
|
|
97
|
+
/// Get methods
|
|
98
|
+
//@{
|
|
99
|
+
inline APOffset getConstantStructFldIdx() const
|
|
100
|
+
{
|
|
101
|
+
return fldIdx;
|
|
102
|
+
}
|
|
103
|
+
inline void setFldIdx(APOffset idx)
|
|
104
|
+
{
|
|
105
|
+
fldIdx = idx;
|
|
106
|
+
}
|
|
107
|
+
inline const IdxOperandPairs& getIdxOperandPairVec() const
|
|
108
|
+
{
|
|
109
|
+
return idxOperandPairs;
|
|
110
|
+
}
|
|
111
|
+
inline const SVFType* gepSrcPointeeType() const
|
|
112
|
+
{
|
|
113
|
+
return gepPointeeType;
|
|
114
|
+
}
|
|
115
|
+
//@}
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* Computes the total constant byte offset of an access path.
|
|
119
|
+
* This function iterates over the offset-variable-type pairs in reverse order,
|
|
120
|
+
* accumulating the total byte offset for constant offsets. For each pair,
|
|
121
|
+
* it retrieves the corresponding SVFValue and determines the type of offset
|
|
122
|
+
* (whether it's an array, pointer, or structure). If the offset corresponds
|
|
123
|
+
* to a structure, it further resolves the actual element type based on the
|
|
124
|
+
* offset value. It then multiplies the offset value by the size of the type
|
|
125
|
+
* to compute the byte offset. This is used to handle composite types where
|
|
126
|
+
* offsets are derived from the type's internal structure, such as arrays
|
|
127
|
+
* or structures with fields of various types and sizes. The function asserts
|
|
128
|
+
* that the access path must have a constant offset, and it is intended to be
|
|
129
|
+
* used when the offset is known to be constant at compile time.
|
|
130
|
+
*
|
|
131
|
+
* @return APOffset representing the computed total constant byte offset.
|
|
132
|
+
*/
|
|
133
|
+
/// e.g. GepStmt* gep = [i32*4], 2
|
|
134
|
+
/// APOffset byteOffset = gep->accumulateConstantByteOffset();
|
|
135
|
+
/// byteOffset should be 8 since i32 is 4 bytes and index is 2.
|
|
136
|
+
APOffset computeConstantByteOffset() const;
|
|
137
|
+
|
|
138
|
+
/// Return accumulated constant offset given OffsetVarVec
|
|
139
|
+
/// compard to computeConstantByteOffset, it is field offset rather than byte offset
|
|
140
|
+
/// e.g. GepStmt* gep = [i32*4], 2
|
|
141
|
+
/// APOffset byteOffset = gep->computeConstantOffset();
|
|
142
|
+
/// byteOffset should be 2 since it is field offset.
|
|
143
|
+
APOffset computeConstantOffset() const;
|
|
144
|
+
|
|
145
|
+
/// Return element number of a type.
|
|
146
|
+
u32_t getElementNum(const SVFType* type) const;
|
|
147
|
+
|
|
148
|
+
|
|
149
|
+
bool addOffsetVarAndGepTypePair(const SVFVar* var, const SVFType* gepIterType);
|
|
150
|
+
|
|
151
|
+
/// Return TRUE if this is a constant location set.
|
|
152
|
+
bool isConstantOffset() const;
|
|
153
|
+
|
|
154
|
+
/// Return TRUE if we share any location in common with RHS
|
|
155
|
+
inline bool intersects(const AccessPath& RHS) const
|
|
156
|
+
{
|
|
157
|
+
return computeAllLocations().intersects(RHS.computeAllLocations());
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
/// Return byte offset from the beginning of the structure to the field where it is located for struct type
|
|
161
|
+
u32_t getStructFieldOffset(const SVFVar* idxOperandVar, const SVFStructType* idxOperandType) const;
|
|
162
|
+
|
|
163
|
+
/// Dump location set
|
|
164
|
+
std::string dump() const;
|
|
165
|
+
|
|
166
|
+
private:
|
|
167
|
+
|
|
168
|
+
/// Check relations of two location sets
|
|
169
|
+
LSRelation checkRelation(const AccessPath& LHS, const AccessPath& RHS);
|
|
170
|
+
|
|
171
|
+
/// Compute all possible locations according to offset and number-stride pairs.
|
|
172
|
+
NodeBS computeAllLocations() const;
|
|
173
|
+
|
|
174
|
+
APOffset fldIdx; ///< Accumulated Constant Offsets
|
|
175
|
+
IdxOperandPairs idxOperandPairs; ///< a vector of actual offset in the form of <SVF Var, iterator type>
|
|
176
|
+
const SVFType* gepPointeeType; /// source element type in gep instruction,
|
|
177
|
+
/// e.g., %f1 = getelementptr inbounds %struct.MyStruct, %struct.MyStruct* %arrayidx, i32 0, i32 0
|
|
178
|
+
/// the source element type is %struct.MyStruct
|
|
179
|
+
};
|
|
180
|
+
|
|
181
|
+
} // End namespace SVF
|
|
182
|
+
|
|
183
|
+
template <> struct std::hash<SVF::AccessPath>
|
|
184
|
+
{
|
|
185
|
+
size_t operator()(const SVF::AccessPath &ap) const
|
|
186
|
+
{
|
|
187
|
+
SVF::Hash<std::pair<SVF::NodeID, SVF::NodeID>> h;
|
|
188
|
+
std::hash<SVF::AccessPath::IdxOperandPairs> v;
|
|
189
|
+
return h(std::make_pair(ap.getConstantStructFldIdx(),
|
|
190
|
+
v(ap.getIdxOperandPairVec())));
|
|
191
|
+
}
|
|
192
|
+
};
|
|
193
|
+
|
|
194
|
+
#endif /* AccessPath_H_ */
|