public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base
@ 2013-11-11 21:06 reichelt at gcc dot gnu.org
2013-11-13 15:41 ` [Bug c++/59082] " rguenth at gcc dot gnu.org
` (3 more replies)
0 siblings, 4 replies; 5+ messages in thread
From: reichelt at gcc dot gnu.org @ 2013-11-11 21:06 UTC (permalink / raw)
To: gcc-bugs
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59082
Bug ID: 59082
Summary: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual)
base
Product: gcc
Version: 4.9.0
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: reichelt at gcc dot gnu.org
The following invalid code snippet triggers an ICE since GCC 4.2.0:
================================
struct A {};
struct B : virtual A, A {};
A foo(const B &b)
{
return b;
}
================================
bug.cc:3:23: error: duplicate base type 'A' invalid
struct B : virtual A, A {};
^
bug.cc: In function 'A foo(const B&)':
bug.cc:7:10: internal compiler error: Segmentation fault
return b;
^
0xb2a93f crash_signal
../../gcc/gcc/toplev.c:334
0x618b2d contains_struct_check
../../gcc/gcc/tree.h:2819
0x618b2d build_vfield_ref(tree_node*, tree_node*)
../../gcc/gcc/cp/class.c:639
0x61816b build_base_path(tree_code, tree_node*, tree_node*, int, int)
../../gcc/gcc/cp/class.c:429
0x553a0c convert_like_real
../../gcc/gcc/cp/call.c:6108
0x552e1e convert_like_real
../../gcc/gcc/cp/call.c:6086
0x55491c build_over_call
../../gcc/gcc/cp/call.c:6944
0x550f3e build_new_method_call_1
../../gcc/gcc/cp/call.c:7814
0x550f3e build_new_method_call(tree_node*, tree_node*, vec<tree_node*, va_gc,
vl_embed>**, tree_node*, int, tree_node**, int)
../../gcc/gcc/cp/call.c:7884
0x551e87 build_special_member_call(tree_node*, tree_node*, vec<tree_node*,
va_gc, vl_embed>**, tree_node*, int, int)
../../gcc/gcc/cp/call.c:7441
0x553223 build_temp
../../gcc/gcc/cp/call.c:5784
0x553223 convert_like_real
../../gcc/gcc/cp/call.c:6128
0x5576d9 perform_implicit_conversion_flags(tree_node*, tree_node*, int, int)
../../gcc/gcc/cp/call.c:9019
0x6853c3 check_return_expr(tree_node*, bool*)
../../gcc/gcc/cp/typeck.c:8538
0x6c4bde finish_return_stmt(tree_node*)
../../gcc/gcc/cp/semantics.c:798
0x64d726 cp_parser_jump_statement
../../gcc/gcc/cp/parser.c:10590
0x64d726 cp_parser_statement
../../gcc/gcc/cp/parser.c:9284
0x64dcb9 cp_parser_statement_seq_opt
../../gcc/gcc/cp/parser.c:9654
0x64de2e cp_parser_compound_statement
../../gcc/gcc/cp/parser.c:9608
0x6614cb cp_parser_function_body
../../gcc/gcc/cp/parser.c:18461
Please submit a full bug report, [etc.]
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Bug c++/59082] [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base
2013-11-11 21:06 [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base reichelt at gcc dot gnu.org
@ 2013-11-13 15:41 ` rguenth at gcc dot gnu.org
2014-01-31 11:23 ` paolo.carlini at oracle dot com
` (2 subsequent siblings)
3 siblings, 0 replies; 5+ messages in thread
From: rguenth at gcc dot gnu.org @ 2013-11-13 15:41 UTC (permalink / raw)
To: gcc-bugs
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59082
Richard Biener <rguenth at gcc dot gnu.org> changed:
What |Removed |Added
----------------------------------------------------------------------------
Priority|P3 |P5
Target Milestone|--- |4.7.4
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Bug c++/59082] [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base
2013-11-11 21:06 [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base reichelt at gcc dot gnu.org
2013-11-13 15:41 ` [Bug c++/59082] " rguenth at gcc dot gnu.org
@ 2014-01-31 11:23 ` paolo.carlini at oracle dot com
2014-01-31 16:23 ` paolo at gcc dot gnu.org
2014-01-31 16:24 ` [Bug c++/59082] [4.7/4.8 " paolo.carlini at oracle dot com
3 siblings, 0 replies; 5+ messages in thread
From: paolo.carlini at oracle dot com @ 2014-01-31 11:23 UTC (permalink / raw)
To: gcc-bugs
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59082
Paolo Carlini <paolo.carlini at oracle dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|UNCONFIRMED |ASSIGNED
Last reconfirmed| |2014-01-31
Assignee|unassigned at gcc dot gnu.org |paolo.carlini at oracle dot com
Ever confirmed|0 |1
--- Comment #1 from Paolo Carlini <paolo.carlini at oracle dot com> ---
Mine.
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Bug c++/59082] [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base
2013-11-11 21:06 [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base reichelt at gcc dot gnu.org
2013-11-13 15:41 ` [Bug c++/59082] " rguenth at gcc dot gnu.org
2014-01-31 11:23 ` paolo.carlini at oracle dot com
@ 2014-01-31 16:23 ` paolo at gcc dot gnu.org
2014-01-31 16:24 ` [Bug c++/59082] [4.7/4.8 " paolo.carlini at oracle dot com
3 siblings, 0 replies; 5+ messages in thread
From: paolo at gcc dot gnu.org @ 2014-01-31 16:23 UTC (permalink / raw)
To: gcc-bugs
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59082
--- Comment #2 from paolo at gcc dot gnu.org <paolo at gcc dot gnu.org> ---
Author: paolo
Date: Fri Jan 31 16:22:53 2014
New Revision: 207359
URL: http://gcc.gnu.org/viewcvs?rev=207359&root=gcc&view=rev
Log:
/cp
2014-01-31 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/59082
* class.c (build_vfield_ref): Early return error_mark_node if
TYPE_VFIELD (type) is null.
(build_base_path): Check return value of build_vfield_ref.
/testsuite
2014-01-31 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/59082
* g++.dg/inherit/crash4.C: New.
Added:
trunk/gcc/testsuite/g++.dg/inherit/crash4.C
Modified:
trunk/gcc/cp/ChangeLog
trunk/gcc/cp/class.c
trunk/gcc/testsuite/ChangeLog
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Bug c++/59082] [4.7/4.8 Regression] ICE with duplicate (virtual) base
2013-11-11 21:06 [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base reichelt at gcc dot gnu.org
` (2 preceding siblings ...)
2014-01-31 16:23 ` paolo at gcc dot gnu.org
@ 2014-01-31 16:24 ` paolo.carlini at oracle dot com
3 siblings, 0 replies; 5+ messages in thread
From: paolo.carlini at oracle dot com @ 2014-01-31 16:24 UTC (permalink / raw)
To: gcc-bugs
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59082
Paolo Carlini <paolo.carlini at oracle dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|ASSIGNED |RESOLVED
Resolution|--- |FIXED
Target Milestone|4.7.4 |4.9.0
Summary|[4.7/4.8/4.9 Regression] |[4.7/4.8 Regression] ICE
|ICE with duplicate |with duplicate (virtual)
|(virtual) base |base
--- Comment #3 from Paolo Carlini <paolo.carlini at oracle dot com> ---
Fixed for 4.9.0.
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2014-01-31 16:24 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-11-11 21:06 [Bug c++/59082] New: [4.7/4.8/4.9 Regression] ICE with duplicate (virtual) base reichelt at gcc dot gnu.org
2013-11-13 15:41 ` [Bug c++/59082] " rguenth at gcc dot gnu.org
2014-01-31 11:23 ` paolo.carlini at oracle dot com
2014-01-31 16:23 ` paolo at gcc dot gnu.org
2014-01-31 16:24 ` [Bug c++/59082] [4.7/4.8 " paolo.carlini at oracle dot com
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).