angr 9.2.103__py3-none-manylinux2014_aarch64.whl

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.

Potentially problematic release.


This version of angr might be problematic. Click here for more details.

Files changed (1300) hide show
  1. angr/__init__.py +153 -0
  2. angr/__main__.py +59 -0
  3. angr/analyses/__init__.py +46 -0
  4. angr/analyses/analysis.py +359 -0
  5. angr/analyses/backward_slice.py +691 -0
  6. angr/analyses/binary_optimizer.py +683 -0
  7. angr/analyses/bindiff.py +1251 -0
  8. angr/analyses/boyscout.py +77 -0
  9. angr/analyses/callee_cleanup_finder.py +75 -0
  10. angr/analyses/calling_convention.py +956 -0
  11. angr/analyses/cdg.py +197 -0
  12. angr/analyses/cfg/__init__.py +11 -0
  13. angr/analyses/cfg/cfb.py +436 -0
  14. angr/analyses/cfg/cfg.py +73 -0
  15. angr/analyses/cfg/cfg_arch_options.py +82 -0
  16. angr/analyses/cfg/cfg_base.py +2917 -0
  17. angr/analyses/cfg/cfg_emulated.py +3570 -0
  18. angr/analyses/cfg/cfg_fast.py +5053 -0
  19. angr/analyses/cfg/cfg_fast_soot.py +669 -0
  20. angr/analyses/cfg/cfg_job_base.py +204 -0
  21. angr/analyses/cfg/indirect_jump_resolvers/__init__.py +8 -0
  22. angr/analyses/cfg/indirect_jump_resolvers/amd64_elf_got.py +63 -0
  23. angr/analyses/cfg/indirect_jump_resolvers/amd64_pe_iat.py +52 -0
  24. angr/analyses/cfg/indirect_jump_resolvers/arm_elf_fast.py +151 -0
  25. angr/analyses/cfg/indirect_jump_resolvers/const_resolver.py +141 -0
  26. angr/analyses/cfg/indirect_jump_resolvers/default_resolvers.py +68 -0
  27. angr/analyses/cfg/indirect_jump_resolvers/jumptable.py +2368 -0
  28. angr/analyses/cfg/indirect_jump_resolvers/mips_elf_fast.py +517 -0
  29. angr/analyses/cfg/indirect_jump_resolvers/propagator_utils.py +26 -0
  30. angr/analyses/cfg/indirect_jump_resolvers/resolver.py +74 -0
  31. angr/analyses/cfg/indirect_jump_resolvers/x86_elf_pic_plt.py +93 -0
  32. angr/analyses/cfg/indirect_jump_resolvers/x86_pe_iat.py +51 -0
  33. angr/analyses/cfg_slice_to_sink/__init__.py +2 -0
  34. angr/analyses/cfg_slice_to_sink/cfg_slice_to_sink.py +117 -0
  35. angr/analyses/cfg_slice_to_sink/graph.py +84 -0
  36. angr/analyses/cfg_slice_to_sink/transitions.py +25 -0
  37. angr/analyses/class_identifier.py +62 -0
  38. angr/analyses/code_tagging.py +123 -0
  39. angr/analyses/complete_calling_conventions.py +424 -0
  40. angr/analyses/congruency_check.py +384 -0
  41. angr/analyses/data_dep/__init__.py +2 -0
  42. angr/analyses/data_dep/data_dependency_analysis.py +605 -0
  43. angr/analyses/data_dep/dep_nodes.py +170 -0
  44. angr/analyses/data_dep/sim_act_location.py +46 -0
  45. angr/analyses/datagraph_meta.py +105 -0
  46. angr/analyses/ddg.py +1695 -0
  47. angr/analyses/decompiler/__init__.py +13 -0
  48. angr/analyses/decompiler/ail_simplifier.py +1408 -0
  49. angr/analyses/decompiler/ailgraph_walker.py +48 -0
  50. angr/analyses/decompiler/block_io_finder.py +293 -0
  51. angr/analyses/decompiler/block_similarity.py +188 -0
  52. angr/analyses/decompiler/block_simplifier.py +434 -0
  53. angr/analyses/decompiler/call_counter.py +43 -0
  54. angr/analyses/decompiler/callsite_maker.py +403 -0
  55. angr/analyses/decompiler/ccall_rewriters/__init__.py +6 -0
  56. angr/analyses/decompiler/ccall_rewriters/amd64_ccalls.py +489 -0
  57. angr/analyses/decompiler/ccall_rewriters/rewriter_base.py +19 -0
  58. angr/analyses/decompiler/clinic.py +2166 -0
  59. angr/analyses/decompiler/condition_processor.py +1184 -0
  60. angr/analyses/decompiler/decompilation_cache.py +38 -0
  61. angr/analyses/decompiler/decompilation_options.py +274 -0
  62. angr/analyses/decompiler/decompiler.py +544 -0
  63. angr/analyses/decompiler/empty_node_remover.py +211 -0
  64. angr/analyses/decompiler/expression_counters.py +76 -0
  65. angr/analyses/decompiler/expression_narrower.py +92 -0
  66. angr/analyses/decompiler/goto_manager.py +73 -0
  67. angr/analyses/decompiler/graph_region.py +413 -0
  68. angr/analyses/decompiler/jump_target_collector.py +36 -0
  69. angr/analyses/decompiler/jumptable_entry_condition_rewriter.py +66 -0
  70. angr/analyses/decompiler/optimization_passes/__init__.py +108 -0
  71. angr/analyses/decompiler/optimization_passes/base_ptr_save_simplifier.py +144 -0
  72. angr/analyses/decompiler/optimization_passes/code_motion.py +360 -0
  73. angr/analyses/decompiler/optimization_passes/const_derefs.py +265 -0
  74. angr/analyses/decompiler/optimization_passes/cross_jump_reverter.py +108 -0
  75. angr/analyses/decompiler/optimization_passes/deadblock_remover.py +73 -0
  76. angr/analyses/decompiler/optimization_passes/div_simplifier.py +391 -0
  77. angr/analyses/decompiler/optimization_passes/engine_base.py +303 -0
  78. angr/analyses/decompiler/optimization_passes/expr_op_swapper.py +136 -0
  79. angr/analyses/decompiler/optimization_passes/flip_boolean_cmp.py +91 -0
  80. angr/analyses/decompiler/optimization_passes/inlined_string_transformation_simplifier.py +386 -0
  81. angr/analyses/decompiler/optimization_passes/ite_expr_converter.py +226 -0
  82. angr/analyses/decompiler/optimization_passes/ite_region_converter.py +189 -0
  83. angr/analyses/decompiler/optimization_passes/lowered_switch_simplifier.py +757 -0
  84. angr/analyses/decompiler/optimization_passes/mod_simplifier.py +86 -0
  85. angr/analyses/decompiler/optimization_passes/multi_simplifier.py +227 -0
  86. angr/analyses/decompiler/optimization_passes/optimization_pass.py +397 -0
  87. angr/analyses/decompiler/optimization_passes/register_save_area_simplifier.py +198 -0
  88. angr/analyses/decompiler/optimization_passes/ret_addr_save_simplifier.py +172 -0
  89. angr/analyses/decompiler/optimization_passes/ret_deduplicator.py +219 -0
  90. angr/analyses/decompiler/optimization_passes/return_duplicator_base.py +448 -0
  91. angr/analyses/decompiler/optimization_passes/return_duplicator_high.py +57 -0
  92. angr/analyses/decompiler/optimization_passes/return_duplicator_low.py +121 -0
  93. angr/analyses/decompiler/optimization_passes/spilled_register_finder.py +18 -0
  94. angr/analyses/decompiler/optimization_passes/stack_canary_simplifier.py +293 -0
  95. angr/analyses/decompiler/optimization_passes/switch_default_case_duplicator.py +110 -0
  96. angr/analyses/decompiler/optimization_passes/win_stack_canary_simplifier.py +281 -0
  97. angr/analyses/decompiler/optimization_passes/x86_gcc_getpc_simplifier.py +87 -0
  98. angr/analyses/decompiler/peephole_optimizations/__init__.py +69 -0
  99. angr/analyses/decompiler/peephole_optimizations/a_div_const_add_a_mul_n_div_const.py +38 -0
  100. angr/analyses/decompiler/peephole_optimizations/a_mul_const_div_shr_const.py +38 -0
  101. angr/analyses/decompiler/peephole_optimizations/a_shl_const_sub_a.py +31 -0
  102. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div.py +25 -0
  103. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div_const_mul_const.py +56 -0
  104. angr/analyses/decompiler/peephole_optimizations/a_sub_a_sub_n.py +19 -0
  105. angr/analyses/decompiler/peephole_optimizations/arm_cmpf.py +235 -0
  106. angr/analyses/decompiler/peephole_optimizations/base.py +120 -0
  107. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_add_n.py +33 -0
  108. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_and_mask.py +35 -0
  109. angr/analyses/decompiler/peephole_optimizations/bitwise_or_to_logical_or.py +34 -0
  110. angr/analyses/decompiler/peephole_optimizations/bool_expr_xor_1.py +27 -0
  111. angr/analyses/decompiler/peephole_optimizations/bswap.py +131 -0
  112. angr/analyses/decompiler/peephole_optimizations/cmpord_rewriter.py +72 -0
  113. angr/analyses/decompiler/peephole_optimizations/coalesce_same_cascading_ifs.py +27 -0
  114. angr/analyses/decompiler/peephole_optimizations/const_mull_a_shift.py +91 -0
  115. angr/analyses/decompiler/peephole_optimizations/constant_derefs.py +43 -0
  116. angr/analyses/decompiler/peephole_optimizations/conv_a_sub0_shr_and.py +70 -0
  117. angr/analyses/decompiler/peephole_optimizations/conv_shl_shr.py +51 -0
  118. angr/analyses/decompiler/peephole_optimizations/eager_eval.py +225 -0
  119. angr/analyses/decompiler/peephole_optimizations/extended_byte_and_mask.py +55 -0
  120. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy.py +146 -0
  121. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy_consolidation.py +102 -0
  122. angr/analyses/decompiler/peephole_optimizations/inlined_wstrcpy.py +159 -0
  123. angr/analyses/decompiler/peephole_optimizations/invert_negated_logical_conjuction_disjunction.py +50 -0
  124. angr/analyses/decompiler/peephole_optimizations/one_sub_bool.py +33 -0
  125. angr/analyses/decompiler/peephole_optimizations/remove_cascading_conversions.py +19 -0
  126. angr/analyses/decompiler/peephole_optimizations/remove_empty_if_body.py +45 -0
  127. angr/analyses/decompiler/peephole_optimizations/remove_noop_conversions.py +26 -0
  128. angr/analyses/decompiler/peephole_optimizations/remove_redundant_bitmasks.py +48 -0
  129. angr/analyses/decompiler/peephole_optimizations/remove_redundant_conversions.py +160 -0
  130. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_branch.py +29 -0
  131. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_comparisons.py +54 -0
  132. angr/analyses/decompiler/peephole_optimizations/remove_redundant_nots.py +17 -0
  133. angr/analyses/decompiler/peephole_optimizations/remove_redundant_reinterprets.py +43 -0
  134. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts.py +44 -0
  135. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts_around_comparators.py +40 -0
  136. angr/analyses/decompiler/peephole_optimizations/rewrite_bit_extractions.py +85 -0
  137. angr/analyses/decompiler/peephole_optimizations/rewrite_mips_gp_loads.py +47 -0
  138. angr/analyses/decompiler/peephole_optimizations/rol_ror.py +77 -0
  139. angr/analyses/decompiler/peephole_optimizations/sar_to_signed_div.py +105 -0
  140. angr/analyses/decompiler/peephole_optimizations/simplify_pc_relative_loads.py +37 -0
  141. angr/analyses/decompiler/peephole_optimizations/single_bit_cond_to_boolexpr.py +52 -0
  142. angr/analyses/decompiler/peephole_optimizations/single_bit_xor.py +26 -0
  143. angr/analyses/decompiler/peephole_optimizations/tidy_stack_addr.py +133 -0
  144. angr/analyses/decompiler/redundant_label_remover.py +116 -0
  145. angr/analyses/decompiler/region_identifier.py +1098 -0
  146. angr/analyses/decompiler/region_simplifiers/__init__.py +1 -0
  147. angr/analyses/decompiler/region_simplifiers/cascading_cond_transformer.py +93 -0
  148. angr/analyses/decompiler/region_simplifiers/cascading_ifs.py +81 -0
  149. angr/analyses/decompiler/region_simplifiers/expr_folding.py +606 -0
  150. angr/analyses/decompiler/region_simplifiers/goto.py +177 -0
  151. angr/analyses/decompiler/region_simplifiers/if_.py +142 -0
  152. angr/analyses/decompiler/region_simplifiers/ifelse.py +90 -0
  153. angr/analyses/decompiler/region_simplifiers/loop.py +135 -0
  154. angr/analyses/decompiler/region_simplifiers/node_address_finder.py +23 -0
  155. angr/analyses/decompiler/region_simplifiers/region_simplifier.py +211 -0
  156. angr/analyses/decompiler/region_simplifiers/switch_cluster_simplifier.py +644 -0
  157. angr/analyses/decompiler/region_simplifiers/switch_expr_simplifier.py +83 -0
  158. angr/analyses/decompiler/region_walker.py +23 -0
  159. angr/analyses/decompiler/return_maker.py +70 -0
  160. angr/analyses/decompiler/seq_to_blocks.py +19 -0
  161. angr/analyses/decompiler/sequence_walker.py +235 -0
  162. angr/analyses/decompiler/structured_codegen/__init__.py +10 -0
  163. angr/analyses/decompiler/structured_codegen/base.py +132 -0
  164. angr/analyses/decompiler/structured_codegen/c.py +3811 -0
  165. angr/analyses/decompiler/structured_codegen/dummy.py +14 -0
  166. angr/analyses/decompiler/structured_codegen/dwarf_import.py +186 -0
  167. angr/analyses/decompiler/structuring/__init__.py +15 -0
  168. angr/analyses/decompiler/structuring/dream.py +1225 -0
  169. angr/analyses/decompiler/structuring/phoenix.py +2546 -0
  170. angr/analyses/decompiler/structuring/recursive_structurer.py +186 -0
  171. angr/analyses/decompiler/structuring/structurer_base.py +954 -0
  172. angr/analyses/decompiler/structuring/structurer_nodes.py +414 -0
  173. angr/analyses/decompiler/utils.py +787 -0
  174. angr/analyses/disassembly.py +1302 -0
  175. angr/analyses/disassembly_utils.py +104 -0
  176. angr/analyses/dominance_frontier.py +39 -0
  177. angr/analyses/find_objects_static.py +203 -0
  178. angr/analyses/flirt.py +185 -0
  179. angr/analyses/forward_analysis/__init__.py +2 -0
  180. angr/analyses/forward_analysis/forward_analysis.py +527 -0
  181. angr/analyses/forward_analysis/job_info.py +64 -0
  182. angr/analyses/forward_analysis/visitors/__init__.py +4 -0
  183. angr/analyses/forward_analysis/visitors/call_graph.py +28 -0
  184. angr/analyses/forward_analysis/visitors/function_graph.py +85 -0
  185. angr/analyses/forward_analysis/visitors/graph.py +250 -0
  186. angr/analyses/forward_analysis/visitors/loop.py +28 -0
  187. angr/analyses/forward_analysis/visitors/single_node_graph.py +38 -0
  188. angr/analyses/identifier/__init__.py +1 -0
  189. angr/analyses/identifier/custom_callable.py +138 -0
  190. angr/analyses/identifier/errors.py +9 -0
  191. angr/analyses/identifier/func.py +57 -0
  192. angr/analyses/identifier/functions/__init__.py +36 -0
  193. angr/analyses/identifier/functions/atoi.py +75 -0
  194. angr/analyses/identifier/functions/based_atoi.py +128 -0
  195. angr/analyses/identifier/functions/fdprintf.py +122 -0
  196. angr/analyses/identifier/functions/free.py +64 -0
  197. angr/analyses/identifier/functions/int2str.py +302 -0
  198. angr/analyses/identifier/functions/malloc.py +113 -0
  199. angr/analyses/identifier/functions/memcmp.py +69 -0
  200. angr/analyses/identifier/functions/memcpy.py +89 -0
  201. angr/analyses/identifier/functions/memset.py +43 -0
  202. angr/analyses/identifier/functions/printf.py +122 -0
  203. angr/analyses/identifier/functions/recv_until.py +315 -0
  204. angr/analyses/identifier/functions/skip_calloc.py +72 -0
  205. angr/analyses/identifier/functions/skip_realloc.py +99 -0
  206. angr/analyses/identifier/functions/skip_recv_n.py +107 -0
  207. angr/analyses/identifier/functions/snprintf.py +114 -0
  208. angr/analyses/identifier/functions/sprintf.py +115 -0
  209. angr/analyses/identifier/functions/strcasecmp.py +32 -0
  210. angr/analyses/identifier/functions/strcmp.py +112 -0
  211. angr/analyses/identifier/functions/strcpy.py +43 -0
  212. angr/analyses/identifier/functions/strlen.py +26 -0
  213. angr/analyses/identifier/functions/strncmp.py +103 -0
  214. angr/analyses/identifier/functions/strncpy.py +65 -0
  215. angr/analyses/identifier/functions/strtol.py +91 -0
  216. angr/analyses/identifier/identify.py +848 -0
  217. angr/analyses/identifier/runner.py +359 -0
  218. angr/analyses/init_finder.py +264 -0
  219. angr/analyses/loop_analysis.py +353 -0
  220. angr/analyses/loopfinder.py +174 -0
  221. angr/analyses/propagator/__init__.py +1 -0
  222. angr/analyses/propagator/engine_ail.py +1560 -0
  223. angr/analyses/propagator/engine_base.py +53 -0
  224. angr/analyses/propagator/engine_vex.py +328 -0
  225. angr/analyses/propagator/outdated_definition_walker.py +158 -0
  226. angr/analyses/propagator/propagator.py +422 -0
  227. angr/analyses/propagator/tmpvar_finder.py +17 -0
  228. angr/analyses/propagator/top_checker_mixin.py +14 -0
  229. angr/analyses/propagator/values.py +116 -0
  230. angr/analyses/propagator/vex_vars.py +67 -0
  231. angr/analyses/proximity_graph.py +452 -0
  232. angr/analyses/reaching_definitions/__init__.py +65 -0
  233. angr/analyses/reaching_definitions/call_trace.py +72 -0
  234. angr/analyses/reaching_definitions/dep_graph.py +392 -0
  235. angr/analyses/reaching_definitions/engine_ail.py +1172 -0
  236. angr/analyses/reaching_definitions/engine_vex.py +1102 -0
  237. angr/analyses/reaching_definitions/external_codeloc.py +0 -0
  238. angr/analyses/reaching_definitions/function_handler.py +603 -0
  239. angr/analyses/reaching_definitions/heap_allocator.py +69 -0
  240. angr/analyses/reaching_definitions/rd_initializer.py +235 -0
  241. angr/analyses/reaching_definitions/rd_state.py +613 -0
  242. angr/analyses/reaching_definitions/reaching_definitions.py +594 -0
  243. angr/analyses/reaching_definitions/subject.py +64 -0
  244. angr/analyses/reassembler.py +2970 -0
  245. angr/analyses/soot_class_hierarchy.py +283 -0
  246. angr/analyses/stack_pointer_tracker.py +832 -0
  247. angr/analyses/static_hooker.py +51 -0
  248. angr/analyses/typehoon/__init__.py +1 -0
  249. angr/analyses/typehoon/dfa.py +108 -0
  250. angr/analyses/typehoon/lifter.py +91 -0
  251. angr/analyses/typehoon/simple_solver.py +1258 -0
  252. angr/analyses/typehoon/translator.py +242 -0
  253. angr/analyses/typehoon/typeconsts.py +294 -0
  254. angr/analyses/typehoon/typehoon.py +239 -0
  255. angr/analyses/typehoon/typevars.py +565 -0
  256. angr/analyses/typehoon/variance.py +10 -0
  257. angr/analyses/variable_recovery/__init__.py +2 -0
  258. angr/analyses/variable_recovery/annotations.py +57 -0
  259. angr/analyses/variable_recovery/engine_ail.py +746 -0
  260. angr/analyses/variable_recovery/engine_base.py +962 -0
  261. angr/analyses/variable_recovery/engine_vex.py +580 -0
  262. angr/analyses/variable_recovery/irsb_scanner.py +131 -0
  263. angr/analyses/variable_recovery/variable_recovery.py +552 -0
  264. angr/analyses/variable_recovery/variable_recovery_base.py +452 -0
  265. angr/analyses/variable_recovery/variable_recovery_fast.py +589 -0
  266. angr/analyses/veritesting.py +635 -0
  267. angr/analyses/vfg.py +1945 -0
  268. angr/analyses/vsa_ddg.py +423 -0
  269. angr/analyses/vtable.py +92 -0
  270. angr/analyses/xrefs.py +263 -0
  271. angr/angrdb/__init__.py +9 -0
  272. angr/angrdb/db.py +208 -0
  273. angr/angrdb/models.py +183 -0
  274. angr/angrdb/serializers/__init__.py +2 -0
  275. angr/angrdb/serializers/cfg_model.py +41 -0
  276. angr/angrdb/serializers/comments.py +59 -0
  277. angr/angrdb/serializers/funcs.py +60 -0
  278. angr/angrdb/serializers/kb.py +110 -0
  279. angr/angrdb/serializers/labels.py +58 -0
  280. angr/angrdb/serializers/loader.py +81 -0
  281. angr/angrdb/serializers/structured_code.py +128 -0
  282. angr/angrdb/serializers/variables.py +58 -0
  283. angr/angrdb/serializers/xrefs.py +48 -0
  284. angr/annocfg.py +320 -0
  285. angr/blade.py +430 -0
  286. angr/block.py +506 -0
  287. angr/callable.py +162 -0
  288. angr/calling_conventions.py +2383 -0
  289. angr/code_location.py +168 -0
  290. angr/codenode.py +140 -0
  291. angr/concretization_strategies/__init__.py +97 -0
  292. angr/concretization_strategies/any.py +15 -0
  293. angr/concretization_strategies/any_named.py +32 -0
  294. angr/concretization_strategies/controlled_data.py +54 -0
  295. angr/concretization_strategies/eval.py +18 -0
  296. angr/concretization_strategies/logging.py +32 -0
  297. angr/concretization_strategies/max.py +24 -0
  298. angr/concretization_strategies/nonzero.py +14 -0
  299. angr/concretization_strategies/nonzero_range.py +20 -0
  300. angr/concretization_strategies/norepeats.py +35 -0
  301. angr/concretization_strategies/norepeats_range.py +35 -0
  302. angr/concretization_strategies/range.py +17 -0
  303. angr/concretization_strategies/signed_add.py +24 -0
  304. angr/concretization_strategies/single.py +12 -0
  305. angr/concretization_strategies/solutions.py +18 -0
  306. angr/concretization_strategies/unlimited_range.py +15 -0
  307. angr/distributed/__init__.py +3 -0
  308. angr/distributed/server.py +198 -0
  309. angr/distributed/worker.py +183 -0
  310. angr/engines/__init__.py +41 -0
  311. angr/engines/concrete.py +178 -0
  312. angr/engines/engine.py +212 -0
  313. angr/engines/failure.py +27 -0
  314. angr/engines/hook.py +67 -0
  315. angr/engines/light/__init__.py +2 -0
  316. angr/engines/light/data.py +715 -0
  317. angr/engines/light/engine.py +1441 -0
  318. angr/engines/pcode/__init__.py +2 -0
  319. angr/engines/pcode/behavior.py +995 -0
  320. angr/engines/pcode/cc.py +123 -0
  321. angr/engines/pcode/emulate.py +446 -0
  322. angr/engines/pcode/engine.py +256 -0
  323. angr/engines/pcode/lifter.py +1423 -0
  324. angr/engines/procedure.py +71 -0
  325. angr/engines/soot/__init__.py +1 -0
  326. angr/engines/soot/engine.py +415 -0
  327. angr/engines/soot/exceptions.py +14 -0
  328. angr/engines/soot/expressions/__init__.py +56 -0
  329. angr/engines/soot/expressions/arrayref.py +21 -0
  330. angr/engines/soot/expressions/base.py +22 -0
  331. angr/engines/soot/expressions/binop.py +27 -0
  332. angr/engines/soot/expressions/cast.py +21 -0
  333. angr/engines/soot/expressions/condition.py +34 -0
  334. angr/engines/soot/expressions/constants.py +45 -0
  335. angr/engines/soot/expressions/instanceOf.py +11 -0
  336. angr/engines/soot/expressions/instancefieldref.py +7 -0
  337. angr/engines/soot/expressions/invoke.py +117 -0
  338. angr/engines/soot/expressions/length.py +7 -0
  339. angr/engines/soot/expressions/local.py +7 -0
  340. angr/engines/soot/expressions/new.py +15 -0
  341. angr/engines/soot/expressions/newArray.py +51 -0
  342. angr/engines/soot/expressions/newMultiArray.py +84 -0
  343. angr/engines/soot/expressions/paramref.py +7 -0
  344. angr/engines/soot/expressions/phi.py +29 -0
  345. angr/engines/soot/expressions/staticfieldref.py +7 -0
  346. angr/engines/soot/expressions/thisref.py +6 -0
  347. angr/engines/soot/expressions/unsupported.py +6 -0
  348. angr/engines/soot/field_dispatcher.py +49 -0
  349. angr/engines/soot/method_dispatcher.py +49 -0
  350. angr/engines/soot/statements/__init__.py +30 -0
  351. angr/engines/soot/statements/assign.py +29 -0
  352. angr/engines/soot/statements/base.py +80 -0
  353. angr/engines/soot/statements/goto.py +11 -0
  354. angr/engines/soot/statements/identity.py +14 -0
  355. angr/engines/soot/statements/if_.py +16 -0
  356. angr/engines/soot/statements/invoke.py +11 -0
  357. angr/engines/soot/statements/return_.py +19 -0
  358. angr/engines/soot/statements/switch.py +38 -0
  359. angr/engines/soot/statements/throw.py +12 -0
  360. angr/engines/soot/values/__init__.py +24 -0
  361. angr/engines/soot/values/arrayref.py +124 -0
  362. angr/engines/soot/values/base.py +4 -0
  363. angr/engines/soot/values/constants.py +17 -0
  364. angr/engines/soot/values/instancefieldref.py +42 -0
  365. angr/engines/soot/values/local.py +17 -0
  366. angr/engines/soot/values/paramref.py +17 -0
  367. angr/engines/soot/values/staticfieldref.py +37 -0
  368. angr/engines/soot/values/strref.py +37 -0
  369. angr/engines/soot/values/thisref.py +148 -0
  370. angr/engines/successors.py +540 -0
  371. angr/engines/syscall.py +53 -0
  372. angr/engines/unicorn.py +483 -0
  373. angr/engines/vex/__init__.py +4 -0
  374. angr/engines/vex/claripy/__init__.py +1 -0
  375. angr/engines/vex/claripy/ccall.py +2097 -0
  376. angr/engines/vex/claripy/datalayer.py +149 -0
  377. angr/engines/vex/claripy/irop.py +1279 -0
  378. angr/engines/vex/heavy/__init__.py +5 -0
  379. angr/engines/vex/heavy/actions.py +237 -0
  380. angr/engines/vex/heavy/concretizers.py +394 -0
  381. angr/engines/vex/heavy/dirty.py +467 -0
  382. angr/engines/vex/heavy/heavy.py +379 -0
  383. angr/engines/vex/heavy/inspect.py +51 -0
  384. angr/engines/vex/heavy/resilience.py +85 -0
  385. angr/engines/vex/heavy/super_fastpath.py +34 -0
  386. angr/engines/vex/lifter.py +424 -0
  387. angr/engines/vex/light/__init__.py +3 -0
  388. angr/engines/vex/light/light.py +555 -0
  389. angr/engines/vex/light/resilience.py +73 -0
  390. angr/engines/vex/light/slicing.py +51 -0
  391. angr/errors.py +604 -0
  392. angr/exploration_techniques/__init__.py +176 -0
  393. angr/exploration_techniques/bucketizer.py +96 -0
  394. angr/exploration_techniques/common.py +56 -0
  395. angr/exploration_techniques/dfs.py +34 -0
  396. angr/exploration_techniques/director.py +523 -0
  397. angr/exploration_techniques/driller_core.py +102 -0
  398. angr/exploration_techniques/explorer.py +146 -0
  399. angr/exploration_techniques/lengthlimiter.py +20 -0
  400. angr/exploration_techniques/local_loop_seer.py +64 -0
  401. angr/exploration_techniques/loop_seer.py +239 -0
  402. angr/exploration_techniques/manual_mergepoint.py +80 -0
  403. angr/exploration_techniques/memory_watcher.py +40 -0
  404. angr/exploration_techniques/oppologist.py +93 -0
  405. angr/exploration_techniques/slicecutor.py +115 -0
  406. angr/exploration_techniques/spiller.py +282 -0
  407. angr/exploration_techniques/spiller_db.py +27 -0
  408. angr/exploration_techniques/stochastic.py +57 -0
  409. angr/exploration_techniques/suggestions.py +156 -0
  410. angr/exploration_techniques/symbion.py +78 -0
  411. angr/exploration_techniques/tech_builder.py +47 -0
  412. angr/exploration_techniques/threading.py +77 -0
  413. angr/exploration_techniques/timeout.py +31 -0
  414. angr/exploration_techniques/tracer.py +1101 -0
  415. angr/exploration_techniques/unique.py +104 -0
  416. angr/exploration_techniques/veritesting.py +36 -0
  417. angr/factory.py +385 -0
  418. angr/flirt/__init__.py +126 -0
  419. angr/flirt/build_sig.py +316 -0
  420. angr/graph_utils.py +0 -0
  421. angr/keyed_region.py +532 -0
  422. angr/knowledge_base/__init__.py +1 -0
  423. angr/knowledge_base/knowledge_base.py +145 -0
  424. angr/knowledge_plugins/__init__.py +18 -0
  425. angr/knowledge_plugins/callsite_prototypes.py +52 -0
  426. angr/knowledge_plugins/cfg/__init__.py +16 -0
  427. angr/knowledge_plugins/cfg/cfg_manager.py +94 -0
  428. angr/knowledge_plugins/cfg/cfg_model.py +1057 -0
  429. angr/knowledge_plugins/cfg/cfg_node.py +541 -0
  430. angr/knowledge_plugins/cfg/indirect_jump.py +67 -0
  431. angr/knowledge_plugins/cfg/memory_data.py +156 -0
  432. angr/knowledge_plugins/comments.py +15 -0
  433. angr/knowledge_plugins/custom_strings.py +37 -0
  434. angr/knowledge_plugins/data.py +21 -0
  435. angr/knowledge_plugins/debug_variables.py +221 -0
  436. angr/knowledge_plugins/functions/__init__.py +2 -0
  437. angr/knowledge_plugins/functions/function.py +1694 -0
  438. angr/knowledge_plugins/functions/function_manager.py +501 -0
  439. angr/knowledge_plugins/functions/function_parser.py +295 -0
  440. angr/knowledge_plugins/functions/soot_function.py +131 -0
  441. angr/knowledge_plugins/indirect_jumps.py +34 -0
  442. angr/knowledge_plugins/key_definitions/__init__.py +16 -0
  443. angr/knowledge_plugins/key_definitions/atoms.py +314 -0
  444. angr/knowledge_plugins/key_definitions/constants.py +23 -0
  445. angr/knowledge_plugins/key_definitions/definition.py +217 -0
  446. angr/knowledge_plugins/key_definitions/environment.py +92 -0
  447. angr/knowledge_plugins/key_definitions/heap_address.py +32 -0
  448. angr/knowledge_plugins/key_definitions/key_definition_manager.py +81 -0
  449. angr/knowledge_plugins/key_definitions/live_definitions.py +1074 -0
  450. angr/knowledge_plugins/key_definitions/liveness.py +170 -0
  451. angr/knowledge_plugins/key_definitions/rd_model.py +176 -0
  452. angr/knowledge_plugins/key_definitions/tag.py +77 -0
  453. angr/knowledge_plugins/key_definitions/undefined.py +67 -0
  454. angr/knowledge_plugins/key_definitions/unknown_size.py +83 -0
  455. angr/knowledge_plugins/key_definitions/uses.py +180 -0
  456. angr/knowledge_plugins/labels.py +109 -0
  457. angr/knowledge_plugins/patches.py +125 -0
  458. angr/knowledge_plugins/plugin.py +23 -0
  459. angr/knowledge_plugins/propagations/__init__.py +2 -0
  460. angr/knowledge_plugins/propagations/prop_value.py +193 -0
  461. angr/knowledge_plugins/propagations/propagation_manager.py +60 -0
  462. angr/knowledge_plugins/propagations/propagation_model.py +74 -0
  463. angr/knowledge_plugins/propagations/states.py +1064 -0
  464. angr/knowledge_plugins/structured_code/__init__.py +1 -0
  465. angr/knowledge_plugins/structured_code/manager.py +59 -0
  466. angr/knowledge_plugins/sync/__init__.py +1 -0
  467. angr/knowledge_plugins/sync/sync_controller.py +329 -0
  468. angr/knowledge_plugins/types.py +87 -0
  469. angr/knowledge_plugins/variables/__init__.py +1 -0
  470. angr/knowledge_plugins/variables/variable_access.py +114 -0
  471. angr/knowledge_plugins/variables/variable_manager.py +1191 -0
  472. angr/knowledge_plugins/xrefs/__init__.py +3 -0
  473. angr/knowledge_plugins/xrefs/xref.py +157 -0
  474. angr/knowledge_plugins/xrefs/xref_manager.py +122 -0
  475. angr/knowledge_plugins/xrefs/xref_types.py +13 -0
  476. angr/lib/angr_native.so +0 -0
  477. angr/misc/__init__.py +8 -0
  478. angr/misc/ansi.py +46 -0
  479. angr/misc/autoimport.py +89 -0
  480. angr/misc/bug_report.py +125 -0
  481. angr/misc/hookset.py +106 -0
  482. angr/misc/import_hooks.py +63 -0
  483. angr/misc/loggers.py +130 -0
  484. angr/misc/picklable_lock.py +45 -0
  485. angr/misc/plugins.py +291 -0
  486. angr/misc/range.py +21 -0
  487. angr/misc/testing.py +23 -0
  488. angr/misc/ux.py +31 -0
  489. angr/misc/weakpatch.py +58 -0
  490. angr/procedures/__init__.py +2 -0
  491. angr/procedures/advapi32/__init__.py +0 -0
  492. angr/procedures/cgc/__init__.py +3 -0
  493. angr/procedures/cgc/_terminate.py +10 -0
  494. angr/procedures/cgc/allocate.py +76 -0
  495. angr/procedures/cgc/deallocate.py +59 -0
  496. angr/procedures/cgc/fdwait.py +62 -0
  497. angr/procedures/cgc/random.py +60 -0
  498. angr/procedures/cgc/receive.py +91 -0
  499. angr/procedures/cgc/transmit.py +63 -0
  500. angr/procedures/definitions/__init__.py +784 -0
  501. angr/procedures/definitions/cgc.py +19 -0
  502. angr/procedures/definitions/glibc.py +8384 -0
  503. angr/procedures/definitions/gnulib.py +35 -0
  504. angr/procedures/definitions/libstdcpp.py +20 -0
  505. angr/procedures/definitions/linux_kernel.py +6167 -0
  506. angr/procedures/definitions/linux_loader.py +6 -0
  507. angr/procedures/definitions/msvcr.py +15 -0
  508. angr/procedures/definitions/parse_syscalls_from_local_system.py +49 -0
  509. angr/procedures/definitions/parse_win32json.py +2556 -0
  510. angr/procedures/definitions/types_win32.py +34481 -0
  511. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-4.py +44 -0
  512. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-6.py +40 -0
  513. angr/procedures/definitions/wdk_clfs.py +154 -0
  514. angr/procedures/definitions/wdk_fltmgr.py +570 -0
  515. angr/procedures/definitions/wdk_fwpkclnt.py +44 -0
  516. angr/procedures/definitions/wdk_fwpuclnt.py +330 -0
  517. angr/procedures/definitions/wdk_gdi32.py +380 -0
  518. angr/procedures/definitions/wdk_hal.py +92 -0
  519. angr/procedures/definitions/wdk_ksecdd.py +76 -0
  520. angr/procedures/definitions/wdk_ndis.py +252 -0
  521. angr/procedures/definitions/wdk_ntoskrnl.py +3463 -0
  522. angr/procedures/definitions/wdk_offreg.py +86 -0
  523. angr/procedures/definitions/wdk_pshed.py +50 -0
  524. angr/procedures/definitions/wdk_secur32.py +54 -0
  525. angr/procedures/definitions/wdk_vhfum.py +48 -0
  526. angr/procedures/definitions/win32_aclui.py +44 -0
  527. angr/procedures/definitions/win32_activeds.py +82 -0
  528. angr/procedures/definitions/win32_advapi32.py +1698 -0
  529. angr/procedures/definitions/win32_advpack.py +138 -0
  530. angr/procedures/definitions/win32_amsi.py +52 -0
  531. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-1.py +58 -0
  532. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-3.py +48 -0
  533. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-6.py +40 -0
  534. angr/procedures/definitions/win32_api-ms-win-core-apiquery-l2-1-0.py +40 -0
  535. angr/procedures/definitions/win32_api-ms-win-core-backgroundtask-l1-1-0.py +40 -0
  536. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-1.py +40 -0
  537. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-2.py +40 -0
  538. angr/procedures/definitions/win32_api-ms-win-core-enclave-l1-1-1.py +44 -0
  539. angr/procedures/definitions/win32_api-ms-win-core-errorhandling-l1-1-3.py +40 -0
  540. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-0.py +48 -0
  541. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-1.py +40 -0
  542. angr/procedures/definitions/win32_api-ms-win-core-file-fromapp-l1-1-0.py +60 -0
  543. angr/procedures/definitions/win32_api-ms-win-core-handle-l1-1-0.py +40 -0
  544. angr/procedures/definitions/win32_api-ms-win-core-ioring-l1-1-0.py +62 -0
  545. angr/procedures/definitions/win32_api-ms-win-core-marshal-l1-1-0.py +46 -0
  546. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-3.py +46 -0
  547. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-4.py +40 -0
  548. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-5.py +44 -0
  549. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-6.py +46 -0
  550. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-7.py +42 -0
  551. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-8.py +44 -0
  552. angr/procedures/definitions/win32_api-ms-win-core-path-l1-1-0.py +82 -0
  553. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-0.py +42 -0
  554. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-1.py +42 -0
  555. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-1.py +44 -0
  556. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-2.py +44 -0
  557. angr/procedures/definitions/win32_api-ms-win-core-slapi-l1-1-0.py +40 -0
  558. angr/procedures/definitions/win32_api-ms-win-core-state-helpers-l1-1-0.py +40 -0
  559. angr/procedures/definitions/win32_api-ms-win-core-synch-l1-2-0.py +44 -0
  560. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-0.py +40 -0
  561. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-3.py +42 -0
  562. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-4.py +42 -0
  563. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-6.py +40 -0
  564. angr/procedures/definitions/win32_api-ms-win-core-util-l1-1-1.py +42 -0
  565. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-0.py +43 -0
  566. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-1.py +37 -0
  567. angr/procedures/definitions/win32_api-ms-win-core-winrt-l1-1-0.py +39 -0
  568. angr/procedures/definitions/win32_api-ms-win-core-winrt-registration-l1-1-0.py +23 -0
  569. angr/procedures/definitions/win32_api-ms-win-core-winrt-robuffer-l1-1-0.py +23 -0
  570. angr/procedures/definitions/win32_api-ms-win-core-winrt-roparameterizediid-l1-1-0.py +27 -0
  571. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-0.py +75 -0
  572. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-1.py +23 -0
  573. angr/procedures/definitions/win32_api-ms-win-core-wow64-l1-1-1.py +44 -0
  574. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-0.py +56 -0
  575. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-1.py +48 -0
  576. angr/procedures/definitions/win32_api-ms-win-dx-d3dkmt-l1-1-0.py +40 -0
  577. angr/procedures/definitions/win32_api-ms-win-gaming-deviceinformation-l1-1-0.py +40 -0
  578. angr/procedures/definitions/win32_api-ms-win-gaming-expandedresources-l1-1-0.py +44 -0
  579. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-0.py +52 -0
  580. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-1.py +42 -0
  581. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-2.py +52 -0
  582. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-3.py +42 -0
  583. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-4.py +54 -0
  584. angr/procedures/definitions/win32_api-ms-win-mm-misc-l1-1-1.py +40 -0
  585. angr/procedures/definitions/win32_api-ms-win-net-isolation-l1-1-0.py +54 -0
  586. angr/procedures/definitions/win32_api-ms-win-security-base-l1-2-2.py +40 -0
  587. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-0.py +40 -0
  588. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-1.py +40 -0
  589. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-3.py +40 -0
  590. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-4.py +40 -0
  591. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-5.py +42 -0
  592. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-0.py +44 -0
  593. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-1.py +50 -0
  594. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-2.py +40 -0
  595. angr/procedures/definitions/win32_api-ms-win-shcore-stream-winrt-l1-1-0.py +27 -0
  596. angr/procedures/definitions/win32_api-ms-win-wsl-api-l1-1-0.py +52 -0
  597. angr/procedures/definitions/win32_apphelp.py +40 -0
  598. angr/procedures/definitions/win32_authz.py +104 -0
  599. angr/procedures/definitions/win32_avicap32.py +46 -0
  600. angr/procedures/definitions/win32_avifil32.py +158 -0
  601. angr/procedures/definitions/win32_avrt.py +66 -0
  602. angr/procedures/definitions/win32_bcp47mrm.py +42 -0
  603. angr/procedures/definitions/win32_bcrypt.py +144 -0
  604. angr/procedures/definitions/win32_bcryptprimitives.py +42 -0
  605. angr/procedures/definitions/win32_bluetoothapis.py +120 -0
  606. angr/procedures/definitions/win32_bthprops.py +33 -0
  607. angr/procedures/definitions/win32_bthprops_cpl.py +50 -0
  608. angr/procedures/definitions/win32_cabinet.py +82 -0
  609. angr/procedures/definitions/win32_certadm.py +74 -0
  610. angr/procedures/definitions/win32_certpoleng.py +54 -0
  611. angr/procedures/definitions/win32_cfgmgr32.py +516 -0
  612. angr/procedures/definitions/win32_chakra.py +212 -0
  613. angr/procedures/definitions/win32_cldapi.py +110 -0
  614. angr/procedures/definitions/win32_clfsw32.py +156 -0
  615. angr/procedures/definitions/win32_clusapi.py +598 -0
  616. angr/procedures/definitions/win32_comctl32.py +268 -0
  617. angr/procedures/definitions/win32_comdlg32.py +80 -0
  618. angr/procedures/definitions/win32_compstui.py +46 -0
  619. angr/procedures/definitions/win32_computecore.py +146 -0
  620. angr/procedures/definitions/win32_computenetwork.py +124 -0
  621. angr/procedures/definitions/win32_computestorage.py +62 -0
  622. angr/procedures/definitions/win32_comsvcs.py +52 -0
  623. angr/procedures/definitions/win32_coremessaging.py +23 -0
  624. angr/procedures/definitions/win32_credui.py +76 -0
  625. angr/procedures/definitions/win32_crypt32.py +496 -0
  626. angr/procedures/definitions/win32_cryptnet.py +48 -0
  627. angr/procedures/definitions/win32_cryptui.py +58 -0
  628. angr/procedures/definitions/win32_cryptxml.py +76 -0
  629. angr/procedures/definitions/win32_cscapi.py +46 -0
  630. angr/procedures/definitions/win32_d2d1.py +64 -0
  631. angr/procedures/definitions/win32_d3d10.py +92 -0
  632. angr/procedures/definitions/win32_d3d10_1.py +42 -0
  633. angr/procedures/definitions/win32_d3d11.py +44 -0
  634. angr/procedures/definitions/win32_d3d12.py +54 -0
  635. angr/procedures/definitions/win32_d3d9.py +60 -0
  636. angr/procedures/definitions/win32_d3dcompiler_47.py +90 -0
  637. angr/procedures/definitions/win32_d3dcsx.py +56 -0
  638. angr/procedures/definitions/win32_davclnt.py +74 -0
  639. angr/procedures/definitions/win32_dbgeng.py +46 -0
  640. angr/procedures/definitions/win32_dbghelp.py +476 -0
  641. angr/procedures/definitions/win32_dbgmodel.py +40 -0
  642. angr/procedures/definitions/win32_dciman32.py +78 -0
  643. angr/procedures/definitions/win32_dcomp.py +62 -0
  644. angr/procedures/definitions/win32_ddraw.py +52 -0
  645. angr/procedures/definitions/win32_deviceaccess.py +40 -0
  646. angr/procedures/definitions/win32_dflayout.py +40 -0
  647. angr/procedures/definitions/win32_dhcpcsvc.py +68 -0
  648. angr/procedures/definitions/win32_dhcpcsvc6.py +50 -0
  649. angr/procedures/definitions/win32_dhcpsapi.py +430 -0
  650. angr/procedures/definitions/win32_diagnosticdataquery.py +108 -0
  651. angr/procedures/definitions/win32_dinput8.py +40 -0
  652. angr/procedures/definitions/win32_directml.py +42 -0
  653. angr/procedures/definitions/win32_dmprocessxmlfiltered.py +40 -0
  654. angr/procedures/definitions/win32_dnsapi.py +166 -0
  655. angr/procedures/definitions/win32_drt.py +70 -0
  656. angr/procedures/definitions/win32_drtprov.py +56 -0
  657. angr/procedures/definitions/win32_drttransport.py +42 -0
  658. angr/procedures/definitions/win32_dsound.py +58 -0
  659. angr/procedures/definitions/win32_dsparse.py +76 -0
  660. angr/procedures/definitions/win32_dsprop.py +52 -0
  661. angr/procedures/definitions/win32_dssec.py +46 -0
  662. angr/procedures/definitions/win32_dsuiext.py +46 -0
  663. angr/procedures/definitions/win32_dwmapi.py +100 -0
  664. angr/procedures/definitions/win32_dwrite.py +40 -0
  665. angr/procedures/definitions/win32_dxcompiler.py +42 -0
  666. angr/procedures/definitions/win32_dxcore.py +40 -0
  667. angr/procedures/definitions/win32_dxgi.py +50 -0
  668. angr/procedures/definitions/win32_dxva2.py +114 -0
  669. angr/procedures/definitions/win32_eappcfg.py +66 -0
  670. angr/procedures/definitions/win32_eappprxy.py +74 -0
  671. angr/procedures/definitions/win32_efswrt.py +42 -0
  672. angr/procedures/definitions/win32_elscore.py +48 -0
  673. angr/procedures/definitions/win32_esent.py +496 -0
  674. angr/procedures/definitions/win32_evr.py +52 -0
  675. angr/procedures/definitions/win32_faultrep.py +46 -0
  676. angr/procedures/definitions/win32_fhsvcctl.py +52 -0
  677. angr/procedures/definitions/win32_firewallapi.py +44 -0
  678. angr/procedures/definitions/win32_fltlib.py +94 -0
  679. angr/procedures/definitions/win32_fontsub.py +42 -0
  680. angr/procedures/definitions/win32_forceinline.py +44 -0
  681. angr/procedures/definitions/win32_fwpuclnt.py +422 -0
  682. angr/procedures/definitions/win32_fxsutility.py +42 -0
  683. angr/procedures/definitions/win32_gdi32.py +900 -0
  684. angr/procedures/definitions/win32_gdiplus.py +1296 -0
  685. angr/procedures/definitions/win32_glu32.py +142 -0
  686. angr/procedures/definitions/win32_gpedit.py +50 -0
  687. angr/procedures/definitions/win32_hhctrl_ocx.py +42 -0
  688. angr/procedures/definitions/win32_hid.py +128 -0
  689. angr/procedures/definitions/win32_hlink.py +94 -0
  690. angr/procedures/definitions/win32_hrtfapo.py +40 -0
  691. angr/procedures/definitions/win32_httpapi.py +124 -0
  692. angr/procedures/definitions/win32_icm32.py +80 -0
  693. angr/procedures/definitions/win32_icmui.py +42 -0
  694. angr/procedures/definitions/win32_icu.py +2088 -0
  695. angr/procedures/definitions/win32_ieframe.py +96 -0
  696. angr/procedures/definitions/win32_imagehlp.py +90 -0
  697. angr/procedures/definitions/win32_imgutil.py +56 -0
  698. angr/procedures/definitions/win32_imm32.py +202 -0
  699. angr/procedures/definitions/win32_infocardapi.py +72 -0
  700. angr/procedures/definitions/win32_inkobjcore.py +92 -0
  701. angr/procedures/definitions/win32_iphlpapi.py +440 -0
  702. angr/procedures/definitions/win32_iscsidsc.py +196 -0
  703. angr/procedures/definitions/win32_isolatedwindowsenvironmentutils.py +42 -0
  704. angr/procedures/definitions/win32_kernel32.py +3199 -0
  705. angr/procedures/definitions/win32_kernelbase.py +50 -0
  706. angr/procedures/definitions/win32_keycredmgr.py +46 -0
  707. angr/procedures/definitions/win32_ksproxy_ax.py +50 -0
  708. angr/procedures/definitions/win32_ksuser.py +54 -0
  709. angr/procedures/definitions/win32_ktmw32.py +116 -0
  710. angr/procedures/definitions/win32_licenseprotection.py +42 -0
  711. angr/procedures/definitions/win32_loadperf.py +62 -0
  712. angr/procedures/definitions/win32_magnification.py +76 -0
  713. angr/procedures/definitions/win32_mapi32.py +170 -0
  714. angr/procedures/definitions/win32_mdmlocalmanagement.py +44 -0
  715. angr/procedures/definitions/win32_mdmregistration.py +68 -0
  716. angr/procedures/definitions/win32_mf.py +162 -0
  717. angr/procedures/definitions/win32_mfcore.py +42 -0
  718. angr/procedures/definitions/win32_mfplat.py +328 -0
  719. angr/procedures/definitions/win32_mfplay.py +40 -0
  720. angr/procedures/definitions/win32_mfreadwrite.py +48 -0
  721. angr/procedures/definitions/win32_mfsensorgroup.py +58 -0
  722. angr/procedures/definitions/win32_mfsrcsnk.py +42 -0
  723. angr/procedures/definitions/win32_mgmtapi.py +56 -0
  724. angr/procedures/definitions/win32_mi.py +40 -0
  725. angr/procedures/definitions/win32_mmdevapi.py +40 -0
  726. angr/procedures/definitions/win32_mpr.py +132 -0
  727. angr/procedures/definitions/win32_mprapi.py +262 -0
  728. angr/procedures/definitions/win32_mqrt.py +106 -0
  729. angr/procedures/definitions/win32_mrmsupport.py +92 -0
  730. angr/procedures/definitions/win32_msacm32.py +122 -0
  731. angr/procedures/definitions/win32_msajapi.py +1132 -0
  732. angr/procedures/definitions/win32_mscms.py +196 -0
  733. angr/procedures/definitions/win32_mscoree.py +92 -0
  734. angr/procedures/definitions/win32_msctfmonitor.py +44 -0
  735. angr/procedures/definitions/win32_msdelta.py +70 -0
  736. angr/procedures/definitions/win32_msdmo.py +60 -0
  737. angr/procedures/definitions/win32_msdrm.py +206 -0
  738. angr/procedures/definitions/win32_msi.py +566 -0
  739. angr/procedures/definitions/win32_msimg32.py +44 -0
  740. angr/procedures/definitions/win32_mspatcha.py +70 -0
  741. angr/procedures/definitions/win32_mspatchc.py +56 -0
  742. angr/procedures/definitions/win32_msports.py +52 -0
  743. angr/procedures/definitions/win32_msrating.py +76 -0
  744. angr/procedures/definitions/win32_mssign32.py +58 -0
  745. angr/procedures/definitions/win32_mstask.py +42 -0
  746. angr/procedures/definitions/win32_msvfw32.py +124 -0
  747. angr/procedures/definitions/win32_mswsock.py +70 -0
  748. angr/procedures/definitions/win32_mtxdm.py +40 -0
  749. angr/procedures/definitions/win32_ncrypt.py +116 -0
  750. angr/procedures/definitions/win32_ndfapi.py +70 -0
  751. angr/procedures/definitions/win32_netapi32.py +450 -0
  752. angr/procedures/definitions/win32_netsh.py +54 -0
  753. angr/procedures/definitions/win32_netshell.py +42 -0
  754. angr/procedures/definitions/win32_newdev.py +60 -0
  755. angr/procedures/definitions/win32_ninput.py +98 -0
  756. angr/procedures/definitions/win32_normaliz.py +42 -0
  757. angr/procedures/definitions/win32_ntdll.py +185 -0
  758. angr/procedures/definitions/win32_ntdllk.py +40 -0
  759. angr/procedures/definitions/win32_ntdsapi.py +200 -0
  760. angr/procedures/definitions/win32_ntlanman.py +58 -0
  761. angr/procedures/definitions/win32_odbc32.py +406 -0
  762. angr/procedures/definitions/win32_odbcbcp.py +92 -0
  763. angr/procedures/definitions/win32_ole32.py +672 -0
  764. angr/procedures/definitions/win32_oleacc.py +72 -0
  765. angr/procedures/definitions/win32_oleaut32.py +848 -0
  766. angr/procedures/definitions/win32_oledlg.py +84 -0
  767. angr/procedures/definitions/win32_ondemandconnroutehelper.py +48 -0
  768. angr/procedures/definitions/win32_opengl32.py +748 -0
  769. angr/procedures/definitions/win32_opmxbox.py +44 -0
  770. angr/procedures/definitions/win32_p2p.py +254 -0
  771. angr/procedures/definitions/win32_p2pgraph.py +112 -0
  772. angr/procedures/definitions/win32_pdh.py +234 -0
  773. angr/procedures/definitions/win32_peerdist.py +94 -0
  774. angr/procedures/definitions/win32_powrprof.py +206 -0
  775. angr/procedures/definitions/win32_prntvpt.py +60 -0
  776. angr/procedures/definitions/win32_projectedfslib.py +76 -0
  777. angr/procedures/definitions/win32_propsys.py +474 -0
  778. angr/procedures/definitions/win32_psapi.py +92 -0
  779. angr/procedures/definitions/win32_quartz.py +42 -0
  780. angr/procedures/definitions/win32_query.py +46 -0
  781. angr/procedures/definitions/win32_qwave.py +60 -0
  782. angr/procedures/definitions/win32_rasapi32.py +206 -0
  783. angr/procedures/definitions/win32_rasdlg.py +50 -0
  784. angr/procedures/definitions/win32_resutils.py +278 -0
  785. angr/procedures/definitions/win32_rometadata.py +23 -0
  786. angr/procedures/definitions/win32_rpcns4.py +160 -0
  787. angr/procedures/definitions/win32_rpcproxy.py +46 -0
  788. angr/procedures/definitions/win32_rpcrt4.py +932 -0
  789. angr/procedures/definitions/win32_rstrtmgr.py +60 -0
  790. angr/procedures/definitions/win32_rtm.py +190 -0
  791. angr/procedures/definitions/win32_rtutils.py +120 -0
  792. angr/procedures/definitions/win32_rtworkq.py +104 -0
  793. angr/procedures/definitions/win32_sas.py +40 -0
  794. angr/procedures/definitions/win32_scarddlg.py +48 -0
  795. angr/procedures/definitions/win32_schannel.py +56 -0
  796. angr/procedures/definitions/win32_sechost.py +42 -0
  797. angr/procedures/definitions/win32_secur32.py +216 -0
  798. angr/procedures/definitions/win32_sensapi.py +44 -0
  799. angr/procedures/definitions/win32_sensorsutilsv2.py +118 -0
  800. angr/procedures/definitions/win32_setupapi.py +706 -0
  801. angr/procedures/definitions/win32_sfc.py +50 -0
  802. angr/procedures/definitions/win32_shdocvw.py +44 -0
  803. angr/procedures/definitions/win32_shell32.py +526 -0
  804. angr/procedures/definitions/win32_shlwapi.py +758 -0
  805. angr/procedures/definitions/win32_slc.py +102 -0
  806. angr/procedures/definitions/win32_slcext.py +46 -0
  807. angr/procedures/definitions/win32_slwga.py +40 -0
  808. angr/procedures/definitions/win32_snmpapi.py +90 -0
  809. angr/procedures/definitions/win32_spoolss.py +90 -0
  810. angr/procedures/definitions/win32_srclient.py +40 -0
  811. angr/procedures/definitions/win32_srpapi.py +60 -0
  812. angr/procedures/definitions/win32_sspicli.py +52 -0
  813. angr/procedures/definitions/win32_sti.py +40 -0
  814. angr/procedures/definitions/win32_t2embed.py +66 -0
  815. angr/procedures/definitions/win32_tapi32.py +536 -0
  816. angr/procedures/definitions/win32_tbs.py +66 -0
  817. angr/procedures/definitions/win32_tdh.py +92 -0
  818. angr/procedures/definitions/win32_tokenbinding.py +58 -0
  819. angr/procedures/definitions/win32_traffic.py +78 -0
  820. angr/procedures/definitions/win32_txfw32.py +56 -0
  821. angr/procedures/definitions/win32_ualapi.py +46 -0
  822. angr/procedures/definitions/win32_uiautomationcore.py +234 -0
  823. angr/procedures/definitions/win32_urlmon.py +192 -0
  824. angr/procedures/definitions/win32_user32.py +1565 -0
  825. angr/procedures/definitions/win32_userenv.py +126 -0
  826. angr/procedures/definitions/win32_usp10.py +118 -0
  827. angr/procedures/definitions/win32_uxtheme.py +192 -0
  828. angr/procedures/definitions/win32_verifier.py +40 -0
  829. angr/procedures/definitions/win32_version.py +66 -0
  830. angr/procedures/definitions/win32_vertdll.py +52 -0
  831. angr/procedures/definitions/win32_virtdisk.py +96 -0
  832. angr/procedures/definitions/win32_vmdevicehost.py +64 -0
  833. angr/procedures/definitions/win32_vmsavedstatedumpprovider.py +124 -0
  834. angr/procedures/definitions/win32_vssapi.py +40 -0
  835. angr/procedures/definitions/win32_wcmapi.py +48 -0
  836. angr/procedures/definitions/win32_wdsbp.py +52 -0
  837. angr/procedures/definitions/win32_wdsclientapi.py +112 -0
  838. angr/procedures/definitions/win32_wdsmc.py +50 -0
  839. angr/procedures/definitions/win32_wdspxe.py +100 -0
  840. angr/procedures/definitions/win32_wdstptc.py +64 -0
  841. angr/procedures/definitions/win32_webauthn.py +64 -0
  842. angr/procedures/definitions/win32_webservices.py +424 -0
  843. angr/procedures/definitions/win32_websocket.py +64 -0
  844. angr/procedures/definitions/win32_wecapi.py +68 -0
  845. angr/procedures/definitions/win32_wer.py +80 -0
  846. angr/procedures/definitions/win32_wevtapi.py +108 -0
  847. angr/procedures/definitions/win32_winbio.py +146 -0
  848. angr/procedures/definitions/win32_windows_ai_machinelearning.py +40 -0
  849. angr/procedures/definitions/win32_windows_data_pdf.py +23 -0
  850. angr/procedures/definitions/win32_windows_media_mediacontrol.py +54 -0
  851. angr/procedures/definitions/win32_windows_networking.py +40 -0
  852. angr/procedures/definitions/win32_windows_ui_xaml.py +42 -0
  853. angr/procedures/definitions/win32_windowscodecs.py +56 -0
  854. angr/procedures/definitions/win32_winfax.py +150 -0
  855. angr/procedures/definitions/win32_winhttp.py +150 -0
  856. angr/procedures/definitions/win32_winhvemulation.py +46 -0
  857. angr/procedures/definitions/win32_winhvplatform.py +170 -0
  858. angr/procedures/definitions/win32_wininet.py +630 -0
  859. angr/procedures/definitions/win32_winml.py +40 -0
  860. angr/procedures/definitions/win32_winmm.py +390 -0
  861. angr/procedures/definitions/win32_winscard.py +178 -0
  862. angr/procedures/definitions/win32_winspool.py +363 -0
  863. angr/procedures/definitions/win32_winspool_drv.py +382 -0
  864. angr/procedures/definitions/win32_wintrust.py +158 -0
  865. angr/procedures/definitions/win32_winusb.py +106 -0
  866. angr/procedures/definitions/win32_wlanapi.py +158 -0
  867. angr/procedures/definitions/win32_wlanui.py +40 -0
  868. angr/procedures/definitions/win32_wldap32.py +524 -0
  869. angr/procedures/definitions/win32_wldp.py +56 -0
  870. angr/procedures/definitions/win32_wmvcore.py +60 -0
  871. angr/procedures/definitions/win32_wnvapi.py +42 -0
  872. angr/procedures/definitions/win32_wofutil.py +60 -0
  873. angr/procedures/definitions/win32_ws2_32.py +358 -0
  874. angr/procedures/definitions/win32_wscapi.py +50 -0
  875. angr/procedures/definitions/win32_wsclient.py +44 -0
  876. angr/procedures/definitions/win32_wsdapi.py +102 -0
  877. angr/procedures/definitions/win32_wsmsvc.py +104 -0
  878. angr/procedures/definitions/win32_wsnmp32.py +136 -0
  879. angr/procedures/definitions/win32_wtsapi32.py +164 -0
  880. angr/procedures/definitions/win32_xaudio2_8.py +46 -0
  881. angr/procedures/definitions/win32_xinput1_4.py +52 -0
  882. angr/procedures/definitions/win32_xinputuap.py +35 -0
  883. angr/procedures/definitions/win32_xmllite.py +50 -0
  884. angr/procedures/definitions/win32_xolehlp.py +46 -0
  885. angr/procedures/definitions/win32_xpsprint.py +42 -0
  886. angr/procedures/glibc/__ctype_b_loc.py +22 -0
  887. angr/procedures/glibc/__ctype_tolower_loc.py +22 -0
  888. angr/procedures/glibc/__ctype_toupper_loc.py +22 -0
  889. angr/procedures/glibc/__errno_location.py +6 -0
  890. angr/procedures/glibc/__init__.py +3 -0
  891. angr/procedures/glibc/__libc_init.py +36 -0
  892. angr/procedures/glibc/__libc_start_main.py +294 -0
  893. angr/procedures/glibc/dynamic_loading.py +19 -0
  894. angr/procedures/glibc/scanf.py +10 -0
  895. angr/procedures/glibc/sscanf.py +5 -0
  896. angr/procedures/gnulib/__init__.py +3 -0
  897. angr/procedures/gnulib/xalloc_die.py +13 -0
  898. angr/procedures/gnulib/xstrtol_fatal.py +13 -0
  899. angr/procedures/java/__init__.py +38 -0
  900. angr/procedures/java/unconstrained.py +64 -0
  901. angr/procedures/java_io/__init__.py +0 -0
  902. angr/procedures/java_io/read.py +11 -0
  903. angr/procedures/java_io/write.py +16 -0
  904. angr/procedures/java_jni/__init__.py +475 -0
  905. angr/procedures/java_jni/array_operations.py +309 -0
  906. angr/procedures/java_jni/class_and_interface_operations.py +31 -0
  907. angr/procedures/java_jni/field_access.py +176 -0
  908. angr/procedures/java_jni/global_and_local_refs.py +56 -0
  909. angr/procedures/java_jni/method_calls.py +364 -0
  910. angr/procedures/java_jni/not_implemented.py +25 -0
  911. angr/procedures/java_jni/object_operations.py +95 -0
  912. angr/procedures/java_jni/string_operations.py +86 -0
  913. angr/procedures/java_jni/version_information.py +11 -0
  914. angr/procedures/java_lang/__init__.py +0 -0
  915. angr/procedures/java_lang/character.py +31 -0
  916. angr/procedures/java_lang/double.py +24 -0
  917. angr/procedures/java_lang/exit.py +12 -0
  918. angr/procedures/java_lang/getsimplename.py +15 -0
  919. angr/procedures/java_lang/integer.py +42 -0
  920. angr/procedures/java_lang/load_library.py +8 -0
  921. angr/procedures/java_lang/math.py +14 -0
  922. angr/procedures/java_lang/string.py +78 -0
  923. angr/procedures/java_lang/stringbuilder.py +43 -0
  924. angr/procedures/java_lang/system.py +17 -0
  925. angr/procedures/java_util/__init__.py +0 -0
  926. angr/procedures/java_util/collection.py +34 -0
  927. angr/procedures/java_util/iterator.py +45 -0
  928. angr/procedures/java_util/list.py +98 -0
  929. angr/procedures/java_util/map.py +132 -0
  930. angr/procedures/java_util/random.py +11 -0
  931. angr/procedures/java_util/scanner_nextline.py +22 -0
  932. angr/procedures/libc/__init__.py +3 -0
  933. angr/procedures/libc/abort.py +8 -0
  934. angr/procedures/libc/access.py +10 -0
  935. angr/procedures/libc/atoi.py +14 -0
  936. angr/procedures/libc/atol.py +12 -0
  937. angr/procedures/libc/calloc.py +7 -0
  938. angr/procedures/libc/closelog.py +9 -0
  939. angr/procedures/libc/err.py +13 -0
  940. angr/procedures/libc/error.py +55 -0
  941. angr/procedures/libc/exit.py +10 -0
  942. angr/procedures/libc/fclose.py +20 -0
  943. angr/procedures/libc/feof.py +19 -0
  944. angr/procedures/libc/fflush.py +15 -0
  945. angr/procedures/libc/fgetc.py +24 -0
  946. angr/procedures/libc/fgets.py +68 -0
  947. angr/procedures/libc/fopen.py +64 -0
  948. angr/procedures/libc/fprintf.py +24 -0
  949. angr/procedures/libc/fputc.py +22 -0
  950. angr/procedures/libc/fputs.py +23 -0
  951. angr/procedures/libc/fread.py +22 -0
  952. angr/procedures/libc/free.py +8 -0
  953. angr/procedures/libc/fscanf.py +20 -0
  954. angr/procedures/libc/fseek.py +32 -0
  955. angr/procedures/libc/ftell.py +21 -0
  956. angr/procedures/libc/fwrite.py +18 -0
  957. angr/procedures/libc/getchar.py +13 -0
  958. angr/procedures/libc/getdelim.py +96 -0
  959. angr/procedures/libc/getegid.py +7 -0
  960. angr/procedures/libc/geteuid.py +7 -0
  961. angr/procedures/libc/getgid.py +7 -0
  962. angr/procedures/libc/gets.py +66 -0
  963. angr/procedures/libc/getuid.py +7 -0
  964. angr/procedures/libc/malloc.py +11 -0
  965. angr/procedures/libc/memcmp.py +69 -0
  966. angr/procedures/libc/memcpy.py +37 -0
  967. angr/procedures/libc/memset.py +69 -0
  968. angr/procedures/libc/openlog.py +9 -0
  969. angr/procedures/libc/perror.py +12 -0
  970. angr/procedures/libc/printf.py +33 -0
  971. angr/procedures/libc/putchar.py +12 -0
  972. angr/procedures/libc/puts.py +16 -0
  973. angr/procedures/libc/rand.py +7 -0
  974. angr/procedures/libc/realloc.py +7 -0
  975. angr/procedures/libc/rewind.py +11 -0
  976. angr/procedures/libc/scanf.py +20 -0
  977. angr/procedures/libc/setbuf.py +8 -0
  978. angr/procedures/libc/setvbuf.py +6 -0
  979. angr/procedures/libc/snprintf.py +33 -0
  980. angr/procedures/libc/sprintf.py +22 -0
  981. angr/procedures/libc/srand.py +6 -0
  982. angr/procedures/libc/sscanf.py +13 -0
  983. angr/procedures/libc/stpcpy.py +18 -0
  984. angr/procedures/libc/strcat.py +13 -0
  985. angr/procedures/libc/strchr.py +44 -0
  986. angr/procedures/libc/strcmp.py +28 -0
  987. angr/procedures/libc/strcpy.py +13 -0
  988. angr/procedures/libc/strlen.py +99 -0
  989. angr/procedures/libc/strncat.py +18 -0
  990. angr/procedures/libc/strncmp.py +180 -0
  991. angr/procedures/libc/strncpy.py +18 -0
  992. angr/procedures/libc/strnlen.py +13 -0
  993. angr/procedures/libc/strstr.py +94 -0
  994. angr/procedures/libc/strtol.py +263 -0
  995. angr/procedures/libc/strtoul.py +9 -0
  996. angr/procedures/libc/system.py +12 -0
  997. angr/procedures/libc/time.py +9 -0
  998. angr/procedures/libc/tmpnam.py +19 -0
  999. angr/procedures/libc/tolower.py +7 -0
  1000. angr/procedures/libc/toupper.py +7 -0
  1001. angr/procedures/libc/ungetc.py +19 -0
  1002. angr/procedures/libc/vsnprintf.py +16 -0
  1003. angr/procedures/libc/wchar.py +15 -0
  1004. angr/procedures/libstdcpp/__init__.py +0 -0
  1005. angr/procedures/libstdcpp/_unwind_resume.py +10 -0
  1006. angr/procedures/libstdcpp/std____throw_bad_alloc.py +12 -0
  1007. angr/procedures/libstdcpp/std____throw_bad_cast.py +12 -0
  1008. angr/procedures/libstdcpp/std____throw_length_error.py +12 -0
  1009. angr/procedures/libstdcpp/std____throw_logic_error.py +12 -0
  1010. angr/procedures/libstdcpp/std__terminate.py +12 -0
  1011. angr/procedures/linux_kernel/__init__.py +3 -0
  1012. angr/procedures/linux_kernel/access.py +17 -0
  1013. angr/procedures/linux_kernel/arch_prctl.py +33 -0
  1014. angr/procedures/linux_kernel/arm_user_helpers.py +58 -0
  1015. angr/procedures/linux_kernel/brk.py +17 -0
  1016. angr/procedures/linux_kernel/cwd.py +27 -0
  1017. angr/procedures/linux_kernel/fstat.py +137 -0
  1018. angr/procedures/linux_kernel/fstat64.py +169 -0
  1019. angr/procedures/linux_kernel/futex.py +17 -0
  1020. angr/procedures/linux_kernel/getegid.py +16 -0
  1021. angr/procedures/linux_kernel/geteuid.py +16 -0
  1022. angr/procedures/linux_kernel/getgid.py +16 -0
  1023. angr/procedures/linux_kernel/getpid.py +13 -0
  1024. angr/procedures/linux_kernel/getrlimit.py +24 -0
  1025. angr/procedures/linux_kernel/gettid.py +8 -0
  1026. angr/procedures/linux_kernel/getuid.py +16 -0
  1027. angr/procedures/linux_kernel/iovec.py +43 -0
  1028. angr/procedures/linux_kernel/lseek.py +39 -0
  1029. angr/procedures/linux_kernel/mmap.py +15 -0
  1030. angr/procedures/linux_kernel/mprotect.py +41 -0
  1031. angr/procedures/linux_kernel/munmap.py +7 -0
  1032. angr/procedures/linux_kernel/openat.py +28 -0
  1033. angr/procedures/linux_kernel/set_tid_address.py +7 -0
  1034. angr/procedures/linux_kernel/sigaction.py +16 -0
  1035. angr/procedures/linux_kernel/sigprocmask.py +20 -0
  1036. angr/procedures/linux_kernel/stat.py +22 -0
  1037. angr/procedures/linux_kernel/sysinfo.py +58 -0
  1038. angr/procedures/linux_kernel/tgkill.py +7 -0
  1039. angr/procedures/linux_kernel/time.py +30 -0
  1040. angr/procedures/linux_kernel/uid.py +29 -0
  1041. angr/procedures/linux_kernel/uname.py +28 -0
  1042. angr/procedures/linux_kernel/unlink.py +22 -0
  1043. angr/procedures/linux_kernel/vsyscall.py +15 -0
  1044. angr/procedures/linux_loader/__init__.py +3 -0
  1045. angr/procedures/linux_loader/_dl_initial_error_catch_tsd.py +6 -0
  1046. angr/procedures/linux_loader/_dl_rtld_lock.py +14 -0
  1047. angr/procedures/linux_loader/sim_loader.py +53 -0
  1048. angr/procedures/linux_loader/tls.py +40 -0
  1049. angr/procedures/msvcr/__getmainargs.py +15 -0
  1050. angr/procedures/msvcr/__init__.py +4 -0
  1051. angr/procedures/msvcr/_initterm.py +37 -0
  1052. angr/procedures/msvcr/fmode.py +28 -0
  1053. angr/procedures/ntdll/__init__.py +0 -0
  1054. angr/procedures/ntdll/exceptions.py +57 -0
  1055. angr/procedures/posix/__init__.py +3 -0
  1056. angr/procedures/posix/accept.py +29 -0
  1057. angr/procedures/posix/bind.py +12 -0
  1058. angr/procedures/posix/bzero.py +6 -0
  1059. angr/procedures/posix/chroot.py +26 -0
  1060. angr/procedures/posix/close.py +9 -0
  1061. angr/procedures/posix/closedir.py +6 -0
  1062. angr/procedures/posix/dup.py +55 -0
  1063. angr/procedures/posix/fcntl.py +9 -0
  1064. angr/procedures/posix/fdopen.py +77 -0
  1065. angr/procedures/posix/fileno.py +17 -0
  1066. angr/procedures/posix/fork.py +10 -0
  1067. angr/procedures/posix/getenv.py +34 -0
  1068. angr/procedures/posix/gethostbyname.py +42 -0
  1069. angr/procedures/posix/getpass.py +18 -0
  1070. angr/procedures/posix/getsockopt.py +10 -0
  1071. angr/procedures/posix/htonl.py +11 -0
  1072. angr/procedures/posix/htons.py +11 -0
  1073. angr/procedures/posix/inet_ntoa.py +61 -0
  1074. angr/procedures/posix/listen.py +12 -0
  1075. angr/procedures/posix/mmap.py +140 -0
  1076. angr/procedures/posix/open.py +17 -0
  1077. angr/procedures/posix/opendir.py +9 -0
  1078. angr/procedures/posix/poll.py +54 -0
  1079. angr/procedures/posix/pread64.py +45 -0
  1080. angr/procedures/posix/pthread.py +87 -0
  1081. angr/procedures/posix/pwrite64.py +45 -0
  1082. angr/procedures/posix/read.py +12 -0
  1083. angr/procedures/posix/readdir.py +59 -0
  1084. angr/procedures/posix/recv.py +12 -0
  1085. angr/procedures/posix/recvfrom.py +12 -0
  1086. angr/procedures/posix/select.py +46 -0
  1087. angr/procedures/posix/send.py +22 -0
  1088. angr/procedures/posix/setsockopt.py +8 -0
  1089. angr/procedures/posix/sigaction.py +20 -0
  1090. angr/procedures/posix/sim_time.py +45 -0
  1091. angr/procedures/posix/sleep.py +7 -0
  1092. angr/procedures/posix/socket.py +18 -0
  1093. angr/procedures/posix/strcasecmp.py +23 -0
  1094. angr/procedures/posix/strdup.py +17 -0
  1095. angr/procedures/posix/strtok_r.py +65 -0
  1096. angr/procedures/posix/syslog.py +15 -0
  1097. angr/procedures/posix/tz.py +8 -0
  1098. angr/procedures/posix/unlink.py +10 -0
  1099. angr/procedures/posix/usleep.py +7 -0
  1100. angr/procedures/posix/write.py +12 -0
  1101. angr/procedures/procedure_dict.py +48 -0
  1102. angr/procedures/stubs/CallReturn.py +12 -0
  1103. angr/procedures/stubs/NoReturnUnconstrained.py +12 -0
  1104. angr/procedures/stubs/Nop.py +6 -0
  1105. angr/procedures/stubs/PathTerminator.py +8 -0
  1106. angr/procedures/stubs/Redirect.py +15 -0
  1107. angr/procedures/stubs/ReturnChar.py +10 -0
  1108. angr/procedures/stubs/ReturnUnconstrained.py +24 -0
  1109. angr/procedures/stubs/UnresolvableCallTarget.py +8 -0
  1110. angr/procedures/stubs/UnresolvableJumpTarget.py +8 -0
  1111. angr/procedures/stubs/UserHook.py +15 -0
  1112. angr/procedures/stubs/__init__.py +3 -0
  1113. angr/procedures/stubs/b64_decode.py +12 -0
  1114. angr/procedures/stubs/caller.py +13 -0
  1115. angr/procedures/stubs/crazy_scanf.py +17 -0
  1116. angr/procedures/stubs/format_parser.py +677 -0
  1117. angr/procedures/stubs/syscall_stub.py +26 -0
  1118. angr/procedures/testing/__init__.py +3 -0
  1119. angr/procedures/testing/manyargs.py +8 -0
  1120. angr/procedures/testing/retreg.py +8 -0
  1121. angr/procedures/tracer/__init__.py +4 -0
  1122. angr/procedures/tracer/random.py +8 -0
  1123. angr/procedures/tracer/receive.py +21 -0
  1124. angr/procedures/tracer/transmit.py +24 -0
  1125. angr/procedures/uclibc/__init__.py +3 -0
  1126. angr/procedures/uclibc/__uClibc_main.py +9 -0
  1127. angr/procedures/win32/EncodePointer.py +6 -0
  1128. angr/procedures/win32/ExitProcess.py +8 -0
  1129. angr/procedures/win32/GetCommandLine.py +11 -0
  1130. angr/procedures/win32/GetCurrentProcessId.py +6 -0
  1131. angr/procedures/win32/GetCurrentThreadId.py +6 -0
  1132. angr/procedures/win32/GetLastInputInfo.py +37 -0
  1133. angr/procedures/win32/GetModuleHandle.py +30 -0
  1134. angr/procedures/win32/GetProcessAffinityMask.py +34 -0
  1135. angr/procedures/win32/InterlockedExchange.py +14 -0
  1136. angr/procedures/win32/IsProcessorFeaturePresent.py +6 -0
  1137. angr/procedures/win32/VirtualAlloc.py +113 -0
  1138. angr/procedures/win32/VirtualProtect.py +59 -0
  1139. angr/procedures/win32/__init__.py +3 -0
  1140. angr/procedures/win32/critical_section.py +11 -0
  1141. angr/procedures/win32/dynamic_loading.py +103 -0
  1142. angr/procedures/win32/file_handles.py +47 -0
  1143. angr/procedures/win32/gethostbyname.py +10 -0
  1144. angr/procedures/win32/heap.py +42 -0
  1145. angr/procedures/win32/is_bad_ptr.py +25 -0
  1146. angr/procedures/win32/local_storage.py +85 -0
  1147. angr/procedures/win32/mutex.py +10 -0
  1148. angr/procedures/win32/sim_time.py +135 -0
  1149. angr/procedures/win32/system_paths.py +34 -0
  1150. angr/procedures/win32_kernel/ExAllocatePool.py +12 -0
  1151. angr/procedures/win32_kernel/ExFreePoolWithTag.py +7 -0
  1152. angr/procedures/win32_kernel/__init__.py +3 -0
  1153. angr/procedures/win_user32/__init__.py +0 -0
  1154. angr/procedures/win_user32/chars.py +12 -0
  1155. angr/procedures/win_user32/keyboard.py +13 -0
  1156. angr/procedures/win_user32/messagebox.py +49 -0
  1157. angr/project.py +834 -0
  1158. angr/protos/__init__.py +13 -0
  1159. angr/protos/cfg_pb2.py +31 -0
  1160. angr/protos/function_pb2.py +37 -0
  1161. angr/protos/primitives_pb2.py +124 -0
  1162. angr/protos/variables_pb2.py +126 -0
  1163. angr/protos/xrefs_pb2.py +34 -0
  1164. angr/py.typed +1 -0
  1165. angr/serializable.py +63 -0
  1166. angr/service.py +35 -0
  1167. angr/sim_manager.py +971 -0
  1168. angr/sim_options.py +444 -0
  1169. angr/sim_procedure.py +606 -0
  1170. angr/sim_state.py +1003 -0
  1171. angr/sim_state_options.py +409 -0
  1172. angr/sim_type.py +3372 -0
  1173. angr/sim_variable.py +562 -0
  1174. angr/simos/__init__.py +31 -0
  1175. angr/simos/cgc.py +152 -0
  1176. angr/simos/javavm.py +471 -0
  1177. angr/simos/linux.py +519 -0
  1178. angr/simos/simos.py +450 -0
  1179. angr/simos/snimmuc_nxp.py +152 -0
  1180. angr/simos/userland.py +163 -0
  1181. angr/simos/windows.py +562 -0
  1182. angr/slicer.py +353 -0
  1183. angr/state_hierarchy.py +262 -0
  1184. angr/state_plugins/__init__.py +29 -0
  1185. angr/state_plugins/callstack.py +404 -0
  1186. angr/state_plugins/cgc.py +153 -0
  1187. angr/state_plugins/concrete.py +297 -0
  1188. angr/state_plugins/debug_variables.py +194 -0
  1189. angr/state_plugins/filesystem.py +469 -0
  1190. angr/state_plugins/gdb.py +146 -0
  1191. angr/state_plugins/globals.py +62 -0
  1192. angr/state_plugins/heap/__init__.py +5 -0
  1193. angr/state_plugins/heap/heap_base.py +126 -0
  1194. angr/state_plugins/heap/heap_brk.py +134 -0
  1195. angr/state_plugins/heap/heap_freelist.py +210 -0
  1196. angr/state_plugins/heap/heap_libc.py +45 -0
  1197. angr/state_plugins/heap/heap_ptmalloc.py +646 -0
  1198. angr/state_plugins/heap/utils.py +21 -0
  1199. angr/state_plugins/history.py +548 -0
  1200. angr/state_plugins/inspect.py +376 -0
  1201. angr/state_plugins/javavm_classloader.py +133 -0
  1202. angr/state_plugins/jni_references.py +93 -0
  1203. angr/state_plugins/libc.py +1263 -0
  1204. angr/state_plugins/light_registers.py +170 -0
  1205. angr/state_plugins/log.py +85 -0
  1206. angr/state_plugins/loop_data.py +92 -0
  1207. angr/state_plugins/plugin.py +155 -0
  1208. angr/state_plugins/posix.py +709 -0
  1209. angr/state_plugins/preconstrainer.py +195 -0
  1210. angr/state_plugins/scratch.py +175 -0
  1211. angr/state_plugins/sim_action.py +334 -0
  1212. angr/state_plugins/sim_action_object.py +148 -0
  1213. angr/state_plugins/sim_event.py +58 -0
  1214. angr/state_plugins/solver.py +1129 -0
  1215. angr/state_plugins/symbolizer.py +292 -0
  1216. angr/state_plugins/trace_additions.py +752 -0
  1217. angr/state_plugins/uc_manager.py +85 -0
  1218. angr/state_plugins/unicorn_engine.py +1899 -0
  1219. angr/state_plugins/view.py +341 -0
  1220. angr/storage/__init__.py +9 -0
  1221. angr/storage/file.py +1219 -0
  1222. angr/storage/memory_mixins/__init__.py +393 -0
  1223. angr/storage/memory_mixins/__init__.pyi +49 -0
  1224. angr/storage/memory_mixins/actions_mixin.py +69 -0
  1225. angr/storage/memory_mixins/address_concretization_mixin.py +388 -0
  1226. angr/storage/memory_mixins/bvv_conversion_mixin.py +74 -0
  1227. angr/storage/memory_mixins/clouseau_mixin.py +131 -0
  1228. angr/storage/memory_mixins/conditional_store_mixin.py +24 -0
  1229. angr/storage/memory_mixins/convenient_mappings_mixin.py +257 -0
  1230. angr/storage/memory_mixins/default_filler_mixin.py +146 -0
  1231. angr/storage/memory_mixins/dirty_addrs_mixin.py +9 -0
  1232. angr/storage/memory_mixins/hex_dumper_mixin.py +85 -0
  1233. angr/storage/memory_mixins/javavm_memory/__init__.py +1 -0
  1234. angr/storage/memory_mixins/javavm_memory/javavm_memory_mixin.py +394 -0
  1235. angr/storage/memory_mixins/keyvalue_memory/__init__.py +1 -0
  1236. angr/storage/memory_mixins/keyvalue_memory/keyvalue_memory_mixin.py +36 -0
  1237. angr/storage/memory_mixins/label_merger_mixin.py +31 -0
  1238. angr/storage/memory_mixins/multi_value_merger_mixin.py +68 -0
  1239. angr/storage/memory_mixins/name_resolution_mixin.py +70 -0
  1240. angr/storage/memory_mixins/paged_memory/__init__.py +0 -0
  1241. angr/storage/memory_mixins/paged_memory/page_backer_mixins.py +266 -0
  1242. angr/storage/memory_mixins/paged_memory/paged_memory_mixin.py +750 -0
  1243. angr/storage/memory_mixins/paged_memory/paged_memory_multivalue_mixin.py +63 -0
  1244. angr/storage/memory_mixins/paged_memory/pages/__init__.py +33 -0
  1245. angr/storage/memory_mixins/paged_memory/pages/cooperation.py +330 -0
  1246. angr/storage/memory_mixins/paged_memory/pages/history_tracking_mixin.py +87 -0
  1247. angr/storage/memory_mixins/paged_memory/pages/ispo_mixin.py +53 -0
  1248. angr/storage/memory_mixins/paged_memory/pages/list_page.py +346 -0
  1249. angr/storage/memory_mixins/paged_memory/pages/multi_values.py +290 -0
  1250. angr/storage/memory_mixins/paged_memory/pages/mv_list_page.py +434 -0
  1251. angr/storage/memory_mixins/paged_memory/pages/permissions_mixin.py +33 -0
  1252. angr/storage/memory_mixins/paged_memory/pages/refcount_mixin.py +51 -0
  1253. angr/storage/memory_mixins/paged_memory/pages/ultra_page.py +468 -0
  1254. angr/storage/memory_mixins/paged_memory/privileged_mixin.py +36 -0
  1255. angr/storage/memory_mixins/paged_memory/stack_allocation_mixin.py +73 -0
  1256. angr/storage/memory_mixins/regioned_memory/__init__.py +6 -0
  1257. angr/storage/memory_mixins/regioned_memory/abstract_address_descriptor.py +35 -0
  1258. angr/storage/memory_mixins/regioned_memory/abstract_merger_mixin.py +43 -0
  1259. angr/storage/memory_mixins/regioned_memory/region_category_mixin.py +7 -0
  1260. angr/storage/memory_mixins/regioned_memory/region_data.py +245 -0
  1261. angr/storage/memory_mixins/regioned_memory/region_meta_mixin.py +125 -0
  1262. angr/storage/memory_mixins/regioned_memory/regioned_address_concretization_mixin.py +118 -0
  1263. angr/storage/memory_mixins/regioned_memory/regioned_memory_mixin.py +462 -0
  1264. angr/storage/memory_mixins/regioned_memory/static_find_mixin.py +70 -0
  1265. angr/storage/memory_mixins/simple_interface_mixin.py +73 -0
  1266. angr/storage/memory_mixins/simplification_mixin.py +13 -0
  1267. angr/storage/memory_mixins/size_resolution_mixin.py +140 -0
  1268. angr/storage/memory_mixins/slotted_memory.py +140 -0
  1269. angr/storage/memory_mixins/smart_find_mixin.py +159 -0
  1270. angr/storage/memory_mixins/symbolic_merger_mixin.py +12 -0
  1271. angr/storage/memory_mixins/top_merger_mixin.py +24 -0
  1272. angr/storage/memory_mixins/underconstrained_mixin.py +67 -0
  1273. angr/storage/memory_mixins/unwrapper_mixin.py +26 -0
  1274. angr/storage/memory_object.py +194 -0
  1275. angr/storage/pcap.py +65 -0
  1276. angr/tablespecs.py +90 -0
  1277. angr/utils/__init__.py +33 -0
  1278. angr/utils/algo.py +33 -0
  1279. angr/utils/constants.py +7 -0
  1280. angr/utils/cowdict.py +64 -0
  1281. angr/utils/dynamic_dictlist.py +92 -0
  1282. angr/utils/enums_conv.py +80 -0
  1283. angr/utils/env.py +11 -0
  1284. angr/utils/formatting.py +124 -0
  1285. angr/utils/funcid.py +133 -0
  1286. angr/utils/graph.py +822 -0
  1287. angr/utils/lazy_import.py +12 -0
  1288. angr/utils/library.py +214 -0
  1289. angr/utils/loader.py +55 -0
  1290. angr/utils/mp.py +64 -0
  1291. angr/utils/segment_list.py +558 -0
  1292. angr/utils/timing.py +45 -0
  1293. angr/utils/typing.py +17 -0
  1294. angr/vaults.py +370 -0
  1295. angr-9.2.103.dist-info/LICENSE +24 -0
  1296. angr-9.2.103.dist-info/METADATA +119 -0
  1297. angr-9.2.103.dist-info/RECORD +1300 -0
  1298. angr-9.2.103.dist-info/WHEEL +5 -0
  1299. angr-9.2.103.dist-info/entry_points.txt +2 -0
  1300. angr-9.2.103.dist-info/top_level.txt +1 -0
