]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
GCN: Enable effective-target 'vect_early_break', 'vect_early_break_hw'
authorThomas Schwinge <thomas@codesourcery.com>
Tue, 9 Jan 2024 09:25:48 +0000 (10:25 +0100)
committerThomas Schwinge <tschwinge@baylibre.com>
Fri, 29 Mar 2024 10:16:59 +0000 (11:16 +0100)
Via XPASSing test cases after commit a657c7e3518fcfc796f223d47385cad5e97dc9a5
"testsuite: un-xfail TSVC loops that check for exit control flow vectorization":

    PASS: gcc.dg/vect/tsvc/vect-tsvc-s332.c (test for excess errors)
    PASS: gcc.dg/vect/tsvc/vect-tsvc-s332.c execution test
    [-XFAIL:-]{+XPASS:+} gcc.dg/vect/tsvc/vect-tsvc-s332.c scan-tree-dump vect "vectorized 1 loops"

    PASS: gcc.dg/vect/tsvc/vect-tsvc-s481.c (test for excess errors)
    PASS: gcc.dg/vect/tsvc/vect-tsvc-s481.c execution test
    [-XFAIL:-]{+XPASS:+} gcc.dg/vect/tsvc/vect-tsvc-s481.c scan-tree-dump vect "vectorized 1 loops"

    PASS: gcc.dg/vect/tsvc/vect-tsvc-s482.c (test for excess errors)
    PASS: gcc.dg/vect/tsvc/vect-tsvc-s482.c execution test
    [-XFAIL:-]{+XPASS:+} gcc.dg/vect/tsvc/vect-tsvc-s482.c scan-tree-dump vect "vectorized 1 loops"

..., it became apparent that GCN, too, does support vectorization of loops with
early breaks.  The relevant test cases are all-PASS with just the following
exceptions, to be looked into individually, later on:

    PASS: gcc.dg/vect/vect-early-break_25.c (test for excess errors)
    PASS: gcc.dg/vect/vect-early-break_25.c scan-tree-dump-times vect "vectorized 1 loops" 1
    FAIL: gcc.dg/vect/vect-early-break_25.c scan-tree-dump-times vect "Alignment of access forced using peeling" 1

    PASS: gcc.dg/vect/vect-early-break_56.c (test for excess errors)
    PASS: gcc.dg/vect/vect-early-break_56.c execution test
    XPASS: gcc.dg/vect/vect-early-break_56.c scan-tree-dump-times vect "vectorized 2 loops" 2

gcc/testsuite/
* lib/target-supports.exp
(check_effective_target_vect_early_break)
(check_effective_target_vect_early_break_hw): Enable for GCN.

gcc/testsuite/lib/target-supports.exp

index 843515f69d7857b4b44724576ce2f608e077bf7a..9b3bf57d86d1e67f144328aa07f473891710cf64 100644 (file)
@@ -4104,6 +4104,7 @@ proc check_effective_target_vect_early_break { } {
        [istarget aarch64*-*-*]
        || [check_effective_target_arm_v8_neon_ok]
        || [check_effective_target_sse4]
+       || [istarget amdgcn-*-*]
        }}]
 }
 
@@ -4118,6 +4119,7 @@ proc check_effective_target_vect_early_break_hw { } {
        [istarget aarch64*-*-*]
        || [check_effective_target_arm_v8_neon_hw]
        || [check_sse4_hw_available]
+       || [istarget amdgcn-*-*]
        }}]
 }