public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
@ 2024-04-11 17:37 zsojka at seznam dot cz
  2024-04-12 11:46 ` [Bug target/114696] " hjl.tools at gmail dot com
                   ` (4 more replies)
  0 siblings, 5 replies; 6+ messages in thread
From: zsojka at seznam dot cz @ 2024-04-11 17:37 UTC (permalink / raw)
  To: gcc-bugs

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

            Bug ID: 114696
           Summary: ICE: in extract_constrain_insn_cached, at
                    recog.cc:2725 insn does not satisfy its constraints:
                    {*anddi_1} with -mapxf -mx32
           Product: gcc
           Version: 14.0
            Status: UNCONFIRMED
          Keywords: ice-on-valid-code
          Severity: normal
          Priority: P3
         Component: target
          Assignee: unassigned at gcc dot gnu.org
          Reporter: zsojka at seznam dot cz
  Target Milestone: ---
              Host: x86_64-pc-linux-gnu
            Target: x86_64-pc-linux-gnu

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

Compiler output:
$ x86_64-pc-linux-gnu-gcc -mapxf -mx32 testcase.c 
testcase.c: In function 'foo':
testcase.c:8:1: error: insn does not satisfy its constraints:
    8 | }
      | ^
(insn 43 42 44 2 (parallel [
            (set (reg:DI 1 dx [+8 ])
                (and:DI (mem/c:DI (plus:SI (reg:SI 4 si [110])
                            (const_int 8 [0x8])) [1 a+8 S8 A64 AS1])
                    (const_int 1 [0x1])))
            (clobber (reg:CC 17 flags))
        ]) "testcase.c":7:7 613 {*anddi_1}
     (nil))
during RTL pass: shorten
testcase.c:8:1: internal compiler error: in extract_constrain_insn_cached, at
recog.cc:2725
0x808789 _fatal_insn(char const*, rtx_def const*, char const*, int, char
const*)
        /repo/gcc-trunk/gcc/rtl-error.cc:108
0x808810 _fatal_insn_not_found(rtx_def const*, char const*, int, char const*)
        /repo/gcc-trunk/gcc/rtl-error.cc:118
0x7f8fbf extract_constrain_insn_cached(rtx_insn*)
        /repo/gcc-trunk/gcc/recog.cc:2725
0x1dce737 get_attr_modrm(rtx_insn*)
        /repo/gcc-trunk/gcc/config/i386/i386.md:759
0x1dd2bb7 insn_default_length(rtx_insn*)
        /repo/gcc-trunk/gcc/config/i386/i386.md:785
0x10e00ee shorten_branches(rtx_insn*)
        /repo/gcc-trunk/gcc/final.cc:1089
0x10e022f rest_of_handle_shorten_branches
        /repo/gcc-trunk/gcc/final.cc:4335
0x10e022f execute
        /repo/gcc-trunk/gcc/final.cc:4364
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.


$ x86_64-pc-linux-gnu-gcc -v
Using built-in specs.
COLLECT_GCC=/repo/gcc-trunk/binary-latest-amd64/bin/x86_64-pc-linux-gnu-gcc
COLLECT_LTO_WRAPPER=/repo/gcc-trunk/binary-trunk-r14-9911-20240411110356-g52b63100b1e-checking-yes-rtl-df-extra-nobootstrap-amd64/bin/../libexec/gcc/x86_64-pc-linux-gnu/14.0.1/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: /repo/gcc-trunk//configure --enable-languages=c,c++
--enable-valgrind-annotations --disable-nls --enable-checking=yes,rtl,df,extra
--disable-bootstrap --with-cloog --with-ppl --with-isl
--build=x86_64-pc-linux-gnu --host=x86_64-pc-linux-gnu
--target=x86_64-pc-linux-gnu --with-ld=/usr/bin/x86_64-pc-linux-gnu-ld
--with-as=/usr/bin/x86_64-pc-linux-gnu-as --enable-libsanitizer
--disable-libstdcxx-pch
--prefix=/repo/gcc-trunk//binary-trunk-r14-9911-20240411110356-g52b63100b1e-checking-yes-rtl-df-extra-nobootstrap-amd64
Thread model: posix
Supported LTO compression algorithms: zlib zstd
gcc version 14.0.1 20240411 (experimental) (GCC)

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

* [Bug target/114696] ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
  2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
@ 2024-04-12 11:46 ` hjl.tools at gmail dot com
  2024-04-12 15:32 ` hjl.tools at gmail dot com
                   ` (3 subsequent siblings)
  4 siblings, 0 replies; 6+ messages in thread
From: hjl.tools at gmail dot com @ 2024-04-12 11:46 UTC (permalink / raw)
  To: gcc-bugs

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

H.J. Lu <hjl.tools at gmail dot com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
     Ever confirmed|0                           |1
   Last reconfirmed|                            |2024-04-12
             Status|UNCONFIRMED                 |NEW

--- Comment #1 from H.J. Lu <hjl.tools at gmail dot com> ---
The problem is that the APX encoding length for AND exceeds 15 bytes with
-mx32.

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

* [Bug target/114696] ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
  2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
  2024-04-12 11:46 ` [Bug target/114696] " hjl.tools at gmail dot com
