[Bug c++/84091] New: ICE on valid C++ code: Segmentation fault
su at cs dot ucdavis.edu
gcc-bugzilla@gcc.gnu.org
Mon Jan 29 04:28:00 GMT 2018
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84091
Bug ID: 84091
Summary: ICE on valid C++ code: Segmentation fault
Product: gcc
Version: unknown
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: su at cs dot ucdavis.edu
Target Milestone: ---
This appears to be a recent regression.
$ g++tk -v
Using built-in specs.
COLLECT_GCC=g++tk
COLLECT_LTO_WRAPPER=/home/su/software/tmp/gcc/gcc-trunk/libexec/gcc/x86_64-pc-linux-gnu/8.0.1/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: ../gcc-source-trunk/configure --enable-languages=c,c++,lto
--prefix=/home/su/software/tmp/gcc/gcc-trunk --disable-bootstrap
Thread model: posix
gcc version 8.0.1 20180128 (experimental) [trunk revision 257131] (GCC)
$
$ g++-7.2.0 tmp.cpp
$
$ g++tk tmp.cpp
tmp.cpp: In instantiation of ‘void f() [with <template-parameter-1-1> = int]’:
tmp.cpp:8:14: required from here
tmp.cpp:3:15: internal compiler error: Segmentation fault
[] { struct A {} a; } ();
^
0xe9e57f crash_signal
../../gcc-source-trunk/gcc/toplev.c:325
0x77a0a1 tree_check
../../gcc-source-trunk/gcc/tree.h:3131
0x77a0a1 determine_visibility(tree_node*)
../../gcc-source-trunk/gcc/cp/decl2.c:2472
0x7ea06a do_pushtag
../../gcc-source-trunk/gcc/cp/name-lookup.c:6479
0x7ea06a pushtag(tree_node*, tree_node*, tag_scope)
../../gcc-source-trunk/gcc/cp/name-lookup.c:6491
0x87fb7c lookup_template_class_1
../../gcc-source-trunk/gcc/cp/pt.c:8966
0x87fb7c lookup_template_class(tree_node*, tree_node*, tree_node*, tree_node*,
int, int)
../../gcc-source-trunk/gcc/cp/pt.c:9168
0x875a4f tsubst_aggr_type
../../gcc-source-trunk/gcc/cp/pt.c:12036
0x8778b0 tsubst(tree_node*, tree_node*, int, tree_node*)
../../gcc-source-trunk/gcc/cp/pt.c:13669
0x86fa34 tsubst_decl
../../gcc-source-trunk/gcc/cp/pt.c:12965
0x877de6 tsubst(tree_node*, tree_node*, int, tree_node*)
../../gcc-source-trunk/gcc/cp/pt.c:13586
0x857b4c tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16080
0x8533eb tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16007
0x8545c8 tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16284
0x8545c8 tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16284
0x89c366 tsubst_lambda_expr(tree_node*, tree_node*, int, tree_node*)
../../gcc-source-trunk/gcc/cp/pt.c:17019
0x861011 tsubst_copy_and_build(tree_node*, tree_node*, int, tree_node*, bool,
bool)
../../gcc-source-trunk/gcc/cp/pt.c:18308
0x86416b tsubst_copy_and_build(tree_node*, tree_node*, int, tree_node*, bool,
bool)
../../gcc-source-trunk/gcc/cp/pt.c:17628
0x853b9f tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16800
0x855965 tsubst_expr(tree_node*, tree_node*, int, tree_node*, bool)
../../gcc-source-trunk/gcc/cp/pt.c:16021
Please submit a full bug report,
with preprocessed source if appropriate.
Please include the complete backtrace with any bug report.
See <https://gcc.gnu.org/bugs/> for instructions.
$
----------------------------------
template < typename > void f ()
{
[] { struct A {} a; } ();
}
int main ()
{
f < int > ();
return 0;
}
More information about the Gcc-bugs
mailing list