public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug c++/112557] New: ICE with coroutines in build_special_member_call, at cp/call.cc:11093
@ 2023-11-16  3:35 tobi at gcc dot gnu.org
  2023-11-20  3:43 ` [Bug c++/112557] " tobi at gcc dot gnu.org
  0 siblings, 1 reply; 2+ messages in thread
From: tobi at gcc dot gnu.org @ 2023-11-16  3:35 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=112557

            Bug ID: 112557
           Summary: ICE with coroutines in build_special_member_call, at
                    cp/call.cc:11093
           Product: gcc
           Version: unknown
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: tobi at gcc dot gnu.org
  Target Milestone: ---

Created attachment 56599
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=56599&action=edit
gzipped source code reduced from -report-bug output

The attached code ICEs when compiling with g++ 13.2 and compiler explorer's
trunk version . I found the same bug with the un-preprocessed code with Ubuntu
22.04's default g++11.

Compiler Explorer link here:
https://godbolt.org/z/3cMn45xz6

example command line to trigger the bug: /usr/bin/g++ -DEIGEN_MPL2_ONLY
-DSPDLOG_COMPILED_LIB -DSPDLOG_FMT_EXTERNAL
-I/home/lpresearch/LPResearch/lpopenvr_lpviz/00_3rdparty/00_tracking_systems/DTrackSDK_v2.8.0/include
-I/home/lpresearch/LPResearch/lpopenvr_lpviz/00_tools -isystem
/home/lpresearch/.conan/data/boost/1.83.0/_/_/package/8cc3305c27e5ff838d1c7590662e309638310dfc/include
-isystem
/home/lpresearch/.conan/data/eigen/3.4.0/_/_/package/5ab84d6acfe1f23c4fae0ab88f26e3a396351ac9/include/eigen3
-isystem
/home/lpresearch/.conan/data/fmt/10.1.1/_/_/package/20da98908a15523bbe9f086a5c57a4bde424a9c0/include
-isystem
/home/lpresearch/.conan/data/expected-lite/0.6.3/_/_/package/5ab84d6acfe1f23c4fae0ab88f26e3a396351ac9/include
-isystem
/home/lpresearch/.conan/data/spdlog/1.12.0/_/_/package/17da8a8753b9f1e2e594e9ec31ee01c6fcb2c8f9/include
-g -fPIC -fvisibility=hidden -fvisibility-inlines-hidden -std=gnu++20 -MD -c
~/bug.cpp -freport-bug

Example output (leaving aside the warnings about mismatched linemarkers due to
the way I reduced this):

/home/lpresearch/LPResearch/lpopenvr_lpviz/00_3rdparty/00_tracking_systems/DTrackSDK_v2.8.0/include/DTrackParse.hpp:
In static member function ‘static
boost::asio::awaitable<std::unique_ptr<LP::DTrackDebugDataListener::Impl> >
LP::DTrackDebugDataListener::Impl::start(const LP::ArtController&)’:
/home/lpresearch/LPResearch/lpopenvr_lpviz/00_3rdparty/00_tracking_systems/DTrackSDK_v2.8.0/include/DTrackParse.hpp:263:5:
internal compiler error: in build_special_member_call, at cp/call.cc:11085
0x85a411 build_special_member_call(tree_node*, tree_node*, vec<tree_node*,
va_gc, vl_embed>**, tree_node*, int, int)
        ../../src/gcc/cp/call.cc:11085
0xbe851b maybe_promote_temps
        ../../src/gcc/cp/coroutines.cc:3146
0xbe851b await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3757
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0xbe7c4e await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3428
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0x126b23c walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11558
0xbe7c4e await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3428
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0x126b23c walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11558
0xbe7c4e await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3428
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0x126b23c walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11558
0xbe7c4e await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3428
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0x126b23c walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11558
0xbe7c4e await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3428
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
0xbe7bfd await_statement_walker
        ../../src/gcc/cp/coroutines.cc:3417
0x126b106 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*))
        ../../src/gcc/tree.cc:11327
Please submit a full bug report, with preprocessed source.
Please include the complete backtrace with any bug report.
See <file:///usr/share/doc/gcc-13/README.Bugs> for instructions.

^ permalink raw reply	[flat|nested] 2+ messages in thread

* [Bug c++/112557] ICE with coroutines in build_special_member_call, at cp/call.cc:11093
  2023-11-16  3:35 [Bug c++/112557] New: ICE with coroutines in build_special_member_call, at cp/call.cc:11093 tobi at gcc dot gnu.org
@ 2023-11-20  3:43 ` tobi at gcc dot gnu.org
  0 siblings, 0 replies; 2+ messages in thread