@ 2024-04-12 15:32 ` hjl.tools at gmail dot com
  2024-04-12 22:44 ` hjl.tools at gmail dot com
                   ` (2 subsequent siblings)
  4 siblings, 0 replies; 6+ messages in thread
From: hjl.tools at gmail dot com @ 2024-04-12 15:32 UTC (permalink / raw)
  To: gcc-bugs

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

H.J. Lu <hjl.tools at gmail dot com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
           Assignee|unassigned at gcc dot gnu.org      |hjl.tools at gmail dot com

--- Comment #2 from H.J. Lu <hjl.tools at gmail dot com> ---
Created attachment 57934
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=57934&action=edit
A patch

I am testing this.

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

* [Bug target/114696] ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
  2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
  2024-04-12 11:46 ` [Bug target/114696] " hjl.tools at gmail dot com
  2024-04-12 15:32 ` hjl.tools at gmail dot com
@ 2024-04-12 22:44 ` hjl.tools at gmail dot com
  2024-04-15 11:21 ` cvs-commit at gcc dot gnu.org
  2024-04-15 11:30 ` hjl.tools at gmail dot com
  4 siblings, 0 replies; 6+ messages in thread
From: hjl.tools at gmail dot com @ 2024-04-12 22:44 UTC (permalink / raw)
  To: gcc-bugs

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

H.J. Lu <hjl.tools at gmail dot com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
   Target Milestone|---                         |14.0

--- Comment #3 from H.J. Lu <hjl.tools at gmail dot com> ---
A patch is posted at

https://patchwork.sourceware.org/project/gcc/list/?series=32811

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

* [Bug target/114696] ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
  2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
                   ` (2 preceding siblings ...)
  2024-04-12 22:44 ` hjl.tools at gmail dot com
@ 2024-04-15 11:21 ` cvs-commit at gcc dot gnu.org
  2024-04-15 11:30 ` hjl.tools at gmail dot com
  4 siblings, 0 replies; 6+ messages in thread
From: cvs-commit at gcc dot gnu.org @ 2024-04-15 11:21 UTC (permalink / raw)
  To: gcc-bugs

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

--- Comment #4 from GCC Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by H.J. Lu <hjl@gcc.gnu.org>:

https://gcc.gnu.org/g:a3281dd0f4b46c16ec1192ad411c0a96e6d086eb

commit r14-9970-ga3281dd0f4b46c16ec1192ad411c0a96e6d086eb
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Fri Apr 12 15:42:12 2024 -0700

    x86: Allow TImode offsettable memory only with 8-bit constant

    The x86 instruction size limit is 15 bytes.  If a NDD instruction has
    a segment prefix byte, a 4-byte opcode prefix, a MODRM byte, a SIB byte,
    a 4-byte displacement and a 4-byte immediate, adding an address size
    prefix will exceed the size limit.  Change TImode ADD, AND, OR and XOR
    to allow offsettable memory only with 8-bit signed integer constant,
    which is encoded with a 1-byte immediate, if the address size prefix
    is used.

    gcc/

            PR target/114696
            * config/i386/i386.md (isa): Add apx_ndd_64.
            (enabled): Likewise.
            (*add<dwi>3_doubleword): Change rjO to r,ro,jO with 8-bit
            signed integer constant and enable jO only for apx_ndd_64.
            (*add<dwi>3_doubleword_cc_overflow_1): Likewise.
            (*and<dwi>3_doubleword): Likewise.
            (*<code><dwi>3_doubleword): Likewise.

    gcc/testsuite/

            PR target/114696
            * gcc.target/i386/apx-ndd-x32-2a.c: New test.
            * gcc.target/i386/apx-ndd-x32-2b.c: Likewise.
            * gcc.target/i386/apx-ndd-x32-2c.c: Likewise.
            * gcc.target/i386/apx-ndd-x32-2d.c: Likewise.

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

* [Bug target/114696] ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32
  2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
                   ` (3 preceding siblings ...)
  2024-04-15 11:21 ` cvs-commit at gcc dot gnu.org
@ 2024-04-15 11:30 ` hjl.tools at gmail dot com
  4 siblings, 0 replies; 6+ messages in thread
From: hjl.tools at gmail dot com @ 2024-04-15 11:30 UTC (permalink / raw)
  To: gcc-bugs

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

H.J. Lu <hjl.tools at gmail dot com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|NEW                         |RESOLVED
         Resolution|---                         |FIXED

--- Comment #5 from H.J. Lu <hjl.tools at gmail dot com> ---
Fixed.

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

end of thread, other threads:[~2024-04-15 11:30 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-04-11 17:37 [Bug target/114696] New: ICE: in extract_constrain_insn_cached, at recog.cc:2725 insn does not satisfy its constraints: {*anddi_1} with -mapxf -mx32 zsojka at seznam dot cz
2024-04-12 11:46 ` [Bug target/114696] " hjl.tools at gmail dot com
2024-04-12 15:32 ` hjl.tools at gmail dot com
2024-04-12 22:44 ` hjl.tools at gmail dot com
2024-04-15 11:21 ` cvs-commit at gcc dot gnu.org
2024-04-15 11:30 ` hjl.tools at gmail dot com

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