angr 9.2.103__py3-none-macosx_11_0_arm64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (1300) hide show
  1. angr/__init__.py +153 -0
  2. angr/__main__.py +59 -0
  3. angr/analyses/__init__.py +46 -0
  4. angr/analyses/analysis.py +359 -0
  5. angr/analyses/backward_slice.py +691 -0
  6. angr/analyses/binary_optimizer.py +683 -0
  7. angr/analyses/bindiff.py +1251 -0
  8. angr/analyses/boyscout.py +77 -0
  9. angr/analyses/callee_cleanup_finder.py +75 -0
  10. angr/analyses/calling_convention.py +956 -0
  11. angr/analyses/cdg.py +197 -0
  12. angr/analyses/cfg/__init__.py +11 -0
  13. angr/analyses/cfg/cfb.py +436 -0
  14. angr/analyses/cfg/cfg.py +73 -0
  15. angr/analyses/cfg/cfg_arch_options.py +82 -0
  16. angr/analyses/cfg/cfg_base.py +2917 -0
  17. angr/analyses/cfg/cfg_emulated.py +3570 -0
  18. angr/analyses/cfg/cfg_fast.py +5053 -0
  19. angr/analyses/cfg/cfg_fast_soot.py +669 -0
  20. angr/analyses/cfg/cfg_job_base.py +204 -0
  21. angr/analyses/cfg/indirect_jump_resolvers/__init__.py +8 -0
  22. angr/analyses/cfg/indirect_jump_resolvers/amd64_elf_got.py +63 -0
  23. angr/analyses/cfg/indirect_jump_resolvers/amd64_pe_iat.py +52 -0
  24. angr/analyses/cfg/indirect_jump_resolvers/arm_elf_fast.py +151 -0
  25. angr/analyses/cfg/indirect_jump_resolvers/const_resolver.py +141 -0
  26. angr/analyses/cfg/indirect_jump_resolvers/default_resolvers.py +68 -0
  27. angr/analyses/cfg/indirect_jump_resolvers/jumptable.py +2368 -0
  28. angr/analyses/cfg/indirect_jump_resolvers/mips_elf_fast.py +517 -0
  29. angr/analyses/cfg/indirect_jump_resolvers/propagator_utils.py +26 -0
  30. angr/analyses/cfg/indirect_jump_resolvers/resolver.py +74 -0
  31. angr/analyses/cfg/indirect_jump_resolvers/x86_elf_pic_plt.py +93 -0
  32. angr/analyses/cfg/indirect_jump_resolvers/x86_pe_iat.py +51 -0
  33. angr/analyses/cfg_slice_to_sink/__init__.py +2 -0
  34. angr/analyses/cfg_slice_to_sink/cfg_slice_to_sink.py +117 -0
  35. angr/analyses/cfg_slice_to_sink/graph.py +84 -0
  36. angr/analyses/cfg_slice_to_sink/transitions.py +25 -0
  37. angr/analyses/class_identifier.py +62 -0
  38. angr/analyses/code_tagging.py +123 -0
  39. angr/analyses/complete_calling_conventions.py +424 -0
  40. angr/analyses/congruency_check.py +384 -0
  41. angr/analyses/data_dep/__init__.py +2 -0
  42. angr/analyses/data_dep/data_dependency_analysis.py +605 -0
  43. angr/analyses/data_dep/dep_nodes.py +170 -0
  44. angr/analyses/data_dep/sim_act_location.py +46 -0
  45. angr/analyses/datagraph_meta.py +105 -0
  46. angr/analyses/ddg.py +1695 -0
  47. angr/analyses/decompiler/__init__.py +13 -0
  48. angr/analyses/decompiler/ail_simplifier.py +1408 -0
  49. angr/analyses/decompiler/ailgraph_walker.py +48 -0
  50. angr/analyses/decompiler/block_io_finder.py +293 -0
  51. angr/analyses/decompiler/block_similarity.py +188 -0
  52. angr/analyses/decompiler/block_simplifier.py +434 -0
  53. angr/analyses/decompiler/call_counter.py +43 -0
  54. angr/analyses/decompiler/callsite_maker.py +403 -0
  55. angr/analyses/decompiler/ccall_rewriters/__init__.py +6 -0
  56. angr/analyses/decompiler/ccall_rewriters/amd64_ccalls.py +489 -0
  57. angr/analyses/decompiler/ccall_rewriters/rewriter_base.py +19 -0
  58. angr/analyses/decompiler/clinic.py +2166 -0
  59. angr/analyses/decompiler/condition_processor.py +1184 -0
  60. angr/analyses/decompiler/decompilation_cache.py +38 -0
  61. angr/analyses/decompiler/decompilation_options.py +274 -0
  62. angr/analyses/decompiler/decompiler.py +544 -0
  63. angr/analyses/decompiler/empty_node_remover.py +211 -0
  64. angr/analyses/decompiler/expression_counters.py +76 -0
  65. angr/analyses/decompiler/expression_narrower.py +92 -0
  66. angr/analyses/decompiler/goto_manager.py +73 -0
  67. angr/analyses/decompiler/graph_region.py +413 -0
  68. angr/analyses/decompiler/jump_target_collector.py +36 -0
  69. angr/analyses/decompiler/jumptable_entry_condition_rewriter.py +66 -0
  70. angr/analyses/decompiler/optimization_passes/__init__.py +108 -0
  71. angr/analyses/decompiler/optimization_passes/base_ptr_save_simplifier.py +144 -0
  72. angr/analyses/decompiler/optimization_passes/code_motion.py +360 -0
  73. angr/analyses/decompiler/optimization_passes/const_derefs.py +265 -0
  74. angr/analyses/decompiler/optimization_passes/cross_jump_reverter.py +108 -0
  75. angr/analyses/decompiler/optimization_passes/deadblock_remover.py +73 -0
  76. angr/analyses/decompiler/optimization_passes/div_simplifier.py +391 -0
  77. angr/analyses/decompiler/optimization_passes/engine_base.py +303 -0
  78. angr/analyses/decompiler/optimization_passes/expr_op_swapper.py +136 -0
  79. angr/analyses/decompiler/optimization_passes/flip_boolean_cmp.py +91 -0
  80. angr/analyses/decompiler/optimization_passes/inlined_string_transformation_simplifier.py +386 -0
  81. angr/analyses/decompiler/optimization_passes/ite_expr_converter.py +226 -0
  82. angr/analyses/decompiler/optimization_passes/ite_region_converter.py +189 -0
  83. angr/analyses/decompiler/optimization_passes/lowered_switch_simplifier.py +757 -0
  84. angr/analyses/decompiler/optimization_passes/mod_simplifier.py +86 -0
  85. angr/analyses/decompiler/optimization_passes/multi_simplifier.py +227 -0
  86. angr/analyses/decompiler/optimization_passes/optimization_pass.py +397 -0
  87. angr/analyses/decompiler/optimization_passes/register_save_area_simplifier.py +198 -0
  88. angr/analyses/decompiler/optimization_passes/ret_addr_save_simplifier.py +172 -0
  89. angr/analyses/decompiler/optimization_passes/ret_deduplicator.py +219 -0
  90. angr/analyses/decompiler/optimization_passes/return_duplicator_base.py +448 -0
  91. angr/analyses/decompiler/optimization_passes/return_duplicator_high.py +57 -0
  92. angr/analyses/decompiler/optimization_passes/return_duplicator_low.py +121 -0
  93. angr/analyses/decompiler/optimization_passes/spilled_register_finder.py +18 -0
  94. angr/analyses/decompiler/optimization_passes/stack_canary_simplifier.py +293 -0
  95. angr/analyses/decompiler/optimization_passes/switch_default_case_duplicator.py +110 -0
  96. angr/analyses/decompiler/optimization_passes/win_stack_canary_simplifier.py +281 -0
  97. angr/analyses/decompiler/optimization_passes/x86_gcc_getpc_simplifier.py +87 -0
  98. angr/analyses/decompiler/peephole_optimizations/__init__.py +69 -0
  99. angr/analyses/decompiler/peephole_optimizations/a_div_const_add_a_mul_n_div_const.py +38 -0
  100. angr/analyses/decompiler/peephole_optimizations/a_mul_const_div_shr_const.py +38 -0
  101. angr/analyses/decompiler/peephole_optimizations/a_shl_const_sub_a.py +31 -0
  102. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div.py +25 -0
  103. angr/analyses/decompiler/peephole_optimizations/a_sub_a_div_const_mul_const.py +56 -0
  104. angr/analyses/decompiler/peephole_optimizations/a_sub_a_sub_n.py +19 -0
  105. angr/analyses/decompiler/peephole_optimizations/arm_cmpf.py +235 -0
  106. angr/analyses/decompiler/peephole_optimizations/base.py +120 -0
  107. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_add_n.py +33 -0
  108. angr/analyses/decompiler/peephole_optimizations/basepointeroffset_and_mask.py +35 -0
  109. angr/analyses/decompiler/peephole_optimizations/bitwise_or_to_logical_or.py +34 -0
  110. angr/analyses/decompiler/peephole_optimizations/bool_expr_xor_1.py +27 -0
  111. angr/analyses/decompiler/peephole_optimizations/bswap.py +131 -0
  112. angr/analyses/decompiler/peephole_optimizations/cmpord_rewriter.py +72 -0
  113. angr/analyses/decompiler/peephole_optimizations/coalesce_same_cascading_ifs.py +27 -0
  114. angr/analyses/decompiler/peephole_optimizations/const_mull_a_shift.py +91 -0
  115. angr/analyses/decompiler/peephole_optimizations/constant_derefs.py +43 -0
  116. angr/analyses/decompiler/peephole_optimizations/conv_a_sub0_shr_and.py +70 -0
  117. angr/analyses/decompiler/peephole_optimizations/conv_shl_shr.py +51 -0
  118. angr/analyses/decompiler/peephole_optimizations/eager_eval.py +225 -0
  119. angr/analyses/decompiler/peephole_optimizations/extended_byte_and_mask.py +55 -0
  120. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy.py +146 -0
  121. angr/analyses/decompiler/peephole_optimizations/inlined_strcpy_consolidation.py +102 -0
  122. angr/analyses/decompiler/peephole_optimizations/inlined_wstrcpy.py +159 -0
  123. angr/analyses/decompiler/peephole_optimizations/invert_negated_logical_conjuction_disjunction.py +50 -0
  124. angr/analyses/decompiler/peephole_optimizations/one_sub_bool.py +33 -0
  125. angr/analyses/decompiler/peephole_optimizations/remove_cascading_conversions.py +19 -0
  126. angr/analyses/decompiler/peephole_optimizations/remove_empty_if_body.py +45 -0
  127. angr/analyses/decompiler/peephole_optimizations/remove_noop_conversions.py +26 -0
  128. angr/analyses/decompiler/peephole_optimizations/remove_redundant_bitmasks.py +48 -0
  129. angr/analyses/decompiler/peephole_optimizations/remove_redundant_conversions.py +160 -0
  130. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_branch.py +29 -0
  131. angr/analyses/decompiler/peephole_optimizations/remove_redundant_ite_comparisons.py +54 -0
  132. angr/analyses/decompiler/peephole_optimizations/remove_redundant_nots.py +17 -0
  133. angr/analyses/decompiler/peephole_optimizations/remove_redundant_reinterprets.py +43 -0
  134. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts.py +44 -0
  135. angr/analyses/decompiler/peephole_optimizations/remove_redundant_shifts_around_comparators.py +40 -0
  136. angr/analyses/decompiler/peephole_optimizations/rewrite_bit_extractions.py +85 -0
  137. angr/analyses/decompiler/peephole_optimizations/rewrite_mips_gp_loads.py +47 -0
  138. angr/analyses/decompiler/peephole_optimizations/rol_ror.py +77 -0
  139. angr/analyses/decompiler/peephole_optimizations/sar_to_signed_div.py +105 -0
  140. angr/analyses/decompiler/peephole_optimizations/simplify_pc_relative_loads.py +37 -0
  141. angr/analyses/decompiler/peephole_optimizations/single_bit_cond_to_boolexpr.py +52 -0
  142. angr/analyses/decompiler/peephole_optimizations/single_bit_xor.py +26 -0
  143. angr/analyses/decompiler/peephole_optimizations/tidy_stack_addr.py +133 -0
  144. angr/analyses/decompiler/redundant_label_remover.py +116 -0
  145. angr/analyses/decompiler/region_identifier.py +1098 -0
  146. angr/analyses/decompiler/region_simplifiers/__init__.py +1 -0
  147. angr/analyses/decompiler/region_simplifiers/cascading_cond_transformer.py +93 -0
  148. angr/analyses/decompiler/region_simplifiers/cascading_ifs.py +81 -0
  149. angr/analyses/decompiler/region_simplifiers/expr_folding.py +606 -0
  150. angr/analyses/decompiler/region_simplifiers/goto.py +177 -0
  151. angr/analyses/decompiler/region_simplifiers/if_.py +142 -0
  152. angr/analyses/decompiler/region_simplifiers/ifelse.py +90 -0
  153. angr/analyses/decompiler/region_simplifiers/loop.py +135 -0
  154. angr/analyses/decompiler/region_simplifiers/node_address_finder.py +23 -0
  155. angr/analyses/decompiler/region_simplifiers/region_simplifier.py +211 -0
  156. angr/analyses/decompiler/region_simplifiers/switch_cluster_simplifier.py +644 -0
  157. angr/analyses/decompiler/region_simplifiers/switch_expr_simplifier.py +83 -0
  158. angr/analyses/decompiler/region_walker.py +23 -0
  159. angr/analyses/decompiler/return_maker.py +70 -0
  160. angr/analyses/decompiler/seq_to_blocks.py +19 -0
  161. angr/analyses/decompiler/sequence_walker.py +235 -0
  162. angr/analyses/decompiler/structured_codegen/__init__.py +10 -0
  163. angr/analyses/decompiler/structured_codegen/base.py +132 -0
  164. angr/analyses/decompiler/structured_codegen/c.py +3811 -0
  165. angr/analyses/decompiler/structured_codegen/dummy.py +14 -0
  166. angr/analyses/decompiler/structured_codegen/dwarf_import.py +186 -0
  167. angr/analyses/decompiler/structuring/__init__.py +15 -0
  168. angr/analyses/decompiler/structuring/dream.py +1225 -0
  169. angr/analyses/decompiler/structuring/phoenix.py +2546 -0
  170. angr/analyses/decompiler/structuring/recursive_structurer.py +186 -0
  171. angr/analyses/decompiler/structuring/structurer_base.py +954 -0
  172. angr/analyses/decompiler/structuring/structurer_nodes.py +414 -0
  173. angr/analyses/decompiler/utils.py +787 -0
  174. angr/analyses/disassembly.py +1302 -0
  175. angr/analyses/disassembly_utils.py +104 -0
  176. angr/analyses/dominance_frontier.py +39 -0
  177. angr/analyses/find_objects_static.py +203 -0
  178. angr/analyses/flirt.py +185 -0
  179. angr/analyses/forward_analysis/__init__.py +2 -0
  180. angr/analyses/forward_analysis/forward_analysis.py +527 -0
  181. angr/analyses/forward_analysis/job_info.py +64 -0
  182. angr/analyses/forward_analysis/visitors/__init__.py +4 -0
  183. angr/analyses/forward_analysis/visitors/call_graph.py +28 -0
  184. angr/analyses/forward_analysis/visitors/function_graph.py +85 -0
  185. angr/analyses/forward_analysis/visitors/graph.py +250 -0
  186. angr/analyses/forward_analysis/visitors/loop.py +28 -0
  187. angr/analyses/forward_analysis/visitors/single_node_graph.py +38 -0
  188. angr/analyses/identifier/__init__.py +1 -0
  189. angr/analyses/identifier/custom_callable.py +138 -0
  190. angr/analyses/identifier/errors.py +9 -0
  191. angr/analyses/identifier/func.py +57 -0
  192. angr/analyses/identifier/functions/__init__.py +36 -0
  193. angr/analyses/identifier/functions/atoi.py +75 -0
  194. angr/analyses/identifier/functions/based_atoi.py +128 -0
  195. angr/analyses/identifier/functions/fdprintf.py +122 -0
  196. angr/analyses/identifier/functions/free.py +64 -0
  197. angr/analyses/identifier/functions/int2str.py +302 -0
  198. angr/analyses/identifier/functions/malloc.py +113 -0
  199. angr/analyses/identifier/functions/memcmp.py +69 -0
  200. angr/analyses/identifier/functions/memcpy.py +89 -0
  201. angr/analyses/identifier/functions/memset.py +43 -0
  202. angr/analyses/identifier/functions/printf.py +122 -0
  203. angr/analyses/identifier/functions/recv_until.py +315 -0
  204. angr/analyses/identifier/functions/skip_calloc.py +72 -0
  205. angr/analyses/identifier/functions/skip_realloc.py +99 -0
  206. angr/analyses/identifier/functions/skip_recv_n.py +107 -0
  207. angr/analyses/identifier/functions/snprintf.py +114 -0
  208. angr/analyses/identifier/functions/sprintf.py +115 -0
  209. angr/analyses/identifier/functions/strcasecmp.py +32 -0
  210. angr/analyses/identifier/functions/strcmp.py +112 -0
  211. angr/analyses/identifier/functions/strcpy.py +43 -0
  212. angr/analyses/identifier/functions/strlen.py +26 -0
  213. angr/analyses/identifier/functions/strncmp.py +103 -0
  214. angr/analyses/identifier/functions/strncpy.py +65 -0
  215. angr/analyses/identifier/functions/strtol.py +91 -0
  216. angr/analyses/identifier/identify.py +848 -0
  217. angr/analyses/identifier/runner.py +359 -0
  218. angr/analyses/init_finder.py +264 -0
  219. angr/analyses/loop_analysis.py +353 -0
  220. angr/analyses/loopfinder.py +174 -0
  221. angr/analyses/propagator/__init__.py +1 -0
  222. angr/analyses/propagator/engine_ail.py +1560 -0
  223. angr/analyses/propagator/engine_base.py +53 -0
  224. angr/analyses/propagator/engine_vex.py +328 -0
  225. angr/analyses/propagator/outdated_definition_walker.py +158 -0
  226. angr/analyses/propagator/propagator.py +422 -0
  227. angr/analyses/propagator/tmpvar_finder.py +17 -0
  228. angr/analyses/propagator/top_checker_mixin.py +14 -0
  229. angr/analyses/propagator/values.py +116 -0
  230. angr/analyses/propagator/vex_vars.py +67 -0
  231. angr/analyses/proximity_graph.py +452 -0
  232. angr/analyses/reaching_definitions/__init__.py +65 -0
  233. angr/analyses/reaching_definitions/call_trace.py +72 -0
  234. angr/analyses/reaching_definitions/dep_graph.py +392 -0
  235. angr/analyses/reaching_definitions/engine_ail.py +1172 -0
  236. angr/analyses/reaching_definitions/engine_vex.py +1102 -0
  237. angr/analyses/reaching_definitions/external_codeloc.py +0 -0
  238. angr/analyses/reaching_definitions/function_handler.py +603 -0
  239. angr/analyses/reaching_definitions/heap_allocator.py +69 -0
  240. angr/analyses/reaching_definitions/rd_initializer.py +235 -0
  241. angr/analyses/reaching_definitions/rd_state.py +613 -0
  242. angr/analyses/reaching_definitions/reaching_definitions.py +594 -0
  243. angr/analyses/reaching_definitions/subject.py +64 -0
  244. angr/analyses/reassembler.py +2970 -0
  245. angr/analyses/soot_class_hierarchy.py +283 -0
  246. angr/analyses/stack_pointer_tracker.py +832 -0
  247. angr/analyses/static_hooker.py +51 -0
  248. angr/analyses/typehoon/__init__.py +1 -0
  249. angr/analyses/typehoon/dfa.py +108 -0
  250. angr/analyses/typehoon/lifter.py +91 -0
  251. angr/analyses/typehoon/simple_solver.py +1258 -0
  252. angr/analyses/typehoon/translator.py +242 -0
  253. angr/analyses/typehoon/typeconsts.py +294 -0
  254. angr/analyses/typehoon/typehoon.py +239 -0
  255. angr/analyses/typehoon/typevars.py +565 -0
  256. angr/analyses/typehoon/variance.py +10 -0
  257. angr/analyses/variable_recovery/__init__.py +2 -0
  258. angr/analyses/variable_recovery/annotations.py +57 -0
  259. angr/analyses/variable_recovery/engine_ail.py +746 -0
  260. angr/analyses/variable_recovery/engine_base.py +962 -0
  261. angr/analyses/variable_recovery/engine_vex.py +580 -0
  262. angr/analyses/variable_recovery/irsb_scanner.py +131 -0
  263. angr/analyses/variable_recovery/variable_recovery.py +552 -0
  264. angr/analyses/variable_recovery/variable_recovery_base.py +452 -0
  265. angr/analyses/variable_recovery/variable_recovery_fast.py +589 -0
  266. angr/analyses/veritesting.py +635 -0
  267. angr/analyses/vfg.py +1945 -0
  268. angr/analyses/vsa_ddg.py +423 -0
  269. angr/analyses/vtable.py +92 -0
  270. angr/analyses/xrefs.py +263 -0
  271. angr/angrdb/__init__.py +9 -0
  272. angr/angrdb/db.py +208 -0
  273. angr/angrdb/models.py +183 -0
  274. angr/angrdb/serializers/__init__.py +2 -0
  275. angr/angrdb/serializers/cfg_model.py +41 -0
  276. angr/angrdb/serializers/comments.py +59 -0
  277. angr/angrdb/serializers/funcs.py +60 -0
  278. angr/angrdb/serializers/kb.py +110 -0
  279. angr/angrdb/serializers/labels.py +58 -0
  280. angr/angrdb/serializers/loader.py +81 -0
  281. angr/angrdb/serializers/structured_code.py +128 -0
  282. angr/angrdb/serializers/variables.py +58 -0
  283. angr/angrdb/serializers/xrefs.py +48 -0
  284. angr/annocfg.py +320 -0
  285. angr/blade.py +430 -0
  286. angr/block.py +506 -0
  287. angr/callable.py +162 -0
  288. angr/calling_conventions.py +2383 -0
  289. angr/code_location.py +168 -0
  290. angr/codenode.py +140 -0
  291. angr/concretization_strategies/__init__.py +97 -0
  292. angr/concretization_strategies/any.py +15 -0
  293. angr/concretization_strategies/any_named.py +32 -0
  294. angr/concretization_strategies/controlled_data.py +54 -0
  295. angr/concretization_strategies/eval.py +18 -0
  296. angr/concretization_strategies/logging.py +32 -0
  297. angr/concretization_strategies/max.py +24 -0
  298. angr/concretization_strategies/nonzero.py +14 -0
  299. angr/concretization_strategies/nonzero_range.py +20 -0
  300. angr/concretization_strategies/norepeats.py +35 -0
  301. angr/concretization_strategies/norepeats_range.py +35 -0
  302. angr/concretization_strategies/range.py +17 -0
  303. angr/concretization_strategies/signed_add.py +24 -0
  304. angr/concretization_strategies/single.py +12 -0
  305. angr/concretization_strategies/solutions.py +18 -0
  306. angr/concretization_strategies/unlimited_range.py +15 -0
  307. angr/distributed/__init__.py +3 -0
  308. angr/distributed/server.py +198 -0
  309. angr/distributed/worker.py +183 -0
  310. angr/engines/__init__.py +41 -0
  311. angr/engines/concrete.py +178 -0
  312. angr/engines/engine.py +212 -0
  313. angr/engines/failure.py +27 -0
  314. angr/engines/hook.py +67 -0
  315. angr/engines/light/__init__.py +2 -0
  316. angr/engines/light/data.py +715 -0
  317. angr/engines/light/engine.py +1441 -0
  318. angr/engines/pcode/__init__.py +2 -0
  319. angr/engines/pcode/behavior.py +995 -0
  320. angr/engines/pcode/cc.py +123 -0
  321. angr/engines/pcode/emulate.py +446 -0
  322. angr/engines/pcode/engine.py +256 -0
  323. angr/engines/pcode/lifter.py +1423 -0
  324. angr/engines/procedure.py +71 -0
  325. angr/engines/soot/__init__.py +1 -0
  326. angr/engines/soot/engine.py +415 -0
  327. angr/engines/soot/exceptions.py +14 -0
  328. angr/engines/soot/expressions/__init__.py +56 -0
  329. angr/engines/soot/expressions/arrayref.py +21 -0
  330. angr/engines/soot/expressions/base.py +22 -0
  331. angr/engines/soot/expressions/binop.py +27 -0
  332. angr/engines/soot/expressions/cast.py +21 -0
  333. angr/engines/soot/expressions/condition.py +34 -0
  334. angr/engines/soot/expressions/constants.py +45 -0
  335. angr/engines/soot/expressions/instanceOf.py +11 -0
  336. angr/engines/soot/expressions/instancefieldref.py +7 -0
  337. angr/engines/soot/expressions/invoke.py +117 -0
  338. angr/engines/soot/expressions/length.py +7 -0
  339. angr/engines/soot/expressions/local.py +7 -0
  340. angr/engines/soot/expressions/new.py +15 -0
  341. angr/engines/soot/expressions/newArray.py +51 -0
  342. angr/engines/soot/expressions/newMultiArray.py +84 -0
  343. angr/engines/soot/expressions/paramref.py +7 -0
  344. angr/engines/soot/expressions/phi.py +29 -0
  345. angr/engines/soot/expressions/staticfieldref.py +7 -0
  346. angr/engines/soot/expressions/thisref.py +6 -0
  347. angr/engines/soot/expressions/unsupported.py +6 -0
  348. angr/engines/soot/field_dispatcher.py +49 -0
  349. angr/engines/soot/method_dispatcher.py +49 -0
  350. angr/engines/soot/statements/__init__.py +30 -0
  351. angr/engines/soot/statements/assign.py +29 -0
  352. angr/engines/soot/statements/base.py +80 -0
  353. angr/engines/soot/statements/goto.py +11 -0
  354. angr/engines/soot/statements/identity.py +14 -0
  355. angr/engines/soot/statements/if_.py +16 -0
  356. angr/engines/soot/statements/invoke.py +11 -0
  357. angr/engines/soot/statements/return_.py +19 -0
  358. angr/engines/soot/statements/switch.py +38 -0
  359. angr/engines/soot/statements/throw.py +12 -0
  360. angr/engines/soot/values/__init__.py +24 -0
  361. angr/engines/soot/values/arrayref.py +124 -0
  362. angr/engines/soot/values/base.py +4 -0
  363. angr/engines/soot/values/constants.py +17 -0
  364. angr/engines/soot/values/instancefieldref.py +42 -0
  365. angr/engines/soot/values/local.py +17 -0
  366. angr/engines/soot/values/paramref.py +17 -0
  367. angr/engines/soot/values/staticfieldref.py +37 -0
  368. angr/engines/soot/values/strref.py +37 -0
  369. angr/engines/soot/values/thisref.py +148 -0
  370. angr/engines/successors.py +540 -0
  371. angr/engines/syscall.py +53 -0
  372. angr/engines/unicorn.py +483 -0
  373. angr/engines/vex/__init__.py +4 -0
  374. angr/engines/vex/claripy/__init__.py +1 -0
  375. angr/engines/vex/claripy/ccall.py +2097 -0
  376. angr/engines/vex/claripy/datalayer.py +149 -0
  377. angr/engines/vex/claripy/irop.py +1279 -0
  378. angr/engines/vex/heavy/__init__.py +5 -0
  379. angr/engines/vex/heavy/actions.py +237 -0
  380. angr/engines/vex/heavy/concretizers.py +394 -0
  381. angr/engines/vex/heavy/dirty.py +467 -0
  382. angr/engines/vex/heavy/heavy.py +379 -0
  383. angr/engines/vex/heavy/inspect.py +51 -0
  384. angr/engines/vex/heavy/resilience.py +85 -0
  385. angr/engines/vex/heavy/super_fastpath.py +34 -0
  386. angr/engines/vex/lifter.py +424 -0
  387. angr/engines/vex/light/__init__.py +3 -0
  388. angr/engines/vex/light/light.py +555 -0
  389. angr/engines/vex/light/resilience.py +73 -0
  390. angr/engines/vex/light/slicing.py +51 -0
  391. angr/errors.py +604 -0
  392. angr/exploration_techniques/__init__.py +176 -0
  393. angr/exploration_techniques/bucketizer.py +96 -0
  394. angr/exploration_techniques/common.py +56 -0
  395. angr/exploration_techniques/dfs.py +34 -0
  396. angr/exploration_techniques/director.py +523 -0
  397. angr/exploration_techniques/driller_core.py +102 -0
  398. angr/exploration_techniques/explorer.py +146 -0
  399. angr/exploration_techniques/lengthlimiter.py +20 -0
  400. angr/exploration_techniques/local_loop_seer.py +64 -0
  401. angr/exploration_techniques/loop_seer.py +239 -0
  402. angr/exploration_techniques/manual_mergepoint.py +80 -0
  403. angr/exploration_techniques/memory_watcher.py +40 -0
  404. angr/exploration_techniques/oppologist.py +93 -0
  405. angr/exploration_techniques/slicecutor.py +115 -0
  406. angr/exploration_techniques/spiller.py +282 -0
  407. angr/exploration_techniques/spiller_db.py +27 -0
  408. angr/exploration_techniques/stochastic.py +57 -0
  409. angr/exploration_techniques/suggestions.py +156 -0
  410. angr/exploration_techniques/symbion.py +78 -0
  411. angr/exploration_techniques/tech_builder.py +47 -0
  412. angr/exploration_techniques/threading.py +77 -0
  413. angr/exploration_techniques/timeout.py +31 -0
  414. angr/exploration_techniques/tracer.py +1101 -0
  415. angr/exploration_techniques/unique.py +104 -0
  416. angr/exploration_techniques/veritesting.py +36 -0
  417. angr/factory.py +385 -0
  418. angr/flirt/__init__.py +126 -0
  419. angr/flirt/build_sig.py +316 -0
  420. angr/graph_utils.py +0 -0
  421. angr/keyed_region.py +532 -0
  422. angr/knowledge_base/__init__.py +1 -0
  423. angr/knowledge_base/knowledge_base.py +145 -0
  424. angr/knowledge_plugins/__init__.py +18 -0
  425. angr/knowledge_plugins/callsite_prototypes.py +52 -0
  426. angr/knowledge_plugins/cfg/__init__.py +16 -0
  427. angr/knowledge_plugins/cfg/cfg_manager.py +94 -0
  428. angr/knowledge_plugins/cfg/cfg_model.py +1057 -0
  429. angr/knowledge_plugins/cfg/cfg_node.py +541 -0
  430. angr/knowledge_plugins/cfg/indirect_jump.py +67 -0
  431. angr/knowledge_plugins/cfg/memory_data.py +156 -0
  432. angr/knowledge_plugins/comments.py +15 -0
  433. angr/knowledge_plugins/custom_strings.py +37 -0
  434. angr/knowledge_plugins/data.py +21 -0
  435. angr/knowledge_plugins/debug_variables.py +221 -0
  436. angr/knowledge_plugins/functions/__init__.py +2 -0
  437. angr/knowledge_plugins/functions/function.py +1694 -0
  438. angr/knowledge_plugins/functions/function_manager.py +501 -0
  439. angr/knowledge_plugins/functions/function_parser.py +295 -0
  440. angr/knowledge_plugins/functions/soot_function.py +131 -0
  441. angr/knowledge_plugins/indirect_jumps.py +34 -0
  442. angr/knowledge_plugins/key_definitions/__init__.py +16 -0
  443. angr/knowledge_plugins/key_definitions/atoms.py +314 -0
  444. angr/knowledge_plugins/key_definitions/constants.py +23 -0
  445. angr/knowledge_plugins/key_definitions/definition.py +217 -0
  446. angr/knowledge_plugins/key_definitions/environment.py +92 -0
  447. angr/knowledge_plugins/key_definitions/heap_address.py +32 -0
  448. angr/knowledge_plugins/key_definitions/key_definition_manager.py +81 -0
  449. angr/knowledge_plugins/key_definitions/live_definitions.py +1074 -0
  450. angr/knowledge_plugins/key_definitions/liveness.py +170 -0
  451. angr/knowledge_plugins/key_definitions/rd_model.py +176 -0
  452. angr/knowledge_plugins/key_definitions/tag.py +77 -0
  453. angr/knowledge_plugins/key_definitions/undefined.py +67 -0
  454. angr/knowledge_plugins/key_definitions/unknown_size.py +83 -0
  455. angr/knowledge_plugins/key_definitions/uses.py +180 -0
  456. angr/knowledge_plugins/labels.py +109 -0
  457. angr/knowledge_plugins/patches.py +125 -0
  458. angr/knowledge_plugins/plugin.py +23 -0
  459. angr/knowledge_plugins/propagations/__init__.py +2 -0
  460. angr/knowledge_plugins/propagations/prop_value.py +193 -0
  461. angr/knowledge_plugins/propagations/propagation_manager.py +60 -0
  462. angr/knowledge_plugins/propagations/propagation_model.py +74 -0
  463. angr/knowledge_plugins/propagations/states.py +1064 -0
  464. angr/knowledge_plugins/structured_code/__init__.py +1 -0
  465. angr/knowledge_plugins/structured_code/manager.py +59 -0
  466. angr/knowledge_plugins/sync/__init__.py +1 -0
  467. angr/knowledge_plugins/sync/sync_controller.py +329 -0
  468. angr/knowledge_plugins/types.py +87 -0
  469. angr/knowledge_plugins/variables/__init__.py +1 -0
  470. angr/knowledge_plugins/variables/variable_access.py +114 -0
  471. angr/knowledge_plugins/variables/variable_manager.py +1191 -0
  472. angr/knowledge_plugins/xrefs/__init__.py +3 -0
  473. angr/knowledge_plugins/xrefs/xref.py +157 -0
  474. angr/knowledge_plugins/xrefs/xref_manager.py +122 -0
  475. angr/knowledge_plugins/xrefs/xref_types.py +13 -0
  476. angr/lib/angr_native.dylib +0 -0
  477. angr/misc/__init__.py +8 -0
  478. angr/misc/ansi.py +46 -0
  479. angr/misc/autoimport.py +89 -0
  480. angr/misc/bug_report.py +125 -0
  481. angr/misc/hookset.py +106 -0
  482. angr/misc/import_hooks.py +63 -0
  483. angr/misc/loggers.py +130 -0
  484. angr/misc/picklable_lock.py +45 -0
  485. angr/misc/plugins.py +291 -0
  486. angr/misc/range.py +21 -0
  487. angr/misc/testing.py +23 -0
  488. angr/misc/ux.py +31 -0
  489. angr/misc/weakpatch.py +58 -0
  490. angr/procedures/__init__.py +2 -0
  491. angr/procedures/advapi32/__init__.py +0 -0
  492. angr/procedures/cgc/__init__.py +3 -0
  493. angr/procedures/cgc/_terminate.py +10 -0
  494. angr/procedures/cgc/allocate.py +76 -0
  495. angr/procedures/cgc/deallocate.py +59 -0
  496. angr/procedures/cgc/fdwait.py +62 -0
  497. angr/procedures/cgc/random.py +60 -0
  498. angr/procedures/cgc/receive.py +91 -0
  499. angr/procedures/cgc/transmit.py +63 -0
  500. angr/procedures/definitions/__init__.py +784 -0
  501. angr/procedures/definitions/cgc.py +19 -0
  502. angr/procedures/definitions/glibc.py +8384 -0
  503. angr/procedures/definitions/gnulib.py +35 -0
  504. angr/procedures/definitions/libstdcpp.py +20 -0
  505. angr/procedures/definitions/linux_kernel.py +6167 -0
  506. angr/procedures/definitions/linux_loader.py +6 -0
  507. angr/procedures/definitions/msvcr.py +15 -0
  508. angr/procedures/definitions/parse_syscalls_from_local_system.py +49 -0
  509. angr/procedures/definitions/parse_win32json.py +2556 -0
  510. angr/procedures/definitions/types_win32.py +34481 -0
  511. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-4.py +44 -0
  512. angr/procedures/definitions/wdk_api-ms-win-dx-d3dkmt-l1-1-6.py +40 -0
  513. angr/procedures/definitions/wdk_clfs.py +154 -0
  514. angr/procedures/definitions/wdk_fltmgr.py +570 -0
  515. angr/procedures/definitions/wdk_fwpkclnt.py +44 -0
  516. angr/procedures/definitions/wdk_fwpuclnt.py +330 -0
  517. angr/procedures/definitions/wdk_gdi32.py +380 -0
  518. angr/procedures/definitions/wdk_hal.py +92 -0
  519. angr/procedures/definitions/wdk_ksecdd.py +76 -0
  520. angr/procedures/definitions/wdk_ndis.py +252 -0
  521. angr/procedures/definitions/wdk_ntoskrnl.py +3463 -0
  522. angr/procedures/definitions/wdk_offreg.py +86 -0
  523. angr/procedures/definitions/wdk_pshed.py +50 -0
  524. angr/procedures/definitions/wdk_secur32.py +54 -0
  525. angr/procedures/definitions/wdk_vhfum.py +48 -0
  526. angr/procedures/definitions/win32_aclui.py +44 -0
  527. angr/procedures/definitions/win32_activeds.py +82 -0
  528. angr/procedures/definitions/win32_advapi32.py +1698 -0
  529. angr/procedures/definitions/win32_advpack.py +138 -0
  530. angr/procedures/definitions/win32_amsi.py +52 -0
  531. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-1.py +58 -0
  532. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-3.py +48 -0
  533. angr/procedures/definitions/win32_api-ms-win-appmodel-runtime-l1-1-6.py +40 -0
  534. angr/procedures/definitions/win32_api-ms-win-core-apiquery-l2-1-0.py +40 -0
  535. angr/procedures/definitions/win32_api-ms-win-core-backgroundtask-l1-1-0.py +40 -0
  536. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-1.py +40 -0
  537. angr/procedures/definitions/win32_api-ms-win-core-comm-l1-1-2.py +40 -0
  538. angr/procedures/definitions/win32_api-ms-win-core-enclave-l1-1-1.py +44 -0
  539. angr/procedures/definitions/win32_api-ms-win-core-errorhandling-l1-1-3.py +40 -0
  540. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-0.py +48 -0
  541. angr/procedures/definitions/win32_api-ms-win-core-featurestaging-l1-1-1.py +40 -0
  542. angr/procedures/definitions/win32_api-ms-win-core-file-fromapp-l1-1-0.py +60 -0
  543. angr/procedures/definitions/win32_api-ms-win-core-handle-l1-1-0.py +40 -0
  544. angr/procedures/definitions/win32_api-ms-win-core-ioring-l1-1-0.py +62 -0
  545. angr/procedures/definitions/win32_api-ms-win-core-marshal-l1-1-0.py +46 -0
  546. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-3.py +46 -0
  547. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-4.py +40 -0
  548. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-5.py +44 -0
  549. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-6.py +46 -0
  550. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-7.py +42 -0
  551. angr/procedures/definitions/win32_api-ms-win-core-memory-l1-1-8.py +44 -0
  552. angr/procedures/definitions/win32_api-ms-win-core-path-l1-1-0.py +82 -0
  553. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-0.py +42 -0
  554. angr/procedures/definitions/win32_api-ms-win-core-psm-appnotify-l1-1-1.py +42 -0
  555. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-1.py +44 -0
  556. angr/procedures/definitions/win32_api-ms-win-core-realtime-l1-1-2.py +44 -0
  557. angr/procedures/definitions/win32_api-ms-win-core-slapi-l1-1-0.py +40 -0
  558. angr/procedures/definitions/win32_api-ms-win-core-state-helpers-l1-1-0.py +40 -0
  559. angr/procedures/definitions/win32_api-ms-win-core-synch-l1-2-0.py +44 -0
  560. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-0.py +40 -0
  561. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-3.py +42 -0
  562. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-4.py +42 -0
  563. angr/procedures/definitions/win32_api-ms-win-core-sysinfo-l1-2-6.py +40 -0
  564. angr/procedures/definitions/win32_api-ms-win-core-util-l1-1-1.py +42 -0
  565. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-0.py +43 -0
  566. angr/procedures/definitions/win32_api-ms-win-core-winrt-error-l1-1-1.py +37 -0
  567. angr/procedures/definitions/win32_api-ms-win-core-winrt-l1-1-0.py +39 -0
  568. angr/procedures/definitions/win32_api-ms-win-core-winrt-registration-l1-1-0.py +23 -0
  569. angr/procedures/definitions/win32_api-ms-win-core-winrt-robuffer-l1-1-0.py +23 -0
  570. angr/procedures/definitions/win32_api-ms-win-core-winrt-roparameterizediid-l1-1-0.py +27 -0
  571. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-0.py +75 -0
  572. angr/procedures/definitions/win32_api-ms-win-core-winrt-string-l1-1-1.py +23 -0
  573. angr/procedures/definitions/win32_api-ms-win-core-wow64-l1-1-1.py +44 -0
  574. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-0.py +56 -0
  575. angr/procedures/definitions/win32_api-ms-win-devices-query-l1-1-1.py +48 -0
  576. angr/procedures/definitions/win32_api-ms-win-dx-d3dkmt-l1-1-0.py +40 -0
  577. angr/procedures/definitions/win32_api-ms-win-gaming-deviceinformation-l1-1-0.py +40 -0
  578. angr/procedures/definitions/win32_api-ms-win-gaming-expandedresources-l1-1-0.py +44 -0
  579. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-0.py +52 -0
  580. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-1.py +42 -0
  581. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-2.py +52 -0
  582. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-3.py +42 -0
  583. angr/procedures/definitions/win32_api-ms-win-gaming-tcui-l1-1-4.py +54 -0
  584. angr/procedures/definitions/win32_api-ms-win-mm-misc-l1-1-1.py +40 -0
  585. angr/procedures/definitions/win32_api-ms-win-net-isolation-l1-1-0.py +54 -0
  586. angr/procedures/definitions/win32_api-ms-win-security-base-l1-2-2.py +40 -0
  587. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-0.py +40 -0
  588. angr/procedures/definitions/win32_api-ms-win-security-isolatedcontainer-l1-1-1.py +40 -0
  589. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-3.py +40 -0
  590. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-4.py +40 -0
  591. angr/procedures/definitions/win32_api-ms-win-service-core-l1-1-5.py +42 -0
  592. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-0.py +44 -0
  593. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-1.py +50 -0
  594. angr/procedures/definitions/win32_api-ms-win-shcore-scaling-l1-1-2.py +40 -0
  595. angr/procedures/definitions/win32_api-ms-win-shcore-stream-winrt-l1-1-0.py +27 -0
  596. angr/procedures/definitions/win32_api-ms-win-wsl-api-l1-1-0.py +52 -0
  597. angr/procedures/definitions/win32_apphelp.py +40 -0
  598. angr/procedures/definitions/win32_authz.py +104 -0
  599. angr/procedures/definitions/win32_avicap32.py +46 -0
  600. angr/procedures/definitions/win32_avifil32.py +158 -0
  601. angr/procedures/definitions/win32_avrt.py +66 -0
  602. angr/procedures/definitions/win32_bcp47mrm.py +42 -0
  603. angr/procedures/definitions/win32_bcrypt.py +144 -0
  604. angr/procedures/definitions/win32_bcryptprimitives.py +42 -0
  605. angr/procedures/definitions/win32_bluetoothapis.py +120 -0
  606. angr/procedures/definitions/win32_bthprops.py +33 -0
  607. angr/procedures/definitions/win32_bthprops_cpl.py +50 -0
  608. angr/procedures/definitions/win32_cabinet.py +82 -0
  609. angr/procedures/definitions/win32_certadm.py +74 -0
  610. angr/procedures/definitions/win32_certpoleng.py +54 -0
  611. angr/procedures/definitions/win32_cfgmgr32.py +516 -0
  612. angr/procedures/definitions/win32_chakra.py +212 -0
  613. angr/procedures/definitions/win32_cldapi.py +110 -0
  614. angr/procedures/definitions/win32_clfsw32.py +156 -0
  615. angr/procedures/definitions/win32_clusapi.py +598 -0
  616. angr/procedures/definitions/win32_comctl32.py +268 -0
  617. angr/procedures/definitions/win32_comdlg32.py +80 -0
  618. angr/procedures/definitions/win32_compstui.py +46 -0
  619. angr/procedures/definitions/win32_computecore.py +146 -0
  620. angr/procedures/definitions/win32_computenetwork.py +124 -0
  621. angr/procedures/definitions/win32_computestorage.py +62 -0
  622. angr/procedures/definitions/win32_comsvcs.py +52 -0
  623. angr/procedures/definitions/win32_coremessaging.py +23 -0
  624. angr/procedures/definitions/win32_credui.py +76 -0
  625. angr/procedures/definitions/win32_crypt32.py +496 -0
  626. angr/procedures/definitions/win32_cryptnet.py +48 -0
  627. angr/procedures/definitions/win32_cryptui.py +58 -0
  628. angr/procedures/definitions/win32_cryptxml.py +76 -0
  629. angr/procedures/definitions/win32_cscapi.py +46 -0
  630. angr/procedures/definitions/win32_d2d1.py +64 -0
  631. angr/procedures/definitions/win32_d3d10.py +92 -0
  632. angr/procedures/definitions/win32_d3d10_1.py +42 -0
  633. angr/procedures/definitions/win32_d3d11.py +44 -0
  634. angr/procedures/definitions/win32_d3d12.py +54 -0
  635. angr/procedures/definitions/win32_d3d9.py +60 -0
  636. angr/procedures/definitions/win32_d3dcompiler_47.py +90 -0
  637. angr/procedures/definitions/win32_d3dcsx.py +56 -0
  638. angr/procedures/definitions/win32_davclnt.py +74 -0
  639. angr/procedures/definitions/win32_dbgeng.py +46 -0
  640. angr/procedures/definitions/win32_dbghelp.py +476 -0
  641. angr/procedures/definitions/win32_dbgmodel.py +40 -0
  642. angr/procedures/definitions/win32_dciman32.py +78 -0
  643. angr/procedures/definitions/win32_dcomp.py +62 -0
  644. angr/procedures/definitions/win32_ddraw.py +52 -0
  645. angr/procedures/definitions/win32_deviceaccess.py +40 -0
  646. angr/procedures/definitions/win32_dflayout.py +40 -0
  647. angr/procedures/definitions/win32_dhcpcsvc.py +68 -0
  648. angr/procedures/definitions/win32_dhcpcsvc6.py +50 -0
  649. angr/procedures/definitions/win32_dhcpsapi.py +430 -0
  650. angr/procedures/definitions/win32_diagnosticdataquery.py +108 -0
  651. angr/procedures/definitions/win32_dinput8.py +40 -0
  652. angr/procedures/definitions/win32_directml.py +42 -0
  653. angr/procedures/definitions/win32_dmprocessxmlfiltered.py +40 -0
  654. angr/procedures/definitions/win32_dnsapi.py +166 -0
  655. angr/procedures/definitions/win32_drt.py +70 -0
  656. angr/procedures/definitions/win32_drtprov.py +56 -0
  657. angr/procedures/definitions/win32_drttransport.py +42 -0
  658. angr/procedures/definitions/win32_dsound.py +58 -0
  659. angr/procedures/definitions/win32_dsparse.py +76 -0
  660. angr/procedures/definitions/win32_dsprop.py +52 -0
  661. angr/procedures/definitions/win32_dssec.py +46 -0
  662. angr/procedures/definitions/win32_dsuiext.py +46 -0
  663. angr/procedures/definitions/win32_dwmapi.py +100 -0
  664. angr/procedures/definitions/win32_dwrite.py +40 -0
  665. angr/procedures/definitions/win32_dxcompiler.py +42 -0
  666. angr/procedures/definitions/win32_dxcore.py +40 -0
  667. angr/procedures/definitions/win32_dxgi.py +50 -0
  668. angr/procedures/definitions/win32_dxva2.py +114 -0
  669. angr/procedures/definitions/win32_eappcfg.py +66 -0
  670. angr/procedures/definitions/win32_eappprxy.py +74 -0
  671. angr/procedures/definitions/win32_efswrt.py +42 -0
  672. angr/procedures/definitions/win32_elscore.py +48 -0
  673. angr/procedures/definitions/win32_esent.py +496 -0
  674. angr/procedures/definitions/win32_evr.py +52 -0
  675. angr/procedures/definitions/win32_faultrep.py +46 -0
  676. angr/procedures/definitions/win32_fhsvcctl.py +52 -0
  677. angr/procedures/definitions/win32_firewallapi.py +44 -0
  678. angr/procedures/definitions/win32_fltlib.py +94 -0
  679. angr/procedures/definitions/win32_fontsub.py +42 -0
  680. angr/procedures/definitions/win32_forceinline.py +44 -0
  681. angr/procedures/definitions/win32_fwpuclnt.py +422 -0
  682. angr/procedures/definitions/win32_fxsutility.py +42 -0
  683. angr/procedures/definitions/win32_gdi32.py +900 -0
  684. angr/procedures/definitions/win32_gdiplus.py +1296 -0
  685. angr/procedures/definitions/win32_glu32.py +142 -0
  686. angr/procedures/definitions/win32_gpedit.py +50 -0
  687. angr/procedures/definitions/win32_hhctrl_ocx.py +42 -0
  688. angr/procedures/definitions/win32_hid.py +128 -0
  689. angr/procedures/definitions/win32_hlink.py +94 -0
  690. angr/procedures/definitions/win32_hrtfapo.py +40 -0
  691. angr/procedures/definitions/win32_httpapi.py +124 -0
  692. angr/procedures/definitions/win32_icm32.py +80 -0
  693. angr/procedures/definitions/win32_icmui.py +42 -0
  694. angr/procedures/definitions/win32_icu.py +2088 -0
  695. angr/procedures/definitions/win32_ieframe.py +96 -0
  696. angr/procedures/definitions/win32_imagehlp.py +90 -0
  697. angr/procedures/definitions/win32_imgutil.py +56 -0
  698. angr/procedures/definitions/win32_imm32.py +202 -0
  699. angr/procedures/definitions/win32_infocardapi.py +72 -0
  700. angr/procedures/definitions/win32_inkobjcore.py +92 -0
  701. angr/procedures/definitions/win32_iphlpapi.py +440 -0
  702. angr/procedures/definitions/win32_iscsidsc.py +196 -0
  703. angr/procedures/definitions/win32_isolatedwindowsenvironmentutils.py +42 -0
  704. angr/procedures/definitions/win32_kernel32.py +3199 -0
  705. angr/procedures/definitions/win32_kernelbase.py +50 -0
  706. angr/procedures/definitions/win32_keycredmgr.py +46 -0
  707. angr/procedures/definitions/win32_ksproxy_ax.py +50 -0
  708. angr/procedures/definitions/win32_ksuser.py +54 -0
  709. angr/procedures/definitions/win32_ktmw32.py +116 -0
  710. angr/procedures/definitions/win32_licenseprotection.py +42 -0
  711. angr/procedures/definitions/win32_loadperf.py +62 -0
  712. angr/procedures/definitions/win32_magnification.py +76 -0
  713. angr/procedures/definitions/win32_mapi32.py +170 -0
  714. angr/procedures/definitions/win32_mdmlocalmanagement.py +44 -0
  715. angr/procedures/definitions/win32_mdmregistration.py +68 -0
  716. angr/procedures/definitions/win32_mf.py +162 -0
  717. angr/procedures/definitions/win32_mfcore.py +42 -0
  718. angr/procedures/definitions/win32_mfplat.py +328 -0
  719. angr/procedures/definitions/win32_mfplay.py +40 -0
  720. angr/procedures/definitions/win32_mfreadwrite.py +48 -0
  721. angr/procedures/definitions/win32_mfsensorgroup.py +58 -0
  722. angr/procedures/definitions/win32_mfsrcsnk.py +42 -0
  723. angr/procedures/definitions/win32_mgmtapi.py +56 -0
  724. angr/procedures/definitions/win32_mi.py +40 -0
  725. angr/procedures/definitions/win32_mmdevapi.py +40 -0
  726. angr/procedures/definitions/win32_mpr.py +132 -0
  727. angr/procedures/definitions/win32_mprapi.py +262 -0
  728. angr/procedures/definitions/win32_mqrt.py +106 -0
  729. angr/procedures/definitions/win32_mrmsupport.py +92 -0
  730. angr/procedures/definitions/win32_msacm32.py +122 -0
  731. angr/procedures/definitions/win32_msajapi.py +1132 -0
  732. angr/procedures/definitions/win32_mscms.py +196 -0
  733. angr/procedures/definitions/win32_mscoree.py +92 -0
  734. angr/procedures/definitions/win32_msctfmonitor.py +44 -0
  735. angr/procedures/definitions/win32_msdelta.py +70 -0
  736. angr/procedures/definitions/win32_msdmo.py +60 -0
  737. angr/procedures/definitions/win32_msdrm.py +206 -0
  738. angr/procedures/definitions/win32_msi.py +566 -0
  739. angr/procedures/definitions/win32_msimg32.py +44 -0
  740. angr/procedures/definitions/win32_mspatcha.py +70 -0
  741. angr/procedures/definitions/win32_mspatchc.py +56 -0
  742. angr/procedures/definitions/win32_msports.py +52 -0
  743. angr/procedures/definitions/win32_msrating.py +76 -0
  744. angr/procedures/definitions/win32_mssign32.py +58 -0
  745. angr/procedures/definitions/win32_mstask.py +42 -0
  746. angr/procedures/definitions/win32_msvfw32.py +124 -0
  747. angr/procedures/definitions/win32_mswsock.py +70 -0
  748. angr/procedures/definitions/win32_mtxdm.py +40 -0
  749. angr/procedures/definitions/win32_ncrypt.py +116 -0
  750. angr/procedures/definitions/win32_ndfapi.py +70 -0
  751. angr/procedures/definitions/win32_netapi32.py +450 -0
  752. angr/procedures/definitions/win32_netsh.py +54 -0
  753. angr/procedures/definitions/win32_netshell.py +42 -0
  754. angr/procedures/definitions/win32_newdev.py +60 -0
  755. angr/procedures/definitions/win32_ninput.py +98 -0
  756. angr/procedures/definitions/win32_normaliz.py +42 -0
  757. angr/procedures/definitions/win32_ntdll.py +185 -0
  758. angr/procedures/definitions/win32_ntdllk.py +40 -0
  759. angr/procedures/definitions/win32_ntdsapi.py +200 -0
  760. angr/procedures/definitions/win32_ntlanman.py +58 -0
  761. angr/procedures/definitions/win32_odbc32.py +406 -0
  762. angr/procedures/definitions/win32_odbcbcp.py +92 -0
  763. angr/procedures/definitions/win32_ole32.py +672 -0
  764. angr/procedures/definitions/win32_oleacc.py +72 -0
  765. angr/procedures/definitions/win32_oleaut32.py +848 -0
  766. angr/procedures/definitions/win32_oledlg.py +84 -0
  767. angr/procedures/definitions/win32_ondemandconnroutehelper.py +48 -0
  768. angr/procedures/definitions/win32_opengl32.py +748 -0
  769. angr/procedures/definitions/win32_opmxbox.py +44 -0
  770. angr/procedures/definitions/win32_p2p.py +254 -0
  771. angr/procedures/definitions/win32_p2pgraph.py +112 -0
  772. angr/procedures/definitions/win32_pdh.py +234 -0
  773. angr/procedures/definitions/win32_peerdist.py +94 -0
  774. angr/procedures/definitions/win32_powrprof.py +206 -0
  775. angr/procedures/definitions/win32_prntvpt.py +60 -0
  776. angr/procedures/definitions/win32_projectedfslib.py +76 -0
  777. angr/procedures/definitions/win32_propsys.py +474 -0
  778. angr/procedures/definitions/win32_psapi.py +92 -0
  779. angr/procedures/definitions/win32_quartz.py +42 -0
  780. angr/procedures/definitions/win32_query.py +46 -0
  781. angr/procedures/definitions/win32_qwave.py +60 -0
  782. angr/procedures/definitions/win32_rasapi32.py +206 -0
  783. angr/procedures/definitions/win32_rasdlg.py +50 -0
  784. angr/procedures/definitions/win32_resutils.py +278 -0
  785. angr/procedures/definitions/win32_rometadata.py +23 -0
  786. angr/procedures/definitions/win32_rpcns4.py +160 -0
  787. angr/procedures/definitions/win32_rpcproxy.py +46 -0
  788. angr/procedures/definitions/win32_rpcrt4.py +932 -0
  789. angr/procedures/definitions/win32_rstrtmgr.py +60 -0
  790. angr/procedures/definitions/win32_rtm.py +190 -0
  791. angr/procedures/definitions/win32_rtutils.py +120 -0
  792. angr/procedures/definitions/win32_rtworkq.py +104 -0
  793. angr/procedures/definitions/win32_sas.py +40 -0
  794. angr/procedures/definitions/win32_scarddlg.py +48 -0
  795. angr/procedures/definitions/win32_schannel.py +56 -0
  796. angr/procedures/definitions/win32_sechost.py +42 -0
  797. angr/procedures/definitions/win32_secur32.py +216 -0
  798. angr/procedures/definitions/win32_sensapi.py +44 -0
  799. angr/procedures/definitions/win32_sensorsutilsv2.py +118 -0
  800. angr/procedures/definitions/win32_setupapi.py +706 -0
  801. angr/procedures/definitions/win32_sfc.py +50 -0
  802. angr/procedures/definitions/win32_shdocvw.py +44 -0
  803. angr/procedures/definitions/win32_shell32.py +526 -0
  804. angr/procedures/definitions/win32_shlwapi.py +758 -0
  805. angr/procedures/definitions/win32_slc.py +102 -0
  806. angr/procedures/definitions/win32_slcext.py +46 -0
  807. angr/procedures/definitions/win32_slwga.py +40 -0
  808. angr/procedures/definitions/win32_snmpapi.py +90 -0
  809. angr/procedures/definitions/win32_spoolss.py +90 -0
  810. angr/procedures/definitions/win32_srclient.py +40 -0
  811. angr/procedures/definitions/win32_srpapi.py +60 -0
  812. angr/procedures/definitions/win32_sspicli.py +52 -0
  813. angr/procedures/definitions/win32_sti.py +40 -0
  814. angr/procedures/definitions/win32_t2embed.py +66 -0
  815. angr/procedures/definitions/win32_tapi32.py +536 -0
  816. angr/procedures/definitions/win32_tbs.py +66 -0
  817. angr/procedures/definitions/win32_tdh.py +92 -0
  818. angr/procedures/definitions/win32_tokenbinding.py +58 -0
  819. angr/procedures/definitions/win32_traffic.py +78 -0
  820. angr/procedures/definitions/win32_txfw32.py +56 -0
  821. angr/procedures/definitions/win32_ualapi.py +46 -0
  822. angr/procedures/definitions/win32_uiautomationcore.py +234 -0
  823. angr/procedures/definitions/win32_urlmon.py +192 -0
  824. angr/procedures/definitions/win32_user32.py +1565 -0
  825. angr/procedures/definitions/win32_userenv.py +126 -0
  826. angr/procedures/definitions/win32_usp10.py +118 -0
  827. angr/procedures/definitions/win32_uxtheme.py +192 -0
  828. angr/procedures/definitions/win32_verifier.py +40 -0
  829. angr/procedures/definitions/win32_version.py +66 -0
  830. angr/procedures/definitions/win32_vertdll.py +52 -0
  831. angr/procedures/definitions/win32_virtdisk.py +96 -0
  832. angr/procedures/definitions/win32_vmdevicehost.py +64 -0
  833. angr/procedures/definitions/win32_vmsavedstatedumpprovider.py +124 -0
  834. angr/procedures/definitions/win32_vssapi.py +40 -0
  835. angr/procedures/definitions/win32_wcmapi.py +48 -0
  836. angr/procedures/definitions/win32_wdsbp.py +52 -0
  837. angr/procedures/definitions/win32_wdsclientapi.py +112 -0
  838. angr/procedures/definitions/win32_wdsmc.py +50 -0
  839. angr/procedures/definitions/win32_wdspxe.py +100 -0
  840. angr/procedures/definitions/win32_wdstptc.py +64 -0
  841. angr/procedures/definitions/win32_webauthn.py +64 -0
  842. angr/procedures/definitions/win32_webservices.py +424 -0
  843. angr/procedures/definitions/win32_websocket.py +64 -0
  844. angr/procedures/definitions/win32_wecapi.py +68 -0
  845. angr/procedures/definitions/win32_wer.py +80 -0
  846. angr/procedures/definitions/win32_wevtapi.py +108 -0
  847. angr/procedures/definitions/win32_winbio.py +146 -0
  848. angr/procedures/definitions/win32_windows_ai_machinelearning.py +40 -0
  849. angr/procedures/definitions/win32_windows_data_pdf.py +23 -0
  850. angr/procedures/definitions/win32_windows_media_mediacontrol.py +54 -0
  851. angr/procedures/definitions/win32_windows_networking.py +40 -0
  852. angr/procedures/definitions/win32_windows_ui_xaml.py +42 -0
  853. angr/procedures/definitions/win32_windowscodecs.py +56 -0
  854. angr/procedures/definitions/win32_winfax.py +150 -0
  855. angr/procedures/definitions/win32_winhttp.py +150 -0
  856. angr/procedures/definitions/win32_winhvemulation.py +46 -0
  857. angr/procedures/definitions/win32_winhvplatform.py +170 -0
  858. angr/procedures/definitions/win32_wininet.py +630 -0
  859. angr/procedures/definitions/win32_winml.py +40 -0
  860. angr/procedures/definitions/win32_winmm.py +390 -0
  861. angr/procedures/definitions/win32_winscard.py +178 -0
  862. angr/procedures/definitions/win32_winspool.py +363 -0
  863. angr/procedures/definitions/win32_winspool_drv.py +382 -0
  864. angr/procedures/definitions/win32_wintrust.py +158 -0
  865. angr/procedures/definitions/win32_winusb.py +106 -0
  866. angr/procedures/definitions/win32_wlanapi.py +158 -0
  867. angr/procedures/definitions/win32_wlanui.py +40 -0
  868. angr/procedures/definitions/win32_wldap32.py +524 -0
  869. angr/procedures/definitions/win32_wldp.py +56 -0
  870. angr/procedures/definitions/win32_wmvcore.py +60 -0
  871. angr/procedures/definitions/win32_wnvapi.py +42 -0
  872. angr/procedures/definitions/win32_wofutil.py +60 -0
  873. angr/procedures/definitions/win32_ws2_32.py +358 -0
  874. angr/procedures/definitions/win32_wscapi.py +50 -0
  875. angr/procedures/definitions/win32_wsclient.py +44 -0
  876. angr/procedures/definitions/win32_wsdapi.py +102 -0
  877. angr/procedures/definitions/win32_wsmsvc.py +104 -0
  878. angr/procedures/definitions/win32_wsnmp32.py +136 -0
  879. angr/procedures/definitions/win32_wtsapi32.py +164 -0
  880. angr/procedures/definitions/win32_xaudio2_8.py +46 -0
  881. angr/procedures/definitions/win32_xinput1_4.py +52 -0
  882. angr/procedures/definitions/win32_xinputuap.py +35 -0
  883. angr/procedures/definitions/win32_xmllite.py +50 -0
  884. angr/procedures/definitions/win32_xolehlp.py +46 -0
  885. angr/procedures/definitions/win32_xpsprint.py +42 -0
  886. angr/procedures/glibc/__ctype_b_loc.py +22 -0
  887. angr/procedures/glibc/__ctype_tolower_loc.py +22 -0
  888. angr/procedures/glibc/__ctype_toupper_loc.py +22 -0
  889. angr/procedures/glibc/__errno_location.py +6 -0
  890. angr/procedures/glibc/__init__.py +3 -0
  891. angr/procedures/glibc/__libc_init.py +36 -0
  892. angr/procedures/glibc/__libc_start_main.py +294 -0
  893. angr/procedures/glibc/dynamic_loading.py +19 -0
  894. angr/procedures/glibc/scanf.py +10 -0
  895. angr/procedures/glibc/sscanf.py +5 -0
  896. angr/procedures/gnulib/__init__.py +3 -0
  897. angr/procedures/gnulib/xalloc_die.py +13 -0
  898. angr/procedures/gnulib/xstrtol_fatal.py +13 -0
  899. angr/procedures/java/__init__.py +38 -0
  900. angr/procedures/java/unconstrained.py +64 -0
  901. angr/procedures/java_io/__init__.py +0 -0
  902. angr/procedures/java_io/read.py +11 -0
  903. angr/procedures/java_io/write.py +16 -0
  904. angr/procedures/java_jni/__init__.py +475 -0
  905. angr/procedures/java_jni/array_operations.py +309 -0
  906. angr/procedures/java_jni/class_and_interface_operations.py +31 -0
  907. angr/procedures/java_jni/field_access.py +176 -0
  908. angr/procedures/java_jni/global_and_local_refs.py +56 -0
  909. angr/procedures/java_jni/method_calls.py +364 -0
  910. angr/procedures/java_jni/not_implemented.py +25 -0
  911. angr/procedures/java_jni/object_operations.py +95 -0
  912. angr/procedures/java_jni/string_operations.py +86 -0
  913. angr/procedures/java_jni/version_information.py +11 -0
  914. angr/procedures/java_lang/__init__.py +0 -0
  915. angr/procedures/java_lang/character.py +31 -0
  916. angr/procedures/java_lang/double.py +24 -0
  917. angr/procedures/java_lang/exit.py +12 -0
  918. angr/procedures/java_lang/getsimplename.py +15 -0
  919. angr/procedures/java_lang/integer.py +42 -0
  920. angr/procedures/java_lang/load_library.py +8 -0
  921. angr/procedures/java_lang/math.py +14 -0
  922. angr/procedures/java_lang/string.py +78 -0
  923. angr/procedures/java_lang/stringbuilder.py +43 -0
  924. angr/procedures/java_lang/system.py +17 -0
  925. angr/procedures/java_util/__init__.py +0 -0
  926. angr/procedures/java_util/collection.py +34 -0
  927. angr/procedures/java_util/iterator.py +45 -0
  928. angr/procedures/java_util/list.py +98 -0
  929. angr/procedures/java_util/map.py +132 -0
  930. angr/procedures/java_util/random.py +11 -0
  931. angr/procedures/java_util/scanner_nextline.py +22 -0
  932. angr/procedures/libc/__init__.py +3 -0
  933. angr/procedures/libc/abort.py +8 -0
  934. angr/procedures/libc/access.py +10 -0
  935. angr/procedures/libc/atoi.py +14 -0
  936. angr/procedures/libc/atol.py +12 -0
  937. angr/procedures/libc/calloc.py +7 -0
  938. angr/procedures/libc/closelog.py +9 -0
  939. angr/procedures/libc/err.py +13 -0
  940. angr/procedures/libc/error.py +55 -0
  941. angr/procedures/libc/exit.py +10 -0
  942. angr/procedures/libc/fclose.py +20 -0
  943. angr/procedures/libc/feof.py +19 -0
  944. angr/procedures/libc/fflush.py +15 -0
  945. angr/procedures/libc/fgetc.py +24 -0
  946. angr/procedures/libc/fgets.py +68 -0
  947. angr/procedures/libc/fopen.py +64 -0
  948. angr/procedures/libc/fprintf.py +24 -0
  949. angr/procedures/libc/fputc.py +22 -0
  950. angr/procedures/libc/fputs.py +23 -0
  951. angr/procedures/libc/fread.py +22 -0
  952. angr/procedures/libc/free.py +8 -0
  953. angr/procedures/libc/fscanf.py +20 -0
  954. angr/procedures/libc/fseek.py +32 -0
  955. angr/procedures/libc/ftell.py +21 -0
  956. angr/procedures/libc/fwrite.py +18 -0
  957. angr/procedures/libc/getchar.py +13 -0
  958. angr/procedures/libc/getdelim.py +96 -0
  959. angr/procedures/libc/getegid.py +7 -0
  960. angr/procedures/libc/geteuid.py +7 -0
  961. angr/procedures/libc/getgid.py +7 -0
  962. angr/procedures/libc/gets.py +66 -0
  963. angr/procedures/libc/getuid.py +7 -0
  964. angr/procedures/libc/malloc.py +11 -0
  965. angr/procedures/libc/memcmp.py +69 -0
  966. angr/procedures/libc/memcpy.py +37 -0
  967. angr/procedures/libc/memset.py +69 -0
  968. angr/procedures/libc/openlog.py +9 -0
  969. angr/procedures/libc/perror.py +12 -0
  970. angr/procedures/libc/printf.py +33 -0
  971. angr/procedures/libc/putchar.py +12 -0
  972. angr/procedures/libc/puts.py +16 -0
  973. angr/procedures/libc/rand.py +7 -0
  974. angr/procedures/libc/realloc.py +7 -0
  975. angr/procedures/libc/rewind.py +11 -0
  976. angr/procedures/libc/scanf.py +20 -0
  977. angr/procedures/libc/setbuf.py +8 -0
  978. angr/procedures/libc/setvbuf.py +6 -0
  979. angr/procedures/libc/snprintf.py +33 -0
  980. angr/procedures/libc/sprintf.py +22 -0
  981. angr/procedures/libc/srand.py +6 -0
  982. angr/procedures/libc/sscanf.py +13 -0
  983. angr/procedures/libc/stpcpy.py +18 -0
  984. angr/procedures/libc/strcat.py +13 -0
  985. angr/procedures/libc/strchr.py +44 -0
  986. angr/procedures/libc/strcmp.py +28 -0
  987. angr/procedures/libc/strcpy.py +13 -0
  988. angr/procedures/libc/strlen.py +99 -0
  989. angr/procedures/libc/strncat.py +18 -0
  990. angr/procedures/libc/strncmp.py +180 -0
  991. angr/procedures/libc/strncpy.py +18 -0
  992. angr/procedures/libc/strnlen.py +13 -0
  993. angr/procedures/libc/strstr.py +94 -0
  994. angr/procedures/libc/strtol.py +263 -0
  995. angr/procedures/libc/strtoul.py +9 -0
  996. angr/procedures/libc/system.py +12 -0
  997. angr/procedures/libc/time.py +9 -0
  998. angr/procedures/libc/tmpnam.py +19 -0
  999. angr/procedures/libc/tolower.py +7 -0
  1000. angr/procedures/libc/toupper.py +7 -0
  1001. angr/procedures/libc/ungetc.py +19 -0
  1002. angr/procedures/libc/vsnprintf.py +16 -0
  1003. angr/procedures/libc/wchar.py +15 -0
  1004. angr/procedures/libstdcpp/__init__.py +0 -0
  1005. angr/procedures/libstdcpp/_unwind_resume.py +10 -0
  1006. angr/procedures/libstdcpp/std____throw_bad_alloc.py +12 -0
  1007. angr/procedures/libstdcpp/std____throw_bad_cast.py +12 -0
  1008. angr/procedures/libstdcpp/std____throw_length_error.py +12 -0
  1009. angr/procedures/libstdcpp/std____throw_logic_error.py +12 -0
  1010. angr/procedures/libstdcpp/std__terminate.py +12 -0
  1011. angr/procedures/linux_kernel/__init__.py +3 -0
  1012. angr/procedures/linux_kernel/access.py +17 -0
  1013. angr/procedures/linux_kernel/arch_prctl.py +33 -0
  1014. angr/procedures/linux_kernel/arm_user_helpers.py +58 -0
  1015. angr/procedures/linux_kernel/brk.py +17 -0
  1016. angr/procedures/linux_kernel/cwd.py +27 -0
  1017. angr/procedures/linux_kernel/fstat.py +137 -0
  1018. angr/procedures/linux_kernel/fstat64.py +169 -0
  1019. angr/procedures/linux_kernel/futex.py +17 -0
  1020. angr/procedures/linux_kernel/getegid.py +16 -0
  1021. angr/procedures/linux_kernel/geteuid.py +16 -0
  1022. angr/procedures/linux_kernel/getgid.py +16 -0
  1023. angr/procedures/linux_kernel/getpid.py +13 -0
  1024. angr/procedures/linux_kernel/getrlimit.py +24 -0
  1025. angr/procedures/linux_kernel/gettid.py +8 -0
  1026. angr/procedures/linux_kernel/getuid.py +16 -0
  1027. angr/procedures/linux_kernel/iovec.py +43 -0
  1028. angr/procedures/linux_kernel/lseek.py +39 -0
  1029. angr/procedures/linux_kernel/mmap.py +15 -0
  1030. angr/procedures/linux_kernel/mprotect.py +41 -0
  1031. angr/procedures/linux_kernel/munmap.py +7 -0
  1032. angr/procedures/linux_kernel/openat.py +28 -0
  1033. angr/procedures/linux_kernel/set_tid_address.py +7 -0
  1034. angr/procedures/linux_kernel/sigaction.py +16 -0
  1035. angr/procedures/linux_kernel/sigprocmask.py +20 -0
  1036. angr/procedures/linux_kernel/stat.py +22 -0
  1037. angr/procedures/linux_kernel/sysinfo.py +58 -0
  1038. angr/procedures/linux_kernel/tgkill.py +7 -0
  1039. angr/procedures/linux_kernel/time.py +30 -0
  1040. angr/procedures/linux_kernel/uid.py +29 -0
  1041. angr/procedures/linux_kernel/uname.py +28 -0
  1042. angr/procedures/linux_kernel/unlink.py +22 -0
  1043. angr/procedures/linux_kernel/vsyscall.py +15 -0
  1044. angr/procedures/linux_loader/__init__.py +3 -0
  1045. angr/procedures/linux_loader/_dl_initial_error_catch_tsd.py +6 -0
  1046. angr/procedures/linux_loader/_dl_rtld_lock.py +14 -0
  1047. angr/procedures/linux_loader/sim_loader.py +53 -0
  1048. angr/procedures/linux_loader/tls.py +40 -0
  1049. angr/procedures/msvcr/__getmainargs.py +15 -0
  1050. angr/procedures/msvcr/__init__.py +4 -0
  1051. angr/procedures/msvcr/_initterm.py +37 -0
  1052. angr/procedures/msvcr/fmode.py +28 -0
  1053. angr/procedures/ntdll/__init__.py +0 -0
  1054. angr/procedures/ntdll/exceptions.py +57 -0
  1055. angr/procedures/posix/__init__.py +3 -0
  1056. angr/procedures/posix/accept.py +29 -0
  1057. angr/procedures/posix/bind.py +12 -0
  1058. angr/procedures/posix/bzero.py +6 -0
  1059. angr/procedures/posix/chroot.py +26 -0
  1060. angr/procedures/posix/close.py +9 -0
  1061. angr/procedures/posix/closedir.py +6 -0
  1062. angr/procedures/posix/dup.py +55 -0
  1063. angr/procedures/posix/fcntl.py +9 -0
  1064. angr/procedures/posix/fdopen.py +77 -0
  1065. angr/procedures/posix/fileno.py +17 -0
  1066. angr/procedures/posix/fork.py +10 -0
  1067. angr/procedures/posix/getenv.py +34 -0
  1068. angr/procedures/posix/gethostbyname.py +42 -0
  1069. angr/procedures/posix/getpass.py +18 -0
  1070. angr/procedures/posix/getsockopt.py +10 -0
  1071. angr/procedures/posix/htonl.py +11 -0
  1072. angr/procedures/posix/htons.py +11 -0
  1073. angr/procedures/posix/inet_ntoa.py +61 -0
  1074. angr/procedures/posix/listen.py +12 -0
  1075. angr/procedures/posix/mmap.py +140 -0
  1076. angr/procedures/posix/open.py +17 -0
  1077. angr/procedures/posix/opendir.py +9 -0
  1078. angr/procedures/posix/poll.py +54 -0
  1079. angr/procedures/posix/pread64.py +45 -0
  1080. angr/procedures/posix/pthread.py +87 -0
  1081. angr/procedures/posix/pwrite64.py +45 -0
  1082. angr/procedures/posix/read.py +12 -0
  1083. angr/procedures/posix/readdir.py +59 -0
  1084. angr/procedures/posix/recv.py +12 -0
  1085. angr/procedures/posix/recvfrom.py +12 -0
  1086. angr/procedures/posix/select.py +46 -0
  1087. angr/procedures/posix/send.py +22 -0
  1088. angr/procedures/posix/setsockopt.py +8 -0
  1089. angr/procedures/posix/sigaction.py +20 -0
  1090. angr/procedures/posix/sim_time.py +45 -0
  1091. angr/procedures/posix/sleep.py +7 -0
  1092. angr/procedures/posix/socket.py +18 -0
  1093. angr/procedures/posix/strcasecmp.py +23 -0
  1094. angr/procedures/posix/strdup.py +17 -0
  1095. angr/procedures/posix/strtok_r.py +65 -0
  1096. angr/procedures/posix/syslog.py +15 -0
  1097. angr/procedures/posix/tz.py +8 -0
  1098. angr/procedures/posix/unlink.py +10 -0
  1099. angr/procedures/posix/usleep.py +7 -0
  1100. angr/procedures/posix/write.py +12 -0
  1101. angr/procedures/procedure_dict.py +48 -0
  1102. angr/procedures/stubs/CallReturn.py +12 -0
  1103. angr/procedures/stubs/NoReturnUnconstrained.py +12 -0
  1104. angr/procedures/stubs/Nop.py +6 -0
  1105. angr/procedures/stubs/PathTerminator.py +8 -0
  1106. angr/procedures/stubs/Redirect.py +15 -0
  1107. angr/procedures/stubs/ReturnChar.py +10 -0
  1108. angr/procedures/stubs/ReturnUnconstrained.py +24 -0
  1109. angr/procedures/stubs/UnresolvableCallTarget.py +8 -0
  1110. angr/procedures/stubs/UnresolvableJumpTarget.py +8 -0
  1111. angr/procedures/stubs/UserHook.py +15 -0
  1112. angr/procedures/stubs/__init__.py +3 -0
  1113. angr/procedures/stubs/b64_decode.py +12 -0
  1114. angr/procedures/stubs/caller.py +13 -0
  1115. angr/procedures/stubs/crazy_scanf.py +17 -0
  1116. angr/procedures/stubs/format_parser.py +677 -0
  1117. angr/procedures/stubs/syscall_stub.py +26 -0
  1118. angr/procedures/testing/__init__.py +3 -0
  1119. angr/procedures/testing/manyargs.py +8 -0
  1120. angr/procedures/testing/retreg.py +8 -0
  1121. angr/procedures/tracer/__init__.py +4 -0
  1122. angr/procedures/tracer/random.py +8 -0
  1123. angr/procedures/tracer/receive.py +21 -0
  1124. angr/procedures/tracer/transmit.py +24 -0
  1125. angr/procedures/uclibc/__init__.py +3 -0
  1126. angr/procedures/uclibc/__uClibc_main.py +9 -0
  1127. angr/procedures/win32/EncodePointer.py +6 -0
  1128. angr/procedures/win32/ExitProcess.py +8 -0
  1129. angr/procedures/win32/GetCommandLine.py +11 -0
  1130. angr/procedures/win32/GetCurrentProcessId.py +6 -0
  1131. angr/procedures/win32/GetCurrentThreadId.py +6 -0
  1132. angr/procedures/win32/GetLastInputInfo.py +37 -0
  1133. angr/procedures/win32/GetModuleHandle.py +30 -0
  1134. angr/procedures/win32/GetProcessAffinityMask.py +34 -0
  1135. angr/procedures/win32/InterlockedExchange.py +14 -0
  1136. angr/procedures/win32/IsProcessorFeaturePresent.py +6 -0
  1137. angr/procedures/win32/VirtualAlloc.py +113 -0
  1138. angr/procedures/win32/VirtualProtect.py +59 -0
  1139. angr/procedures/win32/__init__.py +3 -0
  1140. angr/procedures/win32/critical_section.py +11 -0
  1141. angr/procedures/win32/dynamic_loading.py +103 -0
  1142. angr/procedures/win32/file_handles.py +47 -0
  1143. angr/procedures/win32/gethostbyname.py +10 -0
  1144. angr/procedures/win32/heap.py +42 -0
  1145. angr/procedures/win32/is_bad_ptr.py +25 -0
  1146. angr/procedures/win32/local_storage.py +85 -0
  1147. angr/procedures/win32/mutex.py +10 -0
  1148. angr/procedures/win32/sim_time.py +135 -0
  1149. angr/procedures/win32/system_paths.py +34 -0
  1150. angr/procedures/win32_kernel/ExAllocatePool.py +12 -0
  1151. angr/procedures/win32_kernel/ExFreePoolWithTag.py +7 -0
  1152. angr/procedures/win32_kernel/__init__.py +3 -0
  1153. angr/procedures/win_user32/__init__.py +0 -0
  1154. angr/procedures/win_user32/chars.py +12 -0
  1155. angr/procedures/win_user32/keyboard.py +13 -0
  1156. angr/procedures/win_user32/messagebox.py +49 -0
  1157. angr/project.py +834 -0
  1158. angr/protos/__init__.py +13 -0
  1159. angr/protos/cfg_pb2.py +31 -0
  1160. angr/protos/function_pb2.py +37 -0
  1161. angr/protos/primitives_pb2.py +124 -0
  1162. angr/protos/variables_pb2.py +126 -0
  1163. angr/protos/xrefs_pb2.py +34 -0
  1164. angr/py.typed +1 -0
  1165. angr/serializable.py +63 -0
  1166. angr/service.py +35 -0
  1167. angr/sim_manager.py +971 -0
  1168. angr/sim_options.py +444 -0
  1169. angr/sim_procedure.py +606 -0
  1170. angr/sim_state.py +1003 -0
  1171. angr/sim_state_options.py +409 -0
  1172. angr/sim_type.py +3372 -0
  1173. angr/sim_variable.py +562 -0
  1174. angr/simos/__init__.py +31 -0
  1175. angr/simos/cgc.py +152 -0
  1176. angr/simos/javavm.py +471 -0
  1177. angr/simos/linux.py +519 -0
  1178. angr/simos/simos.py +450 -0
  1179. angr/simos/snimmuc_nxp.py +152 -0
  1180. angr/simos/userland.py +163 -0
  1181. angr/simos/windows.py +562 -0
  1182. angr/slicer.py +353 -0
  1183. angr/state_hierarchy.py +262 -0
  1184. angr/state_plugins/__init__.py +29 -0
  1185. angr/state_plugins/callstack.py +404 -0
  1186. angr/state_plugins/cgc.py +153 -0
  1187. angr/state_plugins/concrete.py +297 -0
  1188. angr/state_plugins/debug_variables.py +194 -0
  1189. angr/state_plugins/filesystem.py +469 -0
  1190. angr/state_plugins/gdb.py +146 -0
  1191. angr/state_plugins/globals.py +62 -0
  1192. angr/state_plugins/heap/__init__.py +5 -0
  1193. angr/state_plugins/heap/heap_base.py +126 -0
  1194. angr/state_plugins/heap/heap_brk.py +134 -0
  1195. angr/state_plugins/heap/heap_freelist.py +210 -0
  1196. angr/state_plugins/heap/heap_libc.py +45 -0
  1197. angr/state_plugins/heap/heap_ptmalloc.py +646 -0
  1198. angr/state_plugins/heap/utils.py +21 -0
  1199. angr/state_plugins/history.py +548 -0
  1200. angr/state_plugins/inspect.py +376 -0
  1201. angr/state_plugins/javavm_classloader.py +133 -0
  1202. angr/state_plugins/jni_references.py +93 -0
  1203. angr/state_plugins/libc.py +1263 -0
  1204. angr/state_plugins/light_registers.py +170 -0
  1205. angr/state_plugins/log.py +85 -0
  1206. angr/state_plugins/loop_data.py +92 -0
  1207. angr/state_plugins/plugin.py +155 -0
  1208. angr/state_plugins/posix.py +709 -0
  1209. angr/state_plugins/preconstrainer.py +195 -0
  1210. angr/state_plugins/scratch.py +175 -0
  1211. angr/state_plugins/sim_action.py +334 -0
  1212. angr/state_plugins/sim_action_object.py +148 -0
  1213. angr/state_plugins/sim_event.py +58 -0
  1214. angr/state_plugins/solver.py +1129 -0
  1215. angr/state_plugins/symbolizer.py +292 -0
  1216. angr/state_plugins/trace_additions.py +752 -0
  1217. angr/state_plugins/uc_manager.py +85 -0
  1218. angr/state_plugins/unicorn_engine.py +1899 -0
  1219. angr/state_plugins/view.py +341 -0
  1220. angr/storage/__init__.py +9 -0
  1221. angr/storage/file.py +1219 -0
  1222. angr/storage/memory_mixins/__init__.py +393 -0
  1223. angr/storage/memory_mixins/__init__.pyi +49 -0
  1224. angr/storage/memory_mixins/actions_mixin.py +69 -0
  1225. angr/storage/memory_mixins/address_concretization_mixin.py +388 -0
  1226. angr/storage/memory_mixins/bvv_conversion_mixin.py +74 -0
  1227. angr/storage/memory_mixins/clouseau_mixin.py +131 -0
  1228. angr/storage/memory_mixins/conditional_store_mixin.py +24 -0
  1229. angr/storage/memory_mixins/convenient_mappings_mixin.py +257 -0
  1230. angr/storage/memory_mixins/default_filler_mixin.py +146 -0
  1231. angr/storage/memory_mixins/dirty_addrs_mixin.py +9 -0
  1232. angr/storage/memory_mixins/hex_dumper_mixin.py +85 -0
  1233. angr/storage/memory_mixins/javavm_memory/__init__.py +1 -0
  1234. angr/storage/memory_mixins/javavm_memory/javavm_memory_mixin.py +394 -0
  1235. angr/storage/memory_mixins/keyvalue_memory/__init__.py +1 -0
  1236. angr/storage/memory_mixins/keyvalue_memory/keyvalue_memory_mixin.py +36 -0
  1237. angr/storage/memory_mixins/label_merger_mixin.py +31 -0
  1238. angr/storage/memory_mixins/multi_value_merger_mixin.py +68 -0
  1239. angr/storage/memory_mixins/name_resolution_mixin.py +70 -0
  1240. angr/storage/memory_mixins/paged_memory/__init__.py +0 -0
  1241. angr/storage/memory_mixins/paged_memory/page_backer_mixins.py +266 -0
  1242. angr/storage/memory_mixins/paged_memory/paged_memory_mixin.py +750 -0
  1243. angr/storage/memory_mixins/paged_memory/paged_memory_multivalue_mixin.py +63 -0
  1244. angr/storage/memory_mixins/paged_memory/pages/__init__.py +33 -0
  1245. angr/storage/memory_mixins/paged_memory/pages/cooperation.py +330 -0
  1246. angr/storage/memory_mixins/paged_memory/pages/history_tracking_mixin.py +87 -0
  1247. angr/storage/memory_mixins/paged_memory/pages/ispo_mixin.py +53 -0
  1248. angr/storage/memory_mixins/paged_memory/pages/list_page.py +346 -0
  1249. angr/storage/memory_mixins/paged_memory/pages/multi_values.py +290 -0
  1250. angr/storage/memory_mixins/paged_memory/pages/mv_list_page.py +434 -0
  1251. angr/storage/memory_mixins/paged_memory/pages/permissions_mixin.py +33 -0
  1252. angr/storage/memory_mixins/paged_memory/pages/refcount_mixin.py +51 -0
  1253. angr/storage/memory_mixins/paged_memory/pages/ultra_page.py +468 -0
  1254. angr/storage/memory_mixins/paged_memory/privileged_mixin.py +36 -0
  1255. angr/storage/memory_mixins/paged_memory/stack_allocation_mixin.py +73 -0
  1256. angr/storage/memory_mixins/regioned_memory/__init__.py +6 -0
  1257. angr/storage/memory_mixins/regioned_memory/abstract_address_descriptor.py +35 -0
  1258. angr/storage/memory_mixins/regioned_memory/abstract_merger_mixin.py +43 -0
  1259. angr/storage/memory_mixins/regioned_memory/region_category_mixin.py +7 -0
  1260. angr/storage/memory_mixins/regioned_memory/region_data.py +245 -0
  1261. angr/storage/memory_mixins/regioned_memory/region_meta_mixin.py +125 -0
  1262. angr/storage/memory_mixins/regioned_memory/regioned_address_concretization_mixin.py +118 -0
  1263. angr/storage/memory_mixins/regioned_memory/regioned_memory_mixin.py +462 -0
  1264. angr/storage/memory_mixins/regioned_memory/static_find_mixin.py +70 -0
  1265. angr/storage/memory_mixins/simple_interface_mixin.py +73 -0
  1266. angr/storage/memory_mixins/simplification_mixin.py +13 -0
  1267. angr/storage/memory_mixins/size_resolution_mixin.py +140 -0
  1268. angr/storage/memory_mixins/slotted_memory.py +140 -0
  1269. angr/storage/memory_mixins/smart_find_mixin.py +159 -0
  1270. angr/storage/memory_mixins/symbolic_merger_mixin.py +12 -0
  1271. angr/storage/memory_mixins/top_merger_mixin.py +24 -0
  1272. angr/storage/memory_mixins/underconstrained_mixin.py +67 -0
  1273. angr/storage/memory_mixins/unwrapper_mixin.py +26 -0
  1274. angr/storage/memory_object.py +194 -0
  1275. angr/storage/pcap.py +65 -0
  1276. angr/tablespecs.py +90 -0
  1277. angr/utils/__init__.py +33 -0
  1278. angr/utils/algo.py +33 -0
  1279. angr/utils/constants.py +7 -0
  1280. angr/utils/cowdict.py +64 -0
  1281. angr/utils/dynamic_dictlist.py +92 -0
  1282. angr/utils/enums_conv.py +80 -0
  1283. angr/utils/env.py +11 -0
  1284. angr/utils/formatting.py +124 -0
  1285. angr/utils/funcid.py +133 -0
  1286. angr/utils/graph.py +822 -0
  1287. angr/utils/lazy_import.py +12 -0
  1288. angr/utils/library.py +214 -0
  1289. angr/utils/loader.py +55 -0
  1290. angr/utils/mp.py +64 -0
  1291. angr/utils/segment_list.py +558 -0
  1292. angr/utils/timing.py +45 -0
  1293. angr/utils/typing.py +17 -0
  1294. angr/vaults.py +370 -0
  1295. angr-9.2.103.dist-info/LICENSE +24 -0
  1296. angr-9.2.103.dist-info/METADATA +119 -0
  1297. angr-9.2.103.dist-info/RECORD +1300 -0
  1298. angr-9.2.103.dist-info/WHEEL +5 -0
  1299. angr-9.2.103.dist-info/entry_points.txt +2 -0
  1300. angr-9.2.103.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1101 @@
1
+ from typing import TYPE_CHECKING
2
+ import logging
3
+ import cle
4
+
5
+ from capstone import CS_GRP_CALL, CS_GRP_IRET, CS_GRP_JUMP, CS_GRP_RET
6
+
7
+ from . import ExplorationTechnique
8
+ from .. import BP_BEFORE, BP_AFTER, sim_options
9
+ from ..errors import AngrTracerError, SimIRSBNoDecodeError
10
+
11
+ if TYPE_CHECKING:
12
+ from angr.sim_state import SimState
13
+
14
+
15
+ l = logging.getLogger(name=__name__)
16
+
17
+
18
+ class TracingMode:
19
+ """
20
+ :ivar Strict: Strict mode, the default mode, where an exception is raised immediately if tracer's path
21
+ deviates from the provided trace.
22
+ :ivar Permissive: Permissive mode, where tracer attempts to force the path back to the provided trace when a
23
+ deviation happens. This does not always work, especially when the cause of deviation is related
24
+ to input that will later be used in exploit generation. But, it might work magically sometimes.
25
+ :ivar CatchDesync: CatchDesync mode, catch desync because of sim_procedures. It might be a sign of something
26
+ interesting.
27
+ """
28
+
29
+ Strict = "strict"
30
+ Permissive = "permissive"
31
+ CatchDesync = "catch_desync"
32
+
33
+
34
+ class TracerDesyncError(AngrTracerError):
35
+ """
36
+ An error class to report tracing Tracing desyncronization error
37
+ """
38
+
39
+ def __init__(self, msg, deviating_addr=None, deviating_trace_idx=None):
40
+ super().__init__(msg)
41
+ self.deviating_addr = deviating_addr
42
+ self.deviating_trace_idx = deviating_trace_idx
43
+
44
+
45
+ class RepHook:
46
+ """
47
+ Hook rep movs/stos to speed up constraint solving
48
+ TODO: This should be made an exploration technique later
49
+ """
50
+
51
+ def __init__(self, mnemonic):
52
+ self.mnemonic = mnemonic
53
+
54
+ @staticmethod
55
+ def _inline_call(state, procedure, *arguments, **kwargs):
56
+ e_args = [state.solver.BVV(a, state.arch.bits) if isinstance(a, int) else a for a in arguments]
57
+ p = procedure(project=state.project, **kwargs)
58
+ return p.execute(state, None, arguments=e_args)
59
+
60
+ def run(self, state):
61
+ from .. import SIM_PROCEDURES # pylint: disable=import-outside-toplevel
62
+
63
+ dst = state.regs.edi if state.arch.name == "X86" else state.regs.rdi
64
+
65
+ if self.mnemonic.startswith("stos"):
66
+ # store a string
67
+ if self.mnemonic == "stosb":
68
+ val = state.regs.al
69
+ multiplier = 1
70
+ elif self.mnemonic == "stosw":
71
+ val = state.regs.ax
72
+ multiplier = 2
73
+ elif self.mnemonic == "stosd":
74
+ val = state.regs.eax
75
+ multiplier = 4
76
+ elif self.mnemonic == "stosq":
77
+ val = state.regs.rax
78
+ multiplier = 8
79
+ else:
80
+ raise NotImplementedError("Unsupported mnemonic %s" % self.mnemonic)
81
+
82
+ size = (state.regs.ecx if state.arch.name == "X86" else state.regs.rcx) * multiplier
83
+
84
+ memset = SIM_PROCEDURES["libc"]["memset"]
85
+ memset().execute(state, arguments=[dst, val, size])
86
+
87
+ if state.arch.name == "X86":
88
+ state.regs.edi += size
89
+ state.regs.ecx = 0
90
+ else:
91
+ state.regs.rdi += size
92
+ state.regs.rcx = 0
93
+
94
+ elif self.mnemonic.startswith("movs"):
95
+ src = state.regs.esi if state.arch.name == "X86" else state.regs.rsi
96
+
97
+ # copy a string
98
+ if self.mnemonic == "movsb":
99
+ multiplier = 1
100
+ elif self.mnemonic == "movsw":
101
+ multiplier = 2
102
+ elif self.mnemonic == "movsd":
103
+ multiplier = 4
104
+ elif self.mnemonic == "movsq":
105
+ multiplier = 8
106
+ else:
107
+ raise NotImplementedError("Unsupported mnemonic %s" % self.mnemonic)
108
+
109
+ size = (state.regs.ecx if state.arch.name == "X86" else state.regs.rcx) * multiplier
110
+
111
+ memcpy = SIM_PROCEDURES["libc"]["memcpy"]
112
+ memcpy().execute(state, arguments=[dst, src, size])
113
+
114
+ if state.arch.name == "X86":
115
+ state.regs.edi += size
116
+ state.regs.esi -= size
117
+ state.regs.ecx = 0
118
+ else:
119
+ state.regs.rdi += size
120
+ state.regs.rsi -= size
121
+ state.regs.rcx = 0
122
+
123
+ else:
124
+ raise NotImplementedError("Unsupported mnemonic %s" % self.mnemonic)
125
+
126
+
127
+ class Tracer(ExplorationTechnique):
128
+ """
129
+ An exploration technique that follows an angr path with a concrete input.
130
+ The tracing result is the state at the last address of the trace, which can be found in the
131
+ 'traced' stash.
132
+
133
+ If the given concrete input makes the program crash, you should provide crash_addr, and the
134
+ crashing state will be found in the 'crashed' stash.
135
+
136
+ :param trace: The basic block trace.
137
+ :param resiliency: Should we continue to step forward even if qemu and angr disagree?
138
+ :param keep_predecessors: Number of states before the final state we should log.
139
+ :param crash_addr: If the trace resulted in a crash, provide the crashing instruction
140
+ pointer here, and the 'crashed' stash will be populated with the
141
+ crashing state.
142
+ :param syscall_data: Data related to various syscalls recorded by tracer for replaying
143
+ :param copy_states: Whether COPY_STATES should be enabled for the tracing state. It is
144
+ off by default because most tracing workloads benefit greatly from
145
+ not performing copying. You want to enable it if you want to see
146
+ the missed states. It will be re-added for the last 2% of the trace
147
+ in order to set the predecessors list correctly. If you turn this
148
+ on you may want to enable the LAZY_SOLVES option.
149
+ :param mode: Tracing mode.
150
+ :param aslr: Whether there are aslr slides. if not, tracer uses trace address
151
+ as state address.
152
+ :param follow_unsat: Whether unsatisfiable states should be treated as potential
153
+ successors or not.
154
+
155
+ :ivar predecessors: A list of states in the history before the final state.
156
+ """
157
+
158
+ def __init__(
159
+ self,
160
+ trace=None,
161
+ resiliency=False,
162
+ keep_predecessors=1,
163
+ crash_addr=None,
164
+ syscall_data=None,
165
+ copy_states=False,
166
+ fast_forward_to_entry=True,
167
+ mode=TracingMode.Strict,
168
+ aslr=True,
169
+ follow_unsat=False,
170
+ ):
171
+ super().__init__()
172
+ self._trace = trace
173
+ self._resiliency = resiliency
174
+ self._crash_addr = crash_addr
175
+ self._syscall_data = syscall_data
176
+ self._copy_states = copy_states
177
+ self._mode = mode
178
+ self._aslr = aslr
179
+ self._follow_unsat = follow_unsat
180
+ self._fast_forward_to_entry = fast_forward_to_entry
181
+
182
+ self._aslr_slides: dict[cle.Backend, int] = {}
183
+ self._current_slide = None
184
+
185
+ self._fd_bytes = None
186
+
187
+ # keep track of the last basic block we hit
188
+ self.predecessors: list["SimState"] = [None] * keep_predecessors
189
+ self.last_state = None
190
+
191
+ # whether we should follow the trace
192
+ self._no_follow = self._trace is None
193
+
194
+ # Keep track of count of termination point
195
+ self._last_block_total_count = self._trace.count(self._trace[-1])
196
+ self._last_block_seen_count = 0
197
+
198
+ # sanity check: copy_states must be enabled in Permissive mode since we may need to backtrack from a previous
199
+ # state.
200
+ if self._mode == TracingMode.Permissive and not self._copy_states:
201
+ raise ValueError('"copy_states" must be True when tracing in permissive mode.')
202
+
203
+ def _locate_entry_point(self, angr_addr):
204
+ # ...via heuristics
205
+ indices = set()
206
+ threshold = 0x40000
207
+ while not indices and threshold > 0x2000:
208
+ for idx, addr in enumerate(self._trace):
209
+ if ((addr - angr_addr) & 0xFFF) == 0 and (idx == 0 or abs(self._trace[idx - 1] - addr) > threshold):
210
+ indices.add(idx)
211
+
212
+ indices = {i for i in indices if self._filter_idx(angr_addr, i)}
213
+ threshold //= 2
214
+
215
+ return indices
216
+
217
+ def _identify_aslr_slides(self):
218
+ """
219
+ libraries can be mapped differently in the original run(in the trace) and in angr
220
+ this function identifies the difference(called aslr slides) of each library to help angr translate
221
+ original address and address in angr back and forth
222
+ """
223
+ if self._aslr:
224
+ # if we don't know whether there is any slide, we need to identify the slides via heuristics
225
+ for obj in self.project.loader.all_objects:
226
+ # do not analyze pseudo-objects
227
+ if obj.binary_basename.startswith("cle##"):
228
+ continue
229
+
230
+ # heuristic 1: non-PIC objects are loaded without aslr slides
231
+ if not obj.pic:
232
+ self._aslr_slides[obj] = 0
233
+ continue
234
+
235
+ # heuristic 2: library objects with custom_base_addr are loaded at the correct locations
236
+ if obj._custom_base_addr:
237
+ l.info("%s is assumed to be loaded at the address matching the one in the trace", obj)
238
+ self._aslr_slides[obj] = 0
239
+ continue
240
+
241
+ # heuristic 3: entry point of an object should appear in the trace
242
+ possibilities = None
243
+ for entry in obj.initializers + ([obj.entry] if obj.is_main_bin else []):
244
+ indices = self._locate_entry_point(entry)
245
+ slides = {self._trace[idx] - entry for idx in indices}
246
+ if possibilities is None:
247
+ possibilities = slides
248
+ else:
249
+ possibilities.intersection_update(slides)
250
+
251
+ if possibilities is None:
252
+ continue
253
+
254
+ if len(possibilities) == 0:
255
+ raise AngrTracerError(
256
+ "Trace does not seem to contain object initializers for %s. "
257
+ "Do you want to have a Tracer(aslr=False)?" % obj
258
+ )
259
+ if len(possibilities) == 1:
260
+ self._aslr_slides[obj] = next(iter(possibilities))
261
+ else:
262
+ raise AngrTracerError(
263
+ "Trace seems ambiguous with respect to what the ASLR slides are for %s. "
264
+ "This is surmountable, please open an issue." % obj
265
+ )
266
+ else:
267
+ # if we know there is no slides, just trust the address in the loader
268
+ for obj in self.project.loader.all_objects:
269
+ # do not analyze pseudo-objects
270
+ if obj.binary_basename.startswith("cle##"):
271
+ continue
272
+ self._aslr_slides[obj] = 0
273
+ self._current_slide = 0
274
+
275
+ def _filter_idx(self, angr_addr, idx):
276
+ slide = self._trace[idx] - angr_addr
277
+ block = self.project.factory.block(angr_addr)
278
+ legal_next = block.vex.constant_jump_targets
279
+ if legal_next:
280
+ return any(a + slide == self._trace[idx + 1] for a in legal_next)
281
+ else:
282
+ # the intuition is that if the first block of an initializer does an indirect jump,
283
+ # it's probably a call out to another binary (notably __libc_start_main)
284
+ # this is an awful fucking heuristic but it's as good as we've got
285
+ return abs(self._trace[idx] - self._trace[idx + 1]) > 0x1000
286
+
287
+ def set_fd_data(self, fd_data: dict[int, bytes]):
288
+ """
289
+ Set concrete bytes of various fds read by the program
290
+ """
291
+
292
+ self._fd_bytes = fd_data
293
+
294
+ def setup(self, simgr):
295
+ simgr.populate("missed", [])
296
+ simgr.populate("traced", [])
297
+ simgr.populate("crashed", [])
298
+ simgr.populate("desync", [])
299
+
300
+ if len(simgr.active) != 1:
301
+ raise AngrTracerError("Tracer is being invoked on a SimulationManager without exactly one active state")
302
+
303
+ self._identify_aslr_slides()
304
+
305
+ if self._fast_forward_to_entry:
306
+ idx = self._trace.index(self._translate_state_addr(self.project.entry))
307
+ # step to entry point
308
+ while simgr.one_active.addr != self.project.entry:
309
+ simgr.step(extra_stop_points={self.project.entry})
310
+ if len(simgr.active) == 0:
311
+ raise AngrTracerError("Could not step to the first address of the trace - simgr is empty")
312
+ if len(simgr.active) > 1:
313
+ raise AngrTracerError(
314
+ "Could not step to the first address of the trace - state split. "
315
+ "Do you want to have a Tracer(fast_forward_to_entry=False)?"
316
+ )
317
+ simgr.drop(stash="unsat")
318
+ else:
319
+ idx = 0
320
+
321
+ # initialize the state info
322
+ simgr.one_active.globals["trace_idx"] = idx
323
+ simgr.one_active.globals["sync_idx"] = None
324
+ simgr.one_active.globals["sync_timer"] = 0
325
+ simgr.one_active.globals["is_desync"] = False
326
+
327
+ # disable state copying!
328
+ if not self._copy_states:
329
+ # insulate our caller from this nonsense by making a single copy at the beginning
330
+ simgr.active[0] = simgr.active[0].copy()
331
+ simgr.active[0].options.remove(sim_options.COPY_STATES)
332
+
333
+ def complete(self, simgr):
334
+ return bool(simgr.traced)
335
+
336
+ def filter(self, simgr, state, **kwargs):
337
+ # check completion
338
+ if state.globals["trace_idx"] >= len(self._trace) - 1:
339
+ # if the the state is a desync state and the user wants to keep it,
340
+ # then do what the user wants
341
+ if self._mode == TracingMode.CatchDesync and self.project.is_hooked(state.addr):
342
+ return "desync"
343
+ # do crash windup if necessary
344
+ if self._crash_addr is not None:
345
+ self.last_state, crash_state = self.crash_windup(state, self._crash_addr)
346
+ simgr.populate("crashed", [crash_state])
347
+ self.predecessors.append(state)
348
+ self.predecessors.pop(0)
349
+
350
+ return "traced"
351
+
352
+ return simgr.filter(state, **kwargs)
353
+
354
+ def step(self, simgr, stash="active", **kwargs):
355
+ simgr.drop(stash="missed")
356
+ return simgr.step(stash=stash, syscall_data=self._syscall_data, fd_bytes=self._fd_bytes, **kwargs)
357
+
358
+ def step_state(self, simgr, state, **kwargs):
359
+ if state.history.jumpkind == "Ijk_Exit":
360
+ return {"traced": [state]}
361
+
362
+ # maintain the predecessors list
363
+ self.predecessors.append(state)
364
+ self.predecessors.pop(0)
365
+
366
+ if state.globals["trace_idx"] > len(self._trace) * 0.98:
367
+ state.options.add(sim_options.COPY_STATES)
368
+ state.options.add(sim_options.LAZY_SOLVES)
369
+
370
+ # optimization:
371
+ # look forward, is it a rep stos/movs instruction?
372
+ # if so, we add a temporary hook to speed up constraint solving
373
+ if not self.project.is_hooked(state.addr):
374
+ block = self.project.factory.block(state.addr)
375
+
376
+ if len(block.capstone.insns) == 1 and (
377
+ block.capstone.insns[0].mnemonic.startswith("rep m")
378
+ or block.capstone.insns[0].mnemonic.startswith("rep s")
379
+ ):
380
+ insn = block.capstone.insns[0]
381
+ self.project.hook(state.addr, RepHook(insn.mnemonic.split(" ")[1]).run, length=insn.size)
382
+
383
+ # perform the step. ask qemu to stop at the termination point.
384
+ # if termination point occurs multiple times in trace, pass details to SimEngineUnicorn's native interface so
385
+ # that it can stop at last block
386
+ if self._last_block_total_count > 1:
387
+ stops = set(kwargs.pop("extra_stop_points", ()))
388
+ last_block_details = {
389
+ "addr": self._trace[-1],
390
+ "tot_count": self._last_block_total_count,
391
+ "curr_count": self._last_block_seen_count,
392
+ }
393
+ else:
394
+ stops = set(kwargs.pop("extra_stop_points", ())) | {self._trace[-1]}
395
+ last_block_details = None
396
+
397
+ succs_dict = simgr.step_state(state, extra_stop_points=stops, last_block_details=last_block_details, **kwargs)
398
+ if None not in succs_dict and simgr.errored:
399
+ raise simgr.errored[-1].error
400
+ sat_succs = succs_dict[None] # satisfiable states
401
+ succs = sat_succs + succs_dict["unsat"] # both satisfiable and unsatisfiable states
402
+
403
+ if not self._follow_unsat:
404
+ # Only satisfiable states need to be checked for correct successor
405
+ if len(sat_succs) == 1:
406
+ try:
407
+ self._update_state_tracking(sat_succs[0])
408
+ except TracerDesyncError as ex:
409
+ if self._mode == TracingMode.Permissive:
410
+ succs_dict = self._force_resync(simgr, state, ex.deviating_trace_idx, ex.deviating_addr, kwargs)
411
+ else:
412
+ raise
413
+ elif len(sat_succs) == 0:
414
+ raise Exception("No satisfiable state is available!")
415
+ else:
416
+ succ = self._pick_correct_successor(sat_succs)
417
+ succs_dict[None] = [succ]
418
+ succs_dict["missed"] = [s for s in sat_succs if s is not succ]
419
+ else:
420
+ # Check all states for correct successor
421
+ if len(succs) == 1:
422
+ self._update_state_tracking(succs[0])
423
+ elif len(succs) == 0:
424
+ raise Exception("All states disappeared!")
425
+ else:
426
+ succ = self._pick_correct_successor(succs)
427
+ succs_dict[None] = [succ]
428
+ succs_dict["missed"] = [s for s in succs if s is not succ]
429
+ assert len(succs_dict[None]) == 1
430
+
431
+ # if there is a catchable desync, we should return the last sync state
432
+ if succs_dict[None][0].globals["is_desync"]:
433
+ simgr.active[0].globals["trace_idx"] = len(self._trace)
434
+ succs_dict[None][0] = state
435
+ return succs_dict
436
+
437
+ def _force_resync(self, simgr, state, deviating_trace_idx, deviating_addr, kwargs):
438
+ """
439
+ When a deviation happens, force the tracer to take the branch specified in the trace by manually setting the
440
+ PC to the one in the trace. This method is only used in Permissive tracing mode.
441
+
442
+ :param simgr: The simulation manager instance.
443
+ :param state: The program state before the current step.
444
+ :param deviating_trace_idx: The index of address in the trace where a desync happens.
445
+ :param deviating_addr: The address that tracer takes when the desync happens. Should be different from the
446
+ one in the trace.
447
+ :param kwargs: Other keyword arguments that will be passed to step_state().
448
+ :return: A new successor dict.
449
+ :rtype: dict
450
+ """
451
+
452
+ # if unicorn engine is enabled, disable it. forced execution requires single-stepping in angr.
453
+ unicorn_option_removed = False
454
+ if sim_options.UNICORN in state.options:
455
+ state.options.remove(sim_options.UNICORN)
456
+ unicorn_option_removed = True
457
+
458
+ # single step until right before the deviating state
459
+ trace_idx = state.globals["trace_idx"]
460
+ while trace_idx != deviating_trace_idx - 1:
461
+ succs_dict = simgr.step_state(state, **kwargs)
462
+ succs = succs_dict[None]
463
+ assert len(succs) == 1
464
+ self._update_state_tracking(succs[0])
465
+ state = succs[0]
466
+ trace_idx += 1
467
+
468
+ # step the state further and then manually set the PC
469
+ succs_dict = simgr.step_state(state, **kwargs)
470
+ succs = succs_dict[None]
471
+ if len(succs) != 1 or succs[0].addr != deviating_addr:
472
+ raise TracerDesyncError("Address mismatch during single-stepping.")
473
+ succ = succs[0]
474
+ expected_addr = self._trace[deviating_trace_idx]
475
+ current_obj = self.project.loader.find_object_containing(state.addr)
476
+ assert current_obj is not None
477
+ translated_addr = self._translate_trace_addr(expected_addr, current_obj)
478
+ l.info(
479
+ "Attempt to fix a deviation: Forcing execution from %#x to %#x (instead of %#x).",
480
+ state.addr,
481
+ succ.addr,
482
+ translated_addr,
483
+ )
484
+ succ._ip = translated_addr
485
+
486
+ succ.globals["trace_idx"] = trace_idx + 1
487
+ succs_dict = {None: [succ]}
488
+
489
+ if unicorn_option_removed:
490
+ succ.options.add(sim_options.UNICORN)
491
+
492
+ return succs_dict
493
+
494
+ def _pick_correct_successor(self, succs):
495
+ # there's been a branch of some sort. Try to identify which state stayed on the trace.
496
+ assert len(succs) > 0
497
+ idx = succs[0].globals["trace_idx"]
498
+
499
+ res = []
500
+ last_description = succs[0].history.descriptions[-1]
501
+ if "Unicorn" in last_description:
502
+ # Multiple new states were created in SimEngineUnicorn. State which has non-zero recent block count is a
503
+ # valid successor since only correct successor is sync'd with native state
504
+ for succ in succs:
505
+ if succ.history.recent_block_count > 0:
506
+ res.append(succ)
507
+ else:
508
+ for succ in succs:
509
+ try:
510
+ if self._compare_addr(self._trace[idx + 1], succ.addr):
511
+ res.append(succ)
512
+ except AngrTracerError:
513
+ pass
514
+
515
+ if not res:
516
+ raise Exception("No states followed the trace?")
517
+
518
+ if len(res) > 1:
519
+ raise Exception("The state split but several successors have the same (correct) address?")
520
+
521
+ self._update_state_tracking(res[0])
522
+ return res[0]
523
+
524
+ def _update_state_tracking(self, state: "SimState"):
525
+ idx = state.globals["trace_idx"]
526
+ sync = state.globals["sync_idx"]
527
+ timer = state.globals["sync_timer"]
528
+
529
+ self._last_block_seen_count += state.history.recent_bbl_addrs.count(self._trace[-1])
530
+
531
+ if state.history.recent_block_count > 1:
532
+ # multiple blocks were executed this step. they should follow the trace *perfectly*
533
+ # or else something is up
534
+ # "something else" so far only includes concrete transmits, or...
535
+ # TODO: https://github.com/unicorn-engine/unicorn/issues/874
536
+ # ^ this means we will see desyncs of the form unicorn suddenly skips a bunch of qemu blocks
537
+ assert state.history.recent_block_count == len(state.history.recent_bbl_addrs)
538
+
539
+ for addr_idx, addr in enumerate(state.history.recent_bbl_addrs):
540
+ if addr in [
541
+ state.unicorn.cgc_transmit_addr,
542
+ state.unicorn.cgc_receive_addr,
543
+ state.unicorn.cgc_random_addr,
544
+ ]:
545
+ continue
546
+
547
+ if sync is not None and sync != "entry":
548
+ if self._compare_addr(self._trace[sync], addr):
549
+ # Found the address in trace. Start normal trace checks from next address
550
+ idx = sync + 1
551
+ state.globals["sync_idx"] = None
552
+ sync = None
553
+
554
+ continue
555
+
556
+ if self._compare_addr(self._trace[idx], addr) or self._check_qemu_unicorn_large_block_split(
557
+ state, idx, addr_idx
558
+ ):
559
+ idx += 1
560
+ else:
561
+ is_contained, increment = self._check_qemu_block_in_unicorn_block(state, idx, addr_idx)
562
+ if is_contained:
563
+ idx += increment
564
+ # Big block is now skipped in qemu trace. Perform compare at correct index again.
565
+ if self._compare_addr(self._trace[idx], addr):
566
+ idx += 1
567
+ continue
568
+
569
+ raise TracerDesyncError(
570
+ "Oops! angr did not follow the trace", deviating_addr=addr, deviating_trace_idx=idx
571
+ )
572
+
573
+ idx -= 1 # use normal code to do the last synchronization
574
+
575
+ if sync == "entry":
576
+ trace_addr = self._translate_state_addr(state.addr)
577
+ # this address should only ever appear once in the trace. we verified this during setup.
578
+ idx = self._trace.index(trace_addr)
579
+ state.globals["trace_idx"] = idx
580
+ state.globals["sync_idx"] = None
581
+ elif sync is not None:
582
+ timer -= 1
583
+ if self._compare_addr(self._trace[sync], state.addr):
584
+ state.globals["trace_idx"] = sync
585
+ state.globals["sync_idx"] = None
586
+ state.globals["sync_timer"] = 0
587
+ elif timer > 0:
588
+ state.globals["sync_timer"] = timer
589
+ else:
590
+ raise Exception(
591
+ "Trace failed to synchronize! We expected it to hit %#x (trace addr), "
592
+ "but it failed to do this within a timeout" % self._trace[sync]
593
+ )
594
+
595
+ elif state.history.jumpkind.startswith("Ijk_Exit"):
596
+ # termination! will be handled by filter
597
+ pass
598
+ elif self.project.is_hooked(state.addr) and not self.project.loader.extern_object.contains_addr(state.addr):
599
+ # handle simprocedures
600
+ self._sync_return(state, idx)
601
+ elif self._compare_addr(self._trace[idx + 1], state.addr):
602
+ # normal case
603
+ state.globals["trace_idx"] = idx + 1
604
+ elif self.project.loader._extern_object is not None and self.project.loader.extern_object.contains_addr(
605
+ state.addr
606
+ ):
607
+ # externs
608
+ proc = self.project.hooked_by(state.addr)
609
+ if proc is None:
610
+ raise Exception("Extremely bad news: we're executing an unhooked address in the externs space")
611
+ if proc.display_name == "LinuxLoader":
612
+ state.globals["sync_idx"] = "entry"
613
+ elif proc.is_continuation:
614
+ orig_addr = self.project.loader.find_symbol(proc.display_name).rebased_addr
615
+ obj = self.project.loader.find_object_containing(orig_addr)
616
+ orig_trace_addr = self._translate_state_addr(orig_addr, obj)
617
+ if 0 <= self._trace[idx + 1] - orig_trace_addr <= 0x10000:
618
+ # this is fine. we do nothing and then next round
619
+ # it'll get handled by the is_hooked(state.history.addr) case
620
+ pass
621
+ else:
622
+ # this may also be triggered as a consequence of the unicorn issue linked above
623
+ raise Exception("BUG: State is returning to a continuation that isn't its own???")
624
+ elif state.addr == getattr(self.project.simos, "vsyscall_addr", None):
625
+ if not self._sync_callsite(state, idx, state.history.addr):
626
+ raise AngrTracerError("Could not synchronize following vsyscall")
627
+ elif self.project.hooked_by(state.addr).display_name.startswith("IFuncResolver"):
628
+ if not self._sync_return(state, idx):
629
+ raise AngrTracerError("Could not synchronize at ifunc return address")
630
+ else:
631
+ # see above
632
+ pass
633
+ elif state.history.jumpkind.startswith("Ijk_Sys"):
634
+ # syscalls
635
+ state.globals["sync_idx"] = idx + 1
636
+ state.globals["sync_timer"] = 1
637
+ elif self.project.is_hooked(state.history.addr):
638
+ # simprocedures - is this safe..?
639
+ self._fast_forward(state)
640
+ elif state.addr == self._trace[-1]:
641
+ # we may have prematurely stopped because of setting stop points. try to resync.
642
+ state.globals["sync_idx"] = idx + 1
643
+ state.globals["sync_timer"] = 1
644
+ elif (
645
+ self.project.is_hooked(state.addr)
646
+ and self.project.loader.find_symbol(self.project.hooked_by(state.addr).display_name) is not None
647
+ and self.project.loader.find_symbol(self.project.hooked_by(state.addr).display_name).subtype.value[0] == 10
648
+ ): # STT_GNU_IFUNC #pylint:disable=line-too-long
649
+ if not self._sync_return(state, idx):
650
+ raise AngrTracerError("Could not synchronize at ifunc return address")
651
+ elif self._analyze_misfollow(state, idx):
652
+ # misfollow analysis will set a sync point somewhere if it succeeds
653
+ pass
654
+ else:
655
+ raise TracerDesyncError(
656
+ "Oops! angr did not follow the trace", deviating_addr=state.addr, deviating_trace_idx=idx + 1
657
+ )
658
+
659
+ if state.globals["sync_idx"] is not None:
660
+ l.debug(
661
+ "Trace: %s-%s/%s synchronizing %s",
662
+ state.globals["trace_idx"],
663
+ state.globals["sync_idx"],
664
+ len(self._trace),
665
+ state.globals["sync_timer"],
666
+ )
667
+ else:
668
+ l.debug("Trace: %s/%s", state.globals["trace_idx"], len(self._trace))
669
+
670
+ def _translate_state_addr(self, state_addr, obj=None):
671
+ if obj is None:
672
+ obj = self.project.loader.find_object_containing(state_addr)
673
+ if obj not in self._aslr_slides:
674
+ raise Exception("Internal error: cannot translate address")
675
+ return state_addr + self._aslr_slides[obj]
676
+
677
+ def _translate_trace_addr(self, trace_addr, obj=None):
678
+ if obj is None:
679
+ for obj, slide in self._aslr_slides.items(): # pylint: disable=redefined-argument-from-local
680
+ if obj.contains_addr(trace_addr - slide):
681
+ break
682
+ else:
683
+ raise Exception("Can't figure out which object this address belongs to")
684
+ if obj not in self._aslr_slides:
685
+ raise Exception("Internal error: object is untranslated")
686
+ return trace_addr - self._aslr_slides[obj]
687
+
688
+ def _compare_addr(self, trace_addr, state_addr):
689
+ if self._current_slide is not None and trace_addr == state_addr + self._current_slide:
690
+ return True
691
+
692
+ current_bin = self.project.loader.find_object_containing(state_addr)
693
+ if current_bin is self.project.loader._extern_object or current_bin is self.project.loader._kernel_object:
694
+ return False
695
+ elif current_bin in self._aslr_slides:
696
+ self._current_slide = self._aslr_slides[current_bin]
697
+ return trace_addr == state_addr + self._current_slide
698
+ elif ((trace_addr - state_addr) & 0xFFF) == 0:
699
+ self._aslr_slides[current_bin] = self._current_slide = trace_addr - state_addr
700
+ return True
701
+ # error handling
702
+ elif current_bin:
703
+ raise AngrTracerError(
704
+ "Trace desynced on jumping into %s. "
705
+ "Did you load the right version of this library?" % current_bin.provides
706
+ )
707
+ else:
708
+ raise AngrTracerError("Trace desynced on jumping into %#x, where no library is mapped!" % state_addr)
709
+
710
+ def _check_qemu_block_in_unicorn_block(self, state: "SimState", trace_curr_idx, state_desync_block_idx):
711
+ """
712
+ Check if desync occurred because unicorn block was split into multiple blocks in qemu tracer. If yes, find the
713
+ correct increment for trace index
714
+ """
715
+
716
+ # We first find the block address where the trace and state's history match
717
+ for trace_match_idx in range(trace_curr_idx - 1, -1, -1):
718
+ if self._trace[trace_match_idx] == state.history.recent_bbl_addrs[state_desync_block_idx - 1]:
719
+ break
720
+ else:
721
+ # Failed to find matching block address. qemu block is probably not contained in a previous block.
722
+ return (False, -1)
723
+
724
+ control_flow_insn_types = [CS_GRP_CALL, CS_GRP_IRET, CS_GRP_JUMP, CS_GRP_RET]
725
+ big_block_start = self._trace[trace_match_idx]
726
+ big_block_end = None
727
+ curr_block_addr = big_block_start
728
+ while True:
729
+ curr_block = state.project.factory.block(self._translate_trace_addr(curr_block_addr))
730
+ curr_block_last_insn = curr_block.capstone.insns[-1]
731
+ if any(curr_block_last_insn.group(insn_type) for insn_type in control_flow_insn_types):
732
+ # Found last block
733
+ big_block_end = curr_block.addr + curr_block.size - 1
734
+ break
735
+
736
+ curr_block_addr = curr_block.addr + curr_block.size
737
+
738
+ for last_contain_index in range(trace_match_idx + 1, trace_curr_idx + 1):
739
+ if self._trace[last_contain_index] <= big_block_start or self._trace[last_contain_index] > big_block_end:
740
+ # This qemu block is not contained in the bigger block
741
+ return (False, -1)
742
+
743
+ # Check for future blocks in trace contained in big block
744
+ for next_contain_index in range(trace_curr_idx + 1, len(self._trace)):
745
+ if self._trace[next_contain_index] < big_block_start or self._trace[next_contain_index] > big_block_end:
746
+ # This qemu block is not contained in bigger block
747
+ break
748
+
749
+ return (True, next_contain_index - trace_curr_idx)
750
+
751
+ def _check_qemu_unicorn_large_block_split(self, state: "SimState", trace_curr_idx, state_desync_block_idx):
752
+ """
753
+ Check if desync occurred because large blocks are split up at different instructions by qemu and unicorn. This
754
+ is done by reconstructing part of block executed so far from the trace and state history and checking if they
755
+ the same
756
+ """
757
+
758
+ control_flow_insn_types = [CS_GRP_CALL, CS_GRP_IRET, CS_GRP_JUMP, CS_GRP_RET]
759
+
760
+ prev_trace_block = state.project.factory.block(self._translate_trace_addr(self._trace[trace_curr_idx - 1]))
761
+ for insn_type in control_flow_insn_types:
762
+ if prev_trace_block.capstone.insns[-1].group(insn_type):
763
+ # Previous block ends in a control flow instruction. It is not large block different split.
764
+ return False
765
+
766
+ # The previous block did not end in a control flow instruction. Let's find the start of this big block from
767
+ # trace: it'll be the first block executed after a control flow instruction.
768
+ big_block_start_addr = None
769
+ for trace_block_idx in range(trace_curr_idx - 2, -1, -1):
770
+ trace_block = state.project.factory.block(self._translate_trace_addr(self._trace[trace_block_idx]))
771
+ trace_block_last_insn = trace_block.capstone.insns[-1]
772
+ for insn_type in control_flow_insn_types:
773
+ if trace_block_last_insn.group(insn_type):
774
+ big_block_start_addr = self._translate_trace_addr(self._trace[trace_block_idx + 1])
775
+ break
776
+
777
+ if big_block_start_addr is not None:
778
+ break
779
+ else:
780
+ # Failed to find end of the big basic block in trace. Treat as trace desync.
781
+ return False
782
+
783
+ # Now we check the part of the state history corresponding to this big basic block to ensure there are no
784
+ # control flow instructions at end of any blocks in the part. This check moves backwards starting from the
785
+ # desyncing block to the start of the big block we found earlier
786
+ for state_history_block_addr in reversed(state.history.recent_bbl_addrs[:state_desync_block_idx]):
787
+ state_history_block = state.project.factory.block(state_history_block_addr)
788
+ state_history_block_last_insn = state_history_block.capstone.insns[-1]
789
+ for insn_type in control_flow_insn_types:
790
+ if state_history_block_last_insn.group(insn_type):
791
+ # We haven't found the start of big block according to the trace but found a block ending with a
792
+ # control flow instruction. It is a trace desync then.
793
+ return False
794
+
795
+ if state_history_block_addr == big_block_start_addr:
796
+ # We found start of the big block and no control flow statements in between that and the block where
797
+ # desync happend.
798
+ break
799
+
800
+ # Let's find the address of the last byte of the big basic block using VEX lifter
801
+ angr_big_block_end_addr = None
802
+ curr_block_addr = big_block_start_addr
803
+ while True:
804
+ curr_block = state.project.factory.block(self._translate_trace_addr(curr_block_addr))
805
+ curr_block_last_insn = curr_block.capstone.insns[-1]
806
+ if any(curr_block_last_insn.group(insn_type) for insn_type in control_flow_insn_types):
807
+ # Found last block
808
+ angr_big_block_end_addr = curr_block.addr + curr_block.size - 1
809
+ break
810
+
811
+ curr_block_addr = curr_block.addr + curr_block.size
812
+
813
+ # Let's find the address of the last bytes of the big basic block from the trace
814
+ big_block_end_addr = None
815
+ for trace_block_idx in range(trace_curr_idx, len(self._trace)):
816
+ trace_block = state.project.factory.block(self._translate_trace_addr(self._trace[trace_block_idx]))
817
+ trace_block_last_insn = trace_block.capstone.insns[-1]
818
+ for insn_type in control_flow_insn_types:
819
+ if trace_block_last_insn.group(insn_type):
820
+ # Found first block in trace ending in a control flow instruction. Verify it matches the end of big
821
+ # block according to VEX lifter
822
+ big_block_end_addr = trace_block.addr + trace_block.size - 1
823
+ if angr_big_block_end_addr != big_block_end_addr:
824
+ # End does not match. Treat as trace desync.
825
+ return False
826
+ else:
827
+ break
828
+
829
+ if big_block_end_addr is not None:
830
+ break
831
+ else:
832
+ # Failed to find end of the big basic block in trace. Treat as trace desync.
833
+ return False
834
+
835
+ # At this point, we know the following:
836
+ # - There is no control flow instruction between big_block_start_addr and big_block_end_addr
837
+ # - There is no control flow instruction between big_block_start_addr and state_desync_block_addr
838
+ # - state_desync_block_addr is definitely executed after big_block_start_addr
839
+ # So it's enough to check if desyncing block's address is less than big_block_end_addr to ensure that it
840
+ # is part of the big block
841
+ return state.history.recent_bbl_addrs[state_desync_block_idx] < big_block_end_addr
842
+
843
+ def _analyze_misfollow(self, state, idx):
844
+ angr_addr = state.addr
845
+ obj = self.project.loader.find_object_containing(angr_addr)
846
+ if obj not in self._aslr_slides: # this SHOULD be an invariant given the way _compare_addrs works
847
+ raise Exception("BUG: misfollow analysis initiated when jumping into a new object")
848
+
849
+ slide = self._aslr_slides[obj]
850
+ trace_addr = self._trace[idx + 1] - slide
851
+ l.info("Misfollow: angr says %#x, trace says %#x", angr_addr, trace_addr)
852
+ if not obj.contains_addr(trace_addr):
853
+ l.error("Translated trace address lives in a different object from the angr trace")
854
+ return False
855
+
856
+ # TODO: add rep handling
857
+
858
+ if "IRSB" in state.history.recent_description:
859
+ VEXMaxInsnsPerBlock = 99
860
+ last_block = state.block(state.history.bbl_addrs[-1])
861
+
862
+ # Case 1: angr block contains more instructions than trace block
863
+ if self._trace[idx + 1] - slide in last_block.instruction_addrs:
864
+ # we have disparate block sizes!
865
+ # specifically, the angr block size is larger than the trace's.
866
+ # allow the trace to catch up.
867
+
868
+ while self._trace[idx + 1] - slide in last_block.instruction_addrs:
869
+ idx += 1
870
+
871
+ l.info("...resolved: disparate block sizes")
872
+
873
+ if self._trace[idx + 1] - slide == state.addr:
874
+ state.globals["trace_idx"] = idx + 1
875
+ return True
876
+ else:
877
+ state.globals["trace_idx"] = idx
878
+ # state.globals['trace_desync'] = True
879
+ return True
880
+
881
+ # Case 2: trace block contains more instructions than angr
882
+ # block. Caused by VEX's maximum instruction limit of 99
883
+ # instructions
884
+ elif (
885
+ state.project.factory.block(state.history.addr).instructions == VEXMaxInsnsPerBlock
886
+ and state.history.jumpkind == "Ijk_Boring"
887
+ ):
888
+ l.info("...resolved: vex block limit")
889
+ return True
890
+
891
+ prev_addr = state.history.bbl_addrs[-1]
892
+ prev_obj = self.project.loader.find_object_containing(prev_addr)
893
+
894
+ if state.block(prev_addr).vex.jumpkind == "Ijk_Call":
895
+ l.info("...syncing at callsite")
896
+ return self._sync_callsite(state, idx, prev_addr)
897
+
898
+ if prev_addr in getattr(prev_obj, "reverse_plt", ()):
899
+ prev_name = prev_obj.reverse_plt[prev_addr]
900
+ l.info("...syncing at PLT callsite for %s", prev_name)
901
+ # TODO: this method is newer than sync_callsite. should it be used always?
902
+ return self._sync_return(state, idx, assert_obj=prev_obj)
903
+
904
+ if prev_obj is not None:
905
+ prev_section = prev_obj.find_section_containing(prev_addr)
906
+ if prev_section is not None:
907
+ if prev_section.name in (".plt",):
908
+ l.info("...syncing at PLT callsite (type 2)")
909
+ return self._sync_return(state, idx, assert_obj=prev_obj)
910
+
911
+ l.info("...all analyses failed.")
912
+ return False
913
+
914
+ def _sync_callsite(self, state, idx, callsite_addr):
915
+ retsite_addr = state.block(callsite_addr).size + callsite_addr
916
+ return self._sync(state, idx, retsite_addr)
917
+
918
+ def _sync_return(self, state, idx, assert_obj=None):
919
+ ret_addr_bv = self.project.factory.cc().return_addr.get_value(state)
920
+ if state.solver.symbolic(ret_addr_bv):
921
+ l.info("...symbolic return address. I refuse to deal with this.")
922
+ return False
923
+
924
+ ret_addr = state.solver.eval(ret_addr_bv)
925
+ if assert_obj is not None and not assert_obj.contains_addr(ret_addr):
926
+ l.info("...address is not in the correct object, aborting analysis")
927
+ return False
928
+ return self._sync(state, idx, ret_addr)
929
+
930
+ def _sync(self, state, idx, addr):
931
+ addr_translated = self._translate_state_addr(addr)
932
+ try:
933
+ sync_idx = self._trace.index(addr_translated, idx)
934
+ except ValueError:
935
+ l.error("Trying to synchronize at %#x (%#x) but it does not appear in the trace?", addr_translated, addr)
936
+ return False
937
+
938
+ state.globals["sync_idx"] = sync_idx
939
+ state.globals["trace_idx"] = idx
940
+ state.globals["sync_timer"] = 10000 # TODO: ???
941
+ return True
942
+
943
+ def _fast_forward(self, state):
944
+ target_addr = state.addr
945
+ target_obj = self.project.loader.find_object_containing(target_addr)
946
+ if target_obj not in self._aslr_slides:
947
+ # if you see this message, consider implementing the find-entry-point hack for this, since if we're coming
948
+ # out of a hook and get a cache miss like this the jump between objects is probably happening in the final
949
+ # step of the skipped trace as well
950
+ raise AngrTracerError("Trace needs to synchronize at an address for which the ASLR slide is unavailable!")
951
+ self._current_slide = self._aslr_slides[target_obj]
952
+ target_addr += self._current_slide
953
+ try:
954
+ target_idx = self._trace.index(target_addr, state.globals["trace_idx"])
955
+ except ValueError as e:
956
+ # if the user wants to catch desync caused by sim_procedure,
957
+ # mark this state as a desync state and then end the tracing prematurely
958
+ if self._mode == TracingMode.CatchDesync:
959
+ state.globals["is_desync"] = True
960
+ return
961
+ raise AngrTracerError(
962
+ "Trace failed to synchronize during fast forward? You might want to unhook %s."
963
+ % (self.project.hooked_by(state.history.addr).display_name)
964
+ ) from e
965
+ else:
966
+ state.globals["trace_idx"] = target_idx
967
+
968
+ @classmethod
969
+ def crash_windup(cls, state, crash_addr):
970
+ # first check: are we just executing user-controlled code?
971
+ if not state.ip.symbolic and state.mem[state.ip].char.resolved.symbolic:
972
+ l.debug("executing input-related code")
973
+ return state, state
974
+ # second check: is this code mapped and executable?
975
+ section = state.project.loader.find_section_containing(state.addr)
976
+ if not section or not (section.flags & 0x4): # pylint:disable=superfluous-parens
977
+ return state, state
978
+ # in case we can't unwind, we return the state itself
979
+ if state.addr == crash_addr:
980
+ return state, state
981
+
982
+ state = state.copy()
983
+ state.options.add(sim_options.COPY_STATES)
984
+ state.options.discard(sim_options.STRICT_PAGE_ACCESS)
985
+
986
+ # before we step through and collect the actions we have to set
987
+ # up a special case for address concretization in the case of a
988
+ # controlled read or write vulnerability.
989
+ bp1 = state.inspect.b("address_concretization", BP_BEFORE, action=cls._check_add_constraints)
990
+
991
+ bp2 = state.inspect.b("address_concretization", BP_AFTER, action=cls._grab_concretization_results)
992
+
993
+ # step to the end of the crashing basic block,
994
+ # to capture its actions with those breakpoints
995
+ state.step()
996
+
997
+ # Add the constraints from concretized addrs back
998
+ for var, concrete_vals in state.preconstrainer.address_concretization:
999
+ if len(concrete_vals) > 0:
1000
+ l.debug("constraining addr to be %#x", concrete_vals[0])
1001
+ state.add_constraints(var == concrete_vals[0])
1002
+
1003
+ # then we step again up to the crashing instruction
1004
+ inst_addrs = state.block().instruction_addrs
1005
+ inst_cnt = len(inst_addrs)
1006
+
1007
+ if inst_cnt == 0:
1008
+ insts = 0
1009
+ elif crash_addr in inst_addrs:
1010
+ insts = inst_addrs.index(crash_addr)
1011
+ else:
1012
+ insts = inst_cnt - 1
1013
+
1014
+ l.debug("windup step...")
1015
+ succs = state.step(num_inst=insts).flat_successors
1016
+
1017
+ last_state = None
1018
+ if len(succs) > 0:
1019
+ if len(succs) > 1:
1020
+ succs = [s for s in succs if s.solver.satisfiable()]
1021
+ state = succs[0]
1022
+ last_state = state
1023
+
1024
+ # remove the preconstraints
1025
+ l.debug("removing preconstraints")
1026
+ state.preconstrainer.remove_preconstraints()
1027
+
1028
+ l.debug("reconstraining... ")
1029
+ state.preconstrainer.reconstrain()
1030
+
1031
+ l.debug("final step...")
1032
+ try:
1033
+ succs = state.step(num_inst=1)
1034
+ except SimIRSBNoDecodeError:
1035
+ # See https://github.com/angr/angr/issues/71
1036
+ # Basically, we probably tried to single step over a delay slot.
1037
+ succs = state.step(num_inst=2)
1038
+
1039
+ successors = succs.flat_successors + succs.unconstrained_successors
1040
+ crash_state = successors[0]
1041
+
1042
+ # now remove our breakpoints since other people might not want them
1043
+ for s in [last_state, crash_state]:
1044
+ if s is None:
1045
+ continue
1046
+ s.inspect.remove_breakpoint("address_concretization", bp1)
1047
+ s.inspect.remove_breakpoint("address_concretization", bp2)
1048
+
1049
+ return last_state, crash_state
1050
+
1051
+ # the below are utility functions for crash windup
1052
+
1053
+ @classmethod
1054
+ def _grab_concretization_results(cls, state):
1055
+ """
1056
+ Grabs the concretized result so we can add the constraint ourselves.
1057
+ """
1058
+ # only grab ones that match the constrained addrs
1059
+ if cls._should_add_constraints(state):
1060
+ addr = state.inspect.address_concretization_expr
1061
+ result = state.inspect.address_concretization_result
1062
+ if result is None:
1063
+ l.warning("addr concretization result is None")
1064
+ return
1065
+ state.preconstrainer.address_concretization.append((addr, result))
1066
+
1067
+ @classmethod
1068
+ def _check_add_constraints(cls, state):
1069
+ """
1070
+ Obnoxious way to handle this, should ONLY be called from crash monitor.
1071
+ """
1072
+ # for each constrained addrs check to see if the variables match,
1073
+ # if so keep the constraints
1074
+ state.inspect.address_concretization_add_constraints = cls._should_add_constraints(state)
1075
+
1076
+ @classmethod
1077
+ def _should_add_constraints(cls, state):
1078
+ """
1079
+ Check to see if the current address concretization variable is any of the registered
1080
+ constrained_addrs we want to allow concretization for
1081
+ """
1082
+ expr = state.inspect.address_concretization_expr
1083
+ hit_indices = cls._to_indices(state, expr)
1084
+
1085
+ for action in state.preconstrainer._constrained_addrs:
1086
+ var_indices = cls._to_indices(state, action.addr)
1087
+ if var_indices == hit_indices:
1088
+ return True
1089
+ return False
1090
+
1091
+ @staticmethod
1092
+ def _to_indices(state, expr):
1093
+ indices = []
1094
+ for descr in state.solver.describe_variables(expr):
1095
+ if descr[0] == "file" and descr[1] == state.posix.stdin.ident:
1096
+ if descr[2] == "packet":
1097
+ indices.append(descr[3])
1098
+ elif type(descr[2]) is int:
1099
+ indices.append(descr[2])
1100
+
1101
+ return sorted(indices)