On 9/29/2021 2:08 AM, Andrew Pinski wrote:
On Wed, Sep 29, 2021 at 1:06 AM Jakub Jelinek via Gcc-patches
<gcc-patches@gcc.gnu.org> wrote:
On Mon, Sep 20, 2021 at 09:41:03AM -0600, Jeff Law via Gcc-patches wrote:

On 9/19/2021 10:14 PM, apinski--- via Gcc-patches wrote:
From: Andrew Pinski <apin...@marvell.com>

So GCC has always accepted non-pointer types in computed gotos but
that was wrong based on the documentation:
Any expression of type void * is allowed.

So this fixes the problem by requiring the type to
be a pointer type.

OK? Bootstrapped and tested on x86_64-linux-gnu with no regressions.

     PR c/32122

gcc/c/ChangeLog:

     * c-parser.c (c_parser_statement_after_labels): Pass
     the c_expr instead of the tree to c_finish_goto_ptr.
     * c-typeck.c (c_finish_goto_ptr): Change the second
     argument type to c_expr.
     * c-tree.h (c_finish_goto_ptr): Likewise.
     Error out if the expression was not of a pointer type.

gcc/testsuite/ChangeLog:

     * gcc.dg/comp-goto-5.c: New test.
     * gcc.dg/comp-goto-6.c: New test.
OK
This change regressed:
+FAIL: gcc.c-torture/compile/920826-1.c   -O0  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -O1  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -O2  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -O3 -g  (test for excess errors)
+FAIL: gcc.c-torture/compile/920826-1.c   -Os  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O0  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O1  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O2  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -O3 -g  (test for excess errors)
+FAIL: gcc.c-torture/compile/920831-1.c   -Os  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O0  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O1  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O2  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -O3 -g  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr27863.c   -Os  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O0  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O1  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O2  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -O3 -g  (test for excess errors)
+FAIL: gcc.c-torture/compile/pr70190.c   -Os  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O0  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O1  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O2  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O3 -fomit-frame-pointer -funroll-loops 
-fpeel-loops -ftracer -finline-functions  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -O3 -g  (test for excess errors)
+FAIL: gcc.dg/torture/pr89135.c   -Os  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O0  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O1  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O2  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O2 -flto -fno-use-linker-plugin 
-flto-partition=none  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O2 -flto -fuse-linker-plugin 
-fno-fat-lto-objects  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O3 -fomit-frame-pointer -funroll-loops 
-fpeel-loops -ftracer -finline-functions  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -O3 -g  (test for excess errors)
+FAIL: gcc.dg/torture/pr90071.c   -Os  (test for excess errors)
on both x86_64-linux and i686-linux.
I literally just pushed the testsuite fixes for this.
THanks.  I wasn't looking forward to dealing with this on top of the threader stuff :-)

jeff

Reply via email to