From: Michael Matz Date: Wed, 23 Jan 2008 16:44:27 +0000 (+0000) Subject: re PR debug/34895 (ICE in force_type_die, at dwarf2out.c:12923) X-Git-Tag: releases/gcc-4.3.0~452 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b4da9f9dd016e83cea7d443f171fe91f0b962b9e;p=thirdparty%2Fgcc.git re PR debug/34895 (ICE in force_type_die, at dwarf2out.c:12923) PR debug/34895 * dwarf2out.c (force_type_die): Use modified_type_die instead of gen_type_die. * g++.dg/debug/pr34895.cc: New testcase. From-SVN: r131761 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c34dbd07bd88..99fe6282519f 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-01-23 Michael Matz + + PR debug/34895 + * dwarf2out.c (force_type_die): Use modified_type_die instead of + gen_type_die. + 2008-01-23 Andreas Krebbel * ipa-struct-reorg.c (create_new_malloc): Use pointer type as diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index 829b9ee328f5..c1df45af12ad 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -13736,11 +13736,8 @@ force_type_die (tree type) else context_die = comp_unit_die; - type_die = lookup_type_die (type); - if (type_die) - return type_die; - gen_type_die (type, context_die); - type_die = lookup_type_die (type); + type_die = modified_type_die (type, TYPE_READONLY (type), + TYPE_VOLATILE (type), context_die); gcc_assert (type_die); } return type_die; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 2608146190fb..fe9442a92b80 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-01-23 Michael Matz + + PR debug/34895 + * g++.dg/debug/pr34895.cc: New testcase. + 2008-01-23 Richard Guenther PR middle-end/31529 diff --git a/gcc/testsuite/g++.dg/debug/pr34895.C b/gcc/testsuite/g++.dg/debug/pr34895.C new file mode 100644 index 000000000000..ca06336c62ab --- /dev/null +++ b/gcc/testsuite/g++.dg/debug/pr34895.C @@ -0,0 +1,19 @@ +// { dg-do compile } +// { dg-options "-O2 -g" } +// +// Copyright (C) 2008 Free Software Foundation, Inc. +// Contributed by Theodore.Papadopoulo 20 Jan 2008 + +struct A { + A() { } + unsigned operator()() { return 1; } +}; +struct B: public A { + typedef const A base; + using base::operator(); + B() { } +}; +int +main() { + B b; +}