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

            Bug ID: 115956
           Summary: ICE: in change_stack, at reg-stack.cc:2732
           Product: gcc
           Version: 15.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: iamanonymous.cs at gmail dot com
  Target Milestone: ---
            Target: x86_64

Created attachment 58684
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=58684&action=edit
cpp testcase

*******************************************************************************
The compiler produces a segfault during build_this_conversion when compiling
the provided code with the specified options. 
The issue can also be reproduced on Compiler Explorer.

*******************************************************************************
OS and Platform:
# uname -a
Linux ubuntu 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023
x86_64 x86_64 x86_64 GNU/Linux
*******************************************************************************
# g++ -v
Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/root/gdbtest/gcc/gcc-15/libexec/gcc/x86_64-pc-linux-gnu/15.0.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: /root/gdbtest/gcc/obj/../gcc/configure
--prefix=/root/gdbtest/gcc/gcc-15 --enable-languages=c,c++,fortran,go
--disable-multilib
Thread model: posix
Supported LTO compression algorithms: zlib
gcc version 15.0.0 20240509 (experimental) (GCC) 
*******************************************************************************
Program:Please refer to the attachment.
*******************************************************************************
Command Lines:
# g++ random.cpp -O2 -std=c11 -march=native -msse2 -Wall -Wextra 
-Wconversion -Wshadow -Wold-style-cast -Wcast-align -Woverloaded-virtual  -c -o
random.o

