annotate gcc/testsuite/g++.target/aarch64/sve2/acle/aarch64-sve2-acle-asm.exp @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 # Assembly-based regression-test driver for the SVE ACLE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 # Copyright (C) 2009-2020 Free Software Foundation, Inc.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 #
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 # This file is part of GCC.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 #
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 # GCC is free software; you can redistribute it and/or modify it
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 # under the terms of the GNU General Public License as published by
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 # the Free Software Foundation; either version 3, or (at your option)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 # any later version.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 #
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 # GCC is distributed in the hope that it will be useful, but
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 # WITHOUT ANY WARRANTY; without even the implied warranty of
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 # General Public License for more details.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 #
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 # You should have received a copy of the GNU General Public License
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 # along with GCC; see the file COPYING3. If not see
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 # <http://www.gnu.org/licenses/>. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 # GCC testsuite that uses the `dg.exp' driver.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 # Exit immediately if this isn't an AArch64 target.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 if { ![istarget aarch64*-*-*] } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 return
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 # Load support procs.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 load_lib g++-dg.exp
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 # Initialize `dg'.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 dg-init
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 # Force SVE if we're not testing it already.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 if { [check_effective_target_aarch64_sve2] } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 set sve2_flags ""
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 } else {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 set sve2_flags "-march=armv8.5-a+sve2"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 set gcc_subdir [string replace $subdir 0 2 gcc]
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 lappend extra_flags "-fno-ipa-icf" "-I$srcdir/$gcc_subdir/../../sve/acle/asm"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 global gcc_runtest_parallelize_limit_minor
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 if { [info exists gcc_runtest_parallelize_limit_minor] } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 set old_limit_minor $gcc_runtest_parallelize_limit_minor
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 set gcc_runtest_parallelize_limit_minor 1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 torture-init
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 set-torture-options {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 "-std=c++98 -O0 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 "-std=c++98 -O1 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 "-std=c++11 -O2 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 "-std=c++14 -O3 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 "-std=c++17 -Og -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 "-std=c++2a -Os -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 "-std=gnu++98 -O2 -fno-schedule-insns -DCHECK_ASM --save-temps"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 "-std=gnu++11 -Ofast -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 "-std=gnu++17 -O3 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 "-std=gnu++2a -O0 -g"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 "-DTEST_FULL"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 "-DTEST_OVERLOADS"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66 # Main loop.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 set files [glob -nocomplain $srcdir/$gcc_subdir/asm/*.c]
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 set save-dg-do-what-default ${dg-do-what-default}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 if { [check_effective_target_aarch64_asm_sve_ok]
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 && [check_effective_target_aarch64_variant_pcs] } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 set dg-do-what-default assemble
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 } else {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 set dg-do-what-default compile
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 gcc-dg-runtest [lsort $files] "" "$sve2_flags $extra_flags"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 set dg-do-what-default ${save-dg-do-what-default}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 torture-finish
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 if { [info exists gcc_runtest_parallelize_limit_minor] } {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81 set gcc_runtest_parallelize_limit_minor $old_limit_minor
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 # All done.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 dg-finish