angr 9.2.156__cp310-cp310-win_amd64.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 (1393) hide show
  1. angr/__init__.py +363 -0
  2. angr/__main__.py +152 -0
  3. angr/analyses/__init__.py +113 -0
  4. angr/analyses/analysis.py +407 -0
  5. angr/analyses/backward_slice.py +686 -0
  6. angr/analyses/binary_optimizer.py +670 -0
  7. angr/analyses/bindiff.py +1512 -0
  8. angr/analyses/boyscout.py +76 -0
  9. angr/analyses/callee_cleanup_finder.py +74 -0
  10. angr/analyses/calling_convention/__init__.py +6 -0
  11. angr/analyses/calling_convention/calling_convention.py +1092 -0
  12. angr/analyses/calling_convention/fact_collector.py +636 -0
  13. angr/analyses/calling_convention/utils.py +60 -0
  14. angr/analyses/cdg.py +189 -0
  15. angr/analyses/cfg/__init__.py +23 -0
  16. angr/analyses/cfg/cfb.py +428 -0
  17. angr/analyses/cfg/cfg.py +74 -0
  18. angr/analyses/cfg/cfg_arch_options.py +95 -0
  19. angr/analyses/cfg/cfg_base.py +2886 -0
  20. angr/analyses/cfg/cfg_emulated.py +3447 -0
  21. angr/analyses/cfg/cfg_fast.py +5273 -0
  22. angr/analyses/cfg/cfg_fast_soot.py +662 -0
  23. angr/analyses/cfg/cfg_job_base.py +203 -0
  24. angr/analyses/cfg/indirect_jump_resolvers/__init__.py +28 -0
  25. angr/analyses/cfg/indirect_jump_resolvers/amd64_elf_got.py +62 -0
  26. angr/analyses/cfg/indirect_jump_resolvers/amd64_pe_iat.py +51 -0
  27. angr/analyses/cfg/indirect_jump_resolvers/arm_elf_fast.py +149 -0
  28. angr/analyses/cfg/indirect_jump_resolvers/const_resolver.py +186 -0
  29. angr/analyses/cfg/indirect_jump_resolvers/constant_value_manager.py +107 -0
  30. angr/analyses/cfg/indirect_jump_resolvers/default_resolvers.py +76 -0
  31. angr/analyses/cfg/indirect_jump_resolvers/jumptable.py +2367 -0
  32. angr/analyses/cfg/indirect_jump_resolvers/memload_resolver.py +81 -0
  33. angr/analyses/cfg/indirect_jump_resolvers/mips_elf_fast.py +286 -0
  34. angr/analyses/cfg/indirect_jump_resolvers/mips_elf_got.py +148 -0
  35. angr/analyses/cfg/indirect_jump_resolvers/propagator_utils.py +46 -0
  36. angr/analyses/cfg/indirect_jump_resolvers/resolver.py +74 -0
  37. angr/analyses/cfg/indirect_jump_resolvers/syscall_resolver.py +92 -0
  38. angr/analyses/cfg/indirect_jump_resolvers/x86_elf_pic_plt.py +88 -0
  39. angr/analyses/cfg/indirect_jump_resolvers/x86_pe_iat.py +47 -0
  40. angr/analyses/cfg_slice_to_sink/__init__.py +11 -0
  41. angr/analyses/cfg_slice_to_sink/cfg_slice_to_sink.py +117 -0
  42. angr/analyses/cfg_slice_to_sink/graph.py +87 -0
  43. angr/analyses/cfg_slice_to_sink/transitions.py +27 -0
  44. angr/analyses/class_identifier.py +63 -0
  45. angr/analyses/code_tagging.py +123 -0
  46. angr/analyses/codecave.py +77 -0
  47. angr/analyses/complete_calling_conventions.py +461 -0
  48. angr/analyses/congruency_check.py +377 -0
  49. angr/analyses/data_dep/__init__.py +16 -0
  50. angr/analyses/data_dep/data_dependency_analysis.py +595 -0
  51. angr/analyses/data_dep/dep_nodes.py +171 -0
  52. angr/analyses/data_dep/sim_act_location.py +49 -0
  53. angr/analyses/datagraph_meta.py +105 -0
  54. angr/analyses/ddg.py +1670 -0
  55. angr/analyses/decompiler/__init__.py +41 -0
  56. angr/analyses/decompiler/ail_simplifier.py +1872 -0
  57. angr/analyses/decompiler/ailgraph_walker.py +49 -0
  58. angr/analyses/decompiler/block_io_finder.py +302 -0
  59. angr/analyses/decompiler/block_similarity.py +196 -0
  60. angr/analyses/decompiler/block_simplifier.py +371 -0
  61. angr/analyses/decompiler/callsite_maker.py +555 -0
  62. angr/analyses/decompiler/ccall_rewriters/__init__.py +9 -0
  63. angr/analyses/decompiler/ccall_rewriters/amd64_ccalls.py +580 -0
  64. angr/analyses/decompiler/ccall_rewriters/rewriter_base.py +20 -0
  65. angr/analyses/decompiler/ccall_rewriters/x86_ccalls.py +313 -0
  66. angr/analyses/decompiler/clinic.py +3222 -0
  67. angr/analyses/decompiler/condition_processor.py +1245 -0
  68. angr/analyses/decompiler/counters/__init__.py +16 -0
  69. angr/analyses/decompiler/counters/boolean_counter.py +27 -0
  70. angr/analyses/decompiler/counters/call_counter.py +47 -0
  71. angr/analyses/decompiler/counters/expression_counters.py +77 -0
  72. angr/analyses/decompiler/counters/seq_cf_structure_counter.py +63 -0
  73. angr/analyses/decompiler/decompilation_cache.py +46 -0
  74. angr/analyses/decompiler/decompilation_options.py +275 -0
  75. angr/analyses/decompiler/decompiler.py +692 -0
  76. angr/analyses/decompiler/dephication/__init__.py +6 -0
  77. angr/analyses/decompiler/dephication/dephication_base.py +89 -0
  78. angr/analyses/decompiler/dephication/graph_dephication.py +63 -0
  79. angr/analyses/decompiler/dephication/graph_rewriting.py +116 -0
  80. angr/analyses/decompiler/dephication/graph_vvar_mapping.py +326 -0
  81. angr/analyses/decompiler/dephication/rewriting_engine.py +504 -0
  82. angr/analyses/decompiler/dephication/seqnode_dephication.py +134 -0
  83. angr/analyses/decompiler/empty_node_remover.py +212 -0
  84. angr/analyses/decompiler/expression_narrower.py +287 -0
  85. angr/analyses/decompiler/goto_manager.py +112 -0
  86. angr/analyses/decompiler/graph_region.py +398 -0
  87. angr/analyses/decompiler/jump_target_collector.py +37 -0
  88. angr/analyses/decompiler/jumptable_entry_condition_rewriter.py +67 -0
  89. angr/analyses/decompiler/label_collector.py +32 -0
  90. angr/analyses/decompiler/optimization_passes/__init__.py +151 -0
  91. angr/analyses/decompiler/optimization_passes/base_ptr_save_simplifier.py +157 -0
  92. angr/analyses/decompiler/optimization_passes/call_stmt_rewriter.py +46 -0
  93. angr/analyses/decompiler/optimization_passes/code_motion.py +362 -0
  94. angr/analyses/decompiler/optimization_passes/condition_constprop.py +219 -0
  95. angr/analyses/decompiler/optimization_passes/const_derefs.py +266 -0
  96. angr/analyses/decompiler/optimization_passes/const_prop_reverter.py +365 -0
  97. angr/analyses/decompiler/optimization_passes/cross_jump_reverter.py +106 -0
  98. angr/analyses/decompiler/optimization_passes/deadblock_remover.py +82 -0
  99. angr/analyses/decompiler/optimization_passes/determine_load_sizes.py +64 -0
  100. angr/analyses/decompiler/optimization_passes/div_simplifier.py +425 -0
  101. angr/analyses/decompiler/optimization_passes/duplication_reverter/__init__.py +5 -0
  102. angr/analyses/decompiler/optimization_passes/duplication_reverter/ail_merge_graph.py +503 -0
  103. angr/analyses/decompiler/optimization_passes/duplication_reverter/duplication_reverter.py +1218 -0
  104. angr/analyses/decompiler/optimization_passes/duplication_reverter/errors.py +16 -0
  105. angr/analyses/decompiler/optimization_passes/duplication_reverter/similarity.py +126 -0
  106. angr/analyses/decompiler/optimization_passes/duplication_reverter/utils.py +167 -0
  107. angr/analyses/decompiler/optimization_passes/eager_std_string_concatenation.py +165 -0
  108. angr/analyses/decompiler/optimization_passes/engine_base.py +500 -0
  109. angr/analyses/decompiler/optimization_passes/expr_op_swapper.py +135 -0
  110. angr/analyses/decompiler/optimization_passes/flip_boolean_cmp.py +113 -0
  111. angr/analyses/decompiler/optimization_passes/inlined_string_transformation_simplifier.py +615 -0
  112. angr/analyses/decompiler/optimization_passes/ite_expr_converter.py +224 -0
  113. angr/analyses/decompiler/optimization_passes/ite_region_converter.py +335 -0
  114. angr/analyses/decompiler/optimization_passes/lowered_switch_simplifier.py +922 -0
  115. angr/analyses/decompiler/optimization_passes/mod_simplifier.py +99 -0
  116. angr/analyses/decompiler/optimization_passes/optimization_pass.py +659 -0
  117. angr/analyses/decompiler/optimization_passes/register_save_area_simplifier.py +221 -0
  118. angr/analyses/decompiler/optimization_passes/ret_addr_save_simplifier.py +171 -0
  119. angr/analyses/decompiler/optimization_passes/ret_deduplicator.py +222 -0
  120. angr/analyses/decompiler/optimization_passes/return_duplicator_base.py +640 -0
  121. angr/analyses/decompiler/optimization_passes/return_duplicator_high.py +61 -0
  122. angr/analyses/decompiler/optimization_passes/return_duplicator_low.py +235 -0
  123. angr/analyses/decompiler/optimization_passes/stack_canary_simplifier.py +333 -0
  124. angr/analyses/decompiler/optimization_passes/switch_default_case_duplicator.py +149 -0
  125. angr/analyses/decompiler/optimization_passes/switch_reused_entry_rewriter.py +102 -0
  126. angr/analyses/decompiler/optimization_passes/tag_slicer.py +41 -0
  127. angr/analyses/decompiler/optimization_passes/win_stack_canary_simplifier.py +421 -0
  128. angr/analyses/decompiler/optimization_passes/x86_gcc_getpc_simplifier.py +88 -0
  129. angr/analyses/decompiler/peephole_optimizations/__init__.py +127 -0
  130. angr/analyses/decompiler/peephole_optimizations/a_div_const_add_a_mul_n_div_const.py +42 -0
  131. angr/analyses/decompiler/peephole_optimizations/a_mul_const_div_shr_const.py +38 -0
  132. angr/analyses/decompiler/peephole_optimizations/a_mul_const_sub_a.py +34 -0
  133. angr/analyses/decompiler/peephole_optimizations/a_shl_const_sub_a.py +34 -0
  134. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div.py +25 -0
  135. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div_const_mul_const.py +57 -0
  136. angr/analyses/decompiler/peephole_optimizations/a_sub_a_shr_const_shr_const.py +37 -0
  137. angr/analyses/decompiler/peephole_optimizations/a_sub_a_sub_n.py +23 -0
  138. angr/analyses/decompiler/peephole_optimizations/arm_cmpf.py +236 -0
  139. angr/analyses/decompiler/peephole_optimizations/base.py +157 -0
  140. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_add_n.py +34 -0
  141. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_and_mask.py +36 -0
  142. angr/analyses/decompiler/peephole_optimizations/bitwise_or_to_logical_or.py +34 -0
  143. angr/analyses/decompiler/peephole_optimizations/bool_expr_xor_1.py +27 -0
  144. angr/analyses/decompiler/peephole_optimizations/bswap.py +142 -0
  145. angr/analyses/decompiler/peephole_optimizations/cas_intrinsics.py +115 -0
  146. angr/analyses/decompiler/peephole_optimizations/cmpord_rewriter.py +71 -0
  147. angr/analyses/decompiler/peephole_optimizations/coalesce_adjacent_shrs.py +39 -0
  148. angr/analyses/decompiler/peephole_optimizations/coalesce_same_cascading_ifs.py +28 -0
  149. angr/analyses/decompiler/peephole_optimizations/const_mull_a_shift.py +189 -0
  150. angr/analyses/decompiler/peephole_optimizations/constant_derefs.py +44 -0
  151. angr/analyses/decompiler/peephole_optimizations/conv_a_sub0_shr_and.py +69 -0
  152. angr/analyses/decompiler/peephole_optimizations/conv_shl_shr.py +52 -0
  153. angr/analyses/decompiler/peephole_optimizations/eager_eval.py +372 -0
  154. angr/analyses/decompiler/peephole_optimizations/extended_byte_and_mask.py +56 -0
  155. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy.py +160 -0
  156. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy_consolidation.py +109 -0
  157. angr/analyses/decompiler/peephole_optimizations/inlined_wstrcpy.py +170 -0
  158. angr/analyses/decompiler/peephole_optimizations/invert_negated_logical_conjuction_disjunction.py +50 -0
  159. angr/analyses/decompiler/peephole_optimizations/one_sub_bool.py +33 -0
  160. angr/analyses/decompiler/peephole_optimizations/remove_cascading_conversions.py +45 -0
  161. angr/analyses/decompiler/peephole_optimizations/remove_cxx_destructor_calls.py +32 -0
  162. angr/analyses/decompiler/peephole_optimizations/remove_empty_if_body.py +46 -0
  163. angr/analyses/decompiler/peephole_optimizations/remove_noop_conversions.py +47 -0
  164. angr/analyses/decompiler/peephole_optimizations/remove_redundant_bitmasks.py +116 -0
  165. angr/analyses/decompiler/peephole_optimizations/remove_redundant_conversions.py +247 -0
  166. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_branch.py +30 -0
  167. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_comparisons.py +54 -0
  168. angr/analyses/decompiler/peephole_optimizations/remove_redundant_nots.py +36 -0
  169. angr/analyses/decompiler/peephole_optimizations/remove_redundant_reinterprets.py +44 -0
  170. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts.py +95 -0
  171. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts_around_comparators.py +44 -0
  172. angr/analyses/decompiler/peephole_optimizations/rewrite_bit_extractions.py +85 -0
  173. angr/analyses/decompiler/peephole_optimizations/rewrite_conv_mul.py +40 -0
  174. angr/analyses/decompiler/peephole_optimizations/rewrite_cxx_operator_calls.py +90 -0
  175. angr/analyses/decompiler/peephole_optimizations/rewrite_mips_gp_loads.py +49 -0
  176. angr/analyses/decompiler/peephole_optimizations/rol_ror.py +130 -0
  177. angr/analyses/decompiler/peephole_optimizations/sar_to_signed_div.py +112 -0
  178. angr/analyses/decompiler/peephole_optimizations/shl_to_mul.py +25 -0
  179. angr/analyses/decompiler/peephole_optimizations/simplify_pc_relative_loads.py +51 -0
  180. angr/analyses/decompiler/peephole_optimizations/single_bit_cond_to_boolexpr.py +53 -0
  181. angr/analyses/decompiler/peephole_optimizations/single_bit_xor.py +29 -0
  182. angr/analyses/decompiler/peephole_optimizations/tidy_stack_addr.py +131 -0
  183. angr/analyses/decompiler/peephole_optimizations/utils.py +18 -0
  184. angr/analyses/decompiler/presets/__init__.py +20 -0
  185. angr/analyses/decompiler/presets/basic.py +32 -0
  186. angr/analyses/decompiler/presets/fast.py +58 -0
  187. angr/analyses/decompiler/presets/full.py +68 -0
  188. angr/analyses/decompiler/presets/preset.py +37 -0
  189. angr/analyses/decompiler/redundant_label_remover.py +134 -0
  190. angr/analyses/decompiler/region_identifier.py +1218 -0
  191. angr/analyses/decompiler/region_simplifiers/__init__.py +5 -0
  192. angr/analyses/decompiler/region_simplifiers/cascading_cond_transformer.py +95 -0
  193. angr/analyses/decompiler/region_simplifiers/cascading_ifs.py +82 -0
  194. angr/analyses/decompiler/region_simplifiers/expr_folding.py +789 -0
  195. angr/analyses/decompiler/region_simplifiers/goto.py +178 -0
  196. angr/analyses/decompiler/region_simplifiers/if_.py +135 -0
  197. angr/analyses/decompiler/region_simplifiers/ifelse.py +91 -0
  198. angr/analyses/decompiler/region_simplifiers/loop.py +143 -0
  199. angr/analyses/decompiler/region_simplifiers/node_address_finder.py +24 -0
  200. angr/analyses/decompiler/region_simplifiers/region_simplifier.py +234 -0
  201. angr/analyses/decompiler/region_simplifiers/switch_cluster_simplifier.py +654 -0
  202. angr/analyses/decompiler/region_simplifiers/switch_expr_simplifier.py +87 -0
  203. angr/analyses/decompiler/region_walker.py +24 -0
  204. angr/analyses/decompiler/return_maker.py +72 -0
  205. angr/analyses/decompiler/seq_to_blocks.py +20 -0
  206. angr/analyses/decompiler/sequence_walker.py +257 -0
  207. angr/analyses/decompiler/ssailification/__init__.py +4 -0
  208. angr/analyses/decompiler/ssailification/rewriting.py +379 -0
  209. angr/analyses/decompiler/ssailification/rewriting_engine.py +1053 -0
  210. angr/analyses/decompiler/ssailification/rewriting_state.py +61 -0
  211. angr/analyses/decompiler/ssailification/ssailification.py +276 -0
  212. angr/analyses/decompiler/ssailification/traversal.py +124 -0
  213. angr/analyses/decompiler/ssailification/traversal_engine.py +297 -0
  214. angr/analyses/decompiler/ssailification/traversal_state.py +48 -0
  215. angr/analyses/decompiler/stack_item.py +36 -0
  216. angr/analyses/decompiler/structured_codegen/__init__.py +25 -0
  217. angr/analyses/decompiler/structured_codegen/base.py +132 -0
  218. angr/analyses/decompiler/structured_codegen/c.py +4069 -0
  219. angr/analyses/decompiler/structured_codegen/dummy.py +15 -0
  220. angr/analyses/decompiler/structured_codegen/dwarf_import.py +190 -0
  221. angr/analyses/decompiler/structuring/__init__.py +30 -0
  222. angr/analyses/decompiler/structuring/dream.py +1217 -0
  223. angr/analyses/decompiler/structuring/phoenix.py +2999 -0
  224. angr/analyses/decompiler/structuring/recursive_structurer.py +187 -0
  225. angr/analyses/decompiler/structuring/sailr.py +112 -0
  226. angr/analyses/decompiler/structuring/structurer_base.py +1067 -0
  227. angr/analyses/decompiler/structuring/structurer_nodes.py +438 -0
  228. angr/analyses/decompiler/utils.py +1106 -0
  229. angr/analyses/deobfuscator/__init__.py +18 -0
  230. angr/analyses/deobfuscator/api_obf_finder.py +325 -0
  231. angr/analyses/deobfuscator/api_obf_peephole_optimizer.py +51 -0
  232. angr/analyses/deobfuscator/api_obf_type2_finder.py +166 -0
  233. angr/analyses/deobfuscator/irsb_reg_collector.py +54 -0
  234. angr/analyses/deobfuscator/string_obf_finder.py +861 -0
  235. angr/analyses/deobfuscator/string_obf_opt_passes.py +133 -0
  236. angr/analyses/deobfuscator/string_obf_peephole_optimizer.py +47 -0
  237. angr/analyses/disassembly.py +1301 -0
  238. angr/analyses/disassembly_utils.py +101 -0
  239. angr/analyses/dominance_frontier.py +57 -0
  240. angr/analyses/fcp/__init__.py +4 -0
  241. angr/analyses/fcp/fcp.py +426 -0
  242. angr/analyses/find_objects_static.py +205 -0
  243. angr/analyses/flirt/__init__.py +47 -0
  244. angr/analyses/flirt/consts.py +160 -0
  245. angr/analyses/flirt/flirt.py +244 -0
  246. angr/analyses/flirt/flirt_function.py +20 -0
  247. angr/analyses/flirt/flirt_matcher.py +351 -0
  248. angr/analyses/flirt/flirt_module.py +32 -0
  249. angr/analyses/flirt/flirt_node.py +23 -0
  250. angr/analyses/flirt/flirt_sig.py +356 -0
  251. angr/analyses/flirt/flirt_utils.py +31 -0
  252. angr/analyses/forward_analysis/__init__.py +12 -0
  253. angr/analyses/forward_analysis/forward_analysis.py +530 -0
  254. angr/analyses/forward_analysis/job_info.py +64 -0
  255. angr/analyses/forward_analysis/visitors/__init__.py +14 -0
  256. angr/analyses/forward_analysis/visitors/call_graph.py +29 -0
  257. angr/analyses/forward_analysis/visitors/function_graph.py +86 -0
  258. angr/analyses/forward_analysis/visitors/graph.py +242 -0
  259. angr/analyses/forward_analysis/visitors/loop.py +29 -0
  260. angr/analyses/forward_analysis/visitors/single_node_graph.py +38 -0
  261. angr/analyses/identifier/__init__.py +5 -0
  262. angr/analyses/identifier/custom_callable.py +137 -0
  263. angr/analyses/identifier/errors.py +10 -0
  264. angr/analyses/identifier/func.py +60 -0
  265. angr/analyses/identifier/functions/__init__.py +37 -0
  266. angr/analyses/identifier/functions/atoi.py +73 -0
  267. angr/analyses/identifier/functions/based_atoi.py +125 -0
  268. angr/analyses/identifier/functions/fdprintf.py +123 -0
  269. angr/analyses/identifier/functions/free.py +64 -0
  270. angr/analyses/identifier/functions/int2str.py +287 -0
  271. angr/analyses/identifier/functions/malloc.py +111 -0
  272. angr/analyses/identifier/functions/memcmp.py +67 -0
  273. angr/analyses/identifier/functions/memcpy.py +89 -0
  274. angr/analyses/identifier/functions/memset.py +43 -0
  275. angr/analyses/identifier/functions/printf.py +123 -0
  276. angr/analyses/identifier/functions/recv_until.py +312 -0
  277. angr/analyses/identifier/functions/skip_calloc.py +73 -0
  278. angr/analyses/identifier/functions/skip_realloc.py +97 -0
  279. angr/analyses/identifier/functions/skip_recv_n.py +105 -0
  280. angr/analyses/identifier/functions/snprintf.py +112 -0
  281. angr/analyses/identifier/functions/sprintf.py +116 -0
  282. angr/analyses/identifier/functions/strcasecmp.py +33 -0
  283. angr/analyses/identifier/functions/strcmp.py +113 -0
  284. angr/analyses/identifier/functions/strcpy.py +43 -0
  285. angr/analyses/identifier/functions/strlen.py +27 -0
  286. angr/analyses/identifier/functions/strncmp.py +104 -0
  287. angr/analyses/identifier/functions/strncpy.py +65 -0
  288. angr/analyses/identifier/functions/strtol.py +89 -0
  289. angr/analyses/identifier/identify.py +825 -0
  290. angr/analyses/identifier/runner.py +360 -0
  291. angr/analyses/init_finder.py +289 -0
  292. angr/analyses/loop_analysis.py +349 -0
  293. angr/analyses/loopfinder.py +171 -0
  294. angr/analyses/patchfinder.py +137 -0
  295. angr/analyses/pathfinder.py +282 -0
  296. angr/analyses/propagator/__init__.py +5 -0
  297. angr/analyses/propagator/engine_base.py +62 -0
  298. angr/analyses/propagator/engine_vex.py +297 -0
  299. angr/analyses/propagator/propagator.py +361 -0
  300. angr/analyses/propagator/top_checker_mixin.py +218 -0
  301. angr/analyses/propagator/values.py +117 -0
  302. angr/analyses/propagator/vex_vars.py +68 -0
  303. angr/analyses/proximity_graph.py +444 -0
  304. angr/analyses/reaching_definitions/__init__.py +67 -0
  305. angr/analyses/reaching_definitions/call_trace.py +73 -0
  306. angr/analyses/reaching_definitions/dep_graph.py +433 -0
  307. angr/analyses/reaching_definitions/engine_ail.py +1130 -0
  308. angr/analyses/reaching_definitions/engine_vex.py +1127 -0
  309. angr/analyses/reaching_definitions/external_codeloc.py +0 -0
  310. angr/analyses/reaching_definitions/function_handler.py +637 -0
  311. angr/analyses/reaching_definitions/function_handler_library/__init__.py +12 -0
  312. angr/analyses/reaching_definitions/function_handler_library/stdio.py +268 -0
  313. angr/analyses/reaching_definitions/function_handler_library/stdlib.py +189 -0
  314. angr/analyses/reaching_definitions/function_handler_library/string.py +147 -0
  315. angr/analyses/reaching_definitions/function_handler_library/unistd.py +44 -0
  316. angr/analyses/reaching_definitions/heap_allocator.py +70 -0
  317. angr/analyses/reaching_definitions/rd_initializer.py +237 -0
  318. angr/analyses/reaching_definitions/rd_state.py +579 -0
  319. angr/analyses/reaching_definitions/reaching_definitions.py +581 -0
  320. angr/analyses/reaching_definitions/subject.py +65 -0
  321. angr/analyses/reassembler.py +2900 -0
  322. angr/analyses/s_liveness.py +203 -0
  323. angr/analyses/s_propagator.py +544 -0
  324. angr/analyses/s_reaching_definitions/__init__.py +12 -0
  325. angr/analyses/s_reaching_definitions/s_rda_model.py +135 -0
  326. angr/analyses/s_reaching_definitions/s_rda_view.py +315 -0
  327. angr/analyses/s_reaching_definitions/s_reaching_definitions.py +174 -0
  328. angr/analyses/smc.py +161 -0
  329. angr/analyses/soot_class_hierarchy.py +273 -0
  330. angr/analyses/stack_pointer_tracker.py +957 -0
  331. angr/analyses/static_hooker.py +53 -0
  332. angr/analyses/typehoon/__init__.py +5 -0
  333. angr/analyses/typehoon/dfa.py +118 -0
  334. angr/analyses/typehoon/lifter.py +122 -0
  335. angr/analyses/typehoon/simple_solver.py +1450 -0
  336. angr/analyses/typehoon/translator.py +279 -0
  337. angr/analyses/typehoon/typeconsts.py +336 -0
  338. angr/analyses/typehoon/typehoon.py +305 -0
  339. angr/analyses/typehoon/typevars.py +578 -0
  340. angr/analyses/typehoon/variance.py +11 -0
  341. angr/analyses/unpacker/__init__.py +6 -0
  342. angr/analyses/unpacker/obfuscation_detector.py +103 -0
  343. angr/analyses/unpacker/packing_detector.py +138 -0
  344. angr/analyses/variable_recovery/__init__.py +9 -0
  345. angr/analyses/variable_recovery/annotations.py +58 -0
  346. angr/analyses/variable_recovery/engine_ail.py +891 -0
  347. angr/analyses/variable_recovery/engine_base.py +1185 -0
  348. angr/analyses/variable_recovery/engine_vex.py +593 -0
  349. angr/analyses/variable_recovery/irsb_scanner.py +143 -0
  350. angr/analyses/variable_recovery/variable_recovery.py +573 -0
  351. angr/analyses/variable_recovery/variable_recovery_base.py +461 -0
  352. angr/analyses/variable_recovery/variable_recovery_fast.py +652 -0
  353. angr/analyses/veritesting.py +626 -0
  354. angr/analyses/vfg.py +1898 -0
  355. angr/analyses/vsa_ddg.py +420 -0
  356. angr/analyses/vtable.py +92 -0
  357. angr/analyses/xrefs.py +286 -0
  358. angr/angrdb/__init__.py +14 -0
  359. angr/angrdb/db.py +206 -0
  360. angr/angrdb/models.py +184 -0
  361. angr/angrdb/serializers/__init__.py +10 -0
  362. angr/angrdb/serializers/cfg_model.py +41 -0
  363. angr/angrdb/serializers/comments.py +60 -0
  364. angr/angrdb/serializers/funcs.py +61 -0
  365. angr/angrdb/serializers/kb.py +111 -0
  366. angr/angrdb/serializers/labels.py +59 -0
  367. angr/angrdb/serializers/loader.py +165 -0
  368. angr/angrdb/serializers/structured_code.py +125 -0
  369. angr/angrdb/serializers/variables.py +58 -0
  370. angr/angrdb/serializers/xrefs.py +48 -0
  371. angr/annocfg.py +317 -0
  372. angr/blade.py +426 -0
  373. angr/block.py +509 -0
  374. angr/callable.py +168 -0
  375. angr/calling_conventions.py +2580 -0
  376. angr/code_location.py +163 -0
  377. angr/codenode.py +145 -0
  378. angr/concretization_strategies/__init__.py +32 -0
  379. angr/concretization_strategies/any.py +17 -0
  380. angr/concretization_strategies/any_named.py +35 -0
  381. angr/concretization_strategies/base.py +81 -0
  382. angr/concretization_strategies/controlled_data.py +58 -0
  383. angr/concretization_strategies/eval.py +19 -0
  384. angr/concretization_strategies/logging.py +35 -0
  385. angr/concretization_strategies/max.py +25 -0
  386. angr/concretization_strategies/nonzero.py +16 -0
  387. angr/concretization_strategies/nonzero_range.py +22 -0
  388. angr/concretization_strategies/norepeats.py +37 -0
  389. angr/concretization_strategies/norepeats_range.py +37 -0
  390. angr/concretization_strategies/range.py +19 -0
  391. angr/concretization_strategies/signed_add.py +31 -0
  392. angr/concretization_strategies/single.py +15 -0
  393. angr/concretization_strategies/solutions.py +20 -0
  394. angr/concretization_strategies/unlimited_range.py +17 -0
  395. angr/distributed/__init__.py +9 -0
  396. angr/distributed/server.py +197 -0
  397. angr/distributed/worker.py +185 -0
  398. angr/engines/__init__.py +67 -0
  399. angr/engines/engine.py +29 -0
  400. angr/engines/failure.py +27 -0
  401. angr/engines/hook.py +68 -0
  402. angr/engines/light/__init__.py +23 -0
  403. angr/engines/light/data.py +681 -0
  404. angr/engines/light/engine.py +1285 -0
  405. angr/engines/pcode/__init__.py +9 -0
  406. angr/engines/pcode/behavior.py +997 -0
  407. angr/engines/pcode/cc.py +128 -0
  408. angr/engines/pcode/emulate.py +443 -0
  409. angr/engines/pcode/engine.py +242 -0
  410. angr/engines/pcode/lifter.py +1428 -0
  411. angr/engines/procedure.py +70 -0
  412. angr/engines/soot/__init__.py +5 -0
  413. angr/engines/soot/engine.py +410 -0
  414. angr/engines/soot/exceptions.py +17 -0
  415. angr/engines/soot/expressions/__init__.py +87 -0
  416. angr/engines/soot/expressions/arrayref.py +22 -0
  417. angr/engines/soot/expressions/base.py +21 -0
  418. angr/engines/soot/expressions/binop.py +28 -0
  419. angr/engines/soot/expressions/cast.py +22 -0
  420. angr/engines/soot/expressions/condition.py +35 -0
  421. angr/engines/soot/expressions/constants.py +47 -0
  422. angr/engines/soot/expressions/instanceOf.py +15 -0
  423. angr/engines/soot/expressions/instancefieldref.py +8 -0
  424. angr/engines/soot/expressions/invoke.py +114 -0
  425. angr/engines/soot/expressions/length.py +8 -0
  426. angr/engines/soot/expressions/local.py +8 -0
  427. angr/engines/soot/expressions/new.py +16 -0
  428. angr/engines/soot/expressions/newArray.py +54 -0
  429. angr/engines/soot/expressions/newMultiArray.py +86 -0
  430. angr/engines/soot/expressions/paramref.py +8 -0
  431. angr/engines/soot/expressions/phi.py +30 -0
  432. angr/engines/soot/expressions/staticfieldref.py +8 -0
  433. angr/engines/soot/expressions/thisref.py +7 -0
  434. angr/engines/soot/expressions/unsupported.py +7 -0
  435. angr/engines/soot/field_dispatcher.py +46 -0
  436. angr/engines/soot/method_dispatcher.py +46 -0
  437. angr/engines/soot/statements/__init__.py +44 -0
  438. angr/engines/soot/statements/assign.py +30 -0
  439. angr/engines/soot/statements/base.py +79 -0
  440. angr/engines/soot/statements/goto.py +14 -0
  441. angr/engines/soot/statements/identity.py +15 -0
  442. angr/engines/soot/statements/if_.py +19 -0
  443. angr/engines/soot/statements/invoke.py +12 -0
  444. angr/engines/soot/statements/return_.py +20 -0
  445. angr/engines/soot/statements/switch.py +41 -0
  446. angr/engines/soot/statements/throw.py +15 -0
  447. angr/engines/soot/values/__init__.py +38 -0
  448. angr/engines/soot/values/arrayref.py +122 -0
  449. angr/engines/soot/values/base.py +7 -0
  450. angr/engines/soot/values/constants.py +18 -0
  451. angr/engines/soot/values/instancefieldref.py +44 -0
  452. angr/engines/soot/values/local.py +18 -0
  453. angr/engines/soot/values/paramref.py +18 -0
  454. angr/engines/soot/values/staticfieldref.py +38 -0
  455. angr/engines/soot/values/strref.py +38 -0
  456. angr/engines/soot/values/thisref.py +149 -0
  457. angr/engines/successors.py +654 -0
  458. angr/engines/syscall.py +51 -0
  459. angr/engines/unicorn.py +490 -0
  460. angr/engines/vex/__init__.py +20 -0
  461. angr/engines/vex/claripy/__init__.py +5 -0
  462. angr/engines/vex/claripy/ccall.py +2097 -0
  463. angr/engines/vex/claripy/datalayer.py +141 -0
  464. angr/engines/vex/claripy/irop.py +1276 -0
  465. angr/engines/vex/heavy/__init__.py +16 -0
  466. angr/engines/vex/heavy/actions.py +231 -0
  467. angr/engines/vex/heavy/concretizers.py +403 -0
  468. angr/engines/vex/heavy/dirty.py +466 -0
  469. angr/engines/vex/heavy/heavy.py +370 -0
  470. angr/engines/vex/heavy/inspect.py +52 -0
  471. angr/engines/vex/heavy/resilience.py +85 -0
  472. angr/engines/vex/heavy/super_fastpath.py +34 -0
  473. angr/engines/vex/lifter.py +420 -0
  474. angr/engines/vex/light/__init__.py +11 -0
  475. angr/engines/vex/light/light.py +551 -0
  476. angr/engines/vex/light/resilience.py +74 -0
  477. angr/engines/vex/light/slicing.py +52 -0
  478. angr/errors.py +609 -0
  479. angr/exploration_techniques/__init__.py +53 -0
  480. angr/exploration_techniques/base.py +126 -0
  481. angr/exploration_techniques/bucketizer.py +94 -0
  482. angr/exploration_techniques/common.py +56 -0
  483. angr/exploration_techniques/dfs.py +37 -0
  484. angr/exploration_techniques/director.py +520 -0
  485. angr/exploration_techniques/driller_core.py +100 -0
  486. angr/exploration_techniques/explorer.py +152 -0
  487. angr/exploration_techniques/lengthlimiter.py +22 -0
  488. angr/exploration_techniques/local_loop_seer.py +65 -0
  489. angr/exploration_techniques/loop_seer.py +236 -0
  490. angr/exploration_techniques/manual_mergepoint.py +82 -0
  491. angr/exploration_techniques/memory_watcher.py +43 -0
  492. angr/exploration_techniques/oppologist.py +92 -0
  493. angr/exploration_techniques/slicecutor.py +118 -0
  494. angr/exploration_techniques/spiller.py +280 -0
  495. angr/exploration_techniques/spiller_db.py +27 -0
  496. angr/exploration_techniques/stochastic.py +56 -0
  497. angr/exploration_techniques/stub_stasher.py +19 -0
  498. angr/exploration_techniques/suggestions.py +159 -0
  499. angr/exploration_techniques/tech_builder.py +49 -0
  500. angr/exploration_techniques/threading.py +69 -0
  501. angr/exploration_techniques/timeout.py +34 -0
  502. angr/exploration_techniques/tracer.py +1098 -0
  503. angr/exploration_techniques/unique.py +106 -0
  504. angr/exploration_techniques/veritesting.py +37 -0
  505. angr/factory.py +404 -0
  506. angr/flirt/__init__.py +97 -0
  507. angr/flirt/build_sig.py +305 -0
  508. angr/graph_utils.py +0 -0
  509. angr/keyed_region.py +525 -0
  510. angr/knowledge_base.py +143 -0
  511. angr/knowledge_plugins/__init__.py +43 -0
  512. angr/knowledge_plugins/callsite_prototypes.py +53 -0
  513. angr/knowledge_plugins/cfg/__init__.py +18 -0
  514. angr/knowledge_plugins/cfg/cfg_manager.py +95 -0
  515. angr/knowledge_plugins/cfg/cfg_model.py +1045 -0
  516. angr/knowledge_plugins/cfg/cfg_node.py +536 -0
  517. angr/knowledge_plugins/cfg/indirect_jump.py +65 -0
  518. angr/knowledge_plugins/cfg/memory_data.py +156 -0
  519. angr/knowledge_plugins/comments.py +16 -0
  520. angr/knowledge_plugins/custom_strings.py +38 -0
  521. angr/knowledge_plugins/data.py +22 -0
  522. angr/knowledge_plugins/debug_variables.py +216 -0
  523. angr/knowledge_plugins/functions/__init__.py +9 -0
  524. angr/knowledge_plugins/functions/function.py +1772 -0
  525. angr/knowledge_plugins/functions/function_manager.py +526 -0
  526. angr/knowledge_plugins/functions/function_parser.py +299 -0
  527. angr/knowledge_plugins/functions/soot_function.py +128 -0
  528. angr/knowledge_plugins/indirect_jumps.py +35 -0
  529. angr/knowledge_plugins/key_definitions/__init__.py +17 -0
  530. angr/knowledge_plugins/key_definitions/atoms.py +374 -0
  531. angr/knowledge_plugins/key_definitions/constants.py +29 -0
  532. angr/knowledge_plugins/key_definitions/definition.py +214 -0
  533. angr/knowledge_plugins/key_definitions/environment.py +96 -0
  534. angr/knowledge_plugins/key_definitions/heap_address.py +33 -0
  535. angr/knowledge_plugins/key_definitions/key_definition_manager.py +82 -0
  536. angr/knowledge_plugins/key_definitions/live_definitions.py +1010 -0
  537. angr/knowledge_plugins/key_definitions/liveness.py +165 -0
  538. angr/knowledge_plugins/key_definitions/rd_model.py +171 -0
  539. angr/knowledge_plugins/key_definitions/tag.py +78 -0
  540. angr/knowledge_plugins/key_definitions/undefined.py +70 -0
  541. angr/knowledge_plugins/key_definitions/unknown_size.py +86 -0
  542. angr/knowledge_plugins/key_definitions/uses.py +178 -0
  543. angr/knowledge_plugins/labels.py +110 -0
  544. angr/knowledge_plugins/obfuscations.py +37 -0
  545. angr/knowledge_plugins/patches.py +126 -0
  546. angr/knowledge_plugins/plugin.py +24 -0
  547. angr/knowledge_plugins/propagations/__init__.py +10 -0
  548. angr/knowledge_plugins/propagations/prop_value.py +191 -0
  549. angr/knowledge_plugins/propagations/propagation_manager.py +60 -0
  550. angr/knowledge_plugins/propagations/propagation_model.py +73 -0
  551. angr/knowledge_plugins/propagations/states.py +552 -0
  552. angr/knowledge_plugins/structured_code.py +63 -0
  553. angr/knowledge_plugins/types.py +88 -0
  554. angr/knowledge_plugins/variables/__init__.py +8 -0
  555. angr/knowledge_plugins/variables/variable_access.py +113 -0
  556. angr/knowledge_plugins/variables/variable_manager.py +1368 -0
  557. angr/knowledge_plugins/xrefs/__init__.py +12 -0
  558. angr/knowledge_plugins/xrefs/xref.py +150 -0
  559. angr/knowledge_plugins/xrefs/xref_manager.py +127 -0
  560. angr/knowledge_plugins/xrefs/xref_types.py +16 -0
  561. angr/lib/angr_native.dll +0 -0
  562. angr/misc/__init__.py +19 -0
  563. angr/misc/ansi.py +47 -0
  564. angr/misc/autoimport.py +90 -0
  565. angr/misc/bug_report.py +117 -0
  566. angr/misc/hookset.py +106 -0
  567. angr/misc/loggers.py +130 -0
  568. angr/misc/picklable_lock.py +46 -0
  569. angr/misc/plugins.py +289 -0
  570. angr/misc/telemetry.py +54 -0
  571. angr/misc/testing.py +24 -0
  572. angr/misc/ux.py +31 -0
  573. angr/procedures/__init__.py +12 -0
  574. angr/procedures/advapi32/__init__.py +0 -0
  575. angr/procedures/cgc/__init__.py +3 -0
  576. angr/procedures/cgc/_terminate.py +11 -0
  577. angr/procedures/cgc/allocate.py +75 -0
  578. angr/procedures/cgc/deallocate.py +67 -0
  579. angr/procedures/cgc/fdwait.py +65 -0
  580. angr/procedures/cgc/random.py +67 -0
  581. angr/procedures/cgc/receive.py +93 -0
  582. angr/procedures/cgc/transmit.py +65 -0
  583. angr/procedures/definitions/__init__.py +779 -0
  584. angr/procedures/definitions/cgc.py +20 -0
  585. angr/procedures/definitions/glibc.py +8372 -0
  586. angr/procedures/definitions/gnulib.py +32 -0
  587. angr/procedures/definitions/libstdcpp.py +21 -0
  588. angr/procedures/definitions/linux_kernel.py +6171 -0
  589. angr/procedures/definitions/linux_loader.py +7 -0
  590. angr/procedures/definitions/msvcr.py +16 -0
  591. angr/procedures/definitions/parse_syscalls_from_local_system.py +50 -0
  592. angr/procedures/definitions/parse_win32json.py +2553 -0
  593. angr/procedures/definitions/types_stl.py +22 -0
  594. angr/procedures/definitions/types_win32.py +34482 -0
  595. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-4.py +30 -0
  596. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-6.py +26 -0
  597. angr/procedures/definitions/wdk_clfs.py +140 -0
  598. angr/procedures/definitions/wdk_fltmgr.py +556 -0
  599. angr/procedures/definitions/wdk_fwpkclnt.py +30 -0
  600. angr/procedures/definitions/wdk_fwpuclnt.py +316 -0
  601. angr/procedures/definitions/wdk_gdi32.py +366 -0
  602. angr/procedures/definitions/wdk_hal.py +78 -0
  603. angr/procedures/definitions/wdk_ksecdd.py +62 -0
  604. angr/procedures/definitions/wdk_ndis.py +238 -0
  605. angr/procedures/definitions/wdk_ntoskrnl.py +3451 -0
  606. angr/procedures/definitions/wdk_offreg.py +72 -0
  607. angr/procedures/definitions/wdk_pshed.py +36 -0
  608. angr/procedures/definitions/wdk_secur32.py +40 -0
  609. angr/procedures/definitions/wdk_vhfum.py +34 -0
  610. angr/procedures/definitions/win32_aclui.py +30 -0
  611. angr/procedures/definitions/win32_activeds.py +68 -0
  612. angr/procedures/definitions/win32_advapi32.py +1684 -0
  613. angr/procedures/definitions/win32_advpack.py +124 -0
  614. angr/procedures/definitions/win32_amsi.py +38 -0
  615. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-1.py +44 -0
  616. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-3.py +34 -0
  617. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-6.py +26 -0
  618. angr/procedures/definitions/win32_api-ms-win-core-apiquery-l2-1-0.py +26 -0
  619. angr/procedures/definitions/win32_api-ms-win-core-backgroundtask-l1-1-0.py +26 -0
  620. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-1.py +26 -0
  621. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-2.py +26 -0
  622. angr/procedures/definitions/win32_api-ms-win-core-enclave-l1-1-1.py +30 -0
  623. angr/procedures/definitions/win32_api-ms-win-core-errorhandling-l1-1-3.py +26 -0
  624. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-0.py +34 -0
  625. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-1.py +26 -0
  626. angr/procedures/definitions/win32_api-ms-win-core-file-fromapp-l1-1-0.py +46 -0
  627. angr/procedures/definitions/win32_api-ms-win-core-handle-l1-1-0.py +26 -0
  628. angr/procedures/definitions/win32_api-ms-win-core-ioring-l1-1-0.py +48 -0
  629. angr/procedures/definitions/win32_api-ms-win-core-marshal-l1-1-0.py +32 -0
  630. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-3.py +32 -0
  631. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-4.py +26 -0
  632. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-5.py +30 -0
  633. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-6.py +32 -0
  634. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-7.py +28 -0
  635. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-8.py +30 -0
  636. angr/procedures/definitions/win32_api-ms-win-core-path-l1-1-0.py +68 -0
  637. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-0.py +28 -0
  638. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-1.py +28 -0
  639. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-1.py +30 -0
  640. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-2.py +30 -0
  641. angr/procedures/definitions/win32_api-ms-win-core-slapi-l1-1-0.py +26 -0
  642. angr/procedures/definitions/win32_api-ms-win-core-state-helpers-l1-1-0.py +26 -0
  643. angr/procedures/definitions/win32_api-ms-win-core-synch-l1-2-0.py +30 -0
  644. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-0.py +26 -0
  645. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-3.py +28 -0
  646. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-4.py +28 -0
  647. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-6.py +26 -0
  648. angr/procedures/definitions/win32_api-ms-win-core-util-l1-1-1.py +28 -0
  649. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-0.py +44 -0
  650. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-1.py +38 -0
  651. angr/procedures/definitions/win32_api-ms-win-core-winrt-l1-1-0.py +40 -0
  652. angr/procedures/definitions/win32_api-ms-win-core-winrt-registration-l1-1-0.py +24 -0
  653. angr/procedures/definitions/win32_api-ms-win-core-winrt-robuffer-l1-1-0.py +24 -0
  654. angr/procedures/definitions/win32_api-ms-win-core-winrt-roparameterizediid-l1-1-0.py +28 -0
  655. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-0.py +76 -0
  656. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-1.py +24 -0
  657. angr/procedures/definitions/win32_api-ms-win-core-wow64-l1-1-1.py +30 -0
  658. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-0.py +42 -0
  659. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-1.py +34 -0
  660. angr/procedures/definitions/win32_api-ms-win-dx-d3dkmt-l1-1-0.py +26 -0
  661. angr/procedures/definitions/win32_api-ms-win-gaming-deviceinformation-l1-1-0.py +26 -0
  662. angr/procedures/definitions/win32_api-ms-win-gaming-expandedresources-l1-1-0.py +30 -0
  663. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-0.py +38 -0
  664. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-1.py +28 -0
  665. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-2.py +38 -0
  666. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-3.py +28 -0
  667. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-4.py +40 -0
  668. angr/procedures/definitions/win32_api-ms-win-mm-misc-l1-1-1.py +26 -0
  669. angr/procedures/definitions/win32_api-ms-win-net-isolation-l1-1-0.py +40 -0
  670. angr/procedures/definitions/win32_api-ms-win-security-base-l1-2-2.py +26 -0
  671. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-0.py +26 -0
  672. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-1.py +26 -0
  673. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-3.py +26 -0
  674. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-4.py +26 -0
  675. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-5.py +28 -0
  676. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-0.py +30 -0
  677. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-1.py +36 -0
  678. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-2.py +26 -0
  679. angr/procedures/definitions/win32_api-ms-win-shcore-stream-winrt-l1-1-0.py +28 -0
  680. angr/procedures/definitions/win32_api-ms-win-wsl-api-l1-1-0.py +38 -0
  681. angr/procedures/definitions/win32_apphelp.py +26 -0
  682. angr/procedures/definitions/win32_authz.py +90 -0
  683. angr/procedures/definitions/win32_avicap32.py +32 -0
  684. angr/procedures/definitions/win32_avifil32.py +144 -0
  685. angr/procedures/definitions/win32_avrt.py +52 -0
  686. angr/procedures/definitions/win32_bcp47mrm.py +28 -0
  687. angr/procedures/definitions/win32_bcrypt.py +130 -0
  688. angr/procedures/definitions/win32_bcryptprimitives.py +28 -0
  689. angr/procedures/definitions/win32_bluetoothapis.py +106 -0
  690. angr/procedures/definitions/win32_bthprops.py +34 -0
  691. angr/procedures/definitions/win32_bthprops_cpl.py +36 -0
  692. angr/procedures/definitions/win32_cabinet.py +68 -0
  693. angr/procedures/definitions/win32_certadm.py +60 -0
  694. angr/procedures/definitions/win32_certpoleng.py +40 -0
  695. angr/procedures/definitions/win32_cfgmgr32.py +502 -0
  696. angr/procedures/definitions/win32_chakra.py +198 -0
  697. angr/procedures/definitions/win32_cldapi.py +96 -0
  698. angr/procedures/definitions/win32_clfsw32.py +142 -0
  699. angr/procedures/definitions/win32_clusapi.py +584 -0
  700. angr/procedures/definitions/win32_comctl32.py +254 -0
  701. angr/procedures/definitions/win32_comdlg32.py +66 -0
  702. angr/procedures/definitions/win32_compstui.py +32 -0
  703. angr/procedures/definitions/win32_computecore.py +132 -0
  704. angr/procedures/definitions/win32_computenetwork.py +110 -0
  705. angr/procedures/definitions/win32_computestorage.py +48 -0
  706. angr/procedures/definitions/win32_comsvcs.py +38 -0
  707. angr/procedures/definitions/win32_coremessaging.py +24 -0
  708. angr/procedures/definitions/win32_credui.py +62 -0
  709. angr/procedures/definitions/win32_crypt32.py +482 -0
  710. angr/procedures/definitions/win32_cryptnet.py +34 -0
  711. angr/procedures/definitions/win32_cryptui.py +44 -0
  712. angr/procedures/definitions/win32_cryptxml.py +62 -0
  713. angr/procedures/definitions/win32_cscapi.py +32 -0
  714. angr/procedures/definitions/win32_d2d1.py +50 -0
  715. angr/procedures/definitions/win32_d3d10.py +78 -0
  716. angr/procedures/definitions/win32_d3d10_1.py +28 -0
  717. angr/procedures/definitions/win32_d3d11.py +30 -0
  718. angr/procedures/definitions/win32_d3d12.py +40 -0
  719. angr/procedures/definitions/win32_d3d9.py +46 -0
  720. angr/procedures/definitions/win32_d3dcompiler_47.py +76 -0
  721. angr/procedures/definitions/win32_d3dcsx.py +42 -0
  722. angr/procedures/definitions/win32_davclnt.py +60 -0
  723. angr/procedures/definitions/win32_dbgeng.py +32 -0
  724. angr/procedures/definitions/win32_dbghelp.py +462 -0
  725. angr/procedures/definitions/win32_dbgmodel.py +26 -0
  726. angr/procedures/definitions/win32_dciman32.py +64 -0
  727. angr/procedures/definitions/win32_dcomp.py +48 -0
  728. angr/procedures/definitions/win32_ddraw.py +38 -0
  729. angr/procedures/definitions/win32_deviceaccess.py +26 -0
  730. angr/procedures/definitions/win32_dflayout.py +26 -0
  731. angr/procedures/definitions/win32_dhcpcsvc.py +54 -0
  732. angr/procedures/definitions/win32_dhcpcsvc6.py +36 -0
  733. angr/procedures/definitions/win32_dhcpsapi.py +416 -0
  734. angr/procedures/definitions/win32_diagnosticdataquery.py +94 -0
  735. angr/procedures/definitions/win32_dinput8.py +26 -0
  736. angr/procedures/definitions/win32_directml.py +28 -0
  737. angr/procedures/definitions/win32_dmprocessxmlfiltered.py +26 -0
  738. angr/procedures/definitions/win32_dnsapi.py +152 -0
  739. angr/procedures/definitions/win32_drt.py +56 -0
  740. angr/procedures/definitions/win32_drtprov.py +42 -0
  741. angr/procedures/definitions/win32_drttransport.py +28 -0
  742. angr/procedures/definitions/win32_dsound.py +44 -0
  743. angr/procedures/definitions/win32_dsparse.py +62 -0
  744. angr/procedures/definitions/win32_dsprop.py +38 -0
  745. angr/procedures/definitions/win32_dssec.py +32 -0
  746. angr/procedures/definitions/win32_dsuiext.py +32 -0
  747. angr/procedures/definitions/win32_dwmapi.py +86 -0
  748. angr/procedures/definitions/win32_dwrite.py +26 -0
  749. angr/procedures/definitions/win32_dxcompiler.py +28 -0
  750. angr/procedures/definitions/win32_dxcore.py +26 -0
  751. angr/procedures/definitions/win32_dxgi.py +36 -0
  752. angr/procedures/definitions/win32_dxva2.py +100 -0
  753. angr/procedures/definitions/win32_eappcfg.py +52 -0
  754. angr/procedures/definitions/win32_eappprxy.py +60 -0
  755. angr/procedures/definitions/win32_efswrt.py +28 -0
  756. angr/procedures/definitions/win32_elscore.py +34 -0
  757. angr/procedures/definitions/win32_esent.py +482 -0
  758. angr/procedures/definitions/win32_evr.py +38 -0
  759. angr/procedures/definitions/win32_faultrep.py +32 -0
  760. angr/procedures/definitions/win32_fhsvcctl.py +38 -0
  761. angr/procedures/definitions/win32_firewallapi.py +30 -0
  762. angr/procedures/definitions/win32_fltlib.py +80 -0
  763. angr/procedures/definitions/win32_fontsub.py +28 -0
  764. angr/procedures/definitions/win32_forceinline.py +30 -0
  765. angr/procedures/definitions/win32_fwpuclnt.py +408 -0
  766. angr/procedures/definitions/win32_fxsutility.py +28 -0
  767. angr/procedures/definitions/win32_gdi32.py +886 -0
  768. angr/procedures/definitions/win32_gdiplus.py +1282 -0
  769. angr/procedures/definitions/win32_glu32.py +128 -0
  770. angr/procedures/definitions/win32_gpedit.py +36 -0
  771. angr/procedures/definitions/win32_hhctrl_ocx.py +28 -0
  772. angr/procedures/definitions/win32_hid.py +114 -0
  773. angr/procedures/definitions/win32_hlink.py +80 -0
  774. angr/procedures/definitions/win32_hrtfapo.py +26 -0
  775. angr/procedures/definitions/win32_httpapi.py +110 -0
  776. angr/procedures/definitions/win32_icm32.py +66 -0
  777. angr/procedures/definitions/win32_icmui.py +28 -0
  778. angr/procedures/definitions/win32_icu.py +2074 -0
  779. angr/procedures/definitions/win32_ieframe.py +82 -0
  780. angr/procedures/definitions/win32_imagehlp.py +76 -0
  781. angr/procedures/definitions/win32_imgutil.py +42 -0
  782. angr/procedures/definitions/win32_imm32.py +188 -0
  783. angr/procedures/definitions/win32_infocardapi.py +58 -0
  784. angr/procedures/definitions/win32_inkobjcore.py +78 -0
  785. angr/procedures/definitions/win32_iphlpapi.py +426 -0
  786. angr/procedures/definitions/win32_iscsidsc.py +182 -0
  787. angr/procedures/definitions/win32_isolatedwindowsenvironmentutils.py +28 -0
  788. angr/procedures/definitions/win32_kernel32.py +3185 -0
  789. angr/procedures/definitions/win32_kernelbase.py +36 -0
  790. angr/procedures/definitions/win32_keycredmgr.py +32 -0
  791. angr/procedures/definitions/win32_ksproxy_ax.py +36 -0
  792. angr/procedures/definitions/win32_ksuser.py +40 -0
  793. angr/procedures/definitions/win32_ktmw32.py +102 -0
  794. angr/procedures/definitions/win32_licenseprotection.py +28 -0
  795. angr/procedures/definitions/win32_loadperf.py +48 -0
  796. angr/procedures/definitions/win32_magnification.py +62 -0
  797. angr/procedures/definitions/win32_mapi32.py +156 -0
  798. angr/procedures/definitions/win32_mdmlocalmanagement.py +30 -0
  799. angr/procedures/definitions/win32_mdmregistration.py +54 -0
  800. angr/procedures/definitions/win32_mf.py +148 -0
  801. angr/procedures/definitions/win32_mfcore.py +28 -0
  802. angr/procedures/definitions/win32_mfplat.py +314 -0
  803. angr/procedures/definitions/win32_mfplay.py +26 -0
  804. angr/procedures/definitions/win32_mfreadwrite.py +34 -0
  805. angr/procedures/definitions/win32_mfsensorgroup.py +44 -0
  806. angr/procedures/definitions/win32_mfsrcsnk.py +28 -0
  807. angr/procedures/definitions/win32_mgmtapi.py +42 -0
  808. angr/procedures/definitions/win32_mi.py +26 -0
  809. angr/procedures/definitions/win32_mmdevapi.py +26 -0
  810. angr/procedures/definitions/win32_mpr.py +118 -0
  811. angr/procedures/definitions/win32_mprapi.py +248 -0
  812. angr/procedures/definitions/win32_mqrt.py +92 -0
  813. angr/procedures/definitions/win32_mrmsupport.py +78 -0
  814. angr/procedures/definitions/win32_msacm32.py +108 -0
  815. angr/procedures/definitions/win32_msajapi.py +1118 -0
  816. angr/procedures/definitions/win32_mscms.py +182 -0
  817. angr/procedures/definitions/win32_mscoree.py +78 -0
  818. angr/procedures/definitions/win32_msctfmonitor.py +30 -0
  819. angr/procedures/definitions/win32_msdelta.py +56 -0
  820. angr/procedures/definitions/win32_msdmo.py +46 -0
  821. angr/procedures/definitions/win32_msdrm.py +192 -0
  822. angr/procedures/definitions/win32_msi.py +552 -0
  823. angr/procedures/definitions/win32_msimg32.py +30 -0
  824. angr/procedures/definitions/win32_mspatcha.py +56 -0
  825. angr/procedures/definitions/win32_mspatchc.py +42 -0
  826. angr/procedures/definitions/win32_msports.py +38 -0
  827. angr/procedures/definitions/win32_msrating.py +62 -0
  828. angr/procedures/definitions/win32_mssign32.py +44 -0
  829. angr/procedures/definitions/win32_mstask.py +28 -0
  830. angr/procedures/definitions/win32_msvfw32.py +110 -0
  831. angr/procedures/definitions/win32_mswsock.py +56 -0
  832. angr/procedures/definitions/win32_mtxdm.py +26 -0
  833. angr/procedures/definitions/win32_ncrypt.py +102 -0
  834. angr/procedures/definitions/win32_ndfapi.py +56 -0
  835. angr/procedures/definitions/win32_netapi32.py +436 -0
  836. angr/procedures/definitions/win32_netsh.py +40 -0
  837. angr/procedures/definitions/win32_netshell.py +28 -0
  838. angr/procedures/definitions/win32_newdev.py +46 -0
  839. angr/procedures/definitions/win32_ninput.py +84 -0
  840. angr/procedures/definitions/win32_normaliz.py +28 -0
  841. angr/procedures/definitions/win32_ntdll.py +171 -0
  842. angr/procedures/definitions/win32_ntdllk.py +26 -0
  843. angr/procedures/definitions/win32_ntdsapi.py +186 -0
  844. angr/procedures/definitions/win32_ntlanman.py +44 -0
  845. angr/procedures/definitions/win32_odbc32.py +392 -0
  846. angr/procedures/definitions/win32_odbcbcp.py +78 -0
  847. angr/procedures/definitions/win32_ole32.py +658 -0
  848. angr/procedures/definitions/win32_oleacc.py +58 -0
  849. angr/procedures/definitions/win32_oleaut32.py +834 -0
  850. angr/procedures/definitions/win32_oledlg.py +70 -0
  851. angr/procedures/definitions/win32_ondemandconnroutehelper.py +34 -0
  852. angr/procedures/definitions/win32_opengl32.py +734 -0
  853. angr/procedures/definitions/win32_opmxbox.py +30 -0
  854. angr/procedures/definitions/win32_p2p.py +240 -0
  855. angr/procedures/definitions/win32_p2pgraph.py +98 -0
  856. angr/procedures/definitions/win32_pdh.py +220 -0
  857. angr/procedures/definitions/win32_peerdist.py +80 -0
  858. angr/procedures/definitions/win32_powrprof.py +192 -0
  859. angr/procedures/definitions/win32_prntvpt.py +46 -0
  860. angr/procedures/definitions/win32_projectedfslib.py +62 -0
  861. angr/procedures/definitions/win32_propsys.py +460 -0
  862. angr/procedures/definitions/win32_psapi.py +78 -0
  863. angr/procedures/definitions/win32_quartz.py +28 -0
  864. angr/procedures/definitions/win32_query.py +32 -0
  865. angr/procedures/definitions/win32_qwave.py +46 -0
  866. angr/procedures/definitions/win32_rasapi32.py +192 -0
  867. angr/procedures/definitions/win32_rasdlg.py +36 -0
  868. angr/procedures/definitions/win32_resutils.py +264 -0
  869. angr/procedures/definitions/win32_rometadata.py +24 -0
  870. angr/procedures/definitions/win32_rpcns4.py +146 -0
  871. angr/procedures/definitions/win32_rpcproxy.py +32 -0
  872. angr/procedures/definitions/win32_rpcrt4.py +918 -0
  873. angr/procedures/definitions/win32_rstrtmgr.py +46 -0
  874. angr/procedures/definitions/win32_rtm.py +176 -0
  875. angr/procedures/definitions/win32_rtutils.py +106 -0
  876. angr/procedures/definitions/win32_rtworkq.py +90 -0
  877. angr/procedures/definitions/win32_sas.py +26 -0
  878. angr/procedures/definitions/win32_scarddlg.py +34 -0
  879. angr/procedures/definitions/win32_schannel.py +42 -0
  880. angr/procedures/definitions/win32_sechost.py +28 -0
  881. angr/procedures/definitions/win32_secur32.py +202 -0
  882. angr/procedures/definitions/win32_sensapi.py +30 -0
  883. angr/procedures/definitions/win32_sensorsutilsv2.py +104 -0
  884. angr/procedures/definitions/win32_setupapi.py +692 -0
  885. angr/procedures/definitions/win32_sfc.py +36 -0
  886. angr/procedures/definitions/win32_shdocvw.py +30 -0
  887. angr/procedures/definitions/win32_shell32.py +512 -0
  888. angr/procedures/definitions/win32_shlwapi.py +744 -0
  889. angr/procedures/definitions/win32_slc.py +88 -0
  890. angr/procedures/definitions/win32_slcext.py +32 -0
  891. angr/procedures/definitions/win32_slwga.py +26 -0
  892. angr/procedures/definitions/win32_snmpapi.py +76 -0
  893. angr/procedures/definitions/win32_spoolss.py +76 -0
  894. angr/procedures/definitions/win32_srclient.py +26 -0
  895. angr/procedures/definitions/win32_srpapi.py +46 -0
  896. angr/procedures/definitions/win32_sspicli.py +38 -0
  897. angr/procedures/definitions/win32_sti.py +26 -0
  898. angr/procedures/definitions/win32_t2embed.py +52 -0
  899. angr/procedures/definitions/win32_tapi32.py +522 -0
  900. angr/procedures/definitions/win32_tbs.py +52 -0
  901. angr/procedures/definitions/win32_tdh.py +78 -0
  902. angr/procedures/definitions/win32_tokenbinding.py +44 -0
  903. angr/procedures/definitions/win32_traffic.py +64 -0
  904. angr/procedures/definitions/win32_txfw32.py +42 -0
  905. angr/procedures/definitions/win32_ualapi.py +32 -0
  906. angr/procedures/definitions/win32_uiautomationcore.py +220 -0
  907. angr/procedures/definitions/win32_urlmon.py +178 -0
  908. angr/procedures/definitions/win32_user32.py +1551 -0
  909. angr/procedures/definitions/win32_userenv.py +112 -0
  910. angr/procedures/definitions/win32_usp10.py +104 -0
  911. angr/procedures/definitions/win32_uxtheme.py +178 -0
  912. angr/procedures/definitions/win32_verifier.py +26 -0
  913. angr/procedures/definitions/win32_version.py +52 -0
  914. angr/procedures/definitions/win32_vertdll.py +38 -0
  915. angr/procedures/definitions/win32_virtdisk.py +82 -0
  916. angr/procedures/definitions/win32_vmdevicehost.py +50 -0
  917. angr/procedures/definitions/win32_vmsavedstatedumpprovider.py +110 -0
  918. angr/procedures/definitions/win32_vssapi.py +26 -0
  919. angr/procedures/definitions/win32_wcmapi.py +34 -0
  920. angr/procedures/definitions/win32_wdsbp.py +38 -0
  921. angr/procedures/definitions/win32_wdsclientapi.py +98 -0
  922. angr/procedures/definitions/win32_wdsmc.py +36 -0
  923. angr/procedures/definitions/win32_wdspxe.py +86 -0
  924. angr/procedures/definitions/win32_wdstptc.py +50 -0
  925. angr/procedures/definitions/win32_webauthn.py +50 -0
  926. angr/procedures/definitions/win32_webservices.py +410 -0
  927. angr/procedures/definitions/win32_websocket.py +50 -0
  928. angr/procedures/definitions/win32_wecapi.py +54 -0
  929. angr/procedures/definitions/win32_wer.py +66 -0
  930. angr/procedures/definitions/win32_wevtapi.py +94 -0
  931. angr/procedures/definitions/win32_winbio.py +132 -0
  932. angr/procedures/definitions/win32_windows_ai_machinelearning.py +26 -0
  933. angr/procedures/definitions/win32_windows_data_pdf.py +24 -0
  934. angr/procedures/definitions/win32_windows_media_mediacontrol.py +40 -0
  935. angr/procedures/definitions/win32_windows_networking.py +26 -0
  936. angr/procedures/definitions/win32_windows_ui_xaml.py +28 -0
  937. angr/procedures/definitions/win32_windowscodecs.py +42 -0
  938. angr/procedures/definitions/win32_winfax.py +136 -0
  939. angr/procedures/definitions/win32_winhttp.py +136 -0
  940. angr/procedures/definitions/win32_winhvemulation.py +32 -0
  941. angr/procedures/definitions/win32_winhvplatform.py +156 -0
  942. angr/procedures/definitions/win32_wininet.py +616 -0
  943. angr/procedures/definitions/win32_winml.py +26 -0
  944. angr/procedures/definitions/win32_winmm.py +376 -0
  945. angr/procedures/definitions/win32_winscard.py +164 -0
  946. angr/procedures/definitions/win32_winspool.py +364 -0
  947. angr/procedures/definitions/win32_winspool_drv.py +368 -0
  948. angr/procedures/definitions/win32_wintrust.py +144 -0
  949. angr/procedures/definitions/win32_winusb.py +92 -0
  950. angr/procedures/definitions/win32_wlanapi.py +144 -0
  951. angr/procedures/definitions/win32_wlanui.py +26 -0
  952. angr/procedures/definitions/win32_wldap32.py +510 -0
  953. angr/procedures/definitions/win32_wldp.py +42 -0
  954. angr/procedures/definitions/win32_wmvcore.py +46 -0
  955. angr/procedures/definitions/win32_wnvapi.py +28 -0
  956. angr/procedures/definitions/win32_wofutil.py +46 -0
  957. angr/procedures/definitions/win32_ws2_32.py +344 -0
  958. angr/procedures/definitions/win32_wscapi.py +36 -0
  959. angr/procedures/definitions/win32_wsclient.py +30 -0
  960. angr/procedures/definitions/win32_wsdapi.py +88 -0
  961. angr/procedures/definitions/win32_wsmsvc.py +90 -0
  962. angr/procedures/definitions/win32_wsnmp32.py +122 -0
  963. angr/procedures/definitions/win32_wtsapi32.py +150 -0
  964. angr/procedures/definitions/win32_xaudio2_8.py +32 -0
  965. angr/procedures/definitions/win32_xinput1_4.py +38 -0
  966. angr/procedures/definitions/win32_xinputuap.py +36 -0
  967. angr/procedures/definitions/win32_xmllite.py +36 -0
  968. angr/procedures/definitions/win32_xolehlp.py +32 -0
  969. angr/procedures/definitions/win32_xpsprint.py +28 -0
  970. angr/procedures/glibc/__ctype_b_loc.py +21 -0
  971. angr/procedures/glibc/__ctype_tolower_loc.py +21 -0
  972. angr/procedures/glibc/__ctype_toupper_loc.py +21 -0
  973. angr/procedures/glibc/__errno_location.py +7 -0
  974. angr/procedures/glibc/__init__.py +3 -0
  975. angr/procedures/glibc/__libc_init.py +37 -0
  976. angr/procedures/glibc/__libc_start_main.py +301 -0
  977. angr/procedures/glibc/dynamic_loading.py +20 -0
  978. angr/procedures/glibc/scanf.py +11 -0
  979. angr/procedures/glibc/sscanf.py +6 -0
  980. angr/procedures/gnulib/__init__.py +3 -0
  981. angr/procedures/gnulib/xalloc_die.py +14 -0
  982. angr/procedures/gnulib/xstrtol_fatal.py +14 -0
  983. angr/procedures/java/__init__.py +42 -0
  984. angr/procedures/java/unconstrained.py +65 -0
  985. angr/procedures/java_io/__init__.py +0 -0
  986. angr/procedures/java_io/read.py +12 -0
  987. angr/procedures/java_io/write.py +17 -0
  988. angr/procedures/java_jni/__init__.py +482 -0
  989. angr/procedures/java_jni/array_operations.py +312 -0
  990. angr/procedures/java_jni/class_and_interface_operations.py +31 -0
  991. angr/procedures/java_jni/field_access.py +173 -0
  992. angr/procedures/java_jni/global_and_local_refs.py +57 -0
  993. angr/procedures/java_jni/method_calls.py +365 -0
  994. angr/procedures/java_jni/not_implemented.py +26 -0
  995. angr/procedures/java_jni/object_operations.py +94 -0
  996. angr/procedures/java_jni/string_operations.py +87 -0
  997. angr/procedures/java_jni/version_information.py +12 -0
  998. angr/procedures/java_lang/__init__.py +0 -0
  999. angr/procedures/java_lang/character.py +30 -0
  1000. angr/procedures/java_lang/double.py +24 -0
  1001. angr/procedures/java_lang/exit.py +13 -0
  1002. angr/procedures/java_lang/getsimplename.py +18 -0
  1003. angr/procedures/java_lang/integer.py +43 -0
  1004. angr/procedures/java_lang/load_library.py +9 -0
  1005. angr/procedures/java_lang/math.py +15 -0
  1006. angr/procedures/java_lang/string.py +78 -0
  1007. angr/procedures/java_lang/stringbuilder.py +44 -0
  1008. angr/procedures/java_lang/system.py +18 -0
  1009. angr/procedures/java_util/__init__.py +0 -0
  1010. angr/procedures/java_util/collection.py +35 -0
  1011. angr/procedures/java_util/iterator.py +46 -0
  1012. angr/procedures/java_util/list.py +99 -0
  1013. angr/procedures/java_util/map.py +131 -0
  1014. angr/procedures/java_util/random.py +14 -0
  1015. angr/procedures/java_util/scanner_nextline.py +23 -0
  1016. angr/procedures/libc/__init__.py +3 -0
  1017. angr/procedures/libc/abort.py +9 -0
  1018. angr/procedures/libc/access.py +13 -0
  1019. angr/procedures/libc/atoi.py +14 -0
  1020. angr/procedures/libc/atol.py +13 -0
  1021. angr/procedures/libc/calloc.py +8 -0
  1022. angr/procedures/libc/closelog.py +10 -0
  1023. angr/procedures/libc/err.py +14 -0
  1024. angr/procedures/libc/error.py +54 -0
  1025. angr/procedures/libc/exit.py +11 -0
  1026. angr/procedures/libc/fclose.py +19 -0
  1027. angr/procedures/libc/feof.py +21 -0
  1028. angr/procedures/libc/fflush.py +16 -0
  1029. angr/procedures/libc/fgetc.py +27 -0
  1030. angr/procedures/libc/fgets.py +68 -0
  1031. angr/procedures/libc/fopen.py +63 -0
  1032. angr/procedures/libc/fprintf.py +25 -0
  1033. angr/procedures/libc/fputc.py +23 -0
  1034. angr/procedures/libc/fputs.py +24 -0
  1035. angr/procedures/libc/fread.py +24 -0
  1036. angr/procedures/libc/free.py +9 -0
  1037. angr/procedures/libc/fscanf.py +20 -0
  1038. angr/procedures/libc/fseek.py +34 -0
  1039. angr/procedures/libc/ftell.py +22 -0
  1040. angr/procedures/libc/fwrite.py +19 -0
  1041. angr/procedures/libc/getchar.py +13 -0
  1042. angr/procedures/libc/getdelim.py +99 -0
  1043. angr/procedures/libc/getegid.py +8 -0
  1044. angr/procedures/libc/geteuid.py +8 -0
  1045. angr/procedures/libc/getgid.py +8 -0
  1046. angr/procedures/libc/gets.py +68 -0
  1047. angr/procedures/libc/getuid.py +8 -0
  1048. angr/procedures/libc/malloc.py +12 -0
  1049. angr/procedures/libc/memcmp.py +69 -0
  1050. angr/procedures/libc/memcpy.py +38 -0
  1051. angr/procedures/libc/memset.py +72 -0
  1052. angr/procedures/libc/openlog.py +10 -0
  1053. angr/procedures/libc/perror.py +13 -0
  1054. angr/procedures/libc/printf.py +34 -0
  1055. angr/procedures/libc/putchar.py +13 -0
  1056. angr/procedures/libc/puts.py +19 -0
  1057. angr/procedures/libc/rand.py +8 -0
  1058. angr/procedures/libc/realloc.py +8 -0
  1059. angr/procedures/libc/rewind.py +12 -0
  1060. angr/procedures/libc/scanf.py +20 -0
  1061. angr/procedures/libc/setbuf.py +9 -0
  1062. angr/procedures/libc/setvbuf.py +7 -0
  1063. angr/procedures/libc/snprintf.py +36 -0
  1064. angr/procedures/libc/sprintf.py +25 -0
  1065. angr/procedures/libc/srand.py +7 -0
  1066. angr/procedures/libc/sscanf.py +13 -0
  1067. angr/procedures/libc/stpcpy.py +18 -0
  1068. angr/procedures/libc/strcat.py +14 -0
  1069. angr/procedures/libc/strchr.py +48 -0
  1070. angr/procedures/libc/strcmp.py +31 -0
  1071. angr/procedures/libc/strcpy.py +13 -0
  1072. angr/procedures/libc/strlen.py +114 -0
  1073. angr/procedures/libc/strncat.py +19 -0
  1074. angr/procedures/libc/strncmp.py +183 -0
  1075. angr/procedures/libc/strncpy.py +22 -0
  1076. angr/procedures/libc/strnlen.py +13 -0
  1077. angr/procedures/libc/strstr.py +101 -0
  1078. angr/procedures/libc/strtol.py +261 -0
  1079. angr/procedures/libc/strtoul.py +9 -0
  1080. angr/procedures/libc/system.py +13 -0
  1081. angr/procedures/libc/time.py +9 -0
  1082. angr/procedures/libc/tmpnam.py +20 -0
  1083. angr/procedures/libc/tolower.py +10 -0
  1084. angr/procedures/libc/toupper.py +10 -0
  1085. angr/procedures/libc/ungetc.py +20 -0
  1086. angr/procedures/libc/vsnprintf.py +17 -0
  1087. angr/procedures/libc/wchar.py +16 -0
  1088. angr/procedures/libstdcpp/__init__.py +0 -0
  1089. angr/procedures/libstdcpp/_unwind_resume.py +11 -0
  1090. angr/procedures/libstdcpp/std____throw_bad_alloc.py +13 -0
  1091. angr/procedures/libstdcpp/std____throw_bad_cast.py +13 -0
  1092. angr/procedures/libstdcpp/std____throw_length_error.py +13 -0
  1093. angr/procedures/libstdcpp/std____throw_logic_error.py +13 -0
  1094. angr/procedures/libstdcpp/std__terminate.py +13 -0
  1095. angr/procedures/linux_kernel/__init__.py +3 -0
  1096. angr/procedures/linux_kernel/access.py +18 -0
  1097. angr/procedures/linux_kernel/arch_prctl.py +34 -0
  1098. angr/procedures/linux_kernel/arm_user_helpers.py +59 -0
  1099. angr/procedures/linux_kernel/brk.py +18 -0
  1100. angr/procedures/linux_kernel/cwd.py +28 -0
  1101. angr/procedures/linux_kernel/fstat.py +138 -0
  1102. angr/procedures/linux_kernel/fstat64.py +170 -0
  1103. angr/procedures/linux_kernel/futex.py +17 -0
  1104. angr/procedures/linux_kernel/getegid.py +17 -0
  1105. angr/procedures/linux_kernel/geteuid.py +17 -0
  1106. angr/procedures/linux_kernel/getgid.py +17 -0
  1107. angr/procedures/linux_kernel/getpid.py +14 -0
  1108. angr/procedures/linux_kernel/getrlimit.py +24 -0
  1109. angr/procedures/linux_kernel/gettid.py +9 -0
  1110. angr/procedures/linux_kernel/getuid.py +17 -0
  1111. angr/procedures/linux_kernel/iovec.py +47 -0
  1112. angr/procedures/linux_kernel/lseek.py +42 -0
  1113. angr/procedures/linux_kernel/mmap.py +16 -0
  1114. angr/procedures/linux_kernel/mprotect.py +42 -0
  1115. angr/procedures/linux_kernel/munmap.py +8 -0
  1116. angr/procedures/linux_kernel/openat.py +26 -0
  1117. angr/procedures/linux_kernel/set_tid_address.py +8 -0
  1118. angr/procedures/linux_kernel/sigaction.py +19 -0
  1119. angr/procedures/linux_kernel/sigprocmask.py +23 -0
  1120. angr/procedures/linux_kernel/stat.py +23 -0
  1121. angr/procedures/linux_kernel/sysinfo.py +59 -0
  1122. angr/procedures/linux_kernel/tgkill.py +10 -0
  1123. angr/procedures/linux_kernel/time.py +34 -0
  1124. angr/procedures/linux_kernel/uid.py +30 -0
  1125. angr/procedures/linux_kernel/uname.py +29 -0
  1126. angr/procedures/linux_kernel/unlink.py +22 -0
  1127. angr/procedures/linux_kernel/vsyscall.py +16 -0
  1128. angr/procedures/linux_loader/__init__.py +3 -0
  1129. angr/procedures/linux_loader/_dl_initial_error_catch_tsd.py +7 -0
  1130. angr/procedures/linux_loader/_dl_rtld_lock.py +15 -0
  1131. angr/procedures/linux_loader/sim_loader.py +54 -0
  1132. angr/procedures/linux_loader/tls.py +40 -0
  1133. angr/procedures/msvcr/__getmainargs.py +16 -0
  1134. angr/procedures/msvcr/__init__.py +4 -0
  1135. angr/procedures/msvcr/_initterm.py +38 -0
  1136. angr/procedures/msvcr/fmode.py +31 -0
  1137. angr/procedures/ntdll/__init__.py +0 -0
  1138. angr/procedures/ntdll/exceptions.py +60 -0
  1139. angr/procedures/posix/__init__.py +3 -0
  1140. angr/procedures/posix/accept.py +29 -0
  1141. angr/procedures/posix/bind.py +13 -0
  1142. angr/procedures/posix/bzero.py +9 -0
  1143. angr/procedures/posix/chroot.py +27 -0
  1144. angr/procedures/posix/close.py +9 -0
  1145. angr/procedures/posix/closedir.py +7 -0
  1146. angr/procedures/posix/dup.py +56 -0
  1147. angr/procedures/posix/fcntl.py +10 -0
  1148. angr/procedures/posix/fdopen.py +76 -0
  1149. angr/procedures/posix/fileno.py +18 -0
  1150. angr/procedures/posix/fork.py +13 -0
  1151. angr/procedures/posix/getenv.py +35 -0
  1152. angr/procedures/posix/gethostbyname.py +43 -0
  1153. angr/procedures/posix/getpass.py +19 -0
  1154. angr/procedures/posix/getsockopt.py +11 -0
  1155. angr/procedures/posix/htonl.py +11 -0
  1156. angr/procedures/posix/htons.py +11 -0
  1157. angr/procedures/posix/inet_ntoa.py +59 -0
  1158. angr/procedures/posix/listen.py +13 -0
  1159. angr/procedures/posix/mmap.py +144 -0
  1160. angr/procedures/posix/open.py +18 -0
  1161. angr/procedures/posix/opendir.py +10 -0
  1162. angr/procedures/posix/poll.py +55 -0
  1163. angr/procedures/posix/pread64.py +46 -0
  1164. angr/procedures/posix/pthread.py +87 -0
  1165. angr/procedures/posix/pwrite64.py +46 -0
  1166. angr/procedures/posix/read.py +13 -0
  1167. angr/procedures/posix/readdir.py +62 -0
  1168. angr/procedures/posix/recv.py +13 -0
  1169. angr/procedures/posix/recvfrom.py +13 -0
  1170. angr/procedures/posix/select.py +48 -0
  1171. angr/procedures/posix/send.py +23 -0
  1172. angr/procedures/posix/setsockopt.py +9 -0
  1173. angr/procedures/posix/sigaction.py +23 -0
  1174. angr/procedures/posix/sim_time.py +48 -0
  1175. angr/procedures/posix/sleep.py +8 -0
  1176. angr/procedures/posix/socket.py +18 -0
  1177. angr/procedures/posix/strcasecmp.py +26 -0
  1178. angr/procedures/posix/strdup.py +18 -0
  1179. angr/procedures/posix/strtok_r.py +64 -0
  1180. angr/procedures/posix/syslog.py +15 -0
  1181. angr/procedures/posix/tz.py +9 -0
  1182. angr/procedures/posix/unlink.py +11 -0
  1183. angr/procedures/posix/usleep.py +8 -0
  1184. angr/procedures/posix/write.py +13 -0
  1185. angr/procedures/procedure_dict.py +50 -0
  1186. angr/procedures/stubs/CallReturn.py +13 -0
  1187. angr/procedures/stubs/NoReturnUnconstrained.py +13 -0
  1188. angr/procedures/stubs/Nop.py +7 -0
  1189. angr/procedures/stubs/PathTerminator.py +9 -0
  1190. angr/procedures/stubs/Redirect.py +18 -0
  1191. angr/procedures/stubs/ReturnChar.py +11 -0
  1192. angr/procedures/stubs/ReturnUnconstrained.py +24 -0
  1193. angr/procedures/stubs/UnresolvableCallTarget.py +9 -0
  1194. angr/procedures/stubs/UnresolvableJumpTarget.py +9 -0
  1195. angr/procedures/stubs/UserHook.py +18 -0
  1196. angr/procedures/stubs/__init__.py +3 -0
  1197. angr/procedures/stubs/b64_decode.py +15 -0
  1198. angr/procedures/stubs/caller.py +14 -0
  1199. angr/procedures/stubs/crazy_scanf.py +20 -0
  1200. angr/procedures/stubs/format_parser.py +669 -0
  1201. angr/procedures/stubs/syscall_stub.py +24 -0
  1202. angr/procedures/testing/__init__.py +3 -0
  1203. angr/procedures/testing/manyargs.py +9 -0
  1204. angr/procedures/testing/retreg.py +8 -0
  1205. angr/procedures/tracer/__init__.py +4 -0
  1206. angr/procedures/tracer/random.py +9 -0
  1207. angr/procedures/tracer/receive.py +23 -0
  1208. angr/procedures/tracer/transmit.py +26 -0
  1209. angr/procedures/uclibc/__init__.py +3 -0
  1210. angr/procedures/uclibc/__uClibc_main.py +10 -0
  1211. angr/procedures/win32/EncodePointer.py +7 -0
  1212. angr/procedures/win32/ExitProcess.py +9 -0
  1213. angr/procedures/win32/GetCommandLine.py +12 -0
  1214. angr/procedures/win32/GetCurrentProcessId.py +7 -0
  1215. angr/procedures/win32/GetCurrentThreadId.py +7 -0
  1216. angr/procedures/win32/GetLastInputInfo.py +40 -0
  1217. angr/procedures/win32/GetModuleHandle.py +29 -0
  1218. angr/procedures/win32/GetProcessAffinityMask.py +37 -0
  1219. angr/procedures/win32/InterlockedExchange.py +15 -0
  1220. angr/procedures/win32/IsProcessorFeaturePresent.py +7 -0
  1221. angr/procedures/win32/VirtualAlloc.py +114 -0
  1222. angr/procedures/win32/VirtualProtect.py +60 -0
  1223. angr/procedures/win32/__init__.py +3 -0
  1224. angr/procedures/win32/critical_section.py +12 -0
  1225. angr/procedures/win32/dynamic_loading.py +104 -0
  1226. angr/procedures/win32/file_handles.py +47 -0
  1227. angr/procedures/win32/gethostbyname.py +12 -0
  1228. angr/procedures/win32/heap.py +45 -0
  1229. angr/procedures/win32/is_bad_ptr.py +26 -0
  1230. angr/procedures/win32/local_storage.py +88 -0
  1231. angr/procedures/win32/mutex.py +11 -0
  1232. angr/procedures/win32/sim_time.py +135 -0
  1233. angr/procedures/win32/system_paths.py +35 -0
  1234. angr/procedures/win32_kernel/ExAllocatePool.py +13 -0
  1235. angr/procedures/win32_kernel/ExFreePoolWithTag.py +8 -0
  1236. angr/procedures/win32_kernel/__fastfail.py +15 -0
  1237. angr/procedures/win32_kernel/__init__.py +3 -0
  1238. angr/procedures/win_user32/__init__.py +0 -0
  1239. angr/procedures/win_user32/chars.py +15 -0
  1240. angr/procedures/win_user32/keyboard.py +14 -0
  1241. angr/procedures/win_user32/messagebox.py +49 -0
  1242. angr/project.py +837 -0
  1243. angr/protos/__init__.py +19 -0
  1244. angr/protos/cfg_pb2.py +31 -0
  1245. angr/protos/function_pb2.py +27 -0
  1246. angr/protos/primitives_pb2.py +52 -0
  1247. angr/protos/variables_pb2.py +44 -0
  1248. angr/protos/xrefs_pb2.py +25 -0
  1249. angr/py.typed +1 -0
  1250. angr/rustylib.cp310-win_amd64.pyd +0 -0
  1251. angr/rustylib.pyi +165 -0
  1252. angr/serializable.py +66 -0
  1253. angr/sim_manager.py +971 -0
  1254. angr/sim_options.py +438 -0
  1255. angr/sim_procedure.py +606 -0
  1256. angr/sim_state.py +901 -0
  1257. angr/sim_state_options.py +403 -0
  1258. angr/sim_type.py +3679 -0
  1259. angr/sim_variable.py +434 -0
  1260. angr/simos/__init__.py +47 -0
  1261. angr/simos/cgc.py +153 -0
  1262. angr/simos/javavm.py +458 -0
  1263. angr/simos/linux.py +509 -0
  1264. angr/simos/simos.py +444 -0
  1265. angr/simos/snimmuc_nxp.py +149 -0
  1266. angr/simos/userland.py +163 -0
  1267. angr/simos/windows.py +601 -0
  1268. angr/simos/xbox.py +32 -0
  1269. angr/slicer.py +352 -0
  1270. angr/state_hierarchy.py +262 -0
  1271. angr/state_plugins/__init__.py +84 -0
  1272. angr/state_plugins/callstack.py +398 -0
  1273. angr/state_plugins/cgc.py +155 -0
  1274. angr/state_plugins/debug_variables.py +192 -0
  1275. angr/state_plugins/filesystem.py +463 -0
  1276. angr/state_plugins/gdb.py +148 -0
  1277. angr/state_plugins/globals.py +65 -0
  1278. angr/state_plugins/heap/__init__.py +15 -0
  1279. angr/state_plugins/heap/heap_base.py +128 -0
  1280. angr/state_plugins/heap/heap_brk.py +136 -0
  1281. angr/state_plugins/heap/heap_freelist.py +213 -0
  1282. angr/state_plugins/heap/heap_libc.py +46 -0
  1283. angr/state_plugins/heap/heap_ptmalloc.py +620 -0
  1284. angr/state_plugins/heap/utils.py +22 -0
  1285. angr/state_plugins/history.py +548 -0
  1286. angr/state_plugins/inspect.py +375 -0
  1287. angr/state_plugins/javavm_classloader.py +134 -0
  1288. angr/state_plugins/jni_references.py +95 -0
  1289. angr/state_plugins/libc.py +1263 -0
  1290. angr/state_plugins/light_registers.py +168 -0
  1291. angr/state_plugins/log.py +84 -0
  1292. angr/state_plugins/loop_data.py +92 -0
  1293. angr/state_plugins/plugin.py +170 -0
  1294. angr/state_plugins/posix.py +703 -0
  1295. angr/state_plugins/preconstrainer.py +196 -0
  1296. angr/state_plugins/scratch.py +173 -0
  1297. angr/state_plugins/sim_action.py +326 -0
  1298. angr/state_plugins/sim_action_object.py +271 -0
  1299. angr/state_plugins/sim_event.py +59 -0
  1300. angr/state_plugins/solver.py +1127 -0
  1301. angr/state_plugins/symbolizer.py +291 -0
  1302. angr/state_plugins/trace_additions.py +738 -0
  1303. angr/state_plugins/uc_manager.py +94 -0
  1304. angr/state_plugins/unicorn_engine.py +1886 -0
  1305. angr/state_plugins/view.py +340 -0
  1306. angr/storage/__init__.py +15 -0
  1307. angr/storage/file.py +1210 -0
  1308. angr/storage/memory_mixins/__init__.py +317 -0
  1309. angr/storage/memory_mixins/actions_mixin.py +72 -0
  1310. angr/storage/memory_mixins/address_concretization_mixin.py +384 -0
  1311. angr/storage/memory_mixins/bvv_conversion_mixin.py +73 -0
  1312. angr/storage/memory_mixins/clouseau_mixin.py +137 -0
  1313. angr/storage/memory_mixins/conditional_store_mixin.py +25 -0
  1314. angr/storage/memory_mixins/convenient_mappings_mixin.py +256 -0
  1315. angr/storage/memory_mixins/default_filler_mixin.py +144 -0
  1316. angr/storage/memory_mixins/dirty_addrs_mixin.py +11 -0
  1317. angr/storage/memory_mixins/hex_dumper_mixin.py +82 -0
  1318. angr/storage/memory_mixins/javavm_memory_mixin.py +392 -0
  1319. angr/storage/memory_mixins/keyvalue_memory_mixin.py +42 -0
  1320. angr/storage/memory_mixins/label_merger_mixin.py +31 -0
  1321. angr/storage/memory_mixins/memory_mixin.py +174 -0
  1322. angr/storage/memory_mixins/multi_value_merger_mixin.py +79 -0
  1323. angr/storage/memory_mixins/name_resolution_mixin.py +67 -0
  1324. angr/storage/memory_mixins/paged_memory/__init__.py +0 -0
  1325. angr/storage/memory_mixins/paged_memory/page_backer_mixins.py +266 -0
  1326. angr/storage/memory_mixins/paged_memory/paged_memory_mixin.py +743 -0
  1327. angr/storage/memory_mixins/paged_memory/paged_memory_multivalue_mixin.py +65 -0
  1328. angr/storage/memory_mixins/paged_memory/pages/__init__.py +26 -0
  1329. angr/storage/memory_mixins/paged_memory/pages/base.py +31 -0
  1330. angr/storage/memory_mixins/paged_memory/pages/cooperation.py +341 -0
  1331. angr/storage/memory_mixins/paged_memory/pages/history_tracking_mixin.py +92 -0
  1332. angr/storage/memory_mixins/paged_memory/pages/ispo_mixin.py +55 -0
  1333. angr/storage/memory_mixins/paged_memory/pages/list_page.py +338 -0
  1334. angr/storage/memory_mixins/paged_memory/pages/multi_values.py +324 -0
  1335. angr/storage/memory_mixins/paged_memory/pages/mv_list_page.py +419 -0
  1336. angr/storage/memory_mixins/paged_memory/pages/permissions_mixin.py +36 -0
  1337. angr/storage/memory_mixins/paged_memory/pages/refcount_mixin.py +52 -0
  1338. angr/storage/memory_mixins/paged_memory/pages/ultra_page.py +503 -0
  1339. angr/storage/memory_mixins/paged_memory/privileged_mixin.py +36 -0
  1340. angr/storage/memory_mixins/paged_memory/stack_allocation_mixin.py +74 -0
  1341. angr/storage/memory_mixins/regioned_memory/__init__.py +17 -0
  1342. angr/storage/memory_mixins/regioned_memory/abstract_address_descriptor.py +36 -0
  1343. angr/storage/memory_mixins/regioned_memory/abstract_merger_mixin.py +31 -0
  1344. angr/storage/memory_mixins/regioned_memory/region_category_mixin.py +9 -0
  1345. angr/storage/memory_mixins/regioned_memory/region_data.py +246 -0
  1346. angr/storage/memory_mixins/regioned_memory/region_meta_mixin.py +241 -0
  1347. angr/storage/memory_mixins/regioned_memory/regioned_address_concretization_mixin.py +119 -0
  1348. angr/storage/memory_mixins/regioned_memory/regioned_memory_mixin.py +441 -0
  1349. angr/storage/memory_mixins/regioned_memory/static_find_mixin.py +69 -0
  1350. angr/storage/memory_mixins/simple_interface_mixin.py +71 -0
  1351. angr/storage/memory_mixins/simplification_mixin.py +15 -0
  1352. angr/storage/memory_mixins/size_resolution_mixin.py +143 -0
  1353. angr/storage/memory_mixins/slotted_memory.py +140 -0
  1354. angr/storage/memory_mixins/smart_find_mixin.py +161 -0
  1355. angr/storage/memory_mixins/symbolic_merger_mixin.py +16 -0
  1356. angr/storage/memory_mixins/top_merger_mixin.py +25 -0
  1357. angr/storage/memory_mixins/underconstrained_mixin.py +67 -0
  1358. angr/storage/memory_mixins/unwrapper_mixin.py +26 -0
  1359. angr/storage/memory_object.py +195 -0
  1360. angr/tablespecs.py +91 -0
  1361. angr/utils/__init__.py +46 -0
  1362. angr/utils/ail.py +70 -0
  1363. angr/utils/algo.py +34 -0
  1364. angr/utils/bits.py +46 -0
  1365. angr/utils/constants.py +9 -0
  1366. angr/utils/cowdict.py +63 -0
  1367. angr/utils/cpp.py +17 -0
  1368. angr/utils/doms.py +149 -0
  1369. angr/utils/dynamic_dictlist.py +89 -0
  1370. angr/utils/endness.py +18 -0
  1371. angr/utils/enums_conv.py +97 -0
  1372. angr/utils/env.py +12 -0
  1373. angr/utils/formatting.py +128 -0
  1374. angr/utils/funcid.py +159 -0
  1375. angr/utils/graph.py +898 -0
  1376. angr/utils/lazy_import.py +13 -0
  1377. angr/utils/library.py +211 -0
  1378. angr/utils/loader.py +55 -0
  1379. angr/utils/mp.py +66 -0
  1380. angr/utils/orderedset.py +74 -0
  1381. angr/utils/ssa/__init__.py +395 -0
  1382. angr/utils/ssa/tmp_uses_collector.py +23 -0
  1383. angr/utils/ssa/vvar_uses_collector.py +37 -0
  1384. angr/utils/tagged_interval_map.py +112 -0
  1385. angr/utils/timing.py +74 -0
  1386. angr/utils/types.py +151 -0
  1387. angr/vaults.py +367 -0
  1388. angr-9.2.156.dist-info/METADATA +112 -0
  1389. angr-9.2.156.dist-info/RECORD +1393 -0
  1390. angr-9.2.156.dist-info/WHEEL +5 -0
  1391. angr-9.2.156.dist-info/entry_points.txt +2 -0
  1392. angr-9.2.156.dist-info/licenses/LICENSE +27 -0
  1393. angr-9.2.156.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1772 @@
