diff options
Diffstat (limited to 'gcc/c')
-rw-r--r-- | gcc/c/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c/c-typeck.c | 6 |
2 files changed, 10 insertions, 2 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index 931e51d..b595b81 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,3 +1,9 @@ +2016-02-11 Jakub Jelinek <jakub@redhat.com> + + PR c/69768 + * c-typeck.c (parser_build_binary_op): Strip nops from integer_zerop + arguments for -Waddress warning. + 2016-02-04 Jakub Jelinek <jakub@redhat.com> PR c/69669 diff --git a/gcc/c/c-typeck.c b/gcc/c/c-typeck.c index 65925cb..82efacf 100644 --- a/gcc/c/c-typeck.c +++ b/gcc/c/c-typeck.c @@ -3597,8 +3597,10 @@ parser_build_binary_op (location_t location, enum tree_code code, of testing for equality or inequality of a string literal with NULL. */ if (code == EQ_EXPR || code == NE_EXPR) { - if ((code1 == STRING_CST && !integer_zerop (arg2.value)) - || (code2 == STRING_CST && !integer_zerop (arg1.value))) + if ((code1 == STRING_CST + && !integer_zerop (tree_strip_nop_conversions (arg2.value))) + || (code2 == STRING_CST + && !integer_zerop (tree_strip_nop_conversions (arg1.value)))) warning_at (location, OPT_Waddress, "comparison with string literal results in unspecified behavior"); } |