]> git.ipfire.org Git - thirdparty/gcc.git/commit - libsanitizer/ChangeLog
re PR sanitizer/80998 (Implement -fsanitize=pointer-overflow)
authorJakub Jelinek <jakub@redhat.com>
Fri, 28 Jul 2017 10:37:51 +0000 (12:37 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 28 Jul 2017 10:37:51 +0000 (12:37 +0200)
commitc9b39a4955f56fe609ef54784f7bf48c4cba6b1a
tree6ddac4284a4bae1e7241b22e28dcaaeb311277f9
parent70affe6aff39d347a0e2b7f12a27e1cad4cae405
re PR sanitizer/80998 (Implement -fsanitize=pointer-overflow)

PR sanitizer/80998
* sanopt.c (pass_sanopt::execute): Handle IFN_UBSAN_PTR.
* tree-ssa-alias.c (call_may_clobber_ref_p_1): Likewise.
* flag-types.h (enum sanitize_code): Add SANITIZER_POINTER_OVERFLOW.
Or it into SANITIZER_UNDEFINED.
* ubsan.c: Include gimple-fold.h and varasm.h.
(ubsan_expand_ptr_ifn): New function.
(instrument_pointer_overflow): New function.
(maybe_instrument_pointer_overflow): New function.
(instrument_object_size): Formatting fix.
(pass_ubsan::execute): Call instrument_pointer_overflow
and maybe_instrument_pointer_overflow.
* internal-fn.c (expand_UBSAN_PTR): New function.
* ubsan.h (ubsan_expand_ptr_ifn): Declare.
* sanitizer.def (__ubsan_handle_pointer_overflow,
__ubsan_handle_pointer_overflow_abort): New builtins.
* tree-ssa-tail-merge.c (merge_stmts_p): Handle IFN_UBSAN_PTR.
* internal-fn.def (UBSAN_PTR): New internal function.
* opts.c (sanitizer_opts): Add pointer-overflow.
* lto-streamer-in.c (input_function): Handle IFN_UBSAN_PTR.
* fold-const.c (build_range_check): Compute pointer range check in
integral type if pointer arithmetics would be needed.  Formatting
fixes.
gcc/testsuite/
* c-c++-common/ubsan/ptr-overflow-1.c: New test.
* c-c++-common/ubsan/ptr-overflow-2.c: New test.
libsanitizer/
* ubsan/ubsan_handlers.cc: Cherry-pick upstream r304461.
* ubsan/ubsan_checks.inc: Likewise.
* ubsan/ubsan_handlers.h: Likewise.

From-SVN: r250656
20 files changed:
gcc/ChangeLog
gcc/flag-types.h
gcc/fold-const.c
gcc/internal-fn.c
gcc/internal-fn.def
gcc/lto-streamer-in.c
gcc/opts.c
gcc/sanitizer.def
gcc/sanopt.c
gcc/testsuite/ChangeLog
gcc/testsuite/c-c++-common/ubsan/ptr-overflow-1.c [new file with mode: 0644]
gcc/testsuite/c-c++-common/ubsan/ptr-overflow-2.c [new file with mode: 0644]
gcc/tree-ssa-alias.c
gcc/tree-ssa-tail-merge.c
gcc/ubsan.c
gcc/ubsan.h
libsanitizer/ChangeLog
libsanitizer/ubsan/ubsan_checks.inc
libsanitizer/ubsan/ubsan_handlers.cc
libsanitizer/ubsan/ubsan_handlers.h