cc1plus: warning: command-line option '-std=c11' is valid for C/ObjC but not
for C++
random.cpp: In member function 'float Random::operator()(int, int, float,
float, float) const':
random.cpp:75:21: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:76:21: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:77:21: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:95:22: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:96:22: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:97:22: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:102:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dx))) * ((double)((((float)dx) * ((((float)dx) * (float)-1) +
(float)2)) - (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:102:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:103:8: warning: narrowing conversion of '(5.0e-1 *
((double)((((float)dx) * (((float)dx) * (((float)3 * ((float)dx)) - (float)5)))
+ (float)2)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:103:8: warning: conversion from 'double' to 'float' may change value
[-Wfloat-conversion]
random.cpp:104:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dx))) * ((double)((((float)dx) * (((float)-3 * ((float)dx)) +
(float)4)) + (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:104:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:105:14: warning: narrowing conversion of '(((5.0e-1 *
((double)((float)dx))) * ((double)((float)dx))) * ((double)(((float)dx) -
(float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:105:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:110:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dy))) * ((double)((((float)dy) * ((((float)dy) * (float)-1) +
(float)2)) - (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:110:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:111:8: warning: narrowing conversion of '(5.0e-1 *
((double)((((float)dy) * (((float)dy) * (((float)3 * ((float)dy)) - (float)5)))
+ (float)2)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:111:8: warning: conversion from 'double' to 'float' may change value
[-Wfloat-conversion]
random.cpp:112:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dy))) * ((double)((((float)dy) * (((float)-3 * ((float)dy)) +
(float)4)) + (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:112:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:113:14: warning: narrowing conversion of '(((5.0e-1 *
((double)((float)dy))) * ((double)((float)dy))) * ((double)(((float)dy) -
(float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:113:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:118:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dt))) * ((double)((((float)dt) * ((((float)dt) * (float)-1) +
(float)2)) - (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:118:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:119:8: warning: narrowing conversion of '(5.0e-1 *
((double)((((float)dt) * (((float)dt) * (((float)3 * ((float)dt)) - (float)5)))
+ (float)2)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:119:8: warning: conversion from 'double' to 'float' may change value
[-Wfloat-conversion]
random.cpp:120:11: warning: narrowing conversion of '((5.0e-1 *
((double)((float)dt))) * ((double)((((float)dt) * (((float)-3 * ((float)dt)) +
(float)4)) + (float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:120:11: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:121:14: warning: narrowing conversion of '(((5.0e-1 *
((double)((float)dt))) * ((double)((float)dt))) * ((double)(((float)dt) -
(float)1)))' from 'double' to 'float' [-Wnarrowing]
random.cpp:121:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:152:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:152:23: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:166:15: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:166:24: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:166:33: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:215:12: warning: use of old-style cast to 'float' [-Wold-style-cast]
random.cpp:217:7: warning: declaration of 'x' shadows a previous local
[-Wshadow]
random.cpp:75:6: note: shadowed declaration is here
random.cpp:217:22: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:218:7: warning: declaration of 'y' shadows a previous local
[-Wshadow]
random.cpp:76:6: note: shadowed declaration is here
random.cpp:218:22: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:219:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:220:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:221:28: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:222:28: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:223:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:224:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:234:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:235:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:236:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:238:28: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:239:28: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:245:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:246:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:247:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:262:12: warning: use of old-style cast to 'float' [-Wold-style-cast]
random.cpp:264:7: warning: declaration of 'x' shadows a previous local
[-Wshadow]
random.cpp:75:6: note: shadowed declaration is here
random.cpp:264:22: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:265:7: warning: declaration of 'y' shadows a previous local
[-Wshadow]
random.cpp:76:6: note: shadowed declaration is here
random.cpp:265:22: warning: use of old-style cast to 'int' [-Wold-style-cast]
random.cpp:266:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:267:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:268:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:269:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:280:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:281:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:282:14: warning: conversion from 'int' to 'float' may change value
[-Wconversion]
random.cpp:284:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:285:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
random.cpp:286:14: warning: conversion from 'double' to 'float' may change
value [-Wfloat-conversion]
In file included from /usr/include/math.h:382,
                 from
/usr/lib/gcc/m68k-linux-gnu/4.1.2/../../../../include/c++/4.1.2/cmath:53,
                 from random.cpp:33:
In function 'double __floor(double)',
    inlined from 'double floor(double)' at
/usr/include/bits/mathinline.h:399:87,
    inlined from 'float Random::operator()(int, int, float, float, float)
const' at random.cpp:75:18:
/usr/include/bits/mathinline.h:243:255: error: output constraint 0 must specify
a single register
In function 'double __floor(double)',
    inlined from 'double floor(double)' at
/usr/include/bits/mathinline.h:399:87,
    inlined from 'float Random::operator()(int, int, float, float, float)
const' at random.cpp:76:18:
/usr/include/bits/mathinline.h:243:255: error: output constraint 0 must specify
a single register
In function 'double __floor(double)',
    inlined from 'double floor(double)' at
/usr/include/bits/mathinline.h:399:87,
    inlined from 'float Random::operator()(int, int, float, float, float)
const' at random.cpp:77:18:
/usr/include/bits/mathinline.h:243:255: error: output constraint 0 must specify
a single register
In function 'double cos(double)',
    inlined from 'float Random::operator()(int, int, float, float, float)
const' at random.cpp:238:14:
/usr/include/bits/mathinline.h:185:87: error: output constraint 0 must specify
a single register
In function 'double cos(double)',
    inlined from 'float Random::operator()(int, int, float, float, float)
const' at random.cpp:239:14:
/usr/include/bits/mathinline.h:185:87: error: output constraint 0 must specify
a single register
during RTL pass: stack
random.cpp: In member function 'float Random::operator()(int, int, float,
float, float) const':
random.cpp:304:1: internal compiler error: in change_stack, at
reg-stack.cc:2732
0x26e78a5 diagnostic_context::diagnostic_impl(rich_location*,
diagnostic_metadata const*, int, char const*, __va_list_tag (*) [1],
diagnostic_t)
        ???:0
0x26f54b5 internal_error(char const*, ...)
        ???:0
0xa67980 fancy_abort(char const*, int, char const*)
        ???:0
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.
Compiler returned: 1

*******************************************************************************

Also ICE on trunk, compiler explorer:https://godbolt.org/z/Y338qh9KP

*******************************************************************************
  • [Bug c++/115956] New: ICE: i... iamanonymous.cs at gmail dot com via Gcc-bugs

Reply via email to