From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mout.gmx.net (mout.gmx.net [212.227.17.22]) by sourceware.org (Postfix) with ESMTPS id EE1B43858D28; Sat, 18 Dec 2021 22:25:52 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.1 sourceware.org EE1B43858D28 X-UI-Sender-Class: 01bb95c1-4bf8-414a-932a-4f6e2808ef9c Received: from [79.251.12.94] ([79.251.12.94]) by web-mail.gmx.net (3c-app-gmx-bap25.server.lan [172.19.172.95]) (via HTTP); Sat, 18 Dec 2021 23:25:51 +0100 MIME-Version: 1.0 Message-ID: From: Harald Anlauf To: fortran , gcc-patches Subject: [PATCH, committed] PR fortran/103412 - [10/11/12 Regression] ICE: Invalid expression in gfc_element_size since r10-2083-g8dc63166e0b85954 Content-Type: multipart/mixed; boundary=sgnirk-a577183f-3d4c-4b8e-9a0e-29e033f0a12f Date: Sat, 18 Dec 2021 23:25:51 +0100 Importance: normal Sensitivity: Normal X-Priority: 3 X-Provags-ID: V03:K1:3sMAPBdtqfEXOE0A5fOw1xdXsLo1JePIBBycgeatxIXsYWii/+MbCn6PbrOlhpLaAo6u3 IrKoyvvsQcI6auQiG5brg1Bmstxa/uSUGh4O6K+pHTBF/RXNyjP7VeDQ3ulI0xSyCeZaW+TRt7y9 w5Gg12CfOWe3y7pFzI7p96ePwgsPePWnh+ROjbYhdSGjbrr0U0oDg7N9I/F3S/pujkdvnFULPxcT QU8a/HoeOnGHo7vHptz3w6stqPyWCwwHn+UAFYB3Ob//zccIxEyZMN4Bb/Ks06aU7r/JpbOJC3L9 TE= X-UI-Out-Filterresults: notjunk:1;V03:K0:8Am+PVvFFdM=:163R6S268bECXIzuiABiTD 5KrRy/q92RNEz3miZ32APixI0gc+Eleh/fpJx4dhirVHT5p5P04h0URQqrwJ7ev3Z0qnrZZp3 Oo2v40OZMTZIbqeoXzJkHeVgxPsxvreabLuj8/2vYLBTYySYlp0yqa85R+J+Ewh9IU5/pPaC5 4i6E3DTgZ6lwcDjJLG1bwH/7d5UBYPLgXHeWNKGv1vbdHP0W3JgUGpum8dKwEXqkjVWQl2XVu 7nasrDZ3ow07AwbZF41IKyD3Ti2WWfR5AHgKLQSYE/Ak5Y+MU7c1rufyq2vxlsy1HSLDJfavJ CY3Y53b99AFIrC50t0hQdcpxVoeJiYMYsjb/bRghtVQoc4BBtELcmUa/S0h9x9gD2RnCIqBpH 1wyvXWborR9ez2xDbm1flnmoIRI01tRbZsUI8NWuNvTvhtVbPkckUkLUt9/xEuOIxR7hXmi5y yVtAKM2zyKgauPwtLvrw2Pgwp/QGOeUj+h/i9PvEr60pHU8VCbuA2DwcLC6ASyRfUOpW2sUUa EM2dhqvDW9oUYXkteSNToYSsvRPpA+iozBgdPLZZPPEKCiU9pb106oheAaORxCkQR7qnUzuyG KIsr13+Ta4nXDrTtd9YTZRnhI3vGLKVOvxuYewsKXKBCnjyXt0UjWfe+Ix2++QtNDA8BawCdg a9lqmhHNLuw1lm1jPlY4v5SMToAnfBhoEgZtsN46i2WTklRIgqFvSeQsixvGGdTZMlxYQCy35 B7W3gPIei5IEoHWXZXfKMMVcQJUsvlbGEZYAVj/EB+1HH+R8LnDlp0RRABgG2kfaZao+RbZKA qulJmH3 X-Spam-Status: No, score=-11.5 required=5.0 tests=BAYES_00, DKIM_SIGNED, DKIM_VALID, FREEMAIL_FROM, GIT_PATCH_0, KAM_NUMSUBJECT, RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2, SPF_HELO_NONE, SPF_PASS, TXREP autolearn=ham autolearn_force=no version=3.4.4 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on server2.sourceware.org X-BeenThere: fortran@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Fortran mailing list List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 18 Dec 2021 22:25:54 -0000 --sgnirk-a577183f-3d4c-4b8e-9a0e-29e033f0a12f Content-Type: text/plain; charset=UTF-8 Dear all, committed as obvious after discussion with Steve: SIZEOF() cannot accept a BOZ argument which has no defined type. Regtested on x86_64-pc-linux-gnu. Thanks, Harald --sgnirk-a577183f-3d4c-4b8e-9a0e-29e033f0a12f Content-Type: text/x-patch Content-Disposition: attachment; filename=0001-Fortran-reject-BOZ-type-argument-to-SIZEOF.patch Content-Transfer-Encoding: quoted-printable =46rom fd74a2ee40456a1d1621e88738f8e57536194080 Mon Sep 17 00:00:00 2001 From: Harald Anlauf Date: Sat, 18 Dec 2021 23:21:35 +0100 Subject: [PATCH] Fortran: reject BOZ type argument to SIZEOF(). gcc/fortran/ChangeLog: PR fortran/103412 * check.c (gfc_check_sizeof): Reject BOZ type argument. gcc/testsuite/ChangeLog: PR fortran/103412 * gfortran.dg/illegal_boz_arg_2.f90: New test. =2D-- gcc/fortran/check.c | 3 +++ gcc/testsuite/gfortran.dg/illegal_boz_arg_2.f90 | 6 ++++++ 2 files changed, 9 insertions(+) create mode 100644 gcc/testsuite/gfortran.dg/illegal_boz_arg_2.f90 diff --git a/gcc/fortran/check.c b/gcc/fortran/check.c index 3934336df2e..625473c90d1 100644 =2D-- a/gcc/fortran/check.c +++ b/gcc/fortran/check.c @@ -5135,6 +5135,9 @@ gfc_check_sizeof (gfc_expr *arg) return false; } + if (illegal_boz_arg (arg)) + return false; + /* TYPE(*) is acceptable if and only if it uses an array descriptor. *= / if (arg->ts.type =3D=3D BT_ASSUMED && (arg->symtree->n.sym->as =3D=3D NULL diff --git a/gcc/testsuite/gfortran.dg/illegal_boz_arg_2.f90 b/gcc/testsui= te/gfortran.dg/illegal_boz_arg_2.f90 new file mode 100644 index 00000000000..3e5f6b6d1d4 =2D-- /dev/null +++ b/gcc/testsuite/gfortran.dg/illegal_boz_arg_2.f90 @@ -0,0 +1,6 @@ +! { dg-do compile } +! PR fortran/103412 + +program p + integer, parameter :: a =3D sizeof(z'1') ! { dg-error "cannot be an act= ual" } +end =2D- 2.26.2 --sgnirk-a577183f-3d4c-4b8e-9a0e-29e033f0a12f--