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
```

Reply via email to