Commit 8e8483e6 by Martin Jambor Committed by Martin Jambor

re PR middle-end/52939 (ice in gimple_get_virt_method_for_binfo with -O3)

2012-04-13  Martin Jambor  <mjambor@suse.cz>

	PR middle-end/52939
	* gimple-fold.c (gimple_get_virt_method_for_binfo): Bail out if
	fold_ctor_reference returns a zero constant.

	* testsuite/g++.dg/ipa/pr52939.C: New test.

From-SVN: r186428
parent 70a69509
2012-04-13 Martin Jambor <mjambor@suse.cz>
PR middle-end/52939
* gimple-fold.c (gimple_get_virt_method_for_binfo): Bail out if
fold_ctor_reference returns a zero constant.
2012-04-13 Enkovich Ilya <ilya.enkovich@intel.com> 2012-04-13 Enkovich Ilya <ilya.enkovich@intel.com>
* config.gcc: Add i386/gnu-user-common.h before all * config.gcc: Add i386/gnu-user-common.h before all
......
...@@ -3087,7 +3087,7 @@ gimple_get_virt_method_for_binfo (HOST_WIDE_INT token, tree known_binfo) ...@@ -3087,7 +3087,7 @@ gimple_get_virt_method_for_binfo (HOST_WIDE_INT token, tree known_binfo)
offset += token * size; offset += token * size;
fn = fold_ctor_reference (TREE_TYPE (TREE_TYPE (v)), DECL_INITIAL (v), fn = fold_ctor_reference (TREE_TYPE (TREE_TYPE (v)), DECL_INITIAL (v),
offset, size); offset, size);
if (!fn) if (!fn || integer_zerop (fn))
return NULL_TREE; return NULL_TREE;
gcc_assert (TREE_CODE (fn) == ADDR_EXPR gcc_assert (TREE_CODE (fn) == ADDR_EXPR
|| TREE_CODE (fn) == FDESC_EXPR); || TREE_CODE (fn) == FDESC_EXPR);
......
2012-04-13 Martin Jambor <mjambor@suse.cz>
PR middle-end/52939
* g++.dg/ipa/pr52939.C: New test.
2012-04-13 Tom de Vries <tom@codesourcery.com> 2012-04-13 Tom de Vries <tom@codesourcery.com>
* gcc.dg/pr52734.c: New test. * gcc.dg/pr52734.c: New test.
......
/* Verify that we do not ICE on invalid devirtualizations (which might
be OK at run-time because never executed). */
/* { dg-do run } */
/* { dg-options "-O3 -fno-early-inlining -fno-inline" } */
extern "C" void abort (void);
class A
{
public:
int data;
virtual int foo (int i);
};
class B : public A
{
public:
virtual int foo (int i);
virtual int bar (int i);
};
int A::foo (int i)
{
return i + 1;
}
int B::foo (int i)
{
return i + 2;
}
int B::bar (int i)
{
return i + 3;
}
static int middleman (class A *obj, int i)
{
class B *b = (class B *) obj;
if (i != 1)
return b->bar (i);
else
return i;
}
int __attribute__ ((noinline,noclone)) get_input(void)
{
return 1;
}
int main (int argc, char *argv[])
{
class A o;
if (middleman (&o, get_input ()) != 1)
abort ();
return 0;
}
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