Commit 87eb16a1 by Jakub Jelinek Committed by Jakub Jelinek

re PR c++/56607 (GCC fails to warn on division by zero)

	PR c++/56607
	* typeck.c (cp_build_binary_op): When calling warn_for_div_by_zero,
	pass op1 through maybe_constant_value first.

	* g++.dg/warn/Wdiv-by-zero-2.C: New test.
	* c-c++-common/pr56607.c: New test.

From-SVN: r196704
parent 9a54d96a
2013-03-16 Jakub Jelinek <jakub@redhat.com>
PR c++/56607
* typeck.c (cp_build_binary_op): When calling warn_for_div_by_zero,
pass op1 through maybe_constant_value first.
2013-03-16 Paolo Carlini <paolo.carlini@oracle.com> 2013-03-16 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/56582 PR c++/56582
......
...@@ -4015,7 +4015,7 @@ cp_build_binary_op (location_t location, ...@@ -4015,7 +4015,7 @@ cp_build_binary_op (location_t location,
{ {
enum tree_code tcode0 = code0, tcode1 = code1; enum tree_code tcode0 = code0, tcode1 = code1;
warn_for_div_by_zero (location, op1); warn_for_div_by_zero (location, maybe_constant_value (op1));
if (tcode0 == COMPLEX_TYPE || tcode0 == VECTOR_TYPE) if (tcode0 == COMPLEX_TYPE || tcode0 == VECTOR_TYPE)
tcode0 = TREE_CODE (TREE_TYPE (TREE_TYPE (op0))); tcode0 = TREE_CODE (TREE_TYPE (TREE_TYPE (op0)));
...@@ -4051,7 +4051,7 @@ cp_build_binary_op (location_t location, ...@@ -4051,7 +4051,7 @@ cp_build_binary_op (location_t location,
case TRUNC_MOD_EXPR: case TRUNC_MOD_EXPR:
case FLOOR_MOD_EXPR: case FLOOR_MOD_EXPR:
warn_for_div_by_zero (location, op1); warn_for_div_by_zero (location, maybe_constant_value (op1));
if (code0 == VECTOR_TYPE && code1 == VECTOR_TYPE if (code0 == VECTOR_TYPE && code1 == VECTOR_TYPE
&& TREE_CODE (TREE_TYPE (type0)) == INTEGER_TYPE && TREE_CODE (TREE_TYPE (type0)) == INTEGER_TYPE
......
2013-03-16 Jakub Jelinek <jakub@redhat.com>
PR c++/56607
* g++.dg/warn/Wdiv-by-zero-2.C: New test.
* c-c++-common/pr56607.c: New test.
2013-03-16 Paolo Carlini <paolo.carlini@oracle.com> 2013-03-16 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/56582 PR c++/56582
......
/* PR c++/56607 */
/* { dg-do compile { target { { lp64 || ilp32 } || llp64 } } } */
/* { dg-options "-O2 -Wdiv-by-zero" } */
int
f1 (void)
{
return 1 / (sizeof (char) - 1); /* { dg-warning "division by zero" } */
}
int
f2 (void)
{
const int x = sizeof (char) - 1;
return 1 / x; /* { dg-warning "division by zero" "" { target c++ } } */
}
int
f3 (void)
{
return 1 / (sizeof (int) / 3 - 1); /* { dg-warning "division by zero" } */
}
int
f4 (void)
{
const int x = sizeof (int) / 3 - 1;
return 1 / x; /* { dg-warning "division by zero" "" { target c++ } } */
}
// PR c++/56607
// { dg-do compile { target { { lp64 || ilp32 } || llp64 } } }
// { dg-options "-O2 -Wdiv-by-zero -std=c++11" }
constexpr int sc () { return sizeof (char); }
constexpr int si () { return sizeof (int); }
constexpr int zc () { return sc () - 1; }
constexpr int zi (int d) { return si () / d - 1; }
int
f1 (void)
{
return 1 / zc (); // { dg-warning "division by zero" }
}
int
f2 (void)
{
constexpr int x = zc ();
return 1 / x; // { dg-warning "division by zero" }
}
int
f3 (void)
{
return 1 / zi (3); // { dg-warning "division by zero" }
}
int
f4 (void)
{
constexpr int x = zi (3);
return 1 / x; // { dg-warning "division by zero" }
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment