aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorThomas Schwinge <tschwinge@baylibre.com>2024-07-22 10:49:16 +0200
committerThomas Schwinge <tschwinge@baylibre.com>2024-09-04 14:06:34 +0200
commitfee2fbedbb43ad7a017a33ed2b820be79b75e7e5 (patch)
treec7a07f50ea967edf187c736d6e6c83e51899337e /gcc
parent35e4414bac06927387fb7a6fe10b373e766da1c1 (diff)
downloadgcc-fee2fbedbb43ad7a017a33ed2b820be79b75e7e5.zip
gcc-fee2fbedbb43ad7a017a33ed2b820be79b75e7e5.tar.gz
gcc-fee2fbedbb43ad7a017a33ed2b820be79b75e7e5.tar.bz2
nvptx: Use 'enum ptx_version', 'enum ptx_isa' instead of 'int'
This allows getting rid of the respective type casts. No change in behavior intended. gcc/ * config/nvptx/gen-opt.sh: Use 'enum ptx_isa' instead of 'int'. * config/nvptx/nvptx-gen.opt: Regenerate. * config/nvptx/nvptx.opt: Use 'enum ptx_version' instead of 'int'. * config/nvptx/nvptx-opts.h (enum ptx_isa): Add 'PTX_ISA_unset'. (enum ptx_version): Add 'PTX_VERSION_unset'. * config/nvptx/nvptx-c.cc (nvptx_cpu_cpp_builtins): Adjust. * config/nvptx/nvptx.cc (default_ptx_version_option) (handle_ptx_version_option, nvptx_option_override) (nvptx_file_start): Likewise.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/config/nvptx/gen-opt.sh14
-rw-r--r--gcc/config/nvptx/nvptx-c.cc6
-rw-r--r--gcc/config/nvptx/nvptx-gen.opt2
-rw-r--r--gcc/config/nvptx/nvptx-opts.h4
-rw-r--r--gcc/config/nvptx/nvptx.cc24
-rw-r--r--gcc/config/nvptx/nvptx.opt9
6 files changed, 37 insertions, 22 deletions
diff --git a/gcc/config/nvptx/gen-opt.sh b/gcc/config/nvptx/gen-opt.sh
index 3f78382..6022f51 100644
--- a/gcc/config/nvptx/gen-opt.sh
+++ b/gcc/config/nvptx/gen-opt.sh
@@ -38,12 +38,24 @@ echo
. $gen_copyright_sh opt
+# Not emitting the following here (in addition to having it in 'nvptx.opt'), as
+# we'll otherwise run into:
+#
+# gtyp-input.list:10: file [...]/gcc/config/nvptx/nvptx-opts.h specified more than once for language (all)
+# make[2]: *** [Makefile:2981: s-gtype] Error 1
+: ||
+cat <<EOF
+
+HeaderInclude
+config/nvptx/nvptx-opts.h
+EOF
+
# Separator.
echo
cat <<EOF
Enum
-Name(ptx_isa) Type(int)
+Name(ptx_isa) Type(enum ptx_isa)
Known PTX ISA target architectures (for use with the -misa= option):
EOF
diff --git a/gcc/config/nvptx/nvptx-c.cc b/gcc/config/nvptx/nvptx-c.cc
index 8538952..516ce90 100644
--- a/gcc/config/nvptx/nvptx-c.cc
+++ b/gcc/config/nvptx/nvptx-c.cc
@@ -51,10 +51,8 @@ nvptx_cpu_cpp_builtins (void)
cpp_define (parse_in, ptx_sm);
{
- unsigned major
- = ptx_version_to_number ((ptx_version)ptx_version_option, true);
- unsigned minor
- = ptx_version_to_number ((ptx_version)ptx_version_option, false);
+ unsigned major = ptx_version_to_number (ptx_version_option, true);
+ unsigned minor = ptx_version_to_number (ptx_version_option, false);
cpp_define_formatted (parse_in, "__PTX_ISA_VERSION_MAJOR__=%u", major);
cpp_define_formatted (parse_in, "__PTX_ISA_VERSION_MINOR__=%u", minor);
}
diff --git a/gcc/config/nvptx/nvptx-gen.opt b/gcc/config/nvptx/nvptx-gen.opt
index b097caf..84b70d6 100644
--- a/gcc/config/nvptx/nvptx-gen.opt
+++ b/gcc/config/nvptx/nvptx-gen.opt
@@ -20,7 +20,7 @@
; <http://www.gnu.org/licenses/>.
Enum
-Name(ptx_isa) Type(int)
+Name(ptx_isa) Type(enum ptx_isa)
Known PTX ISA target architectures (for use with the -misa= option):
EnumValue
diff --git a/gcc/config/nvptx/nvptx-opts.h b/gcc/config/nvptx/nvptx-opts.h
index f897532..fb5147c 100644
--- a/gcc/config/nvptx/nvptx-opts.h
+++ b/gcc/config/nvptx/nvptx-opts.h
@@ -22,6 +22,7 @@
enum ptx_isa
{
+ PTX_ISA_unset,
#define NVPTX_SM(XX, SEP) PTX_ISA_SM ## XX SEP
#define NVPTX_SM_SEP ,
#include "nvptx-sm.def"
@@ -31,7 +32,8 @@ enum ptx_isa
enum ptx_version
{
- PTX_VERSION_default,
+ PTX_VERSION_unset,
+ PTX_VERSION_default = PTX_VERSION_unset,
PTX_VERSION_3_0,
PTX_VERSION_3_1,
PTX_VERSION_4_2,
diff --git a/gcc/config/nvptx/nvptx.cc b/gcc/config/nvptx/nvptx.cc
index 2a8f713..144b8d0 100644
--- a/gcc/config/nvptx/nvptx.cc
+++ b/gcc/config/nvptx/nvptx.cc
@@ -231,8 +231,7 @@ first_ptx_version_supporting_sm (enum ptx_isa sm)
static enum ptx_version
default_ptx_version_option (void)
{
- enum ptx_version first
- = first_ptx_version_supporting_sm ((enum ptx_isa) ptx_isa_option);
+ enum ptx_version first = first_ptx_version_supporting_sm (ptx_isa_option);
/* Pick a version that supports the sm. */
enum ptx_version res = first;
@@ -311,20 +310,21 @@ sm_version_to_string (enum ptx_isa sm)
static void
handle_ptx_version_option (void)
{
- if (!OPTION_SET_P (ptx_version_option)
- || ptx_version_option == PTX_VERSION_default)
+ if (!OPTION_SET_P (ptx_version_option))
+ gcc_checking_assert (ptx_version_option == PTX_VERSION_default);
+
+ if (ptx_version_option == PTX_VERSION_default)
{
ptx_version_option = default_ptx_version_option ();
return;
}
- enum ptx_version first
- = first_ptx_version_supporting_sm ((enum ptx_isa) ptx_isa_option);
+ enum ptx_version first = first_ptx_version_supporting_sm (ptx_isa_option);
if (ptx_version_option < first)
error ("PTX version (%<-mptx%>) needs to be at least %s to support selected"
" %<-misa%> (sm_%s)", ptx_version_to_string (first),
- sm_version_to_string ((enum ptx_isa)ptx_isa_option));
+ sm_version_to_string (ptx_isa_option));
}
/* Implement TARGET_OPTION_OVERRIDE. */
@@ -336,7 +336,9 @@ nvptx_option_override (void)
/* Via nvptx 'OPTION_DEFAULT_SPECS', '-misa' always appears on the command
line; but handle the case that the compiler is not run via the driver. */
- if (!OPTION_SET_P (ptx_isa_option))
+ gcc_checking_assert ((ptx_isa_option == PTX_ISA_unset)
+ == (!OPTION_SET_P (ptx_isa_option)));
+ if (ptx_isa_option == PTX_ISA_unset)
fatal_error (UNKNOWN_LOCATION, "%<-march=%> must be specified");
handle_ptx_version_option ();
@@ -5953,13 +5955,11 @@ nvptx_file_start (void)
fputs ("// BEGIN PREAMBLE\n", asm_out_file);
fputs ("\t.version\t", asm_out_file);
- fputs (ptx_version_to_string ((enum ptx_version)ptx_version_option),
- asm_out_file);
+ fputs (ptx_version_to_string (ptx_version_option), asm_out_file);
fputs ("\n", asm_out_file);
fputs ("\t.target\tsm_", asm_out_file);
- fputs (sm_version_to_string ((enum ptx_isa)ptx_isa_option),
- asm_out_file);
+ fputs (sm_version_to_string (ptx_isa_option), asm_out_file);
fputs ("\n", asm_out_file);
fprintf (asm_out_file, "\t.address_size %d\n", GET_MODE_BITSIZE (Pmode));
diff --git a/gcc/config/nvptx/nvptx.opt b/gcc/config/nvptx/nvptx.opt
index deb0066..c040740 100644
--- a/gcc/config/nvptx/nvptx.opt
+++ b/gcc/config/nvptx/nvptx.opt
@@ -17,6 +17,9 @@
; along with GCC; see the file COPYING3. If not see
; <http://www.gnu.org/licenses/>.
+HeaderInclude
+config/nvptx/nvptx-opts.h
+
; It's not clear whether this was ever build/tested/used, so this is no longer
; exposed to the user.
;m32
@@ -53,7 +56,7 @@ Target Mask(GOMP)
Generate code for OpenMP offloading: enables -msoft-stack and -muniform-simt.
misa=
-Target RejectNegative ToLower Joined Enum(ptx_isa) Var(ptx_isa_option)
+Target RejectNegative ToLower Joined Enum(ptx_isa) Var(ptx_isa_option) Init(PTX_ISA_unset)
Specify the PTX ISA target architecture to use.
march=
@@ -118,7 +121,7 @@ march-map=sm_90a
Target RejectNegative Alias(misa=,sm_80)
Enum
-Name(ptx_version) Type(int)
+Name(ptx_version) Type(enum ptx_version)
Known PTX ISA versions (for use with the -mptx= option):
EnumValue
@@ -137,7 +140,7 @@ EnumValue
Enum(ptx_version) String(_) Value(PTX_VERSION_default)
mptx=
-Target RejectNegative ToLower Joined Enum(ptx_version) Var(ptx_version_option)
+Target RejectNegative ToLower Joined Enum(ptx_version) Var(ptx_version_option) Init(PTX_VERSION_unset)
Specify the PTX ISA version to use.
minit-regs=