From: tobi at gcc dot gnu.org @ 2023-11-20  3:43 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=112557

--- Comment #1 from Tobias Schlüter <tobi at gcc dot gnu.org> ---
With today's trunk on x86-64 I can reproduce this, giving the following:

$ ../gcc.git/build/gcc/cc1plus t.cc --std=c++20 -fpermissive
-fext-numeric-literals 2>&1
[ ... stripping away thousands of warnings ... ]
/home/lpresearch/LPResearch/lpopenvr_lpviz/00_3rdparty/00_tracking_systems/DTrackSDK_v2.8.0/include/DTrackParse.hpp:
In static member function ‘static
boost::asio::awaitable<std::unique_ptr<LP::DTrackDebugDataListener::Impl> >
LP::DTrac>
/home/lpresearch/LPResearch/lpopenvr_lpviz/00_3rdparty/00_tracking_systems/DTrackSDK_v2.8.0/include/DTrackParse.hpp:263:5:
internal compiler error: tree check: expected record_type or union_type or
qual_union_type, have array_type in bu>
0x938c90 tree_check_failed(tree_node const*, char const*, int, char const*,
...)
        ../../gcc/tree.cc:8952
0x73fd02 tree_check3(tree_node*, char const*, int, char const*, tree_code,
tree_code, tree_code)
        ../../gcc/tree.h:3642
0x73fd02 build_special_member_call(tree_node*, tree_node*, vec<tree_node*,
va_gc, vl_embed>**, tree_node*, int, int)
        ../../gcc/cp/call.cc:11071
0xaa0eac maybe_promote_temps
        ../../gcc/cp/coroutines.cc:3142
0xaa0eac await_statement_walker
        ../../gcc/cp/coroutines.cc:3753
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
0xaa0668 await_statement_walker
        ../../gcc/cp/coroutines.cc:3424
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
0x162f934 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11652
0xaa0668 await_statement_walker
        ../../gcc/cp/coroutines.cc:3424
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
0x162f934 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11652
0xaa0668 await_statement_walker
        ../../gcc/cp/coroutines.cc:3424
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
0x162f934 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11652
0xaa0668 await_statement_walker
        ../../gcc/cp/coroutines.cc:3424
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
0x162f934 walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11652
0xaa0668 await_statement_walker
        ../../gcc/cp/coroutines.cc:3424
0x162f7dc walk_tree_1(tree_node**, tree_node* (*)(tree_node**, int*, void*),
void*, hash_set<tree_node*, false, default_hash_traits<tree_node*> >*,
tree_node* (*)(tree_node**, int*, tree_node* (*)(tree_node**, int*, void*),
void*, hash_>
        ../../gcc/tree.cc:11418
Please submit a full bug report, with preprocessed source (by using
-freport-bug).
Please include the complete backtrace with any bug report.
See <https://gcc.gnu.org/bugs/> for instructions.

The error location is this:
#2  build_special_member_call (instance=0x7fffe891d090, name=0x7ffff76f5200,
args=0x0, binfo=0x7fffe88e4540, flags=1, complain=3) at
../../gcc/cp/call.cc:11071
11071         binfo = TYPE_BINFO (binfo);
(gdb) l
11066       {
11067         /* Resolve the name.  */
11068         if (!complete_type_or_maybe_complain (binfo, NULL_TREE,
complain))
11069           return error_mark_node;
11070
11071         binfo = TYPE_BINFO (binfo);
11072       }
11073
11074     gcc_assert (binfo != NULL_TREE);
11075
(gdb)

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2023-11-20  3:43 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-11-16  3:35 [Bug c++/112557] New: ICE with coroutines in build_special_member_call, at cp/call.cc:11093 tobi at gcc dot gnu.org
2023-11-20  3:43 ` [Bug c++/112557] " tobi at gcc dot gnu.org

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).