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