Commit 4e6482d0 by Jakub Jelinek Committed by Jakub Jelinek

re PR c++/89709 (ICE with constexpr and "-O")

	PR c++/89709
	* tree.c (inchash::add_expr): Strip any location wrappers.
	* fold-const.c (operand_equal_p): Move stripping of location wrapper
	after hash verification.

	* g++.dg/cpp0x/constexpr-89709.C: New test.

From-SVN: r269702
parent 8eb2215d
2019-03-15 Jakub Jelinek <jakub@redhat.com>
PR c++/89709
* tree.c (inchash::add_expr): Strip any location wrappers.
* fold-const.c (operand_equal_p): Move stripping of location wrapper
after hash verification.
PR debug/89704
* dwarf2out.c (add_const_value_attribute): Return false for MINUS,
SIGN_EXTEND and ZERO_EXTEND.
......
......@@ -2942,9 +2942,6 @@ combine_comparisons (location_t loc,
int
operand_equal_p (const_tree arg0, const_tree arg1, unsigned int flags)
{
STRIP_ANY_LOCATION_WRAPPER (arg0);
STRIP_ANY_LOCATION_WRAPPER (arg1);
/* When checking, verify at the outermost operand_equal_p call that
if operand_equal_p returns non-zero then ARG0 and ARG1 has the same
hash value. */
......@@ -2967,6 +2964,9 @@ operand_equal_p (const_tree arg0, const_tree arg1, unsigned int flags)
return 0;
}
STRIP_ANY_LOCATION_WRAPPER (arg0);
STRIP_ANY_LOCATION_WRAPPER (arg1);
/* If either is ERROR_MARK, they aren't equal. */
if (TREE_CODE (arg0) == ERROR_MARK || TREE_CODE (arg1) == ERROR_MARK
|| TREE_TYPE (arg0) == error_mark_node
......
2019-03-15 Jakub Jelinek <jakub@redhat.com>
PR c++/89709
* g++.dg/cpp0x/constexpr-89709.C: New test.
PR debug/89704
* gcc.dg/debug/pr89704.c: New test.
......
// PR c++/89709
// { dg-do compile { target c++11 } }
// { dg-options "-O" }
struct A { int i; };
A a;
constexpr int *
foo ()
{
return &a.i;
}
bool
bar ()
{
return foo () == &a.i;
}
......@@ -7743,6 +7743,8 @@ add_expr (const_tree t, inchash::hash &hstate, unsigned int flags)
return;
}
STRIP_ANY_LOCATION_WRAPPER (t);
if (!(flags & OEP_ADDRESS_OF))
STRIP_NOPS (t);
......
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