-
- Downloads
Introduce -fsanitize-address-use-after-scope
* c-warn.c (warn_for_unused_label): Save all labels used in goto or in &label. * asan.c (enum asan_check_flags): Move the enum to header file. (asan_init_shadow_ptr_types): Make type creation more generic. (shadow_mem_size): New function. (asan_emit_stack_protection): Use newly added ASAN_SHADOW_GRANULARITY. Rewritten stack unpoisoning code. (build_shadow_mem_access): Add new argument return_address. (instrument_derefs): Instrument local variables if use after scope sanitization is enabled. (asan_store_shadow_bytes): New function. (asan_expand_mark_ifn): Likewise. (asan_sanitize_stack_p): Moved from asan_sanitize_stack_p. * asan.h (enum asan_mark_flags): Moved here from asan.c (asan_protect_stack_decl): Protect all declaration that need to live in memory. (asan_sanitize_use_after_scope): New function. (asan_no_sanitize_address_p): Likewise. * cfgexpand.c (partition_stack_vars): Consider asan_sanitize_use_after_scope in condition. (expand_stack_vars): Likewise. * common.opt (-fsanitize-address-use-after-scope): New option. * doc/invoke.texi (use-after-scope-direct-emission-threshold): Explain the parameter. * flag-types.h (enum sanitize_code): Define SANITIZE_USE_AFTER_SCOPE. * gimplify.c (build_asan_poison_call_expr): New function. (asan_poison_variable): Likewise. (gimplify_bind_expr): Generate poisoning/unpoisoning for local variables that have address taken. (gimplify_decl_expr): Likewise. (gimplify_target_expr): Likewise for C++ temporaries. (sort_by_decl_uid): New function. (gimplify_expr): Unpoison all variables for a label we can jump from outside of a scope. (gimplify_switch_expr): Unpoison variables defined in the switch context. (gimplify_function_tree): Clear asan_poisoned_variables. (asan_poison_variables): New function. (warn_switch_unreachable_r): Handle IFN_ASAN_MARK. * internal-fn.c (expand_ASAN_MARK): New function. * internal-fn.def (ASAN_MARK): Declare. * opts.c (finish_options): Handle -fstack-reuse if -fsanitize-address-use-after-scope is enabled. (common_handle_option): Enable address sanitization if -fsanitize-address-use-after-scope is enabled. * params.def (PARAM_USE_AFTER_SCOPE_DIRECT_EMISSION_THRESHOLD): New parameter. * params.h: Likewise. * sancov.c (pass_sanopt::execute): Handle IFN_ASAN_MARK. * sanitizer.def: Define __asan_poison_stack_memory and __asan_unpoison_stack_memory functions. * asan.c (asan_mark_poison_p): New function. (transform_statements): Handle asan_mark_poison_p calls. * gimple.c (nonfreeing_call_p): Handle IFN_ASAN_MARK. From-SVN: r241896
Showing
- gcc/ChangeLog 55 additions, 0 deletionsgcc/ChangeLog
- gcc/asan.c 248 additions, 54 deletionsgcc/asan.c
- gcc/asan.h 55 additions, 11 deletionsgcc/asan.h
- gcc/c-family/ChangeLog 5 additions, 0 deletionsgcc/c-family/ChangeLog
- gcc/c-family/c-warn.c 8 additions, 1 deletiongcc/c-family/c-warn.c
- gcc/cfgexpand.c 4 additions, 14 deletionsgcc/cfgexpand.c
- gcc/common.opt 3 additions, 0 deletionsgcc/common.opt
- gcc/doc/invoke.texi 13 additions, 2 deletionsgcc/doc/invoke.texi
- gcc/gimple.c 3 additions, 0 deletionsgcc/gimple.c
- gcc/gimplify.c 219 additions, 15 deletionsgcc/gimplify.c
- gcc/internal-fn.c 9 additions, 0 deletionsgcc/internal-fn.c
- gcc/internal-fn.def 1 addition, 0 deletionsgcc/internal-fn.def
- gcc/opts.c 25 additions, 2 deletionsgcc/opts.c
- gcc/params.def 6 additions, 0 deletionsgcc/params.def
- gcc/params.h 2 additions, 0 deletionsgcc/params.h
- gcc/sanitizer.def 4 additions, 0 deletionsgcc/sanitizer.def
- gcc/sanopt.c 3 additions, 0 deletionsgcc/sanopt.c
Loading
Please register or sign in to comment