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.
Files changed (320) hide show
  1. package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/WorkList.h +0 -0
  2. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
  3. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
  4. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
  5. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
  6. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
  7. package/SVF-linux-aarch64/Release-build/lib/libSvfCore.so.3.1 +0 -0
  8. package/SVF-linux-aarch64/Release-build/lib/libSvfLLVM.so.3.1 +0 -0
  9. package/SVF-linux-aarch64/Release-build/lib/pkgconfig/SVF.pc +12 -0
  10. package/SVF-osx/Release-build/bin/ae +0 -0
  11. package/SVF-osx/Release-build/bin/cfl +0 -0
  12. package/SVF-osx/Release-build/bin/dvf +0 -0
  13. package/SVF-osx/Release-build/bin/llvm2svf +0 -0
  14. package/SVF-osx/Release-build/bin/mta +0 -0
  15. package/SVF-osx/Release-build/bin/saber +0 -0
  16. package/SVF-osx/Release-build/bin/svf-ex +0 -0
  17. package/SVF-osx/Release-build/bin/wpa +0 -0
  18. package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractState.h +425 -0
  19. package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractValue.h +157 -0
  20. package/SVF-osx/Release-build/include/SVF/AE/Core/AddressValue.h +225 -0
  21. package/SVF-osx/Release-build/include/SVF/AE/Core/ICFGWTO.h +135 -0
  22. package/SVF-osx/Release-build/include/SVF/AE/Core/IntervalValue.h +1055 -0
  23. package/SVF-osx/Release-build/include/SVF/AE/Core/NumericValue.h +1292 -0
  24. package/SVF-osx/Release-build/include/SVF/AE/Core/RelExeState.h +226 -0
  25. package/SVF-osx/Release-build/include/SVF/AE/Core/RelationSolver.h +91 -0
  26. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AEDetector.h +439 -0
  27. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbsExtAPI.h +138 -0
  28. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbstractInterpretation.h +384 -0
  29. package/SVF-osx/Release-build/include/SVF/CFL/CFGNormalizer.h +84 -0
  30. package/SVF-osx/Release-build/include/SVF/CFL/CFGrammar.h +468 -0
  31. package/SVF-osx/Release-build/include/SVF/CFL/CFLAlias.h +168 -0
  32. package/SVF-osx/Release-build/include/SVF/CFL/CFLBase.h +118 -0
  33. package/SVF-osx/Release-build/include/SVF/CFL/CFLGramGraphChecker.h +74 -0
  34. package/SVF-osx/Release-build/include/SVF/CFL/CFLGraphBuilder.h +168 -0
  35. package/SVF-osx/Release-build/include/SVF/CFL/CFLSVFGBuilder.h +58 -0
  36. package/SVF-osx/Release-build/include/SVF/CFL/CFLSolver.h +374 -0
  37. package/SVF-osx/Release-build/include/SVF/CFL/CFLStat.h +67 -0
  38. package/SVF-osx/Release-build/include/SVF/CFL/CFLVF.h +68 -0
  39. package/SVF-osx/Release-build/include/SVF/CFL/GrammarBuilder.h +100 -0
  40. package/SVF-osx/Release-build/include/SVF/DDA/ContextDDA.h +230 -0
  41. package/SVF-osx/Release-build/include/SVF/DDA/DDAClient.h +163 -0
  42. package/SVF-osx/Release-build/include/SVF/DDA/DDAPass.h +102 -0
  43. package/SVF-osx/Release-build/include/SVF/DDA/DDAStat.h +121 -0
  44. package/SVF-osx/Release-build/include/SVF/DDA/DDAVFSolver.h +794 -0
  45. package/SVF-osx/Release-build/include/SVF/DDA/FlowDDA.h +178 -0
  46. package/SVF-osx/Release-build/include/SVF/FastCluster/fastcluster.h +80 -0
  47. package/SVF-osx/Release-build/include/SVF/Graphs/BasicBlockG.h +318 -0
  48. package/SVF-osx/Release-build/include/SVF/Graphs/CDG.h +482 -0
  49. package/SVF-osx/Release-build/include/SVF/Graphs/CFLGraph.h +232 -0
  50. package/SVF-osx/Release-build/include/SVF/Graphs/CHG.h +368 -0
  51. package/SVF-osx/Release-build/include/SVF/Graphs/CallGraph.h +497 -0
  52. package/SVF-osx/Release-build/include/SVF/Graphs/ConsG.h +402 -0
  53. package/SVF-osx/Release-build/include/SVF/Graphs/ConsGEdge.h +355 -0
  54. package/SVF-osx/Release-build/include/SVF/Graphs/ConsGNode.h +418 -0
  55. package/SVF-osx/Release-build/include/SVF/Graphs/DOTGraphTraits.h +188 -0
  56. package/SVF-osx/Release-build/include/SVF/Graphs/GenericGraph.h +628 -0
  57. package/SVF-osx/Release-build/include/SVF/Graphs/GraphPrinter.h +111 -0
  58. package/SVF-osx/Release-build/include/SVF/Graphs/GraphTraits.h +150 -0
  59. package/SVF-osx/Release-build/include/SVF/Graphs/GraphWriter.h +380 -0
  60. package/SVF-osx/Release-build/include/SVF/Graphs/ICFG.h +331 -0
  61. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGEdge.h +281 -0
  62. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGNode.h +669 -0
  63. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGStat.h +164 -0
  64. package/SVF-osx/Release-build/include/SVF/Graphs/IRGraph.h +398 -0
  65. package/SVF-osx/Release-build/include/SVF/Graphs/SCC.h +375 -0
  66. package/SVF-osx/Release-build/include/SVF/Graphs/SVFG.h +491 -0
  67. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGEdge.h +237 -0
  68. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGNode.h +501 -0
  69. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGOPT.h +372 -0
  70. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGStat.h +273 -0
  71. package/SVF-osx/Release-build/include/SVF/Graphs/ThreadCallGraph.h +399 -0
  72. package/SVF-osx/Release-build/include/SVF/Graphs/VFG.h +726 -0
  73. package/SVF-osx/Release-build/include/SVF/Graphs/VFGEdge.h +295 -0
  74. package/SVF-osx/Release-build/include/SVF/Graphs/VFGNode.h +1266 -0
  75. package/SVF-osx/Release-build/include/SVF/Graphs/WTO.h +872 -0
  76. package/SVF-osx/Release-build/include/SVF/MSSA/MSSAMuChi.h +722 -0
  77. package/SVF-osx/Release-build/include/SVF/MSSA/MemPartition.h +169 -0
  78. package/SVF-osx/Release-build/include/SVF/MSSA/MemRegion.h +489 -0
  79. package/SVF-osx/Release-build/include/SVF/MSSA/MemSSA.h +452 -0
  80. package/SVF-osx/Release-build/include/SVF/MSSA/SVFGBuilder.h +104 -0
  81. package/SVF-osx/Release-build/include/SVF/MTA/LockAnalysis.h +533 -0
  82. package/SVF-osx/Release-build/include/SVF/MTA/MHP.h +546 -0
  83. package/SVF-osx/Release-build/include/SVF/MTA/MTA.h +97 -0
  84. package/SVF-osx/Release-build/include/SVF/MTA/MTAStat.h +73 -0
  85. package/SVF-osx/Release-build/include/SVF/MTA/TCT.h +620 -0
  86. package/SVF-osx/Release-build/include/SVF/MemoryModel/AbstractPointsToDS.h +316 -0
  87. package/SVF-osx/Release-build/include/SVF/MemoryModel/AccessPath.h +194 -0
  88. package/SVF-osx/Release-build/include/SVF/MemoryModel/ConditionalPT.h +878 -0
  89. package/SVF-osx/Release-build/include/SVF/MemoryModel/MutablePointsToDS.h +1025 -0
  90. package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToCache.h +463 -0
  91. package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToDS.h +955 -0
  92. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysis.h +428 -0
  93. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysisImpl.h +602 -0
  94. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointsTo.h +255 -0
  95. package/SVF-osx/Release-build/include/SVF/MemoryModel/SVFLoop.h +167 -0
  96. package/SVF-osx/Release-build/include/SVF/SABER/DoubleFreeChecker.h +76 -0
  97. package/SVF-osx/Release-build/include/SVF/SABER/FileChecker.h +80 -0
  98. package/SVF-osx/Release-build/include/SVF/SABER/LeakChecker.h +122 -0
  99. package/SVF-osx/Release-build/include/SVF/SABER/ProgSlice.h +327 -0
  100. package/SVF-osx/Release-build/include/SVF/SABER/SaberCheckerAPI.h +151 -0
  101. package/SVF-osx/Release-build/include/SVF/SABER/SaberCondAllocator.h +317 -0
  102. package/SVF-osx/Release-build/include/SVF/SABER/SaberSVFGBuilder.h +114 -0
  103. package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkDDA.h +327 -0
  104. package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkSolver.h +186 -0
  105. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BasicTypes.h +280 -0
  106. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BreakConstantExpr.h +93 -0
  107. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CHGBuilder.h +78 -0
  108. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CppUtil.h +184 -0
  109. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/DCHG.h +474 -0
  110. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/GEPTypeBridgeIterator.h +183 -0
  111. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ICFGBuilder.h +160 -0
  112. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMLoopAnalysis.h +60 -0
  113. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMModule.h +527 -0
  114. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMUtil.h +433 -0
  115. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ObjTypeInference.h +129 -0
  116. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SVFIRBuilder.h +523 -0
  117. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SymbolTableBuilder.h +132 -0
  118. package/SVF-osx/Release-build/include/SVF/SVFIR/ObjTypeInfo.h +224 -0
  119. package/SVF-osx/Release-build/include/SVF/SVFIR/PAGBuilderFromFile.h +80 -0
  120. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFIR.h +856 -0
  121. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFStatements.h +1330 -0
  122. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFType.h +606 -0
  123. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFValue.h +338 -0
  124. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFVariables.h +2212 -0
  125. package/SVF-osx/Release-build/include/SVF/Util/Annotator.h +180 -0
  126. package/SVF-osx/Release-build/include/SVF/Util/BitVector.h +55 -0
  127. package/SVF-osx/Release-build/include/SVF/Util/CDGBuilder.h +107 -0
  128. package/SVF-osx/Release-build/include/SVF/Util/CallGraphBuilder.h +61 -0
  129. package/SVF-osx/Release-build/include/SVF/Util/Casting.h +426 -0
  130. package/SVF-osx/Release-build/include/SVF/Util/CommandLine.h +530 -0
  131. package/SVF-osx/Release-build/include/SVF/Util/CoreBitVector.h +214 -0
  132. package/SVF-osx/Release-build/include/SVF/Util/CxtStmt.h +502 -0
  133. package/SVF-osx/Release-build/include/SVF/Util/DPItem.h +618 -0
  134. package/SVF-osx/Release-build/include/SVF/Util/ExtAPI.h +117 -0
  135. package/SVF-osx/Release-build/include/SVF/Util/GeneralType.h +127 -0
  136. package/SVF-osx/Release-build/include/SVF/Util/GraphReachSolver.h +186 -0
  137. package/SVF-osx/Release-build/include/SVF/Util/NodeIDAllocator.h +203 -0
  138. package/SVF-osx/Release-build/include/SVF/Util/Options.h +273 -0
  139. package/SVF-osx/Release-build/include/SVF/Util/PTAStat.h +83 -0
  140. package/SVF-osx/Release-build/include/SVF/Util/SVFBugReport.h +427 -0
  141. package/SVF-osx/Release-build/include/SVF/Util/SVFLoopAndDomInfo.h +169 -0
  142. package/SVF-osx/Release-build/include/SVF/Util/SVFStat.h +103 -0
  143. package/SVF-osx/Release-build/include/SVF/Util/SVFUtil.h +478 -0
  144. package/SVF-osx/Release-build/include/SVF/Util/SparseBitVector.h +1252 -0
  145. package/SVF-osx/Release-build/include/SVF/Util/ThreadAPI.h +188 -0
  146. package/SVF-osx/Release-build/include/SVF/Util/WorkList.h +317 -0
  147. package/SVF-osx/Release-build/include/SVF/Util/Z3Expr.h +325 -0
  148. package/SVF-osx/Release-build/include/SVF/Util/cJSON.h +300 -0
  149. package/SVF-osx/Release-build/include/SVF/Util/config.h +46 -0
  150. package/SVF-osx/Release-build/include/SVF/Util/iterator.h +407 -0
  151. package/SVF-osx/Release-build/include/SVF/Util/iterator_range.h +76 -0
  152. package/SVF-osx/Release-build/include/SVF/WPA/Andersen.h +434 -0
  153. package/SVF-osx/Release-build/include/SVF/WPA/AndersenPWC.h +160 -0
  154. package/SVF-osx/Release-build/include/SVF/WPA/CSC.h +95 -0
  155. package/SVF-osx/Release-build/include/SVF/WPA/FlowSensitive.h +322 -0
  156. package/SVF-osx/Release-build/include/SVF/WPA/Steensgaard.h +131 -0
  157. package/SVF-osx/Release-build/include/SVF/WPA/TypeAnalysis.h +90 -0
  158. package/SVF-osx/Release-build/include/SVF/WPA/VersionedFlowSensitive.h +295 -0
  159. package/SVF-osx/Release-build/include/SVF/WPA/WPAFSSolver.h +246 -0
  160. package/SVF-osx/Release-build/include/SVF/WPA/WPAPass.h +115 -0
  161. package/SVF-osx/Release-build/include/SVF/WPA/WPASolver.h +205 -0
  162. package/SVF-osx/Release-build/include/SVF/WPA/WPAStat.h +222 -0
  163. package/SVF-osx/Release-build/include/SVF/extapi.bc +2384 -0
  164. package/SVF-osx/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
  165. package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
  166. package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
  167. package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
  168. package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
  169. package/SVF-osx/Release-build/lib/libSvfCore.3.1.dylib +0 -0
  170. package/SVF-osx/Release-build/lib/libSvfLLVM.3.1.dylib +0 -0
  171. package/SVF-osx/Release-build/lib/pkgconfig/SVF.pc +12 -0
  172. package/package.json +1 -1
  173. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PAGGrammar.txt +0 -15
  174. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PEGGrammar.txt +0 -11
  175. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/VFGGrammar.txt +0 -7
  176. package/SVF-linux-aarch64/Release-build/include/FastCluster/LICENSE.TXT +0 -13
  177. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractState.h +0 -0
  178. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractValue.h +0 -0
  179. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AddressValue.h +0 -0
  180. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/ICFGWTO.h +0 -0
  181. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/IntervalValue.h +0 -0
  182. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/NumericValue.h +0 -0
  183. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelExeState.h +0 -0
  184. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelationSolver.h +0 -0
  185. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AEDetector.h +0 -0
  186. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbsExtAPI.h +0 -0
  187. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbstractInterpretation.h +0 -0
  188. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGNormalizer.h +0 -0
  189. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGrammar.h +0 -0
  190. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLAlias.h +0 -0
  191. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLBase.h +0 -0
  192. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGramGraphChecker.h +0 -0
  193. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGraphBuilder.h +0 -0
  194. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSVFGBuilder.h +0 -0
  195. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSolver.h +0 -0
  196. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLStat.h +0 -0
  197. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLVF.h +0 -0
  198. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/GrammarBuilder.h +0 -0
  199. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/ContextDDA.h +0 -0
  200. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAClient.h +0 -0
  201. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAPass.h +0 -0
  202. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAStat.h +0 -0
  203. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAVFSolver.h +0 -0
  204. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/FlowDDA.h +0 -0
  205. /package/SVF-linux-aarch64/Release-build/include/{FastCluster → SVF/FastCluster}/fastcluster.h +0 -0
  206. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/BasicBlockG.h +0 -0
  207. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CDG.h +0 -0
  208. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CFLGraph.h +0 -0
  209. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CHG.h +0 -0
  210. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CallGraph.h +0 -0
  211. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsG.h +0 -0
  212. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGEdge.h +0 -0
  213. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGNode.h +0 -0
  214. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/DOTGraphTraits.h +0 -0
  215. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GenericGraph.h +0 -0
  216. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphPrinter.h +0 -0
  217. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphTraits.h +0 -0
  218. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphWriter.h +0 -0
  219. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFG.h +0 -0
  220. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGEdge.h +0 -0
  221. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGNode.h +0 -0
  222. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGStat.h +0 -0
  223. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/IRGraph.h +0 -0
  224. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SCC.h +0 -0
  225. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFG.h +0 -0
  226. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGEdge.h +0 -0
  227. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGNode.h +0 -0
  228. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGOPT.h +0 -0
  229. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGStat.h +0 -0
  230. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ThreadCallGraph.h +0 -0
  231. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFG.h +0 -0
  232. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGEdge.h +0 -0
  233. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGNode.h +0 -0
  234. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/WTO.h +0 -0
  235. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MSSAMuChi.h +0 -0
  236. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemPartition.h +0 -0
  237. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemRegion.h +0 -0
  238. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemSSA.h +0 -0
  239. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/SVFGBuilder.h +0 -0
  240. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/LockAnalysis.h +0 -0
  241. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MHP.h +0 -0
  242. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTA.h +0 -0
  243. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTAStat.h +0 -0
  244. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/TCT.h +0 -0
  245. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AbstractPointsToDS.h +0 -0
  246. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AccessPath.h +0 -0
  247. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/ConditionalPT.h +0 -0
  248. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/MutablePointsToDS.h +0 -0
  249. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToCache.h +0 -0
  250. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToDS.h +0 -0
  251. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysis.h +0 -0
  252. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysisImpl.h +0 -0
  253. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointsTo.h +0 -0
  254. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/SVFLoop.h +0 -0
  255. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/DoubleFreeChecker.h +0 -0
  256. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/FileChecker.h +0 -0
  257. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/LeakChecker.h +0 -0
  258. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/ProgSlice.h +0 -0
  259. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCheckerAPI.h +0 -0
  260. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCondAllocator.h +0 -0
  261. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberSVFGBuilder.h +0 -0
  262. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkDDA.h +0 -0
  263. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkSolver.h +0 -0
  264. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BasicTypes.h +0 -0
  265. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BreakConstantExpr.h +0 -0
  266. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CHGBuilder.h +0 -0
  267. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CppUtil.h +0 -0
  268. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/DCHG.h +0 -0
  269. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/GEPTypeBridgeIterator.h +0 -0
  270. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ICFGBuilder.h +0 -0
  271. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMLoopAnalysis.h +0 -0
  272. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMModule.h +0 -0
  273. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMUtil.h +0 -0
  274. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ObjTypeInference.h +0 -0
  275. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SVFIRBuilder.h +0 -0
  276. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SymbolTableBuilder.h +0 -0
  277. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/ObjTypeInfo.h +0 -0
  278. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/PAGBuilderFromFile.h +0 -0
  279. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFIR.h +0 -0
  280. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFStatements.h +0 -0
  281. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFType.h +0 -0
  282. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFValue.h +0 -0
  283. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFVariables.h +0 -0
  284. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Annotator.h +0 -0
  285. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/BitVector.h +0 -0
  286. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CDGBuilder.h +0 -0
  287. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CallGraphBuilder.h +0 -0
  288. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Casting.h +0 -0
  289. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CommandLine.h +0 -0
  290. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CoreBitVector.h +0 -0
  291. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CxtStmt.h +0 -0
  292. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/DPItem.h +0 -0
  293. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ExtAPI.h +0 -0
  294. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GeneralType.h +0 -0
  295. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GraphReachSolver.h +0 -0
  296. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/NodeIDAllocator.h +0 -0
  297. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Options.h +0 -0
  298. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/PTAStat.h +0 -0
  299. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFBugReport.h +0 -0
  300. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFLoopAndDomInfo.h +0 -0
  301. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFStat.h +0 -0
  302. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFUtil.h +0 -0
  303. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SparseBitVector.h +0 -0
  304. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ThreadAPI.h +0 -0
  305. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Z3Expr.h +0 -0
  306. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/cJSON.h +0 -0
  307. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator.h +0 -0
  308. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator_range.h +0 -0
  309. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Andersen.h +0 -0
  310. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/AndersenPWC.h +0 -0
  311. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/CSC.h +0 -0
  312. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/FlowSensitive.h +0 -0
  313. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Steensgaard.h +0 -0
  314. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/TypeAnalysis.h +0 -0
  315. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/VersionedFlowSensitive.h +0 -0
  316. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAFSSolver.h +0 -0
  317. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAPass.h +0 -0
  318. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPASolver.h +0 -0
  319. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAStat.h +0 -0
  320. /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_ */