diff options
author | Yury Gribov <y.gribov@samsung.com> | 2014-06-20 13:33:28 +0000 |
---|---|---|
committer | Maxim Ostapenko <chefmax@gcc.gnu.org> | 2014-06-20 16:33:28 +0300 |
commit | 0cbf438b115b95453a1b0414c6cf628bf1ad1ead (patch) | |
tree | fd8dcedd9f898e8f346830bcc90cd385e5f4cca4 /gcc/asan.c | |
parent | bec81025ed968d6ba52308b2a9824bd689628a5f (diff) | |
download | gcc-0cbf438b115b95453a1b0414c6cf628bf1ad1ead.zip gcc-0cbf438b115b95453a1b0414c6cf628bf1ad1ead.tar.gz gcc-0cbf438b115b95453a1b0414c6cf628bf1ad1ead.tar.bz2 |
asan.c (instrument_strlen_call): Fixed instrumentation of trailing byte.
2014-06-18 Yury Gribov <y.gribov@samsung.com>
gcc/
* asan.c (instrument_strlen_call): Fixed instrumentation of
trailing byte.
gcc/testsuite/
* c-c++-common/asan/strlen-overflow-1.c: New test.
Co-Authored-By: Max Ostapenko <m.ostapenko@partner.samsung.com>
From-SVN: r211849
Diffstat (limited to 'gcc/asan.c')
-rw-r--r-- | gcc/asan.c | 20 |
1 files changed, 10 insertions, 10 deletions
@@ -2037,19 +2037,19 @@ instrument_strlen_call (gimple_stmt_iterator *iter) build_check_stmt (loc, gimple_assign_lhs (str_arg_ssa), NULL_TREE, 1, iter, /*non_zero_len_p*/true, /*before_p=*/true, - /*is_store=*/false, /*is_scalar_access*/false, /*align*/0); + /*is_store=*/false, /*is_scalar_access*/true, /*align*/0); - gimple stmt = - gimple_build_assign_with_ops (PLUS_EXPR, - make_ssa_name (TREE_TYPE (len), NULL), - len, - build_int_cst (TREE_TYPE (len), 1)); - gimple_set_location (stmt, loc); - gsi_insert_after (iter, stmt, GSI_NEW_STMT); + gimple g = + gimple_build_assign_with_ops (POINTER_PLUS_EXPR, + make_ssa_name (cptr_type, NULL), + gimple_assign_lhs (str_arg_ssa), + len); + gimple_set_location (g, loc); + gsi_insert_after (iter, g, GSI_NEW_STMT); - build_check_stmt (loc, gimple_assign_lhs (stmt), len, 1, iter, + build_check_stmt (loc, gimple_assign_lhs (g), NULL_TREE, 1, iter, /*non_zero_len_p*/true, /*before_p=*/false, - /*is_store=*/false, /*is_scalar_access*/false, /*align*/0); + /*is_store=*/false, /*is_scalar_access*/true, /*align*/0); return true; } |