1
+ # pylint:disable=too-many-boolean-expressions
2
+ from __future__ import annotations
3
+ import os
4
+ import logging
5
+ import itertools
6
+ from collections import defaultdict
7
+ from collections.abc import Iterable
8
+ import contextlib
9
+ from typing import overload
10
+
11
+ import networkx
12
+ import pydemumble
13
+
14
+ from cle.backends.symbol import Symbol
15
+ from archinfo.arch_arm import get_real_address_if_arm
16
+ import claripy
17
+
18
+ from angr.knowledge_plugins.cfg.memory_data import MemoryDataSort
19
+ from angr.codenode import CodeNode, BlockNode, HookNode, SyscallNode
20
+ from angr.serializable import Serializable
21
+ from angr.errors import AngrValueError, SimEngineError, SimMemoryError
22
+ from angr.procedures import SIM_LIBRARIES
23
+ from angr.procedures.definitions import SimSyscallLibrary
24
+ from angr.protos import function_pb2
25
+ from angr.calling_conventions import DEFAULT_CC, default_cc
26
+ from angr.sim_type import SimTypeFunction, parse_defns
27
+ from angr.calling_conventions import SimCC
28
+ from angr.project import Project
29
+ from angr.utils.library import get_cpp_function_name
30
+ from .function_parser import FunctionParser
31
+
32
+ l = logging.getLogger(name=__name__)
33
+
34
+
35
+ class Function(Serializable):
36
+ """
37
+ A representation of a function and various information about it.
38
+ """
39
+
40
+ __slots__ = (
41
+ "_addr_to_block_node",
42
+ "_argument_registers",
43
+ "_argument_stack_variables",
44
+ "_block_sizes",
45
+ "_call_sites",
46
+ "_callout_sites",
47
+ "_cyclomatic_complexity",
48
+ "_endpoints",
49
+ "_function_manager",
50
+ "_jumpout_sites",
51
+ "_local_block_addrs",
52
+ "_local_blocks",
53
+ "_local_transition_graph",
54
+ "_name",
55
+ "_project",
56
+ "_ret_sites",
57
+ "_retout_sites",
58
+ "_returning",
59
+ "addr",
60
+ "addr",
61
+ "binary_name",
62
+ "bp_on_stack",
63
+ "calling_convention",
64
+ "from_signature",
65
+ "info",
66
+ "is_alignment",
67
+ "is_default_name",
68
+ "is_plt",
69
+ "is_prototype_guessed",
70
+ "is_simprocedure",
71
+ "is_syscall",
72
+ "normalized",
73
+ "previous_names",
74
+ "prototype",
75
+ "prototype_libname",
76
+ "ran_cca",
77
+ "retaddr_on_stack",
78
+ "sp_delta",
79
+ "startpoint",
80
+ "tags",
81
+ "transition_graph",
82
+ )
83
+
84
+ def __init__(
85
+ self,
86
+ function_manager,
87
+ addr,
88
+ name=None,
89
+ syscall=None,
90
+ is_simprocedure: bool | None = None,
91
+ binary_name=None,
92
+ is_plt: bool | None = None,
93
+ returning=None,
94
+ alignment=False,
95
+ calling_convention: SimCC | None = None,
96
+ prototype: SimTypeFunction | None = None,
97
+ prototype_libname: str | None = None,
98
+ is_prototype_guessed: bool = True,
99
+ ):
100
+ """
101
+ Function constructor. If the optional parameters are not provided, they will be automatically determined upon
102
+ the creation of a Function object.
103
+
104
+ :param addr: The address of the function.
105
+
106
+ The following parameters are optional.
107
+
108
+ :param str name: The name of the function.
109
+ :param bool syscall: Whether this function is a syscall or not.
110
+ :param bool is_simprocedure: Whether this function is a SimProcedure or not.
111
+ :param str binary_name: Name of the binary where this function is.
112
+ :param bool is_plt: If this function is a PLT entry.
113
+ :param bool returning: If this function returns.
114
+ :param bool alignment: If this function acts as an alignment filler. Such functions usually only contain nops.
115
+ """
116
+ self.transition_graph = networkx.classes.digraph.DiGraph()
117
+ self._local_transition_graph = None
118
+ self.normalized = False
119
+
120
+ # block nodes at whose ends the function returns
121
+ self._ret_sites: set[BlockNode] = set()
122
+ # block nodes at whose ends the function jumps out to another function (jumps outside)
123
+ self._jumpout_sites: set[BlockNode] = set()
124
+ # block nodes at whose ends the function calls out to another non-returning function
125
+ self._callout_sites: set[BlockNode] = set()
126
+ # block nodes that ends the function by returning out to another function (returns outside). This is rare.
127
+ self._retout_sites: set[BlockNode] = set()
128
+ # block nodes (basic block nodes) at whose ends the function terminates
129
+ # in theory, if everything works fine, endpoints == ret_sites | jumpout_sites | callout_sites
130
+ self._endpoints: defaultdict[str, set[BlockNode]] = defaultdict(set)
131
+
132
+ self._call_sites = {}
133
+ self.addr = addr
134
+ # startpoint can be None if the corresponding CFGNode is a syscall node
135
+ self.startpoint = None
136
+ self._function_manager = function_manager
137
+ self.is_syscall = None
138
+ self.is_simprocedure = False
139
+ self.is_alignment = alignment
140
+
141
+ # These properties are set by VariableManager
142
+ self.bp_on_stack = False
143
+ self.retaddr_on_stack = False
144
+ self.sp_delta = 0
145
+ # Calling convention
146
+ self.calling_convention = calling_convention
147
+ # Function prototype
148
+ self.prototype = prototype
149
+ self.prototype_libname = prototype_libname
150
+ self.is_prototype_guessed = is_prototype_guessed
151
+ # Whether this function returns or not. `None` means it's not determined yet
152
+ self._returning = None
153
+
154
+ self._addr_to_block_node = {} # map addresses to nodes. it's a cache of blocks. if a block is removed from the
155
+ # function, it may not be removed from _addr_to_block_node. if you want to list
156
+ # all blocks of a function, access .blocks.
157
+ self._block_sizes = {} # map addresses to block sizes
158
+ self._local_blocks = {} # a dict of all blocks inside the function
159
+ self._local_block_addrs = set() # a set of addresses of all blocks inside the function
160
+
161
+ self.info = {} # storing special information, like $gp values for MIPS32
162
+ self.tags = () # store function tags. can be set manually by performing CodeTagging analysis.
163
+
164
+ # Initialize _cyclomatic_complexity to None
165
+ self._cyclomatic_complexity = None
166
+
167
+ # TODO: Can we remove the following two members?
168
+ # Register offsets of those arguments passed in registers
169
+ self._argument_registers = []
170
+ # Stack offsets of those arguments passed in stack variables
171
+ self._argument_stack_variables = []
172
+
173
+ self._project: Project | None = None # will be initialized upon the first access to self.project
174
+
175
+ self.ran_cca = False # this is set by CompleteCallingConventions to avoid reprocessing failed functions
176
+
177
+ #
178
+ # Initialize unspecified properties
179
+ #
180
+
181
+ if syscall is not None:
182
+ self.is_syscall = syscall
183
+ else:
184
+ if self.project is None:
185
+ raise ValueError(
186
+ "'syscall' must be specified if you do not specify a function manager for this new function."
187
+ )
188
+
189
+ # Determine whether this function is a syscall or not
190
+ self.is_syscall = self.project.simos.is_syscall_addr(addr)
191
+
192
+ # Determine whether this function is a SimProcedure
193
+ if is_simprocedure is not None:
194
+ self.is_simprocedure = is_simprocedure
195
+ else:
196
+ if self.project is None:
197
+ raise ValueError(
198
+ "'is_simprocedure' must be specified if you do not specify a function manager for this new "
199
+ "function."
200
+ )
201
+
202
+ if self.is_syscall or self.project.is_hooked(addr):
203
+ self.is_simprocedure = True
204
+
205
+ # Determine if this function is a PLT entry
206
+ if is_plt is not None:
207
+ self.is_plt = is_plt
208
+ else:
209
+ # Whether this function is a PLT entry or not is primarily relying on the PLT detection in CLE; it may also
210
+ # be updated (to True) during CFG recovery.
211
+ if self.project is None:
212
+ raise ValueError(
213
+ "'is_plt' must be specified if you do not specify a function manager for this new function."
214
+ )
215
+
216
+ self.is_plt = self.project.loader.find_plt_stub_name(addr) is not None
217
+
218
+ # Determine the name of this function
219
+ if name is None:
220
+ self._name = self._get_initial_name()
221
+ else:
222
+ self.is_default_name = False
223
+ self._name = name
224
+ self.previous_names = []
225
+ self.from_signature: str | None = None
226
+
227
+ # Determine the name the binary where this function is.
228
+ if binary_name is not None:
229
+ self.binary_name = binary_name
230
+ else:
231
+ self.binary_name = self._get_initial_binary_name()
232
+
233
+ # Determine returning status for SimProcedures and Syscalls
234
+ if returning is not None:
235
+ self._returning = returning
236
+ else:
237
+ if self.project is None:
238
+ raise ValueError(
239
+ "'returning' must be specified if you do not specify a function manager for this new function."
240
+ )
241
+
242
+ self._returning = self._get_initial_returning()
243
+
244
+ self._init_prototype_and_calling_convention()
245
+
246
+ @property
247
+ def name(self):
248
+ return self._name
249
+
250
+ @name.setter
251
+ def name(self, v):
252
+ self.previous_names.append(self._name)
253
+ self._name = v
254
+ self._function_manager._kb.labels[self.addr] = v
255
+
256
+ @property
257
+ def project(self):
258
+ if self._project is None and self._function_manager is not None:
259
+ # try to set it from function manager
260
+ self._project: Project | None = self._function_manager._kb._project
261
+ return self._project
262
+
263
+ @property
264
+ def returning(self):
265
+ return self._returning
266
+
267
+ @returning.setter
268
+ def returning(self, v):
269
+ self._returning = v
270
+
271
+ @property
272
+ def blocks(self):
273
+ """
274
+ An iterator of all local blocks in the current function.
275
+
276
+ :return: angr.lifter.Block instances.
277
+ """
278
+
279
+ for block_addr, block in self._local_blocks.items():
280
+ with contextlib.suppress(SimEngineError, SimMemoryError):
281
+ yield self.get_block(
282
+ block_addr, size=block.size, byte_string=block.bytestr if isinstance(block, BlockNode) else None
283
+ )
284
+
285
+ @property
286
+ def cyclomatic_complexity(self):
287
+ """
288
+ The cyclomatic complexity of the function.
289
+
290
+ Cyclomatic complexity is a software metric used to indicate the complexity of a program.
291
+ It is a quantitative measure of the number of linearly independent paths through a program's source code.
292
+ It is computed using the formula: M = E - N + 2P, where
293
+ E = the number of edges in the graph,
294
+ N = the number of nodes in the graph,
295
+ P = the number of connected components.
296
+
297
+ The cyclomatic complexity value is lazily computed and cached for future use.
298
+ Initially this value is None until it is computed for the first time
299
+
300
+ :return: The cyclomatic complexity of the function.
301
+ :rtype: int
302
+ """
303
+ if self._cyclomatic_complexity is None:
304
+ self._cyclomatic_complexity = (
305
+ self.transition_graph.number_of_edges() - self.transition_graph.number_of_nodes() + 2
306
+ )
307
+ return self._cyclomatic_complexity
308
+
309
+ @property
310
+ def xrefs(self):
311
+ """
312
+ An iterator of all xrefs of the current function.
313
+
314
+ :return: angr.knowledge_plugins.xrefs.xref.XRef instances.
315
+ """
316
+ for block in self.blocks:
317
+ yield from self._function_manager._kb.xrefs.get_xrefs_by_ins_addr_region(
318
+ block.addr, block.addr + block.size
319
+ )
320
+
321
+ @property
322
+ def block_addrs(self):
323
+ """
324
+ An iterator of all local block addresses in the current function.
325
+
326
+ :return: block addresses.
327
+ """
328
+
329
+ return self._local_blocks.keys()
330
+
331
+ @property
332
+ def block_addrs_set(self):
333
+ """
334
+ Return a set of block addresses for a better performance of inclusion tests.
335
+
336
+ :return: A set of block addresses.
337
+ :rtype: set
338
+ """
339
+
340
+ return self._local_block_addrs
341
+
342
+ def get_block(self, addr: int, size: int | None = None, byte_string: bytes | None = None):
343
+ """
344
+ Getting a block out of the current function.
345
+
346
+ :param int addr: The address of the block.
347
+ :param int size: The size of the block. This is optional. If not provided, angr will load
348
+ :param byte_string:
349
+ :return:
350
+ """
351
+ if size is None and addr in self.block_addrs:
352
+ # we know the size
353
+ size = self._block_sizes[addr]
354
+
355
+ assert self.project is not None
356
+ block = self.project.factory.block(addr, size=size, byte_string=byte_string)
357
+ if size is None:
358
+ # update block_size dict
359
+ self._block_sizes[addr] = block.size
360
+ return block
361
+
362
+ # compatibility
363
+ _get_block = get_block
364
+
365
+ def get_block_size(self, addr: int) -> int | None:
366
+ return self._block_sizes.get(addr, None)
367
+
368
+ @property
369
+ def nodes(self) -> Iterable[CodeNode]:
370
+ return self.transition_graph.nodes()
371
+
372
+ def get_node(self, addr) -> BlockNode | None:
373
+ return self._addr_to_block_node.get(addr, None)
374
+
375
+ @property
376
+ def has_unresolved_jumps(self):
377
+ for addr in self.block_addrs:
378
+ if addr in self._function_manager._kb.unresolved_indirect_jumps:
379
+ b = self._function_manager._kb._project.factory.block(addr)
380
+ if b.vex.jumpkind == "Ijk_Boring":
381
+ return True
382
+ return False
383
+
384
+ @property
385
+ def has_unresolved_calls(self):
386
+ for addr in self.block_addrs:
387
+ if addr in self._function_manager._kb.unresolved_indirect_jumps:
388
+ b = self._function_manager._kb._project.factory.block(addr)
389
+ if b.vex.jumpkind == "Ijk_Call":
390
+ return True
391
+ return False
392
+
393
+ @property
394
+ def operations(self):
395
+ """
396
+ All of the operations that are done by this functions.
397
+ """
398
+ return [op for block in self.blocks for op in block.vex.operations]
399
+
400
+ @property
401
+ def code_constants(self):
402
+ """
403
+ All of the constants that are used by this functions's code.
404
+ """
405
+ # TODO: remove link register values
406
+ return [const.value for block in self.blocks for const in block.vex.constants]
407
+
408
+ @classmethod
409
+ def _get_cmsg(cls):
410
+ return function_pb2.Function() # pylint:disable=no-member
411
+
412
+ def serialize_to_cmessage(self):
413
+ return FunctionParser.serialize(self)
414
+
415
+ @classmethod
416
+ def parse_from_cmessage(cls, cmsg, **kwargs):
417
+ """
418
+ :param cmsg:
419
+
420
+ :return Function: The function instantiated out of the cmsg data.
421
+ """
422
+ return FunctionParser.parse_from_cmsg(cmsg, **kwargs)
423
+
424
+ def string_references(self, minimum_length=2):
425
+ """
426
+ All of the constant string references used by this function.
427
+
428
+ :param minimum_length: The minimum length of strings to find (default is 1)
429
+ :return: A generator yielding tuples of (address, string) where is address
430
+ is the location of the string in memory.
431
+ """
432
+
433
+ cfg = self._function_manager._kb.cfgs.get_most_accurate()
434
+
435
+ for x in self.xrefs:
436
+ try:
437
+ md = cfg.memory_data[x.dst]
438
+ except KeyError:
439
+ continue
440
+ if md.sort not in {MemoryDataSort.String, MemoryDataSort.UnicodeString}:
441
+ continue
442
+ if len(md.content) < minimum_length:
443
+ continue
444
+
445
+ yield (md.addr, md.content)
446
+
447
+ @property
448
+ def local_runtime_values(self):
449
+ """
450
+ Tries to find all runtime values of this function which do not come from inputs.
451
+ These values are generated by starting from a blank state and reanalyzing the basic blocks once each.
452
+ Function calls are skipped, and back edges are never taken so these values are often unreliable,
453
+ This function is good at finding simple constant addresses which the function will use or calculate.
454
+
455
+ :return: a set of constants
456
+ """
457
+ constants = set()
458
+
459
+ assert self.project is not None
460
+ if not self.project.loader.main_object.contains_addr(self.addr):
461
+ return constants
462
+
463
+ # FIXME the old way was better for architectures like mips, but we need the initial irsb
464
+ # reanalyze function with a new initial state (use persistent registers)
465
+ # initial_state = self._function_manager._cfg.get_any_irsb(self.addr).initial_state
466
+ # fresh_state = self.project.factory.blank_state(mode="fastpath")
467
+ # for reg in initial_state.arch.persistent_regs + ['ip']:
468
+ # fresh_state.registers.store(reg, initial_state.registers.load(reg))
469
+
470
+ # reanalyze function with a new initial state
471
+ fresh_state = self.project.factory.blank_state(mode="fastpath")
472
+ fresh_state.regs.ip = self.addr
473
+
474
+ graph_addrs = {x.addr for x in self.graph.nodes() if isinstance(x, BlockNode)}
475
+
476
+ # process the nodes in a breadth-first order keeping track of which nodes have already been analyzed
477
+ analyzed = set()
478
+ q = [fresh_state]
479
+ analyzed.add(fresh_state.solver.eval(fresh_state.ip))
480
+ while len(q) > 0:
481
+ state = q.pop()
482
+ # make sure its in this function
483
+ if state.solver.eval(state.ip) not in graph_addrs:
484
+ continue
485
+ # don't trace into simprocedures
486
+ if self.project.is_hooked(state.solver.eval(state.ip)):
487
+ continue
488
+ # don't trace outside of the binary
489
+ if not self.project.loader.main_object.contains_addr(state.solver.eval(state.ip)):
490
+ continue
491
+ # don't trace unreachable blocks
492
+ if state.history.jumpkind in {
493
+ "Ijk_EmWarn",
494
+ "Ijk_NoDecode",
495
+ "Ijk_MapFail",
496
+ "Ijk_NoRedir",
497
+ "Ijk_SigTRAP",
498
+ "Ijk_SigSEGV",
499
+ "Ijk_ClientReq",
500
+ }:
501
+ continue
502
+
503
+ curr_ip = state.solver.eval(state.ip)
504
+
505
+ # get runtime values from logs of successors
506
+ successors = self.project.factory.successors(state)
507
+ for succ in successors.flat_successors + successors.unsat_successors:
508
+ for a in succ.history.recent_actions:
509
+ for ao in a.all_objects:
510
+ if not isinstance(ao.ast, claripy.ast.Base):
511
+ constants.add(ao.ast)
512
+ elif not ao.ast.symbolic:
513
+ constants.add(succ.solver.eval(ao.ast))
514
+
515
+ # add successors to the queue to analyze
516
+ if not succ.solver.symbolic(succ.ip):
517
+ succ_ip = succ.solver.eval(succ.ip)
518
+ if succ_ip in self and succ_ip not in analyzed:
519
+ analyzed.add(succ_ip)
520
+ q.insert(0, succ)
521
+
522
+ # force jumps to missing successors
523
+ # (this is a slightly hacky way to force it to explore all the nodes in the function)
524
+ node = self.get_node(curr_ip)
525
+ if node is None:
526
+ # the node does not exist. maybe it's not a block node.
527
+ continue
528
+ missing = {x.addr for x in list(self.graph.successors(node))} - analyzed
529
+ for succ_addr in missing:
530
+ l.info("Forcing jump to missing successor: %#x", succ_addr)
531
+ if succ_addr not in analyzed:
532
+ all_successors = (
533
+ successors.unconstrained_successors + successors.flat_successors + successors.unsat_successors
534
+ )
535
+ if len(all_successors) > 0:
536
+ # set the ip of a copied successor to the successor address
537
+ succ = all_successors[0].copy()
538
+ succ.ip = succ_addr
539
+ analyzed.add(succ_addr)
540
+ q.insert(0, succ)
541
+ else:
542
+ l.warning("Could not reach successor: %#x", succ_addr)
543
+
544
+ return constants
545
+
546
+ @property
547
+ def num_arguments(self):
548
+ return len(self._argument_registers) + len(self._argument_stack_variables)
549
+
550
+ def __contains__(self, val):
551
+ if isinstance(val, int):
552
+ return val in self._block_sizes
553
+ return False
554
+
555
+ def __str__(self):
556
+ return (
557
+ f"Function {self.name} [{self.addr:#x}]\n"
558
+ f" Syscall: {self.is_syscall}\n"
559
+ f" SP difference: {self.sp_delta}\n"
560
+ f" Has return: {self.has_return}\n"
561
+ f" Returning: {'Unknown' if self.returning is None else self.returning}\n"
562
+ f" Alignment: {self.is_alignment}\n"
563
+ f" Arguments: reg: {self._argument_registers}, stack: {self._argument_stack_variables}\n"
564
+ f" Blocks: [{', '.join(f'{i:#x}' for i in self.block_addrs)}]\n"
565
+ f" Cyclomatic Complexity: {self.cyclomatic_complexity}\n"
566
+ f" Calling convention: {self.calling_convention}"
567
+ )
568
+
569
+ def __repr__(self):
570
+ if self.is_syscall:
571
+ return f"<Syscall function {self.name} ({hex(self.addr) if isinstance(self.addr, int) else self.addr})>"
572
+ return f"<Function {self.name} ({hex(self.addr) if isinstance(self.addr, int) else self.addr})>"
573
+
574
+ def __setstate__(self, state):
575
+ for k, v in state.items():
576
+ setattr(self, k, v)
577
+
578
+ def __getstate__(self):
579
+ # self._local_transition_graph is a cache. don't pickle it
580
+ d = {k: getattr(self, k) for k in self.__slots__}
581
+ d["_local_transition_graph"] = None
582
+ d["_project"] = None
583
+ d["_function_manager"] = None
584
+ return d
585
+
586
+ @property
587
+ def endpoints(self):
588
+ return list(itertools.chain(*self._endpoints.values()))
589
+
590
+ @property
591
+ def endpoints_with_type(self):
592
+ return self._endpoints
593
+
594
+ @property
595
+ def ret_sites(self):
596
+ return list(self._ret_sites)
597
+
598
+ @property
599
+ def jumpout_sites(self):
600
+ return list(self._jumpout_sites)
601
+
602
+ @property
603
+ def retout_sites(self):
604
+ return list(self._retout_sites)
605
+
606
+ @property
607
+ def callout_sites(self):
608
+ return list(self._callout_sites)
609
+
610
+ @property
611
+ def size(self):
612
+ return sum(self._block_sizes[addr] for addr in self._local_blocks)
613
+
614
+ @property
615
+ def binary(self):
616
+ """
617
+ Get the object this function belongs to.
618
+ :return: The object this function belongs to.
619
+ """
620
+ assert self.project is not None
621
+ return self.project.loader.find_object_containing(self.addr, membership_check=False)
622
+
623
+ @property
624
+ def offset(self) -> int:
625
+ """
626
+ :return: the function's binary offset (i.e., non-rebased address)
627
+ """
628
+ return self.addr - self.binary.mapped_base
629
+
630
+ @property
631
+ def symbol(self) -> None | Symbol:
632
+ """
633
+ :return: the function's Symbol, if any
634
+ """
635
+ return self.binary.loader.find_symbol(self.addr)
636
+
637
+ @property
638
+ def pseudocode(self) -> str | None:
639
+ """
640
+ :return: the function's pseudocode
641
+ """
642
+ dec = self.project.analyses.Decompiler(self, cfg=self._function_manager._kb.cfgs.get_most_accurate())
643
+ return dec.codegen.text if dec.codegen else None
644
+
645
+ def add_jumpout_site(self, node: CodeNode):
646
+ """
647
+ Add a custom jumpout site.
648
+
649
+ :param node: The address of the basic block that control flow leaves during this transition.
650
+ :return: None
651
+ """
652
+
653
+ node = self._register_node(True, node)
654
+ self._jumpout_sites.add(node)
655
+ self._add_endpoint(node, "transition")
656
+
657
+ def add_retout_site(self, node: CodeNode):
658
+ """
659
+ Add a custom retout site.
660
+
661
+ Retout (returning to outside of the function) sites are very rare. It mostly occurs during CFG recovery when we
662
+ incorrectly identify the beginning of a function in the first iteration, and then correctly identify that
663
+ function later in the same iteration (function alignments can lead to this bizarre case). We will mark all edges
664
+ going out of the header of that function as a outside edge, because all successors now belong to the
665
+ incorrectly-identified function. This identification error will be fixed in the second iteration of CFG
666
+ recovery. However, we still want to keep track of jumpouts/retouts during the first iteration so other logic in
667
+ CFG recovery still work.
668
+
669
+ :param node: The address of the basic block that control flow leaves the current function after a call.
670
+ :return: None
671
+ """
672
+
673
+ node = self._register_node(True, node)
674
+ self._retout_sites.add(node)
675
+ self._add_endpoint(node, "return")
676
+
677
+ def _get_initial_name(self):
678
+ """
679
+ Determine the most suitable name of the function.
680
+
681
+ :return: The initial function name.
682
+ :rtype: string
683
+ """
684
+
685
+ name = None
686
+ addr = self.addr
687
+
688
+ self.is_default_name = False
689
+ # Try to get a name from existing labels
690
+ if self._function_manager is not None and addr in self._function_manager._kb.labels:
691
+ name = self._function_manager._kb.labels[addr]
692
+
693
+ # try to get the name from a hook
694
+ if name is None and self.project is not None:
695
+ project = self.project
696
+ if project.is_hooked(addr):
697
+ hooker = project.hooked_by(addr)
698
+ if hooker is not None:
699
+ name = hooker.display_name
700
+ elif project.simos.is_syscall_addr(addr):
701
+ syscall_inst = project.simos.syscall_from_addr(addr)
702
+ if syscall_inst is not None:
703
+ name = syscall_inst.display_name
704
+
705
+ # generate an IDA-style sub_X name
706
+ if name is None:
707
+ self.is_default_name = True
708
+ name = f"sub_{addr:x}"
709
+
710
+ return name
711
+
712
+ def _get_initial_binary_name(self) -> str | None:
713
+ """
714
+ Determine the name of the binary where this function is.
715
+
716
+ :return: None
717
+ """
718
+
719
+ binary_name = None
720
+
721
+ # if this function is a simprocedure but not a syscall, use its library name as
722
+ # its binary name
723
+ # if it is a syscall, fall back to use self.binary.binary which explicitly says cle##kernel
724
+ if self.project and self.is_simprocedure and not self.is_syscall:
725
+ hooker = self.project.hooked_by(self.addr)
726
+ if hooker is not None:
727
+ binary_name = hooker.library_name
728
+
729
+ if binary_name is None and self.binary is not None and self.binary.binary:
730
+ binary_name = os.path.basename(self.binary.binary)
731
+
732
+ return binary_name
733
+
734
+ def _get_initial_returning(self):
735
+ """
736
+ Determine if this function returns or not *if it is hooked by a SimProcedure or a user hook*.
737
+
738
+ :return: True if the hooker returns, False otherwise.
739
+ :rtype: bool
740
+ """
741
+
742
+ hooker = None
743
+ if self.is_syscall:
744
+ hooker = self.project.simos.syscall_from_addr(self.addr)
745
+ elif self.is_simprocedure:
746
+ hooker = self.project.hooked_by(self.addr)
747
+ if hooker:
748
+ if hasattr(hooker, "DYNAMIC_RET") and hooker.DYNAMIC_RET:
749
+ return True
750
+ if hasattr(hooker, "NO_RET"):
751
+ return not hooker.NO_RET
752
+
753
+ # Cannot determine
754
+ return None
755
+
756
+ def _init_prototype_and_calling_convention(self) -> None:
757
+ """
758
+ Initialize prototype and calling convention from a SimProcedure, if available.
759
+ """
760
+ hooker = None
761
+ if self.is_syscall and self.project is not None and self.project.simos.is_syscall_addr(self.addr):
762
+ hooker = self.project.simos.syscall_from_addr(self.addr)
763
+ elif self.is_simprocedure and self.project is not None:
764
+ hooker = self.project.hooked_by(self.addr)
765
+ if hooker is None or hooker.guessed_prototype:
766
+ return
767
+
768
+ if hooker.prototype:
769
+ self.prototype_libname = hooker.library_name
770
+ self.prototype = hooker.prototype
771
+ self.is_prototype_guessed = False
772
+
773
+ cc = hooker.cc
774
+ if cc is None and self.project is not None:
775
+ arch = self.project.arch
776
+ if arch.name in DEFAULT_CC:
777
+ cc_cls = default_cc(
778
+ arch.name, platform=self.project.simos.name if self.project.simos is not None else None
779
+ )
780
+ if cc_cls is not None:
781
+ cc = cc_cls(arch)
782
+ self.calling_convention = cc
783
+
784
+ def _clear_transition_graph(self):
785
+ self._block_sizes = {}
786
+ self._addr_to_block_node = {}
787
+ self._local_blocks = {}
788
+ self._local_block_addrs = set()
789
+ self.startpoint = None
790
+ self.transition_graph = networkx.classes.digraph.DiGraph()
791
+ self._local_transition_graph = None
792
+
793
+ self._ret_sites = set()
794
+ self._jumpout_sites = set()
795
+ self._callout_sites = set()
796
+ self._retout_sites = set()
797
+ self._endpoints = defaultdict(set)
798
+ self._call_sites = {}
799
+
800
+ def _confirm_fakeret(self, src, dst):
801
+ if src not in self.transition_graph or dst not in self.transition_graph[src]:
802
+ raise AngrValueError(f"FakeRet edge ({src}, {dst}) is not in transition graph.")
803
+
804
+ data = self.transition_graph[src][dst]
805
+
806
+ if "type" not in data or data["type"] != "fake_return":
807
+ raise AngrValueError(f"Edge ({src}, {dst}) is not a FakeRet edge")
808
+
809
+ # it's confirmed. register the node if needed
810
+ if "outside" not in data or data["outside"] is False:
811
+ dst = self._register_node(True, dst)
812
+
813
+ self.transition_graph[src][dst]["confirmed"] = True
814
+
815
+ def _transit_to(
816
+ self, from_node: CodeNode, to_node, outside=False, ins_addr=None, stmt_idx=None, is_exception=False
817
+ ):
818
+ """
819
+ Registers an edge between basic blocks in this function's transition graph.
820
+ Arguments are CodeNode objects.
821
+
822
+ :param from_node The address of the basic block that control
823
+ flow leaves during this transition.
824
+ :param to_node The address of the basic block that control
825
+ flow enters during this transition.
826
+ :param bool outside: If this is a transition to another function, e.g. tail call optimization
827
+ :return: None
828
+ """
829
+
830
+ if outside:
831
+ from_node = self._register_node(True, from_node)
832
+ if to_node is not None:
833
+ to_node = self._register_node(False, to_node)
834
+
835
+ self._jumpout_sites.add(from_node)
836
+ else:
837
+ from_node = self._register_node(True, from_node)
838
+ if to_node is not None:
839
+ to_node = self._register_node(True, to_node)
840
+
841
+ type_ = "transition" if not is_exception else "exception"
842
+ if to_node is not None:
843
+ self.transition_graph.add_edge(
844
+ from_node, to_node, type=type_, outside=outside, ins_addr=ins_addr, stmt_idx=stmt_idx
845
+ )
846
+
847
+ if outside:
848
+ # this node is an endpoint of the current function
849
+ self._add_endpoint(from_node, type_)
850
+
851
+ # clear the cache
852
+ self._local_transition_graph = None
853
+
854
+ def _call_to(self, from_node, to_func, ret_node, stmt_idx=None, ins_addr=None, return_to_outside=False):
855
+ """
856
+ Registers an edge between the caller basic block and callee function.
857
+
858
+ :param from_addr: The basic block that control flow leaves during the transition.
859
+ :type from_addr: angr.knowledge.CodeNode
860
+ :param to_func: The function that we are calling
861
+ :type to_func: Function
862
+ :param ret_node The basic block that control flow should return to after the
863
+ function call.
864
+ :type to_func: angr.knowledge.CodeNode or None
865
+ :param stmt_idx: Statement ID of this call.
866
+ :type stmt_idx: int, str or None
867
+ :param ins_addr: Instruction address of this call.
868
+ :type ins_addr: int or None
869
+ """
870
+
871
+ from_node = self._register_node(True, from_node)
872
+
873
+ if to_func.is_syscall:
874
+ self.transition_graph.add_edge(from_node, to_func, type="syscall", stmt_idx=stmt_idx, ins_addr=ins_addr)
875
+ else:
876
+ self.transition_graph.add_edge(from_node, to_func, type="call", stmt_idx=stmt_idx, ins_addr=ins_addr)
877
+ if ret_node is not None:
878
+ ret_node = self._register_node(return_to_outside is False, ret_node)
879
+ self._fakeret_to(from_node, ret_node, to_outside=return_to_outside)
880
+
881
+ self._local_transition_graph = None
882
+
883
+ def _fakeret_to(self, from_node, to_node, confirmed=None, to_outside=False):
884
+ from_node = self._register_node(True, from_node)
885
+ if confirmed:
886
+ to_node = self._register_node(not to_outside, to_node)
887
+
888
+ if confirmed is None:
889
+ self.transition_graph.add_edge(from_node, to_node, type="fake_return", outside=to_outside)
890
+ else:
891
+ self.transition_graph.add_edge(
892
+ from_node, to_node, type="fake_return", confirmed=confirmed, outside=to_outside
893
+ )
894
+
895
+ self._local_transition_graph = None
896
+
897
+ def _remove_fakeret(self, from_node, to_node):
898
+ self.transition_graph.remove_edge(from_node, to_node)
899
+
900
+ self._local_transition_graph = None
901
+
902
+ def _return_from_call(self, from_func, to_node, to_outside=False):
903
+ self.transition_graph.add_edge(from_func, to_node, type="return", to_outside=to_outside)
904
+ for _, _, data in self.transition_graph.in_edges(to_node, data=True):
905
+ if "type" in data and data["type"] == "fake_return":
906
+ data["confirmed"] = True
907
+
908
+ self._local_transition_graph = None
909
+
910
+ def _update_local_blocks(self, node: CodeNode):
911
+ if node.addr not in self._local_blocks or self._local_blocks[node.addr] != node:
912
+ self._local_blocks[node.addr] = node
913
+ self._local_block_addrs.add(node.addr)
914
+
915
+ def _update_addr_to_block_cache(self, node: BlockNode):
916
+ if node.addr not in self._addr_to_block_node:
917
+ self._addr_to_block_node[node.addr] = node
918
+
919
+ @overload
920
+ def _register_node(self, is_local: bool, node: CodeNode) -> CodeNode: ...
921
+
922
+ @overload
923
+ def _register_node(self, is_local: bool, node: Function) -> Function: ...
924
+
925
+ def _register_node(self, is_local: bool, node: CodeNode | Function) -> CodeNode | Function:
926
+ # if the node already exists and is the same, we reuse the existing node
927
+ if is_local and self._local_blocks.get(node.addr, None) == node:
928
+ return self._local_blocks[node.addr]
929
+
930
+ if node.addr not in self and node not in self.transition_graph:
931
+ # only add each node to the graph once
932
+ self.transition_graph.add_node(node)
933
+
934
+ if not isinstance(node, CodeNode):
935
+ # function and other things bail here
936
+ return node
937
+
938
+ # this is either a new node or a different node at the same address
939
+ node._graph = self.transition_graph
940
+ if self._block_sizes.get(node.addr, 0) == 0:
941
+ self._block_sizes[node.addr] = node.size
942
+ if node.addr == self.addr and (self.startpoint is None or not self.startpoint.is_hook):
943
+ self.startpoint = node
944
+ if is_local and node.addr not in self._local_blocks:
945
+ self._update_local_blocks(node)
946
+ # add BlockNodes to the addr_to_block_node cache if not already there
947
+ if isinstance(node, BlockNode):
948
+ self._update_addr_to_block_cache(node)
949
+ # else:
950
+ # # checks that we don't have multiple block nodes at a single address
951
+ # assert node == self._addr_to_block_node[node.addr]
952
+ return node
953
+
954
+ def _add_return_site(self, return_site: CodeNode):
955
+ """
956
+ Registers a basic block as a site for control flow to return from this function.
957
+
958
+ :param return_site: The block node that ends with a return.
959
+ """
960
+ return_site = self._register_node(True, return_site)
961
+
962
+ self._ret_sites.add(return_site)
963
+ # A return site must be an endpoint of the function - you cannot continue execution of the current function
964
+ # after returning
965
+ self._add_endpoint(return_site, "return")
966
+
967
+ def _add_call_site(self, call_site_addr, call_target_addr, retn_addr):
968
+ """
969
+ Registers a basic block as calling a function and returning somewhere.
970
+
971
+ :param call_site_addr: The address of a basic block that ends in a call.
972
+ :param call_target_addr: The address of the target of said call.
973
+ :param retn_addr: The address that said call will return to.
974
+ """
975
+ self._call_sites[call_site_addr] = (call_target_addr, retn_addr)
976
+
977
+ def _add_endpoint(self, endpoint_node, sort):
978
+ """
979
+ Registers an endpoint with a type of `sort`. The type can be one of the following:
980
+ - call: calling a function that does not return
981
+ - return: returning from the current function
982
+ - transition: a jump/branch targeting a different function
983
+
984
+ It is possible for a block to act as two different sorts of endpoints. For example, consider the following
985
+ block:
986
+
987
+ .text:0000000000024350 mov eax, 1
988
+ .text:0000000000024355 lock xadd [rdi+4], eax
989
+ .text:000000000002435A retn
990
+
991
+ VEX code:
992
+ 00 | ------ IMark(0x424350, 5, 0) ------
993
+ 01 | PUT(rax) = 0x0000000000000001
994
+ 02 | PUT(rip) = 0x0000000000424355
995
+ 03 | ------ IMark(0x424355, 5, 0) ------
996
+ 04 | t11 = GET:I64(rdi)
997
+ 05 | t10 = Add64(t11,0x0000000000000004)
998
+ 06 | t0 = LDle:I32(t10)
999
+ 07 | t2 = Add32(t0,0x00000001)
1000
+ 08 | t(4,4294967295) = CASle(t10 :: (t0,None)->(t2,None))
1001
+ 09 | t14 = CasCmpNE32(t4,t0)
1002
+ 10 | if (t14) { PUT(rip) = 0x424355; Ijk_Boring }
1003
+ 11 | PUT(cc_op) = 0x0000000000000003
1004
+ 12 | t15 = 32Uto64(t0)
1005
+ 13 | PUT(cc_dep1) = t15
1006
+ 14 | PUT(cc_dep2) = 0x0000000000000001
1007
+ 15 | t17 = 32Uto64(t0)
1008
+ 16 | PUT(rax) = t17
1009
+ 17 | PUT(rip) = 0x000000000042435a
1010
+ 18 | ------ IMark(0x42435a, 1, 0) ------
1011
+ 19 | t6 = GET:I64(rsp)
1012
+ 20 | t7 = LDle:I64(t6)
1013
+ 21 | t8 = Add64(t6,0x0000000000000008)
1014
+ 22 | PUT(rsp) = t8
1015
+ 23 | t18 = Sub64(t8,0x0000000000000080)
1016
+ 24 | ====== AbiHint(0xt18, 128, t7) ======
1017
+ NEXT: PUT(rip) = t7; Ijk_Ret
1018
+
1019
+ This block acts as both a return endpoint and a transition endpoint (transitioning to 0x424355).
1020
+
1021
+ :param endpoint_node: The endpoint node.
1022
+ :param sort: Type of the endpoint.
1023
+ :return: None
1024
+ """
1025
+
1026
+ self._endpoints[sort].add(endpoint_node)
1027
+
1028
+ def mark_nonreturning_calls_endpoints(self):
1029
+ """
1030
+ Iterate through all call edges in transition graph. For each call a non-returning function, mark the source
1031
+ basic block as an endpoint.
1032
+
1033
+ This method should only be executed once all functions are recovered and analyzed by CFG recovery, so we know
1034
+ whether each function returns or not.
1035
+
1036
+ :return: None
1037
+ """
1038
+
1039
+ for src, dst, data in self.transition_graph.edges(data=True):
1040
+ if "type" in data and data["type"] == "call":
1041
+ func_addr = dst.addr
1042
+ if func_addr in self._function_manager:
1043
+ function = self._function_manager[func_addr]
1044
+ if function.returning is False:
1045
+ # the target function does not return
1046
+ the_node = self.get_node(src.addr)
1047
+ if the_node is not None:
1048
+ self._callout_sites.add(the_node)
1049
+ self._add_endpoint(the_node, "call")
1050
+
1051
+ def get_call_sites(self) -> Iterable[int]:
1052
+ """
1053
+ Gets a list of all the basic blocks that end in calls.
1054
+
1055
+ :return: A view of the addresses of the blocks that end in calls.
1056
+ """
1057
+ return self._call_sites.keys()
1058
+
1059
+ def get_call_target(self, callsite_addr):
1060
+ """
1061
+ Get the target of a call.
1062
+
1063
+ :param callsite_addr: The address of a basic block that ends in a call.
1064
+ :return: The target of said call, or None if callsite_addr is not a
1065
+ callsite.
1066
+ """
1067
+ if callsite_addr in self._call_sites:
1068
+ return self._call_sites[callsite_addr][0]
1069
+ return None
1070
+
1071
+ def get_call_return(self, callsite_addr):
1072
+ """
1073
+ Get the hypothetical return address of a call.
1074
+
1075
+ :param callsite_addr: The address of the basic block that ends in a call.
1076
+ :return: The likely return target of said call, or None if callsite_addr
1077
+ is not a callsite.
1078
+ """
1079
+ if callsite_addr in self._call_sites:
1080
+ return self._call_sites[callsite_addr][1]
1081
+ return None
1082
+
1083
+ @property
1084
+ def graph(self):
1085
+ """
1086
+ Get a local transition graph. A local transition graph is a transition graph that only contains nodes that
1087
+ belong to the current function. All edges, except for the edges going out from the current function or coming
1088
+ from outside the current function, are included.
1089
+
1090
+ The generated graph is cached in self._local_transition_graph.
1091
+
1092
+ :return: A local transition graph.
1093
+ :rtype: networkx.DiGraph
1094
+ """
1095
+
1096
+ if self._local_transition_graph is not None:
1097
+ return self._local_transition_graph
1098
+
1099
+ g = networkx.classes.digraph.DiGraph()
1100
+ if self.startpoint is not None:
1101
+ g.add_node(self.startpoint)
1102
+ for block in self._local_blocks.values():
1103
+ g.add_node(block)
1104
+ for src, dst, data in self.transition_graph.edges(data=True):
1105
+ if "type" in data and (
1106
+ (data["type"] in ("transition", "exception") and ("outside" not in data or data["outside"] is False))
1107
+ or (data["type"] == "fake_return" and ("outside" not in data or data["outside"] is False))
1108
+ ):
1109
+ g.add_edge(src, dst, **data)
1110
+
1111
+ self._local_transition_graph = g
1112
+
1113
+ return g
1114
+
1115
+ def graph_ex(self, exception_edges=True):
1116
+ """
1117
+ Get a local transition graph with a custom configuration. A local transition graph is a transition graph that
1118
+ only contains nodes that belong to the current function. This method allows user to exclude certain types of
1119
+ edges together with the nodes that are only reachable through such edges, such as exception edges.
1120
+
1121
+ The generated graph is not cached.
1122
+
1123
+ :param bool exception_edges: Should exception edges and the nodes that are only reachable through exception
1124
+ edges be kept.
1125
+ :return: A local transition graph with a special configuration.
1126
+ :rtype: networkx.DiGraph
1127
+ """
1128
+
1129
+ # graph_ex() should not impact any already cached graph
1130
+ old_cached_graph = self._local_transition_graph
1131
+ graph = self.graph
1132
+ self._local_transition_graph = old_cached_graph # restore the cached graph
1133
+
1134
+ # fast path
1135
+ if exception_edges:
1136
+ return graph
1137
+
1138
+ # BFS on local graph but ignoring certain types of graphs
1139
+ g = networkx.classes.digraph.DiGraph()
1140
+ queue = [n for n in graph if n is self.startpoint or graph.in_degree[n] == 0]
1141
+ traversed = set(queue)
1142
+
1143
+ while queue:
1144
+ node = queue.pop(0)
1145
+
1146
+ g.add_node(node)
1147
+ for _, dst, edge_data in graph.out_edges(node, data=True):
1148
+ edge_type = edge_data.get("type", None)
1149
+ if not exception_edges and edge_type == "exception":
1150
+ # ignore this edge
1151
+ continue
1152
+ g.add_edge(node, dst, **edge_data)
1153
+
1154
+ if dst not in traversed:
1155
+ traversed.add(dst)
1156
+ queue.append(dst)
1157
+
1158
+ return g
1159
+
1160
+ def transition_graph_ex(self, exception_edges=True):
1161
+ """
1162
+ Get a transition graph with a custom configuration. This method allows user to exclude certain types of edges
1163
+ together with the nodes that are only reachable through such edges, such as exception edges.
1164
+
1165
+ The generated graph is not cached.
1166
+
1167
+ :param bool exception_edges: Should exception edges and the nodes that are only reachable through exception
1168
+ edges be kept.
1169
+ :return: A local transition graph with a special configuration.
1170
+ :rtype: networkx.DiGraph
1171
+ """
1172
+
1173
+ graph = self.transition_graph
1174
+
1175
+ # fast path
1176
+ if exception_edges:
1177
+ return graph
1178
+
1179
+ # BFS on local graph but ignoring certain types of graphs
1180
+ g = networkx.classes.digraph.DiGraph()
1181
+ queue = [n for n in graph if n is self.startpoint or graph.in_degree[n] == 0]
1182
+ traversed = set(queue)
1183
+
1184
+ while queue:
1185
+ node = queue.pop(0)
1186
+ traversed.add(node)
1187
+
1188
+ g.add_node(node)
1189
+ for _, dst, edge_data in graph.out_edges(node, data=True):
1190
+ edge_type = edge_data.get("type", None)
1191
+ if not exception_edges and edge_type == "exception":
1192
+ # ignore this edge
1193
+ continue
1194
+ g.add_edge(node, dst, **edge_data)
1195
+
1196
+ if dst not in traversed:
1197
+ traversed.add(dst)
1198
+ queue.append(dst)
1199
+
1200
+ return g
1201
+
1202
+ def subgraph(self, ins_addrs):
1203
+ """
1204
+ Generate a sub control flow graph of instruction addresses based on self.graph
1205
+
1206
+ :param iterable ins_addrs: A collection of instruction addresses that should be included in the subgraph.
1207
+ :return networkx.DiGraph: A subgraph.
1208
+ """
1209
+
1210
+ # find all basic blocks that include those instructions
1211
+ blocks = []
1212
+ block_addr_to_insns = {}
1213
+
1214
+ for b in self._local_blocks.values():
1215
+ # TODO: should I call get_blocks?
1216
+ block = self.get_block(b.addr, size=b.size, byte_string=b.bytestr)
1217
+ common_insns = set(block.instruction_addrs).intersection(ins_addrs)
1218
+ if common_insns:
1219
+ blocks.append(b)
1220
+ block_addr_to_insns[b.addr] = sorted(common_insns)
1221
+
1222
+ # subgraph = networkx.subgraph(self.graph, blocks)
1223
+ subgraph = self.graph.subgraph(blocks).copy()
1224
+ g = networkx.classes.digraph.DiGraph()
1225
+
1226
+ for n in subgraph.nodes():
1227
+ insns = block_addr_to_insns[n.addr]
1228
+
1229
+ in_edges = subgraph.in_edges(n)
1230
+ # out_edges = subgraph.out_edges(n)
1231
+ # the first instruction address should be included
1232
+ if len(in_edges) > 1 and n.addr not in insns:
1233
+ insns = [n.addr, *insns]
1234
+
1235
+ for src, _ in in_edges:
1236
+ last_instr = block_addr_to_insns[src.addr][-1]
1237
+ g.add_edge(last_instr, insns[0])
1238
+
1239
+ for i in range(len(insns) - 1):
1240
+ g.add_edge(insns[i], insns[i + 1])
1241
+
1242
+ return g
1243
+
1244
+ def instruction_size(self, insn_addr):
1245
+ """
1246
+ Get the size of the instruction specified by `insn_addr`.
1247
+
1248
+ :param int insn_addr: Address of the instruction
1249
+ :return int: Size of the instruction in bytes, or None if the instruction is not found.
1250
+ """
1251
+
1252
+ for block in self.blocks:
1253
+ if insn_addr in block.instruction_addrs:
1254
+ index = block.instruction_addrs.index(insn_addr)
1255
+ if index == len(block.instruction_addrs) - 1:
1256
+ # the very last instruction
1257
+ size = block.addr + block.size - insn_addr
1258
+ else:
1259
+ size = block.instruction_addrs[index + 1] - insn_addr
1260
+ return size
1261
+
1262
+ return None
1263
+
1264
+ def addr_to_instruction_addr(self, addr):
1265
+ """
1266
+ Obtain the address of the instruction that covers @addr.
1267
+
1268
+ :param int addr: An address.
1269
+ :return: Address of the instruction that covers @addr, or None if this addr is not covered by any
1270
+ instruction of this function.
1271
+ :rtype: int or None
1272
+ """
1273
+
1274
+ # TODO: Replace the linear search with binary search
1275
+ for b in self.blocks:
1276
+ if b.addr <= addr < b.addr + b.size:
1277
+ # found it
1278
+ for i, instr_addr in enumerate(b.instruction_addrs):
1279
+ if (i < len(b.instruction_addrs) - 1 and instr_addr <= addr < b.instruction_addrs[i + 1]) or (
1280
+ i == len(b.instruction_addrs) - 1 and instr_addr <= addr
1281
+ ):
1282
+ return instr_addr
1283
+ # Not covered by any instruction... why?
1284
+ return None
1285
+ return None
1286
+
1287
+ def dbg_print(self):
1288
+ """
1289
+ Returns a representation of the list of basic blocks in this function.
1290
+ """
1291
+ return "[{}]".format(", ".join((f"{n.addr:#08x}") for n in self.transition_graph.nodes()))
1292
+
1293
+ def dbg_draw(self, filename):
1294
+ """
1295
+ Draw the graph and save it to a PNG file.
1296
+ """
1297
+ import matplotlib.pyplot as pyplot # pylint: disable=import-error,import-outside-toplevel
1298
+ from networkx.drawing.nx_agraph import graphviz_layout # pylint: disable=import-error,import-outside-toplevel
1299
+
1300
+ tmp_graph = networkx.classes.digraph.DiGraph()
1301
+ for from_block, to_block in self.transition_graph.edges():
1302
+ node_a = f"{from_block.addr:#08x}"
1303
+ node_b = f"{to_block.addr:#08x}"
1304
+ if node_b in self._ret_sites:
1305
+ node_b += "[Ret]"
1306
+ if node_a in self._call_sites:
1307
+ node_a += "[Call]"
1308
+ tmp_graph.add_edge(node_a, node_b)
1309
+ pos = graphviz_layout(tmp_graph, prog="fdp") # pylint: disable=no-member
1310
+ networkx.draw(tmp_graph, pos, node_size=1200)
1311
+ pyplot.savefig(filename)
1312
+
1313
+ def _add_argument_register(self, reg_offset):
1314
+ """
1315
+ Registers a register offset as being used as an argument to the function.
1316
+
1317
+ :param reg_offset: The offset of the register to register.
1318
+ """
1319
+ if reg_offset in self._function_manager._arg_registers and reg_offset not in self._argument_registers:
1320
+ self._argument_registers.append(reg_offset)
1321
+
1322
+ def _add_argument_stack_variable(self, stack_var_offset):
1323
+ if stack_var_offset not in self._argument_stack_variables:
1324
+ self._argument_stack_variables.append(stack_var_offset)
1325
+
1326
+ @property
1327
+ def arguments(self):
1328
+ if self.calling_convention is None:
1329
+ return self._argument_registers + self._argument_stack_variables
1330
+ if self.prototype is None:
1331
+ return []
1332
+ return self.calling_convention.arg_locs(self.prototype)
1333
+
1334
+ @property
1335
+ def has_return(self):
1336
+ return len(self._ret_sites) > 0
1337
+
1338
+ @property
1339
+ def callable(self):
1340
+ assert self.project is not None
1341
+ return self.project.factory.callable(self.addr)
1342
+
1343
+ def normalize(self):
1344
+ """
1345
+ Make sure all basic blocks in the transition graph of this function do not overlap. You will end up with a CFG
1346
+ that IDA Pro generates.
1347
+
1348
+ This method does not touch the CFG result. You may call CFG{Emulated, Fast}.normalize() for that matter.
1349
+
1350
+ :return: None
1351
+ """
1352
+ assert self.project is not None
1353
+
1354
+ # let's put a check here
1355
+ if self.startpoint is None:
1356
+ # this function is empty
1357
+ l.debug("Unexpected error: %s does not have any blocks. normalize() fails.", repr(self))
1358
+ return
1359
+
1360
+ graph = self.transition_graph
1361
+ end_addresses: defaultdict[int, list[BlockNode]] = defaultdict(list)
1362
+
1363
+ for block in self.nodes:
1364
+ if isinstance(block, BlockNode):
1365
+ end_addr = block.addr + block.size
1366
+ end_addresses[end_addr].append(block)
1367
+
1368
+ while any(len(x) > 1 for x in end_addresses.values()):
1369
+ end_addr, all_nodes = next((end_addr, x) for (end_addr, x) in end_addresses.items() if len(x) > 1)
1370
+
1371
+ all_nodes = sorted(all_nodes, key=lambda node: node.size)
1372
+ smallest_node = all_nodes[0]
1373
+ other_nodes = all_nodes[1:]
1374
+
1375
+ is_outside_node = False
1376
+ if smallest_node not in graph:
1377
+ is_outside_node = True
1378
+
1379
+ # Break other nodes
1380
+ for n in other_nodes:
1381
+ new_size = get_real_address_if_arm(self.project.arch, smallest_node.addr) - get_real_address_if_arm(
1382
+ self.project.arch, n.addr
1383
+ )
1384
+ if new_size == 0:
1385
+ # This is the node that has the same size as the smallest one
1386
+ continue
1387
+
1388
+ new_end_addr = n.addr + new_size
1389
+
1390
+ # Does it already exist?
1391
+ new_node = None
1392
+ if new_end_addr in end_addresses:
1393
+ nodes = [i for i in end_addresses[new_end_addr] if i.addr == n.addr]
1394
+ if len(nodes) > 0:
1395
+ new_node = nodes[0]
1396
+
1397
+ if new_node is None:
1398
+ # TODO: Do this correctly for hook nodes
1399
+ # Create a new one
1400
+ new_node = BlockNode(n.addr, new_size, graph=graph, thumb=n.thumb)
1401
+ self._block_sizes[n.addr] = new_size
1402
+ self._addr_to_block_node[n.addr] = new_node
1403
+ # Put the newnode into end_addresses
1404
+ end_addresses[new_end_addr].append(new_node)
1405
+
1406
+ # Modify the CFG
1407
+ original_predecessors = list(graph.in_edges([n], data=True))
1408
+ original_successors = list(graph.out_edges([n], data=True))
1409
+
1410
+ for _, d, data in original_successors:
1411
+ ins_addr = data.get("ins_addr", None)
1412
+ if ins_addr is not None and ins_addr < d.addr:
1413
+ continue
1414
+ if d not in graph[smallest_node]:
1415
+ if d is n:
1416
+ graph.add_edge(smallest_node, new_node, **data)
1417
+ else:
1418
+ graph.add_edge(smallest_node, d, **data)
1419
+
1420
+ for p, _, _ in original_predecessors:
1421
+ graph.remove_edge(p, n)
1422
+ graph.remove_node(n)
1423
+
1424
+ # update local_blocks
1425
+ if n.addr in self._local_blocks and self._local_blocks[n.addr].size != new_node.size:
1426
+ del self._local_blocks[n.addr]
1427
+ self._local_blocks[n.addr] = new_node
1428
+
1429
+ # update block_cache and block_sizes
1430
+ if n.addr in self._block_sizes and self._block_sizes[n.addr] != new_node.size:
1431
+ # the cache needs updating
1432
+ self._block_sizes[n.addr] = new_node.size
1433
+
1434
+ for p, _, data in original_predecessors:
1435
+ if p not in other_nodes:
1436
+ graph.add_edge(p, new_node, **data)
1437
+
1438
+ # We should find the correct successor
1439
+ new_successors = [i for i in all_nodes if i.addr == smallest_node.addr]
1440
+ if new_successors:
1441
+ new_successor = new_successors[0]
1442
+ new_ins_addrs = self.project.factory.block(new_node.addr, size=new_node.size).instruction_addrs
1443
+ if self.project.arch.branch_delay_slot and len(new_ins_addrs) >= 2:
1444
+ new_ins_addr = new_ins_addrs[-2]
1445
+ elif len(new_ins_addrs) >= 1:
1446
+ new_ins_addr = new_ins_addrs[-1]
1447
+ else:
1448
+ # the new node is somehow not decode-able
1449
+ new_ins_addr = new_node.addr + new_node.size - 1
1450
+ graph.add_edge(
1451
+ new_node,
1452
+ new_successor,
1453
+ type="transition",
1454
+ outside=is_outside_node,
1455
+ ins_addr=new_ins_addr,
1456
+ )
1457
+ else:
1458
+ # We gotta create a new one
1459
+ l.error("normalize(): Please report it to Fish.")
1460
+
1461
+ # update endpoints
1462
+ for sortset in self._endpoints.values():
1463
+ if n in sortset:
1464
+ sortset.remove(n)
1465
+ sortset.add(smallest_node)
1466
+
1467
+ end_addresses[end_addr] = [smallest_node]
1468
+
1469
+ # Rebuild startpoint
1470
+ if self.startpoint.size != self._block_sizes[self.startpoint.addr]:
1471
+ self.startpoint = self.get_node(self.startpoint.addr)
1472
+
1473
+ # Clear the cache
1474
+ self._local_transition_graph = None
1475
+
1476
+ self.normalized = True
1477
+
1478
+ def find_declaration(self, ignore_binary_name: bool = False, binary_name_hint: str | None = None) -> bool:
1479
+ """
1480
+ Find the most likely function declaration from the embedded collection of prototypes, set it to self.prototype,
1481
+ and update self.calling_convention with the declaration.
1482
+
1483
+ :param ignore_binary_name: Do not rely on the executable or library where the function belongs to determine
1484
+ its source library. This is useful when working on statically linked binaries
1485
+ (because all functions will belong to the main executable). We will search for all
1486
+ libraries in angr to find the first declaration match.
1487
+ :param binary_name_hint: Substring of the library name where this function might be originally coming from.
1488
+ Useful for FLIRT-identified functions in statically linked binaries.
1489
+ :return: True if a declaration is found and self.prototype and self.calling_convention are
1490
+ updated. False if we fail to find a matching function declaration, in which case
1491
+ self.prototype or self.calling_convention will be kept untouched.
1492
+ """
1493
+
1494
+ if not ignore_binary_name:
1495
+ # determine the library name
1496
+ if not self.is_plt:
1497
+ binary_name = self.binary_name
1498
+ if binary_name not in SIM_LIBRARIES:
1499
+ return False
1500
+ else:
1501
+ binary_name = None
1502
+ # PLT entries must have the same declaration as their jump targets
1503
+ # Try to determine which library this PLT entry will jump to
1504
+ edges = self.transition_graph.edges()
1505
+ if len(edges) == 0:
1506
+ return False
1507
+ node = next(iter(edges))[1]
1508
+ if len(edges) == 1 and (type(node) is HookNode or type(node) is SyscallNode):
1509
+ target = node.addr
1510
+ if target in self._function_manager:
1511
+ target_func = self._function_manager[target]
1512
+ binary_name = target_func.binary_name
1513
+
1514
+ # cannot determine the binary name. since we are forced to respect binary name, we give up in this case.
1515
+ if binary_name is None:
1516
+ return False
1517
+
1518
+ lib = SIM_LIBRARIES.get(binary_name, None)
1519
+ libraries = set()
1520
+ if lib is not None:
1521
+ libraries.update(lib)
1522
+
1523
+ else:
1524
+ # try all libraries or all libraries that match the given library name hint
1525
+ libraries = set()
1526
+ for lib_name, libs in SIM_LIBRARIES.items():
1527
+ # TODO: Add support for syscall libraries. Note that syscall libraries have different function
1528
+ # prototypes for .has_prototype() and .get_prototype()...
1529
+ for lib in libs:
1530
+ if not isinstance(lib, SimSyscallLibrary):
1531
+ if binary_name_hint:
1532
+ if binary_name_hint.lower() in lib_name.lower():
1533
+ libraries.add(lib)
1534
+ else:
1535
+ libraries.add(lib)
1536
+
1537
+ if not libraries:
1538
+ return False
1539
+
1540
+ name_variants = [self.name]
1541
+ # remove "_" prefixes
1542
+ if self.name.startswith("_"):
1543
+ name_variants.append(self.name[1:])
1544
+ if self.name.startswith("__"):
1545
+ name_variants.append(self.name[2:])
1546
+ # special handling for libc
1547
+ if self.name.startswith("__libc_"):
1548
+ name_variants.append(self.name[7:])
1549
+
1550
+ for library in libraries:
1551
+ for name in name_variants:
1552
+ if isinstance(library, SimSyscallLibrary):
1553
+ # FIXME: we don't support getting declaration from a syscall library yet. we don't have the concept
1554
+ # of abi at this point.
1555
+ continue
1556
+ if not library.has_prototype(name):
1557
+ continue
1558
+
1559
+ proto = library.get_prototype(name)
1560
+ if self.project is None:
1561
+ # we need to get arch from self.project
1562
+ l.warning(
1563
+ "Function %s does not have .project set. A possible prototype is found, but we cannot set it "
1564
+ "without .project.arch."
1565
+ )
1566
+ return False
1567
+ self.prototype = proto.with_arch(self.project.arch)
1568
+ self.prototype_libname = library.name
1569
+
1570
+ # update self.calling_convention if necessary
1571
+ if self.calling_convention is None:
1572
+ if self.project.arch.name in library.default_ccs:
1573
+ self.calling_convention = library.default_ccs[self.project.arch.name](self.project.arch)
1574
+ elif self.project.arch.name in DEFAULT_CC:
1575
+ self.calling_convention = default_cc(
1576
+ self.project.arch.name,
1577
+ platform=self.project.simos.name if self.project.simos is not None else None,
1578
+ )(self.project.arch)
1579
+
1580
+ return True
1581
+
1582
+ return False
1583
+
1584
+ @staticmethod
1585
+ def _addr_to_funcloc(addr):
1586
+ # FIXME
1587
+ if isinstance(addr, tuple):
1588
+ return addr[0]
1589
+ # int, long
1590
+ return addr
1591
+
1592
+ def is_rust_function(self):
1593
+ ast = pydemumble.demangle(self.name)
1594
+ if ast:
1595
+ nodes = ast.split("::")
1596
+ if len(nodes) >= 2:
1597
+ last_node = nodes[-1]
1598
+ return (
1599
+ len(last_node) == 17
1600
+ and last_node.startswith("h")
1601
+ and all(c in "0123456789abcdef" for c in last_node[1:])
1602
+ )
1603
+ return False
1604
+
1605
+ @staticmethod
1606
+ def _rust_fmt_node(node):
1607
+ result = []
1608
+ rest = node
1609
+ if rest.startswith("_$"):
1610
+ rest = rest[1:]
1611
+ while True:
1612
+ if rest.startswith("."):
1613
+ if len(rest) > 1 and rest[1] == ".":
1614
+ result.append("::")
1615
+ rest = rest[2:]
1616
+ else:
1617
+ result.append(".")
1618
+ rest = rest[1:]
1619
+ elif rest.startswith("$"):
1620
+ if "$" in rest[1:]:
1621
+ escape, rest = rest[1:].split("$", 1)
1622
+ else:
1623
+ break
1624
+
1625
+ unescaped = {"SP": "@", "BP": "*", "RF": "&", "LT": "<", "GT": ">", "LP": "(", "RP": ")", "C": ","}.get(
1626
+ escape
1627
+ )
1628
+
1629
+ if unescaped is None and escape.startswith("u"):
1630
+ digits = escape[1:]
1631
+ if all(c in "0123456789abcdef" for c in digits):
1632
+ c = chr(int(digits, 16))
1633
+ if ord(c) >= 32 and ord(c) != 127:
1634
+ result.append(c)
1635
+ continue
1636
+ if unescaped:
1637
+ result.append(unescaped)
1638
+ else:
1639
+ break
1640
+ else:
1641
+ idx = min((rest.find(c) for c in "$." if c in rest), default=len(rest))
1642
+ result.append(rest[:idx])
1643
+ rest = rest[idx:]
1644
+ if not rest:
1645
+ break
1646
+ return "".join(result)
1647
+
1648
+ @property
1649
+ def demangled_name(self):
1650
+ ast = pydemumble.demangle(self.name)
1651
+ if self.is_rust_function():
1652
+ nodes = ast.split("::")[:-1]
1653
+ ast = "::".join([Function._rust_fmt_node(node) for node in nodes])
1654
+ return ast if ast else self.name
1655
+
1656
+ @property
1657
+ def short_name(self):
1658
+ if self.is_rust_function():
1659
+ ast = pydemumble.demangle(self.name)
1660
+ return Function._rust_fmt_node(ast.split("::")[-2])
1661
+ func_name = get_cpp_function_name(self.demangled_name, specialized=False, qualified=True)
1662
+ return func_name.split("::")[-1]
1663
+
1664
+ def get_unambiguous_name(self, display_name: str | None = None) -> str:
1665
+ """
1666
+ Get a disambiguated function name.
1667
+
1668
+ :param display_name: Name to display, otherwise the function name.
1669
+ :return: The function name in the form:
1670
+ ::<name> when the function binary is the main object.
1671
+ ::<obj>::<name> when the function binary is not the main object.
1672
+ ::<addr>::<name> when the function binary is an unnamed non-main object, or when multiple functions with
1673
+ the same name are defined in the function binary.
1674
+ """
1675
+ assert self.project is not None
1676
+ must_disambiguate_by_addr = self.binary is not self.project.loader.main_object and self.binary_name is None
1677
+
1678
+ # If there are multiple functions with the same name in the same object, disambiguate by address
1679
+ if not must_disambiguate_by_addr:
1680
+ for func in self._function_manager.get_by_name(self.name):
1681
+ if func is not self and func.binary is self.binary:
1682
+ must_disambiguate_by_addr = True
1683
+ break
1684
+
1685
+ separator = "::"
1686
+ n = separator
1687
+ if must_disambiguate_by_addr:
1688
+ n += hex(self.addr) + separator
1689
+ elif self.binary is not self.project.loader.main_object and self.binary_name is not None:
1690
+ n += self.binary_name + separator
1691
+ return n + (display_name or self.name)
1692
+
1693
+ def apply_definition(self, definition: str, calling_convention: SimCC | type[SimCC] | None = None) -> None:
1694
+ assert self.project is not None
1695
+ if not definition.endswith(";"):
1696
+ definition += ";"
1697
+ func_def = parse_defns(definition, arch=self.project.arch)
1698
+ if len(func_def.keys()) > 1:
1699
+ raise Exception(f"Too many definitions: {list(func_def.keys())} ")
1700
+
1701
+ name: str
1702
+ ty: SimTypeFunction
1703
+ name, ty = func_def.popitem()
1704
+ self.name = name
1705
+ self.prototype = ty.with_arch(self.project.arch)
1706
+ # setup the calling convention
1707
+ # If a SimCC object is passed assume that this is sane and just use it
1708
+ if isinstance(calling_convention, SimCC):
1709
+ self.calling_convention = calling_convention
1710
+
1711
+ # If it is a subclass of SimCC we can instantiate it
1712
+ elif isinstance(calling_convention, type) and issubclass(calling_convention, SimCC):
1713
+ self.calling_convention = calling_convention(self.project.arch)
1714
+
1715
+ # If none is specified default to something
1716
+ elif calling_convention is None:
1717
+ self.calling_convention = self.project.factory.cc()
1718
+
1719
+ else:
1720
+ raise TypeError("calling_convention has to be one of: [SimCC, type(SimCC), None]")
1721
+
1722
+ def functions_reachable(self) -> set[Function]:
1723
+ """
1724
+ :return: The set of all functions that can be reached from the function represented by self.
1725
+ """
1726
+ called = set()
1727
+
1728
+ def _find_called(function_address):
1729
+ successors = set(self._function_manager.callgraph.successors(function_address)) - called
1730
+ for s in successors:
1731
+ called.add(s)
1732
+ _find_called(s)
1733
+
1734
+ _find_called(self.addr)
1735
+ return {self._function_manager.function(a) for a in called}
1736
+
1737
+ def copy(self):
1738
+ func = Function(self._function_manager, self.addr, name=self.name, syscall=self.is_syscall)
1739
+ func.transition_graph = networkx.DiGraph(self.transition_graph)
1740
+ func.normalized = self.normalized
1741
+ func._ret_sites = self._ret_sites.copy()
1742
+ func._jumpout_sites = self._jumpout_sites.copy()
1743
+ func._retout_sites = self._retout_sites.copy()
1744
+ func._endpoints = self._endpoints.copy()
1745
+ func._call_sites = self._call_sites.copy()
1746
+ func._project = self._project
1747
+ func.previous_names = list(self.previous_names)
1748
+ func.is_plt = self.is_plt
1749
+ func.is_simprocedure = self.is_simprocedure
1750
+ func.binary_name = self.binary_name
1751
+ func.bp_on_stack = self.bp_on_stack
1752
+ func.retaddr_on_stack = self.retaddr_on_stack
1753
+ func.sp_delta = self.sp_delta
1754
+ func.calling_convention = self.calling_convention
1755
+ func.prototype = self.prototype
1756
+ func._returning = self._returning
1757
+ func.is_alignment = self.is_alignment
1758
+ func.startpoint = self.startpoint
1759
+ func._addr_to_block_node = self._addr_to_block_node.copy()
1760
+ func._block_sizes = self._block_sizes.copy()
1761
+ func._local_blocks = self._local_blocks.copy()
1762
+ func._local_block_addrs = self._local_block_addrs.copy()
1763
+ func.info = self.info.copy()
1764
+ func.tags = self.tags
1765
+
1766
+ return func
1767
+
1768
+ def pp(self, **kwargs):
1769
+ """
1770
+ Pretty-print the function disassembly.
1771
+ """
1772
+ print(self.project.analyses.Disassembly(self).render(**kwargs))