https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119807
Bug ID: 119807
Summary: constexpr counter thing causes ICE: in
instantiate_decl, at cp/pt.cc:27844
Product: gcc
Version: 15.0
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: eczbek.void at gmail dot com
Target Milestone: ---
https://godbolt.org/z/zaTaEWesh
Works fine with Clang
```
using size_t = decltype(0uz);
template<auto tag, size_t current>
struct CounterReader {
template<typename>
friend auto counterFlag(CounterReader<tag, current>) noexcept;
};
template<auto tag, size_t current>
struct CounterWriter {
static constexpr size_t value = current;
template<typename>
friend auto counterFlag(CounterReader<tag, current>) noexcept {}
};
template<auto tag, auto unique, size_t current = 0, size_t mask = 1uz <<
(sizeof(size_t) * 8 - 1)>
[[nodiscard]] constexpr size_t counterAdvance() noexcept {
if constexpr (!mask) {
return CounterWriter<tag, current + 1>::value;
} else if constexpr (requires { counterFlag<void>(CounterReader<tag,
current | mask>()); }) {
return counterAdvance<tag, unique, current | mask, (mask >>
1)>();
}
else {
return counterAdvance<tag, unique, current, (mask >> 1)>();
}
}
constexpr auto defaultCounterTag = [] {};
template<auto tag = defaultCounterTag, auto unique = [] {}>
constexpr size_t counter() noexcept {
return counterAdvance<tag, unique>();
}
int main() {
static_assert(counter() == 1);
static_assert(counter() == 2);
}
```
```
Using built-in specs.
COLLECT_GCC=/opt/compiler-explorer/gcc-snapshot/bin/g++
Target: x86_64-linux-gnu
Configured with: ../gcc-trunk-20250414/configure
--prefix=/opt/compiler-explorer/gcc-build/staging
--enable-libstdcxx-backtrace=yes --build=x86_64-linux-gnu
--host=x86_64-linux-gnu --target=x86_64-linux-gnu --disable-bootstrap
--enable-multiarch --with-abi=m64 --with-multilib-list=m32,m64,mx32
--enable-multilib --enable-clocale=gnu
--enable-languages=c,c++,fortran,ada,objc,obj-c++,go,d,rust,m2,cobol
--enable-ld=yes --enable-gold=yes --enable-libstdcxx-debug
--enable-libstdcxx-time=yes --enable-linker-build-id --enable-lto
--enable-plugins --enable-threads=posix
--with-pkgversion=Compiler-Explorer-Build-gcc-d72b4e9f78f841a032538070a035177cc4f20d68-binutils-2.42
Thread model: posix
Supported LTO compression algorithms: zlib
gcc version 15.0.1 20250414 (experimental)
(Compiler-Explorer-Build-gcc-d72b4e9f78f841a032538070a035177cc4f20d68-binutils-2.42)
COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-g' '-o' '/app/output.s'
'-masm=intel' '-fno-verbose-asm' '-S' '-std=c++23' '-v' '-freport-bug'
'-shared-libgcc' '-mtune=generic' '-march=x86-64' '-dumpdir' '/app/'
/opt/compiler-explorer/gcc-trunk-20250414/bin/../libexec/gcc/x86_64-linux-gnu/15.0.1/cc1plus
-quiet -v -imultiarch x86_64-linux-gnu -iprefix
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/
-D_GNU_SOURCE <source> -quiet -dumpdir /app/ -dumpbase output.cpp -dumpbase-ext
.cpp -masm=intel -mtune=generic -march=x86-64 -g -std=c++23 -version
-fdiagnostics-color=always -fno-verbose-asm -freport-bug -o /app/output.s
GNU C++23
(Compiler-Explorer-Build-gcc-d72b4e9f78f841a032538070a035177cc4f20d68-binutils-2.42)
version 15.0.1 20250414 (experimental) (x86_64-linux-gnu)
compiled by GNU C version 11.4.0, GMP version 6.2.1, MPFR version
4.1.0, MPC version 1.2.1, isl version isl-0.24-GMP
GGC heuristics: --param ggc-min-expand=30 --param ggc-min-heapsize=4096
ignoring nonexistent directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../x86_64-linux-gnu/include"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1/x86_64-linux-gnu"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1/backward"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/include"
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/include-fixed/x86_64-linux-gnu"
ignoring duplicate directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/include-fixed"
ignoring nonexistent directory
"/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../x86_64-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1/x86_64-linux-gnu
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/../../../../include/c++/15.0.1/backward
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/include
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/include-fixed/x86_64-linux-gnu
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/x86_64-linux-gnu/15.0.1/include-fixed
/usr/local/include
/opt/compiler-explorer/gcc-trunk-20250414/bin/../lib/gcc/../../include
/usr/include/x86_64-linux-gnu
/usr/include
End of search list.
Compiler executable checksum: 3d92deed85ed5a39b231c772fe6d397c
<source>: In instantiation of 'constexpr size_t counterAdvance() [with auto tag
= <lambda closure object><lambda()>(); auto unique = <lambda closure
object><lambda()>(); long unsigned int current = 0; long unsigned int mask =
9223372036854775808; size_t = long unsigned int]':
<source>:33:36: required from here
33 | return counterAdvance<tag, unique>();
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~
<source>:38:23: in 'constexpr' expansion of 'counter<>()'
<source>:21:58: internal compiler error: in instantiate_decl, at cp/pt.cc:27844
21 | } else if constexpr (requires {
counterFlag<void>(CounterReader<tag, current | mask>()); }) {
|
~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
0x29272c5 diagnostic_context::diagnostic_impl(rich_location*,
diagnostic_metadata const*, diagnostic_option_id, char const*, __va_list_tag
(*) [1], diagnostic_t)
???:0
0x293e296 internal_error(char const*, ...)
???:0
0xad02dc fancy_abort(char const*, int, char const*)
???:0
0xbd78b3 maybe_instantiate_decl(tree_node*)
???:0
0xbd95a7 mark_used(tree_node*, int)
???:0
0xb078ce build_new_function_call(tree_node*, vec<tree_node*, va_gc,
vl_embed>**, int)
???:0
0xd74726 finish_call_expr(tree_node*, vec<tree_node*, va_gc, vl_embed>**, bool,
bool, int)
???:0
0xb58536 tsubst_requires_expr(tree_node*, tree_node*, int, tree_node*)
???:0
0xd1e2fd instantiate_decl(tree_node*, bool, bool)
???:0
0xb4cef2 maybe_constant_value(tree_node*, tree_node*, mce_value)
???:0
0xdc2cae cp_build_binary_op(op_location_t const&, tree_code, tree_node*,
tree_node*, int)
???:0
0xb0a644 build_new_op(op_location_t const&, tree_code, int, tree_node*,
tree_node*, tree_node*, tree_node*, tree_node**, int)
???:0
0xdb41e2 build_x_binary_op(op_location_t const&, tree_code, tree_node*,
tree_code, tree_node*, tree_code, tree_node*, tree_node**, int)
???:0
0xcf38e3 c_parse_file()
???:0
0xe56059 c_common_parse_file()
???:0
Please submit a full bug report, with preprocessed source.
Please include the complete backtrace with any bug report.
See <https://gcc.gnu.org/bugs/> for instructions.
Preprocessed source stored into /tmp/ccshEkd0.out file, please attach this to
your bugreport.
Compiler returned: 1
```