angr/analyses/ddg.py ADDED
@@ -0,0 +1,1695 @@
1
+ import logging
2
+ from collections import defaultdict
3
+
4
+ import networkx
5
+ import pyvex
6
+ from . import Analysis
7
+
8
+ from ..code_location import CodeLocation
9
+ from ..errors import SimSolverModeError, SimUnsatError, AngrDDGError
10
+ from ..sim_variable import (
11
+ SimRegisterVariable,
12
+ SimMemoryVariable,
13
+ SimTemporaryVariable,
14
+ SimConstantVariable,
15
+ SimStackVariable,
16
+ )
17
+
18
+ l = logging.getLogger(name=__name__)
19
+
20
+
21
+ class AST:
22
+ """
23
+ A mini implementation for AST
24
+ """
25
+
26
+ def __init__(self, op, *operands):
27
+ self.op = op
28
+ self.operands = tuple(operands)
29
+
30
+ def __hash__(self):
31
+ return hash((self.op, self.operands))
32
+
33
+ def __eq__(self, other):
34
+ return type(other) is AST and other.op == self.op and other.operands == self.operands
35
+
36
+ def __repr__(self):
37
+ def _short_repr(a):
38
+ return a.short_repr
39
+
40
+ if len(self.operands) == 1:
41
+ return f"{self.op}{_short_repr(self.operands[0])}"
42
+ elif len(self.operands) == 2:
43
+ return f"{_short_repr(self.operands[0])} {self.op} {_short_repr(self.operands[1])}"
44
+ else:
45
+ return f"{self.op} ({self.operands})"
46
+
47
+
48
+ class ProgramVariable:
49
+ """
50
+ Describes a variable in the program at a specific location.
51
+
52
+ :ivar SimVariable variable: The variable.
53
+ :ivar CodeLocation location: Location of the variable.
54
+ """
55
+
56
+ def __init__(self, variable, location, initial=False, arch=None):
57
+ self.variable = variable
58
+ self.location = location
59
+ self.initial = initial
60
+ self._arch = arch # for pretty printing
61
+
62
+ def __hash__(self):
63
+ return hash((self.variable, self.location))
64
+
65
+ def __eq__(self, other):
66
+ if not isinstance(other, ProgramVariable):
67
+ return False
68
+
69
+ return self.variable == other.variable and self.location == other.location
70
+
71
+ def __ne__(self, other):
72
+ return not self.__eq__(other)
73
+
74
+ def __repr__(self):
75
+ if self._arch is not None:
76
+ s = f"{{{self.variable} @ {self.location}}}"
77
+ else:
78
+ s = f"{{{self.variable} @ {self.location}}}"
79
+ return s
80
+
81
+ @property
82
+ def short_repr(self):
83
+ if self._arch is not None:
84
+ s = f"{{{self.variable}@{self.location.short_repr}}}"
85
+ else:
86
+ s = f"{{{self.variable}@{self.location.short_repr}}}"
87
+ return s
88
+
89
+
90
+ class DDGJob:
91
+ def __init__(self, cfg_node, call_depth):
92
+ self.cfg_node = cfg_node
93
+ self.call_depth = call_depth
94
+
95
+ def __repr__(self):
96
+ return "<DDGJob %s, call_depth %d>" % (self.cfg_node, self.call_depth)
97
+
98
+
99
+ class LiveDefinitions:
100
+ """
101
+ A collection of live definitions with some handy interfaces for definition killing and lookups.
102
+ """
103
+
104
+ def __init__(self):
105
+ """
106
+ Constructor.
107
+ """
108
+
109
+ # byte-to-byte mappings
110
+ # TODO: make it copy-on-write in order to save memory.
111
+ # TODO: options are either collections.ChainMap or a modified version of simuvex.SimPagedMemory
112
+ self._memory_map = defaultdict(set)
113
+ self._register_map = defaultdict(set)
114
+ self._defs = defaultdict(set)
115
+
116
+ #
117
+ # Overridden methods
118
+ #
119
+
120
+ def __contains__(self, variable):
121
+ return variable in self._defs
122
+
123
+ #
124
+ # Public methods
125
+ #
126
+
127
+ def branch(self):
128
+ """
129
+ Create a branch of the current live definition collection.
130
+
131
+ :return: A new LiveDefinition instance.
132
+ :rtype: angr.analyses.ddg.LiveDefinitions
133
+ """
134
+
135
+ ld = LiveDefinitions()
136
+ ld._memory_map = self._memory_map.copy()
137
+ ld._register_map = self._register_map.copy()
138
+ ld._defs = self._defs.copy()
139
+
140
+ return ld
141
+
142
+ def copy(self):
143
+ """
144
+ Make a hard copy of `self`.
145
+
146
+ :return: A new LiveDefinition instance.
147
+ :rtype: angr.analyses.ddg.LiveDefinitions
148
+ """
149
+
150
+ ld = LiveDefinitions()
151
+ ld._memory_map = self._memory_map.copy()
152
+ ld._register_map = self._register_map.copy()
153
+ ld._defs = self._defs.copy()
154
+
155
+ return ld
156
+
157
+ def add_def(self, variable, location, size_threshold=32):
158
+ """
159
+ Add a new definition of variable.
160
+
161
+ :param SimVariable variable: The variable being defined.
162
+ :param CodeLocation location: Location of the varaible being defined.
163
+ :param int size_threshold: The maximum bytes to consider for the variable.
164
+ :return: True if the definition was new, False otherwise
165
+ :rtype: bool
166
+ """
167
+
168
+ new_defs_added = False
169
+
170
+ if isinstance(variable, SimRegisterVariable):
171
+ if variable.reg is None:
172
+ l.warning("add_def: Got a None for a SimRegisterVariable. Consider fixing.")
173
+ return new_defs_added
174
+
175
+ size = min(variable.size, size_threshold)
176
+ offset = variable.reg
177
+ while offset < variable.reg + size:
178
+ if location not in self._register_map[offset]:
179
+ new_defs_added = True
180
+ self._register_map[offset].add(location)
181
+ offset += 1
182
+
183
+ self._defs[variable].add(location)
184
+
185
+ elif isinstance(variable, SimMemoryVariable):
186
+ size = min(variable.size, size_threshold)
187
+ offset = variable.addr
188
+ while offset < variable.addr + size:
189
+ if location not in self._memory_map[offset]:
190
+ new_defs_added = True
191
+ self._memory_map[offset].add(location)
192
+ offset += 1
193
+
194
+ self._defs[variable].add(location)
195
+
196
+ else:
197
+ l.error('Unsupported variable type "%s".', type(variable))
198
+
199
+ return new_defs_added
200
+
201
+ def add_defs(self, variable, locations, size_threshold=32):
202
+ """
203
+ Add a collection of new definitions of a variable.
204
+
205
+ :param SimVariable variable: The variable being defined.
206
+ :param iterable locations: A collection of locations where the variable was defined.
207
+ :param int size_threshold: The maximum bytes to consider for the variable.
208
+ :return: True if any of the definition was new, False otherwise
209
+ :rtype: bool
210
+ """
211
+
212
+ new_defs_added = False
213
+
214
+ for loc in locations:
215
+ new_defs_added |= self.add_def(variable, loc, size_threshold=size_threshold)
216
+
217
+ return new_defs_added
218
+
219
+ def kill_def(self, variable, location, size_threshold=32):
220
+ """
221
+ Add a new definition for variable and kill all previous definitions.
222
+
223
+ :param SimVariable variable: The variable to kill.
224
+ :param CodeLocation location: The location where this variable is defined.
225
+ :param int size_threshold: The maximum bytes to consider for the variable.
226
+ :return: None
227
+ """
228
+
229
+ if isinstance(variable, SimRegisterVariable):
230
+ if variable.reg is None:
231
+ l.warning("kill_def: Got a None for a SimRegisterVariable. Consider fixing.")
232
+ return None
233
+
234
+ size = min(variable.size, size_threshold)
235
+ offset = variable.reg
236
+ while offset < variable.reg + size:
237
+ self._register_map[offset] = {location}
238
+ offset += 1
239
+
240
+ self._defs[variable] = {location}
241
+
242
+ elif isinstance(variable, SimMemoryVariable):
243
+ size = min(variable.size, size_threshold)
244
+ offset = variable.addr
245
+ while offset < variable.addr + size:
246
+ self._memory_map[offset] = {location}
247
+ offset += 1
248
+
249
+ self._defs[variable] = {location}
250
+
251
+ else:
252
+ l.error('Unsupported variable type "%s".', type(variable))
253
+
254
+ def lookup_defs(self, variable, size_threshold=32):
255
+ """
256
+ Find all definitions of the variable.
257
+
258
+ :param SimVariable variable: The variable to lookup for.
259
+ :param int size_threshold: The maximum bytes to consider for the variable. For example, if the variable is 100
260
+ byte long, only the first `size_threshold` bytes are considered.
261
+ :return: A set of code locations where the variable is defined.
262
+ :rtype: set
263
+ """
264
+
265
+ live_def_locs = set()
266
+
267
+ if isinstance(variable, SimRegisterVariable):
268
+ if variable.reg is None:
269
+ l.warning("lookup_defs: Got a None for a SimRegisterVariable. Consider fixing.")
270
+ return live_def_locs
271
+
272
+ size = min(variable.size, size_threshold)
273
+ offset = variable.reg
274
+ while offset < variable.reg + size:
275
+ if offset in self._register_map:
276
+ live_def_locs |= self._register_map[offset]
277
+ offset += 1
278
+
279
+ elif isinstance(variable, SimMemoryVariable):
280
+ size = min(variable.size, size_threshold)
281
+ offset = variable.addr
282
+ while offset < variable.addr + size:
283
+ if offset in self._memory_map:
284
+ live_def_locs |= self._memory_map[offset]
285
+ offset += 1
286
+
287
+ else:
288
+ # umm unsupported variable type
289
+ l.error('Unsupported variable type "%s".', type(variable))
290
+
291
+ return live_def_locs
292
+
293
+ def items(self):
294
+ """
295
+ An iterator that returns all live definitions.
296
+
297
+ :return: The iterator.
298
+ :rtype: iter
299
+ """
300
+
301
+ return self._defs.items()
302
+
303
+ def itervariables(self):
304
+ """
305
+ An iterator that returns all live variables.
306
+
307
+ :return: The iterator.
308
+ :rtype: iter
309
+ """
310
+
311
+ return self._defs.keys()
312
+
313
+
314
+ class DDGViewItem:
315
+ def __init__(self, ddg, variable, simplified=False):
316
+ self._ddg = ddg
317
+ self._variable = variable
318
+ self._simplified = simplified
319
+
320
+ @property
321
+ def depends_on(self):
322
+ graph = self._ddg.simplified_data_graph if self._simplified else self._ddg.data_graph
323
+ if self._variable in graph:
324
+ return [
325
+ self._to_viewitem(n)
326
+ for n, _, data in graph.in_edges(self._variable, data=True)
327
+ if data.get("type", None) != "kill"
328
+ ]
329
+ return None
330
+
331
+ @property
332
+ def dependents(self):
333
+ graph = self._ddg.simplified_data_graph if self._simplified else self._ddg.data_graph
334
+ if self._variable in graph:
335
+ return [
336
+ self._to_viewitem(n)
337
+ for _, n, data in graph.in_edges(self._variable, data=True)
338
+ if data.get("type", None) != "kill"
339
+ ]
340
+ return None
341
+
342
+ def __repr__(self):
343
+ s = "[%s, %d dependents, depends on %d]" % (
344
+ self._variable,
345
+ len(self.dependents),
346
+ len(self.depends_on),
347
+ )
348
+ return s
349
+
350
+ def __eq__(self, other):
351
+ return (
352
+ isinstance(other, DDGViewItem)
353
+ and self._variable == other._variable
354
+ and self._simplified == other._simplified
355
+ )
356
+
357
+ def __hash__(self):
358
+ return hash(
359
+ (
360
+ self._ddg,
361
+ self._variable,
362
+ self._simplified,
363
+ )
364
+ )
365
+
366
+ def _to_viewitem(self, prog_var):
367
+ """
368
+ Convert a ProgramVariable instance to a DDGViewItem object.
369
+
370
+ :param ProgramVariable prog_var: The ProgramVariable object to convert.
371
+ :return: The converted DDGViewItem object.
372
+ :rtype: DDGViewItem
373
+ """
374
+
375
+ return DDGViewItem(self._ddg, prog_var, simplified=self._simplified)
376
+
377
+
378
+ class DDGViewInstruction:
379
+ def __init__(self, cfg, ddg, insn_addr, simplified=False):
380
+ self._cfg = cfg
381
+ self._ddg = ddg
382
+ self._insn_addr = insn_addr
383
+ self._simplified = simplified
384
+
385
+ # shorthand
386
+ self._project = self._ddg.project
387
+
388
+ def __getitem__(self, key):
389
+ arch = self._project.arch
390
+ if key in arch.registers:
391
+ # it's a register name
392
+ reg_offset, size = arch.registers[key]
393
+
394
+ # obtain the CFGNode
395
+ cfg_node = self._cfg.model.get_any_node(self._insn_addr, anyaddr=True)
396
+ if cfg_node is None:
397
+ # not found
398
+ raise KeyError("CFGNode for instruction %#x is not found." % self._insn_addr)
399
+
400
+ # determine the statement ID
401
+ vex_block = self._project.factory.block(
402
+ cfg_node.addr, size=cfg_node.size, opt_level=self._cfg._iropt_level
403
+ ).vex
404
+ stmt_idx = None
405
+ insn_addr = cfg_node.addr
406
+ for i, stmt in enumerate(vex_block.statements):
407
+ if isinstance(stmt, pyvex.IRStmt.IMark):
408
+ insn_addr = stmt.addr + stmt.delta
409
+ elif insn_addr == self._insn_addr:
410
+ if isinstance(stmt, pyvex.IRStmt.Put) and stmt.offset == reg_offset:
411
+ stmt_idx = i
412
+ break
413
+ elif insn_addr > self._insn_addr:
414
+ break
415
+
416
+ if stmt_idx is None:
417
+ raise KeyError("Cannot find the statement.")
418
+
419
+ # create a program variable
420
+ variable = SimRegisterVariable(reg_offset, size)
421
+ location = CodeLocation(cfg_node.addr, stmt_idx, ins_addr=self._insn_addr)
422
+ pv = ProgramVariable(variable, location, arch=self._project.arch)
423
+
424
+ return DDGViewItem(self._ddg, pv, simplified=self._simplified)
425
+
426
+ @property
427
+ def definitions(self) -> list[DDGViewItem]:
428
+ """
429
+ Get all definitions located at the current instruction address.
430
+
431
+ :return: A list of ProgramVariable instances.
432
+ """
433
+
434
+ defs = set()
435
+
436
+ if self._simplified:
437
+ graph = self._ddg.simplified_data_graph
438
+ else:
439
+ graph = self._ddg.data_graph
440
+
441
+ n: ProgramVariable
442
+ for n in graph.nodes():
443
+ if n.location.ins_addr == self._insn_addr:
444
+ defs.add(DDGViewItem(self._ddg, n, simplified=self._simplified))
445
+
446
+ return list(defs)
447
+
448
+
449
+ class DDGView:
450
+ """
451
+ A view of the data dependence graph.
452
+ """
453
+
454
+ def __init__(self, cfg, ddg, simplified=False):
455
+ self._cfg = cfg
456
+ self._ddg = ddg
457
+ self._simplified = simplified
458
+
459
+ # shorthand
460
+ self._project = self._ddg.project
461
+
462
+ def __getitem__(self, key):
463
+ if isinstance(key, int):
464
+ # instruction address
465
+ return DDGViewInstruction(self._cfg, self._ddg, key, simplified=self._simplified)
466
+
467
+
468
+ class DDG(Analysis):
469
+ """
470
+ This is a fast data dependence graph directly generated from our CFG analysis result. The only reason for its
471
+ existence is the speed. There is zero guarantee for being sound or accurate. You are supposed to use it only when
472
+ you want to track the simplest data dependence, and you do not care about soundness or accuracy.
473
+
474
+ For a better data dependence graph, please consider performing a better static analysis first (like Value-set
475
+ Analysis), and then construct a dependence graph on top of the analysis result (for example, the VFG in angr).
476
+
477
+ The DDG is based on a CFG, which should ideally be a CFGEmulated generated with the following options:
478
+
479
+ - keep_state=True to keep all input states
480
+ - state_add_options=angr.options.refs to store memory, register, and temporary value accesses
481
+
482
+ You may want to consider a high value for context_sensitivity_level as well when generating the CFG.
483
+
484
+ Also note that since we are using states from CFG, any improvement in analysis performed on CFG (like a points-to
485
+ analysis) will directly benefit the DDG.
486
+ """
487
+
488
+ def __init__(self, cfg, start=None, call_depth=None, block_addrs=None):
489
+ """
490
+ :param cfg: Control flow graph. Please make sure each node has an associated `state` with it, e.g. by
491
+ passing the keep_state=True and state_add_options=angr.options.refs arguments to
492
+ CFGEmulated.
493
+ :param start: An address, Specifies where we start the generation of this data dependence graph.
494
+ :param call_depth: None or integers. A non-negative integer specifies how deep we would like to track in the
495
+ call tree. None disables call_depth limit.
496
+ :param iterable or None block_addrs: A collection of block addresses that the DDG analysis should be performed
497
+ on.
498
+ """
499
+
500
+ # Sanity check
501
+ if not cfg._keep_state:
502
+ raise AngrDDGError('CFG must have "keep_state" set to True.')
503
+
504
+ self._cfg = cfg
505
+ self._start = self.project.entry if start is None else start
506
+ self._call_depth = call_depth
507
+ self._block_addrs = block_addrs
508
+
509
+ # analysis output
510
+ self._stmt_graph = networkx.DiGraph()
511
+ self._data_graph = networkx.DiGraph()
512
+ self._simplified_data_graph = None
513
+
514
+ self._ast_graph = networkx.DiGraph() # A mapping of ProgramVariable to ASTs
515
+
516
+ self._symbolic_mem_ops = set()
517
+
518
+ # Data dependency graph per function
519
+ self._function_data_dependencies = None
520
+
521
+ self.view = DDGView(self._cfg, self, simplified=False)
522
+ self.simple_view = DDGView(self._cfg, self, simplified=True)
523
+
524
+ # Local variables
525
+ self._live_defs = None
526
+ self._temp_variables = None
527
+ self._temp_register_symbols = None
528
+ self._temp_edges = None
529
+ self._temp_register_symbols = None
530
+ self._variables_per_statement = None
531
+ self._custom_data_per_statement = None
532
+ self._register_edges = None
533
+
534
+ # Begin construction!
535
+ self._construct()
536
+
537
+ #
538
+ # Properties
539
+ #
540
+
541
+ @property
542
+ def graph(self):
543
+ """
544
+ :returns: A networkx DiGraph instance representing the dependence relations between statements.
545
+ :rtype: networkx.DiGraph
546
+ """
547
+
548
+ return self._stmt_graph
549
+
550
+ @property
551
+ def data_graph(self):
552
+ """
553
+ Get the data dependence graph.
554
+
555
+ :return: A networkx DiGraph instance representing data dependence.
556
+ :rtype: networkx.DiGraph
557
+ """
558
+
559
+ return self._data_graph
560
+
561
+ @property
562
+ def simplified_data_graph(self):
563
+ """
564
+
565
+ :return:
566
+ """
567
+
568
+ if self._simplified_data_graph is None:
569
+ self._simplified_data_graph = self._simplify_data_graph(self.data_graph)
570
+
571
+ return self._simplified_data_graph
572
+
573
+ @property
574
+ def ast_graph(self):
575
+ return self._ast_graph
576
+
577
+ #
578
+ # Public methods
579
+ #
580
+
581
+ def pp(self):
582
+ """
583
+ Pretty printing.
584
+ """
585
+ # TODO: make it prettier
586
+ for src, dst, data in self.graph.edges(data=True):
587
+ print(f"{src} <-- {dst}, {data}")
588
+
589
+ def dbg_repr(self):
590
+ """
591
+ Representation for debugging.
592
+ """
593
+ # TODO:
594
+ return str(self.graph)
595
+
596
+ def __contains__(self, code_location):
597
+ """
598
+ Returns whether `code_location` is in the graph.
599
+
600
+ :param code_location: A CodeLocation instance.
601
+ :returns: True/False
602
+ """
603
+
604
+ return code_location in self.graph
605
+
606
+ def get_predecessors(self, code_location):
607
+ """
608
+ Returns all predecessors of the code location.
609
+
610
+ :param code_location: A CodeLocation instance.
611
+ :returns: A list of all predecessors.
612
+ """
613
+
614
+ return self.graph.predecessors(code_location)
615
+
616
+ def function_dependency_graph(self, func):
617
+ """
618
+ Get a dependency graph for the function `func`.
619
+
620
+ :param func: The Function object in CFG.function_manager.
621
+ :returns: A networkx.DiGraph instance.
622
+ """
623
+
624
+ if self._function_data_dependencies is None:
625
+ self._build_function_dependency_graphs()
626
+
627
+ if func in self._function_data_dependencies:
628
+ return self._function_data_dependencies[func]
629
+
630
+ # Not found
631
+ return None
632
+
633
+ def data_sub_graph(self, pv, simplified=True, killing_edges=False, excluding_types=None):
634
+ """
635
+ Get a subgraph from the data graph or the simplified data graph that starts from node pv.
636
+
637
+ :param ProgramVariable pv: The starting point of the subgraph.
638
+ :param bool simplified: When True, the simplified data graph is used, otherwise the data graph is used.
639
+ :param bool killing_edges: Are killing edges included or not.
640
+ :param iterable excluding_types: Excluding edges whose types are among those excluded types.
641
+ :return: A subgraph.
642
+ :rtype: networkx.MultiDiGraph
643
+ """
644
+
645
+ result = networkx.MultiDiGraph()
646
+ result.add_node(pv)
647
+
648
+ base_graph = self.simplified_data_graph if simplified else self.data_graph
649
+ if pv not in base_graph:
650
+ return result
651
+
652
+ # traverse all edges and add them to the result graph if needed
653
+ queue = [pv]
654
+ traversed = set()
655
+ while queue:
656
+ elem = queue[0]
657
+ queue = queue[1:]
658
+ if elem in traversed:
659
+ continue
660
+ traversed.add(elem)
661
+
662
+ out_edges = base_graph.out_edges(elem, data=True)
663
+
664
+ if not killing_edges:
665
+ # remove killing edges
666
+ out_edges = [(a, b, data) for a, b, data in out_edges if "type" not in data or data["type"] != "kill"]
667
+
668
+ if excluding_types:
669
+ out_edges = [
670
+ (a, b, data)
671
+ for a, b, data in out_edges
672
+ if "type" not in data or data["type"] not in excluding_types
673
+ ]
674
+
675
+ for src, dst, data in out_edges:
676
+ result.add_edge(src, dst, **data)
677
+
678
+ if dst not in traversed:
679
+ queue.append(dst)
680
+
681
+ return result
682
+
683
+ #
684
+ # Private methods
685
+ #
686
+
687
+ def _construct(self):
688
+ """
689
+ Construct the data dependence graph.
690
+
691
+ We track the following types of dependence:
692
+ - (Intra-IRSB) temporary variable dependencies
693
+ - Register dependencies
694
+ - Memory dependencies, although it's very limited. See below.
695
+
696
+ We track the following types of memory access:
697
+ - (Intra-functional) Stack read/write.
698
+ Trace changes of stack pointers inside a function, and the dereferences of stack pointers.
699
+ - (Inter-functional) Stack read/write.
700
+ - (Global) Static memory positions.
701
+ Keep a map of all accessible memory positions to their source statements per function. After that, we
702
+ traverse the CFG and link each pair of reads/writes together in the order of control-flow.
703
+
704
+ We do not track the following types of memory access
705
+ - Symbolic memory access
706
+ Well, they cannot be tracked under fastpath mode (which is the mode we are generating the CTF) anyways.
707
+ """
708
+
709
+ worklist = []
710
+ worklist_set = set()
711
+
712
+ # Initialize the worklist
713
+ if self._start is None:
714
+ # initial nodes are those nodes in CFG that has no in-degrees
715
+ for n in self._cfg.graph.nodes():
716
+ if self._cfg.graph.in_degree(n) == 0:
717
+ # Put it into the worklist
718
+ job = DDGJob(n, 0)
719
+ self._worklist_append(job, worklist, worklist_set)
720
+ else:
721
+ for n in self._cfg.model.get_all_nodes(self._start):
722
+ job = DDGJob(n, 0)
723
+ self._worklist_append(job, worklist, worklist_set)
724
+
725
+ # A dict storing defs set
726
+ # DDGJob -> LiveDefinition
727
+ live_defs_per_node = {}
728
+
729
+ while worklist:
730
+ # Pop out a node
731
+ ddg_job = worklist[0]
732
+ l.debug("Processing %s.", ddg_job)
733
+ node, call_depth = ddg_job.cfg_node, ddg_job.call_depth
734
+ worklist = worklist[1:]
735
+ worklist_set.remove(node)
736
+
737
+ # Grab all final states. There are usually more than one (one state for each successor), and we gotta
738
+ # process all of them
739
+ final_states = node.final_states
740
+
741
+ if node in live_defs_per_node:
742
+ live_defs = live_defs_per_node[node]
743
+ else:
744
+ live_defs = LiveDefinitions()
745
+ live_defs_per_node[node] = live_defs
746
+
747
+ successing_nodes = list(self._cfg.graph.successors(node))
748
+
749
+ # try to assign every final state to a successor and vice versa
750
+ match_suc = defaultdict(bool)
751
+ match_state = defaultdict(set)
752
+
753
+ for suc in successing_nodes:
754
+ matched = False
755
+ for state in final_states:
756
+ try:
757
+ if state.solver.eval(state.ip) == suc.addr:
758
+ match_suc[suc.addr] = True
759
+ match_state[state].add(suc)
760
+ matched = True
761
+ except (SimUnsatError, SimSolverModeError, ZeroDivisionError):
762
+ # ignore
763
+ matched = matched
764
+ if not matched:
765
+ break
766
+
767
+ # whether all final states could be matched to a successor and vice versa
768
+ matches = len(match_suc) == len(successing_nodes) and len(match_state) == len(final_states)
769
+
770
+ for state in final_states:
771
+ if state.history.jumpkind == "Ijk_FakeRet" and len(final_states) > 1:
772
+ # Skip fakerets if there are other control flow transitions available
773
+ continue
774
+
775
+ new_call_depth = call_depth
776
+ if state.history.jumpkind == "Ijk_Call":
777
+ new_call_depth += 1
778
+ elif state.history.jumpkind == "Ijk_Ret":
779
+ new_call_depth -= 1
780
+
781
+ if self._call_depth is not None and call_depth > self._call_depth:
782
+ l.debug("Do not trace into %s due to the call depth limit", state.ip)
783
+ continue
784
+
785
+ new_defs = self._track(state, live_defs, node.irsb.statements if node.irsb is not None else None)
786
+
787
+ # corresponding_successors = [n for n in successing_nodes if
788
+ # not state.ip.symbolic and n.addr == state.solver.eval(state.ip)]
789
+ # if not corresponding_successors:
790
+ # continue
791
+
792
+ changed = False
793
+
794
+ # if every successor can be matched with one or more final states (by IP address),
795
+ # only take over the LiveDefinition of matching states
796
+ if matches:
797
+ add_state_to_sucs = match_state[state]
798
+ else:
799
+ add_state_to_sucs = successing_nodes
800
+
801
+ for successing_node in add_state_to_sucs:
802
+ if (state.history.jumpkind == "Ijk_Call" or state.history.jumpkind.startswith("Ijk_Sys")) and (
803
+ state.ip.symbolic or successing_node.addr != state.solver.eval(state.ip)
804
+ ):
805
+ suc_new_defs = self._filter_defs_at_call_sites(new_defs)
806
+ else:
807
+ suc_new_defs = new_defs
808
+
809
+ if successing_node in live_defs_per_node:
810
+ defs_for_next_node = live_defs_per_node[successing_node]
811
+ else:
812
+ defs_for_next_node = LiveDefinitions()
813
+ live_defs_per_node[successing_node] = defs_for_next_node
814
+
815
+ for var, code_loc_set in suc_new_defs.items():
816
+ # l.debug("Adding %d new definitions for variable %s.", len(code_loc_set), var)
817
+ changed |= defs_for_next_node.add_defs(var, code_loc_set)
818
+
819
+ if changed:
820
+ if (self._call_depth is None) or (
821
+ self._call_depth is not None and 0 <= new_call_depth <= self._call_depth
822
+ ):
823
+ # Put all reachable successors back to our work-list again
824
+ for successor in self._cfg.model.get_all_successors(node):
825
+ nw = DDGJob(successor, new_call_depth)
826
+ self._worklist_append(nw, worklist, worklist_set)
827
+
828
+ def _track(self, state, live_defs, statements):
829
+ """
830
+ Given all live definitions prior to this program point, track the changes, and return a new list of live
831
+ definitions. We scan through the action list of the new state to track the changes.
832
+
833
+ :param state: The input state at that program point.
834
+ :param live_defs: All live definitions prior to reaching this program point.
835
+ :param list statements: A list of VEX statements.
836
+ :returns: A list of new live definitions.
837
+ :rtype: angr.analyses.ddg.LiveDefinitions
838
+ """
839
+
840
+ # Make a copy of live_defs
841
+ self._live_defs = live_defs.copy()
842
+
843
+ action_list = list(state.history.recent_actions)
844
+
845
+ # Since all temporary variables are local, we simply track them in a dict
846
+ self._temp_variables = {}
847
+ self._temp_register_symbols = {}
848
+
849
+ # All dependence edges are added to the graph either at the end of this method, or when they are going to be
850
+ # overwritten by a new edge. This is because we sometimes have to modify a previous edge (e.g. add new labels
851
+ # to the edge)
852
+ self._temp_edges = defaultdict(list)
853
+ self._register_edges = defaultdict(list)
854
+
855
+ last_statement_id = None
856
+ self._variables_per_statement = (
857
+ None # program variables read out in the same statement. we keep a copy of those variables here so
858
+ )
859
+ # we can link it to the tmp_write action right afterwards
860
+ self._custom_data_per_statement = None
861
+
862
+ for a in action_list:
863
+ if last_statement_id is None or last_statement_id != a.stmt_idx:
864
+ # update statement ID
865
+ last_statement_id = a.stmt_idx
866
+ statement = (
867
+ statements[last_statement_id] if statements and last_statement_id < len(statements) else None
868
+ )
869
+
870
+ # initialize all per-statement data structures
871
+ self._variables_per_statement = []
872
+ self._custom_data_per_statement = None
873
+
874
+ if a.sim_procedure is None:
875
+ current_code_location = CodeLocation(a.bbl_addr, a.stmt_idx, ins_addr=a.ins_addr)
876
+ else:
877
+ current_code_location = CodeLocation(None, None, sim_procedure=a.sim_procedure)
878
+
879
+ if a.type == "exit":
880
+ self._handle_exit(a, current_code_location, state, statement)
881
+ elif a.type == "operation":
882
+ self._handle_operation(a, current_code_location, state, statement)
883
+ elif a.type == "constraint":
884
+ pass
885
+ else:
886
+ handler_name = f"_handle_{a.type}_{a.action}"
887
+ if hasattr(self, handler_name):
888
+ getattr(self, handler_name)(a, current_code_location, state, statement)
889
+ else:
890
+ l.debug("Skip an unsupported action %s.", a)
891
+
892
+ return self._live_defs
893
+
894
+ def _def_lookup(self, variable): # pylint:disable=no-self-use
895
+ """
896
+ This is a backward lookup in the previous defs. Note that, as we are using VSA, it is possible that `variable`
897
+ is affected by several definitions.
898
+
899
+ :param angr.analyses.ddg.LiveDefinitions live_defs:
900
+ The collection of live definitions.
901
+ :param SimVariable: The variable to lookup for definitions.
902
+ :returns: A dict {stmt:labels} where label is the number of individual addresses of `addr_list` (or
903
+ the actual set of addresses depending on the keep_addrs flag) that are definted by stmt.
904
+ """
905
+
906
+ prevdefs = {}
907
+
908
+ for code_loc in self._live_defs.lookup_defs(variable):
909
+ # Label edges with cardinality or actual sets of addresses
910
+ if isinstance(variable, SimMemoryVariable):
911
+ type_ = "mem"
912
+ elif isinstance(variable, SimRegisterVariable):
913
+ type_ = "reg"
914
+ else:
915
+ raise AngrDDGError("Unknown variable type %s" % type(variable))
916
+
917
+ prevdefs[code_loc] = {"type": type_, "data": variable}
918
+
919
+ return prevdefs
920
+
921
+ def _kill(self, variable, code_loc): # pylint:disable=no-self-use
922
+ """
923
+ Kill previous defs. addr_list is a list of normalized addresses.
924
+ """
925
+
926
+ # Case 1: address perfectly match, we kill
927
+ # Case 2: a is a subset of the original address
928
+ # Case 3: a is a superset of the original address
929
+
930
+ # the previous definition is killed. mark it in data graph.
931
+
932
+ if variable in self._live_defs:
933
+ for loc in self._live_defs.lookup_defs(variable):
934
+ pv = ProgramVariable(variable, loc, arch=self.project.arch)
935
+ self._data_graph_add_edge(pv, ProgramVariable(variable, code_loc, arch=self.project.arch), type="kill")
936
+
937
+ self._live_defs.kill_def(variable, code_loc)
938
+
939
+ def _get_register_size(self, reg_offset):
940
+ """
941
+ Get the size of a register.
942
+
943
+ :param int reg_offset: Offset of the register.
944
+ :return: Size in bytes.
945
+ :rtype: int
946
+ """
947
+
948
+ # TODO: support registers that are not aligned
949
+ if reg_offset in self.project.arch.register_names:
950
+ reg_name = self.project.arch.register_names[reg_offset]
951
+ reg_size = self.project.arch.registers[reg_name][1]
952
+ return reg_size
953
+
954
+ l.warning(
955
+ "_get_register_size(): unsupported register offset %d. Assum size 1. "
956
+ "More register name mappings should be implemented in archinfo.",
957
+ reg_offset,
958
+ )
959
+ return 1
960
+
961
+ #
962
+ # Action handling
963
+ #
964
+
965
+ @staticmethod
966
+ def _get_actual_addrs(action, state):
967
+ """
968
+ For memory actions, get a list of addresses it operates on.
969
+
970
+ :param SimAction action: The action object to work with.
971
+ :return: A list of addresses that are accessed with that action.
972
+ :rtype: list
973
+ """
974
+
975
+ if action.actual_addrs is None:
976
+ # For now, mem reads don't necessarily have actual_addrs set properly
977
+ try:
978
+ addr_list = {state.solver.eval(action.addr.ast)}
979
+ except (SimSolverModeError, SimUnsatError, ZeroDivisionError):
980
+ # FIXME: ZeroDivisionError should have been caught by claripy and simuvex.
981
+ # FIXME: see claripy issue #75. this is just a temporary workaround.
982
+ # it's symbolic... just continue
983
+ addr_list = {0x60000000} # TODO: this is a random address that I pick. Fix it.
984
+ else:
985
+ addr_list = set(action.actual_addrs)
986
+
987
+ return addr_list
988
+
989
+ def _create_memory_variable(self, action, addr, addrs):
990
+ """
991
+ Create a SimStackVariable or SimMemoryVariable based on action objects and its address.
992
+
993
+ :param SimAction action: The action to work with.
994
+ :param int addr: The address of the memory variable in creation.
995
+ :param list addrs: A list of all addresses that the action was effective on.
996
+ :return:
997
+ """
998
+
999
+ variable = None
1000
+ if len(addrs) == 1 and len(action.addr.tmp_deps) == 1:
1001
+ addr_tmp = list(action.addr.tmp_deps)[0]
1002
+ if addr_tmp in self._temp_register_symbols:
1003
+ # it must be a stack variable
1004
+ sort, offset = self._temp_register_symbols[addr_tmp]
1005
+ base_addr = addr - offset
1006
+ if base_addr < 0:
1007
+ base_addr += 1 << self.project.arch.bits
1008
+ variable = SimStackVariable(offset, action.size.ast // 8, base=sort, base_addr=base_addr)
1009
+
1010
+ if variable is None:
1011
+ variable = SimMemoryVariable(addr, action.size.ast // 8)
1012
+
1013
+ return variable
1014
+
1015
+ def _make_edges(self, action, prog_var):
1016
+ """
1017
+
1018
+ :param SimAction action:
1019
+ :param ProgramVariable prog_var:
1020
+ :return:
1021
+ """
1022
+
1023
+ # For each of its register dependency and data dependency, we annotate the corresponding edge
1024
+ for reg_offset in action.addr.reg_deps:
1025
+ self._stmt_graph_annotate_edges(self._register_edges[reg_offset], subtype="mem_addr")
1026
+ reg_variable = SimRegisterVariable(reg_offset, self._get_register_size(reg_offset))
1027
+ prev_defs = self._def_lookup(reg_variable)
1028
+ for loc, _ in prev_defs.items():
1029
+ v = ProgramVariable(reg_variable, loc, arch=self.project.arch)
1030
+ self._data_graph_add_edge(v, prog_var, type="mem_addr")
1031
+
1032
+ for tmp in action.addr.tmp_deps:
1033
+ self._stmt_graph_annotate_edges(self._temp_edges[tmp], subtype="mem_addr")
1034
+ if tmp in self._temp_variables:
1035
+ self._data_graph_add_edge(self._temp_variables[tmp], prog_var, type="mem_addr")
1036
+
1037
+ if not action.data.reg_deps and not action.data.tmp_deps:
1038
+ # might be a constant assignment
1039
+ v = action.data.ast
1040
+ if not v.symbolic:
1041
+ const_var = SimConstantVariable(v.concrete_value)
1042
+ const_progvar = ProgramVariable(const_var, prog_var.location)
1043
+ self._data_graph_add_edge(const_progvar, prog_var, type="mem_data")
1044
+
1045
+ else:
1046
+ for reg_offset in action.data.reg_deps:
1047
+ self._stmt_graph_annotate_edges(self._register_edges[reg_offset], subtype="mem_data")
1048
+ reg_variable = SimRegisterVariable(reg_offset, self._get_register_size(reg_offset))
1049
+ prev_defs = self._def_lookup(reg_variable)
1050
+ for loc, _ in prev_defs.items():
1051
+ v = ProgramVariable(reg_variable, loc, arch=self.project.arch)
1052
+ self._data_graph_add_edge(v, prog_var, type="mem_data")
1053
+
1054
+ for tmp in action.data.tmp_deps:
1055
+ self._stmt_graph_annotate_edges(self._temp_edges[tmp], subtype="mem_data")
1056
+ if tmp in self._temp_variables:
1057
+ self._data_graph_add_edge(self._temp_variables[tmp], prog_var, type="mem_data")
1058
+
1059
+ def _handle_mem_read(self, action, code_location, state, statement): # pylint:disable=unused-argument
1060
+ addrs = self._get_actual_addrs(action, state)
1061
+
1062
+ for addr in addrs:
1063
+ variable = self._create_memory_variable(action, addr, addrs)
1064
+
1065
+ variables = []
1066
+
1067
+ # get all definitions
1068
+ defs = self._def_lookup(variable)
1069
+
1070
+ if defs:
1071
+ # for each definition, create an edge on the graph
1072
+ for definition_location, labels in defs.items():
1073
+ self._stmt_graph_add_edge(definition_location, code_location, **labels)
1074
+ pv = ProgramVariable(variable, definition_location, arch=self.project.arch)
1075
+ variables.append(pv)
1076
+ self._make_edges(action, pv)
1077
+ else:
1078
+ # if no definition is found, then this is the first time this variable is accessed
1079
+ # mark it as "initial"
1080
+ pv = ProgramVariable(variable, code_location, initial=True, arch=self.project.arch)
1081
+ variables.append(pv)
1082
+ self._make_edges(action, pv)
1083
+ # make sure to put it into the killing set
1084
+ self._kill(variable, code_location)
1085
+
1086
+ for var in variables:
1087
+ # record accessed variables in var_per_stmt
1088
+ self._variables_per_statement.append(var)
1089
+
1090
+ def _handle_mem_write(self, action, location, state, statement):
1091
+ addrs = self._get_actual_addrs(action, state)
1092
+
1093
+ for addr in addrs:
1094
+ variable = self._create_memory_variable(action, addr, addrs)
1095
+
1096
+ # kill all previous variables
1097
+ self._kill(variable, location)
1098
+
1099
+ # create a new variable at current location
1100
+ pv = ProgramVariable(variable, location, arch=self.project.arch)
1101
+
1102
+ # make edges
1103
+ self._make_edges(action, pv)
1104
+
1105
+ if isinstance(statement, pyvex.IRStmt.Store) and self._variables_per_statement:
1106
+ if isinstance(statement.data, pyvex.IRExpr.RdTmp):
1107
+ # assignment
1108
+ src_tmp_idx = statement.data.tmp
1109
+ src_tmp_def = next(
1110
+ s
1111
+ for s in self._variables_per_statement
1112
+ if isinstance(s.variable, SimTemporaryVariable) and s.variable.tmp_id == src_tmp_idx
1113
+ )
1114
+ self._ast_graph.add_edge(src_tmp_def, pv)
1115
+ elif isinstance(statement.data, pyvex.IRExpr.Const):
1116
+ # assignment
1117
+ const = statement.data.con.value
1118
+ self._ast_graph.add_edge(ProgramVariable(SimConstantVariable(const), location), pv)
1119
+
1120
+ def _handle_reg_read(self, action, location, state, statement): # pylint:disable=unused-argument
1121
+ reg_offset = action.offset
1122
+ variable = SimRegisterVariable(reg_offset, action.data.ast.size() // 8)
1123
+
1124
+ # What do we want to do?
1125
+ definitions = self._def_lookup(variable)
1126
+
1127
+ # add edges to the statement dependence graph
1128
+ for definition_location, labels in definitions.items():
1129
+ self._stmt_graph_add_edge(definition_location, location, **labels)
1130
+
1131
+ # record the edge
1132
+ self._register_edges[reg_offset].append((definition_location, location))
1133
+
1134
+ self._variables_per_statement.append(ProgramVariable(variable, definition_location, arch=self.project.arch))
1135
+
1136
+ if not definitions:
1137
+ # the register was never defined before - it must be passed in as an argument
1138
+ self._variables_per_statement.append(
1139
+ ProgramVariable(variable, location, initial=True, arch=self.project.arch)
1140
+ )
1141
+ # make sure to put it into the killing set
1142
+ self._kill(variable, location)
1143
+
1144
+ if reg_offset == self.project.arch.sp_offset:
1145
+ self._custom_data_per_statement = ("sp", 0)
1146
+ elif reg_offset == self.project.arch.bp_offset:
1147
+ self._custom_data_per_statement = ("bp", 0)
1148
+
1149
+ def _handle_reg_write(self, action, location, state, statement): # pylint:disable=unused-argument
1150
+ reg_offset = action.offset
1151
+ variable = SimRegisterVariable(reg_offset, action.data.ast.size() // 8)
1152
+
1153
+ self._kill(variable, location)
1154
+
1155
+ if reg_offset in self._register_edges:
1156
+ # clear the recoreded edge, since we don't need to alter that edge anymore
1157
+ del self._register_edges[reg_offset]
1158
+
1159
+ # add a node on the data dependence graph
1160
+ pv = ProgramVariable(variable, location, arch=self.project.arch)
1161
+ self._data_graph_add_node(pv)
1162
+
1163
+ if not action.reg_deps and not action.tmp_deps:
1164
+ # moving a constant into the register
1165
+ # try to parse out the constant from statement
1166
+ const_variable = SimConstantVariable()
1167
+ if statement is not None:
1168
+ if isinstance(statement.data, pyvex.IRExpr.Const):
1169
+ const_variable = SimConstantVariable(value=statement.data.con.value)
1170
+ const_pv = ProgramVariable(const_variable, location, arch=self.project.arch)
1171
+ self._data_graph_add_edge(const_pv, pv)
1172
+
1173
+ for tmp in action.tmp_deps:
1174
+ if tmp in self._temp_variables:
1175
+ self._data_graph_add_edge(self._temp_variables[tmp], pv)
1176
+
1177
+ def _handle_tmp_read(self, action, location, state, statement): # pylint:disable=unused-argument
1178
+ tmp = action.tmp
1179
+ tmp_var = self._temp_variables[tmp]
1180
+
1181
+ def_loc = tmp_var.location
1182
+
1183
+ self._stmt_graph_add_edge(def_loc, location, type="tmp", data=action.tmp)
1184
+ # record the edge
1185
+ edge_tuple = (def_loc, location)
1186
+ self._temp_edges[action.tmp].append(edge_tuple)
1187
+
1188
+ if tmp in self._temp_register_symbols:
1189
+ self._custom_data_per_statement = self._temp_register_symbols[tmp]
1190
+
1191
+ self._variables_per_statement.append(tmp_var)
1192
+
1193
+ def _handle_tmp_write(self, action, location, state, statement): # pylint:disable=unused-argument
1194
+ ast = None
1195
+
1196
+ tmp = action.tmp
1197
+ pv = ProgramVariable(SimTemporaryVariable(tmp), location, arch=self.project.arch)
1198
+
1199
+ if ast is not None:
1200
+ for operand in ast.operands:
1201
+ self._ast_graph.add_edge(operand, ast)
1202
+ self._ast_graph.add_edge(ast, pv)
1203
+
1204
+ self._temp_variables[tmp] = pv
1205
+
1206
+ # clear existing edges
1207
+ if tmp in self._temp_edges:
1208
+ del self._temp_edges[tmp]
1209
+
1210
+ for tmp_dep in action.tmp_deps:
1211
+ if tmp_dep in self._temp_variables:
1212
+ self._data_graph_add_edge(self._temp_variables[tmp_dep], pv)
1213
+
1214
+ if self._custom_data_per_statement is not None:
1215
+ self._temp_register_symbols[tmp] = self._custom_data_per_statement
1216
+
1217
+ for data in self._variables_per_statement:
1218
+ self._data_graph_add_edge(data, pv)
1219
+
1220
+ if isinstance(statement, pyvex.IRStmt.WrTmp) and self._variables_per_statement:
1221
+ if isinstance(statement.data, pyvex.IRExpr.RdTmp):
1222
+ # assignment: dst_tmp = src_tmp
1223
+ for s in filter(
1224
+ lambda x: isinstance(x.variable, SimTemporaryVariable) and x.variable.tmp_id != tmp,
1225
+ self._variables_per_statement,
1226
+ ):
1227
+ self._ast_graph.add_edge(s, pv)
1228
+ elif isinstance(statement.data, pyvex.IRExpr.Get):
1229
+ # assignment: dst_tmp = src_reg
1230
+ for s in filter(lambda x: isinstance(x.variable, SimRegisterVariable), self._variables_per_statement):
1231
+ self._ast_graph.add_edge(s, pv)
1232
+ elif isinstance(statement.data, pyvex.IRExpr.Load):
1233
+ # assignment: dst_tmp = [ src_mem ]
1234
+ for s in filter(lambda x: isinstance(x.variable, SimMemoryVariable), self._variables_per_statement):
1235
+ self._ast_graph.add_edge(s, pv)
1236
+
1237
+ if not action.tmp_deps and not self._variables_per_statement and not ast:
1238
+ # read in a constant
1239
+ # try to parse out the constant from statement
1240
+ const_variable = SimConstantVariable()
1241
+ if statement is not None:
1242
+ if isinstance(statement, pyvex.IRStmt.Dirty):
1243
+ l.warning("Dirty statements are not supported in DDG for now.")
1244
+ elif isinstance(statement.data, pyvex.IRExpr.Const):
1245
+ const_variable = SimConstantVariable(value=statement.data.con.value)
1246
+ const_pv = ProgramVariable(const_variable, location, arch=self.project.arch)
1247
+ self._data_graph_add_edge(const_pv, pv)
1248
+
1249
+ def _handle_exit(self, action, location, state, statement): # pylint:disable=unused-argument
1250
+ # exits should only depend on tmps
1251
+ for tmp in action.tmp_deps:
1252
+ prev_code_loc = self._temp_variables[tmp].location
1253
+
1254
+ # add the edge to the graph
1255
+ self._stmt_graph_add_edge(prev_code_loc, location, type="exit", data="tmp")
1256
+
1257
+ # log the edge
1258
+ edge_tuple = (prev_code_loc, location)
1259
+ self._temp_edges[tmp].append(edge_tuple)
1260
+
1261
+ def _handle_operation(self, action, location, state, statement): # pylint:disable=unused-argument
1262
+ if action.op.endswith("Sub32") or action.op.endswith("Sub64"):
1263
+ # subtract
1264
+ expr_0, expr_1 = action.exprs
1265
+
1266
+ if expr_0.tmp_deps and (not expr_1.tmp_deps and not expr_1.reg_deps):
1267
+ # tmp - const
1268
+
1269
+ const_value = expr_1.ast.args[0]
1270
+
1271
+ tmp = next(iter(expr_0.tmp_deps))
1272
+ if tmp in self._temp_register_symbols:
1273
+ sort, offset = self._temp_register_symbols[tmp]
1274
+ offset -= const_value
1275
+ if offset < 0:
1276
+ offset += 1 << self.project.arch.bits
1277
+ self._custom_data_per_statement = (sort, offset)
1278
+
1279
+ elif action.op.endswith("Add32") or action.op.endswith("Add64"):
1280
+ # add
1281
+
1282
+ expr_0, expr_1 = action.exprs
1283
+
1284
+ if expr_0.tmp_deps and (not expr_1.tmp_deps and not expr_1.reg_deps):
1285
+ # tmp + const
1286
+ const_value = expr_1.ast.args[0]
1287
+
1288
+ tmp = next(iter(expr_0.tmp_deps))
1289
+ if tmp in self._temp_register_symbols:
1290
+ sort, offset = self._temp_register_symbols[tmp]
1291
+ offset += const_value
1292
+ if offset >= (1 << self.project.arch.bits):
1293
+ offset -= 1 << self.project.arch.bits
1294
+ self._custom_data_per_statement = (sort, offset)
1295
+
1296
+ def _process_operation(self, action, location, state, statement): # pylint:disable=unused-argument
1297
+ if action.op.endswith("Sub32") or action.op.endswith("Sub64"):
1298
+ # subtract
1299
+ expr_0, expr_1 = action.exprs
1300
+
1301
+ if expr_0.tmp_deps and (not expr_1.tmp_deps and not expr_1.reg_deps):
1302
+ # tmp - const
1303
+ const_value = expr_1.ast.args[0]
1304
+ tmp = next(iter(expr_0.tmp_deps))
1305
+
1306
+ const_def = ProgramVariable(SimConstantVariable(const_value), location)
1307
+ tmp_def = self._temp_variables[tmp]
1308
+ ast = AST("-", tmp_def, const_def)
1309
+ return ast
1310
+
1311
+ elif action.op.endswith("Add32") or action.op.endswith("Add64"):
1312
+ # add
1313
+
1314
+ expr_0, expr_1 = action.exprs
1315
+
1316
+ if expr_0.tmp_deps and (not expr_1.tmp_deps and not expr_1.reg_deps):
1317
+ # tmp + const
1318
+ const_value = expr_1.ast.args[0]
1319
+ tmp = next(iter(expr_0.tmp_deps))
1320
+
1321
+ const_def = ProgramVariable(SimConstantVariable(const_value), location)
1322
+ tmp_def = self._temp_variables[tmp]
1323
+ ast = AST("+", tmp_def, const_def)
1324
+ return ast
1325
+
1326
+ return None
1327
+
1328
+ #
1329
+ # Graph operations
1330
+ #
1331
+
1332
+ def _data_graph_add_node(self, node):
1333
+ """
1334
+ Add a noe in the data dependence graph.
1335
+
1336
+ :param ProgramVariable node: The node to add.
1337
+ :return: None
1338
+ """
1339
+
1340
+ self._data_graph.add_node(node)
1341
+
1342
+ self._simplified_data_graph = None
1343
+
1344
+ def _data_graph_add_edge(self, src, dst, **edge_labels):
1345
+ """
1346
+ Add an edge in the data dependence graph.
1347
+
1348
+ :param ProgramVariable src: Source node.
1349
+ :param ProgramVariable dst: Destination node.
1350
+ :param edge_labels: All labels associated with the edge.
1351
+ :return: None
1352
+ """
1353
+
1354
+ if src in self._data_graph and dst in self._data_graph[src]:
1355
+ return
1356
+
1357
+ self._data_graph.add_edge(src, dst, **edge_labels)
1358
+
1359
+ self._simplified_data_graph = None
1360
+
1361
+ def _stmt_graph_add_edge(self, src, dst, **edge_labels):
1362
+ """
1363
+ Add an edge in the statement dependence graph from a program location `src` to another program location `dst`.
1364
+
1365
+ :param CodeLocation src: Source node.
1366
+ :param CodeLocation dst: Destination node.
1367
+ :param edge_labels: All labels associated with the edge.
1368
+ :returns: None
1369
+ """
1370
+
1371
+ # Is that edge already in the graph ?
1372
+ # If at least one is new, then we are not redoing the same path again
1373
+ if src in self._stmt_graph and dst in self._stmt_graph[src]:
1374
+ return
1375
+
1376
+ self._stmt_graph.add_edge(src, dst, **edge_labels)
1377
+
1378
+ def _stmt_graph_annotate_edges(self, edges_to_annotate, **new_labels):
1379
+ """
1380
+ Add new annotations to edges in the statement dependence graph.
1381
+
1382
+ :param list edges_to_annotate: A list of edges to annotate.
1383
+ :param new_labels: New labels to be added to those edges.
1384
+ :returns: None
1385
+ """
1386
+
1387
+ graph = self.graph
1388
+
1389
+ for src, dst in edges_to_annotate:
1390
+ if src not in graph:
1391
+ continue
1392
+ if dst not in graph[src]:
1393
+ continue
1394
+
1395
+ data = graph[src][dst]
1396
+
1397
+ for k, v in new_labels.items():
1398
+ if k in data:
1399
+ if v not in data[k]:
1400
+ data[k] = data[k] + (v,)
1401
+ else:
1402
+ # Construct a tuple
1403
+ data[k] = (v,)
1404
+
1405
+ def _simplify_data_graph(self, data_graph): # pylint:disable=no-self-use
1406
+ """
1407
+ Simplify a data graph by removing all temp variable nodes on the graph.
1408
+
1409
+ :param networkx.DiGraph data_graph: The data dependence graph to simplify.
1410
+ :return: The simplified graph.
1411
+ :rtype: networkx.MultiDiGraph
1412
+ """
1413
+
1414
+ graph = networkx.MultiDiGraph(data_graph)
1415
+
1416
+ all_nodes = [n for n in graph.nodes() if isinstance(n.variable, SimTemporaryVariable)]
1417
+
1418
+ for tmp_node in all_nodes:
1419
+ # remove each tmp node by linking their successors and predecessors directly
1420
+ in_edges = graph.in_edges(tmp_node, data=True)
1421
+ out_edges = graph.out_edges(tmp_node, data=True)
1422
+
1423
+ for pred, _, _ in in_edges:
1424
+ graph.remove_edge(pred, tmp_node)
1425
+ for _, suc, _ in out_edges:
1426
+ graph.remove_edge(tmp_node, suc)
1427
+
1428
+ for pred, _, data_in in in_edges:
1429
+ for _, suc, data_out in out_edges:
1430
+ if pred is not tmp_node and suc is not tmp_node:
1431
+ if suc not in graph[pred]:
1432
+ data = data_in.copy()
1433
+ data.update(data_out)
1434
+ graph.add_edge(pred, suc, **data)
1435
+
1436
+ graph.remove_node(tmp_node)
1437
+
1438
+ return graph
1439
+
1440
+ def _worklist_append(self, node_wrapper, worklist, worklist_set):
1441
+ """
1442
+ Append a CFGNode and its successors into the work-list, and respect the call-depth limit
1443
+
1444
+ :param node_wrapper: The NodeWrapper instance to insert.
1445
+ :param worklist: The work-list, which is a list.
1446
+ :param worklist_set: A set of all CFGNodes that are inside the work-list, just for the sake of fast look-up.
1447
+ It will be updated as well.
1448
+ :returns: A set of newly-inserted CFGNodes (not NodeWrapper instances).
1449
+ """
1450
+
1451
+ if node_wrapper.cfg_node in worklist_set:
1452
+ # It's already in the work-list
1453
+ return
1454
+
1455
+ worklist.append(node_wrapper)
1456
+ worklist_set.add(node_wrapper.cfg_node)
1457
+
1458
+ stack = [node_wrapper]
1459
+ traversed_nodes = {node_wrapper.cfg_node}
1460
+ inserted = {node_wrapper.cfg_node}
1461
+
1462
+ while stack:
1463
+ nw = stack.pop()
1464
+ n, call_depth = nw.cfg_node, nw.call_depth
1465
+
1466
+ # Get successors
1467
+ edges = self._cfg.graph.out_edges(n, data=True)
1468
+
1469
+ for _, dst, data in edges:
1470
+ if (
1471
+ dst not in traversed_nodes # which means we haven't touch this node in this appending procedure
1472
+ and dst not in worklist_set
1473
+ ): # which means this node is not in the work-list
1474
+ # We see a new node!
1475
+ traversed_nodes.add(dst)
1476
+
1477
+ if data["jumpkind"] == "Ijk_Call":
1478
+ if self._call_depth is None or call_depth < self._call_depth:
1479
+ inserted.add(dst)
1480
+ new_nw = DDGJob(dst, call_depth + 1)
1481
+ worklist.append(new_nw)
1482
+ worklist_set.add(dst)
1483
+ stack.append(new_nw)
1484
+ elif data["jumpkind"] == "Ijk_Ret":
1485
+ if call_depth > 0:
1486
+ inserted.add(dst)
1487
+ new_nw = DDGJob(dst, call_depth - 1)
1488
+ worklist.append(new_nw)
1489
+ worklist_set.add(dst)
1490
+ stack.append(new_nw)
1491
+ else:
1492
+ new_nw = DDGJob(dst, call_depth)
1493
+ inserted.add(dst)
1494
+ worklist_set.add(dst)
1495
+ worklist.append(new_nw)
1496
+ stack.append(new_nw)
1497
+
1498
+ return inserted
1499
+
1500
+ def _build_function_dependency_graphs(self):
1501
+ """
1502
+ Build dependency graphs for each function, and save them in self._function_data_dependencies.
1503
+ """
1504
+
1505
+ # This is a map between functions and its corresponding dependencies
1506
+ self._function_data_dependencies = defaultdict(networkx.DiGraph)
1507
+
1508
+ # Group all dependencies first
1509
+
1510
+ block_addr_to_func = {}
1511
+ for _, func in self.kb.functions.items():
1512
+ for block in func.blocks:
1513
+ block_addr_to_func[block.addr] = func
1514
+
1515
+ for src, dst, data in self.graph.edges(data=True):
1516
+ src_target_func = None
1517
+ if src.block_addr in block_addr_to_func:
1518
+ src_target_func = block_addr_to_func[src.block_addr]
1519
+ self._function_data_dependencies[src_target_func].add_edge(src, dst, **data)
1520
+
1521
+ if dst.block_addr in block_addr_to_func:
1522
+ dst_target_func = block_addr_to_func[dst.block_addr]
1523
+ if dst_target_func is not src_target_func:
1524
+ self._function_data_dependencies[dst_target_func].add_edge(src, dst, **data)
1525
+
1526
+ #
1527
+ # Other private methods
1528
+ #
1529
+
1530
+ def _filter_defs_at_call_sites(self, defs):
1531
+ """
1532
+ If we are not tracing into the function that are called in a real execution, we should properly filter the defs
1533
+ to account for the behavior of the skipped function at this call site.
1534
+
1535
+ This function is a WIP. See TODOs inside.
1536
+
1537
+ :param defs:
1538
+ :return:
1539
+ """
1540
+
1541
+ # TODO: make definition killing architecture independent and calling convention independent
1542
+ # TODO: use information from a calling convention analysis
1543
+ filtered_defs = LiveDefinitions()
1544
+ for variable, locs in defs.items():
1545
+ if isinstance(variable, SimRegisterVariable):
1546
+ if self.project.arch.name == "X86":
1547
+ if variable.reg in (
1548
+ self.project.arch.registers["eax"][0],
1549
+ self.project.arch.registers["ecx"][0],
1550
+ self.project.arch.registers["edx"][0],
1551
+ ):
1552
+ continue
1553
+
1554
+ filtered_defs.add_defs(variable, locs)
1555
+
1556
+ return filtered_defs
1557
+
1558
+ def find_definitions(self, variable, location=None, simplified_graph=True):
1559
+ """
1560
+ Find all definitions of the given variable.
1561
+
1562
+ :param SimVariable variable:
1563
+ :param bool simplified_graph: True if you just want to search in the simplified graph instead of the normal
1564
+ graph. Usually the simplified graph suffices for finding definitions of register
1565
+ or memory variables.
1566
+ :return: A collection of all variable definitions to the specific variable.
1567
+ :rtype: list
1568
+ """
1569
+
1570
+ if simplified_graph:
1571
+ graph = self.simplified_data_graph
1572
+ else:
1573
+ graph = self.data_graph
1574
+
1575
+ defs = []
1576
+
1577
+ n: ProgramVariable
1578
+ for n in graph.nodes():
1579
+ if n.variable == variable:
1580
+ if location is None:
1581
+ defs.append(n)
1582
+ else:
1583
+ # TODO: finish this part
1584
+ if n.location.block_addr == location.block_addr:
1585
+ defs.append(n)
1586
+
1587
+ return defs
1588
+
1589
+ def find_consumers(self, var_def, simplified_graph=True):
1590
+ """
1591
+ Find all consumers to the specified variable definition.
1592
+
1593
+ :param ProgramVariable var_def: The variable definition.
1594
+ :param bool simplified_graph: True if we want to search in the simplified graph, False otherwise.
1595
+ :return: A collection of all consumers to the specified variable definition.
1596
+ :rtype: list
1597
+ """
1598
+
1599
+ if simplified_graph:
1600
+ graph = self.simplified_data_graph
1601
+ else:
1602
+ graph = self.data_graph
1603
+
1604
+ if var_def not in graph:
1605
+ return []
1606
+
1607
+ consumers = []
1608
+ srcs = [var_def]
1609
+ traversed = set()
1610
+
1611
+ while srcs:
1612
+ src = srcs.pop()
1613
+ out_edges = graph.out_edges(src, data=True)
1614
+ for _, dst, data in out_edges:
1615
+ if "type" in data and data["type"] == "kill":
1616
+ # skip killing edges
1617
+ continue
1618
+ if isinstance(dst.variable, SimTemporaryVariable):
1619
+ if dst not in traversed:
1620
+ srcs.append(dst)
1621
+ traversed.add(dst)
1622
+ else:
1623
+ if dst not in consumers:
1624
+ consumers.append(dst)
1625
+
1626
+ return consumers
1627
+
1628
+ def find_killers(self, var_def, simplified_graph=True):
1629
+ """
1630
+ Find all killers to the specified variable definition.
1631
+
1632
+ :param ProgramVariable var_def: The variable definition.
1633
+ :param bool simplified_graph: True if we want to search in the simplified graph, False otherwise.
1634
+ :return: A collection of all killers to the specified variable definition.
1635
+ :rtype: list
1636
+ """
1637
+
1638
+ if simplified_graph:
1639
+ graph = self.simplified_data_graph
1640
+ else:
1641
+ graph = self.data_graph
1642
+
1643
+ if var_def not in graph:
1644
+ return []
1645
+
1646
+ killers = []
1647
+ out_edges = graph.out_edges(var_def, data=True)
1648
+ for _, dst, data in out_edges:
1649
+ if "type" in data and data["type"] == "kill":
1650
+ killers.append(dst)
1651
+
1652
+ return killers
1653
+
1654
+ def find_sources(self, var_def, simplified_graph=True):
1655
+ """
1656
+ Find all sources to the specified variable definition.
1657
+
1658
+ :param ProgramVariable var_def: The variable definition.
1659
+ :param bool simplified_graph: True if we want to search in the simplified graph, False otherwise.
1660
+ :return: A collection of all sources to the specified variable definition.
1661
+ :rtype: list
1662
+ """
1663
+
1664
+ if simplified_graph:
1665
+ graph = self.simplified_data_graph
1666
+ else:
1667
+ graph = self.data_graph
1668
+
1669
+ if var_def not in graph:
1670
+ return []
1671
+
1672
+ sources = []
1673
+ defs = [var_def]
1674
+ traversed = set()
1675
+
1676
+ while defs:
1677
+ definition = defs.pop()
1678
+ in_edges = graph.in_edges(definition, data=True)
1679
+ for src, _, data in in_edges:
1680
+ if "type" in data and data["type"] == "kill":
1681
+ continue
1682
+ if isinstance(src.variable, SimTemporaryVariable):
1683
+ if src not in traversed:
1684
+ defs.append(src)
1685
+ traversed.add(src)
1686
+ else:
1687
+ if src not in sources:
1688
+ sources.append(src)
1689
+
1690
+ return sources
1691
+
1692
+
1693
+ from angr.analyses import AnalysesHub
1694
+
1695
+ AnalysesHub.register_default("DDG", DDG)