diff options
author | Richard Sandiford <richard.sandiford@arm.com> | 2019-11-14 14:55:12 +0000 |
---|---|---|
committer | Richard Sandiford <rsandifo@gcc.gnu.org> | 2019-11-14 14:55:12 +0000 |
commit | 10116ec1c147a76522cafba6b6a5b4ed1cb37b77 (patch) | |
tree | 776dc1f9e2372ad4300b7120c178f4dfc3c7121a /gcc/config | |
parent | e8738f4e9686203451fd11f05b268b8a31b95ebd (diff) | |
download | gcc-10116ec1c147a76522cafba6b6a5b4ed1cb37b77.zip gcc-10116ec1c147a76522cafba6b6a5b4ed1cb37b77.tar.gz gcc-10116ec1c147a76522cafba6b6a5b4ed1cb37b77.tar.bz2 |
Pass the data vector mode to get_mask_mode
This patch passes the data vector mode to get_mask_mode, rather than its
size and nunits. This is a bit simpler and allows targets to distinguish
between modes that happen to have the same size and number of elements.
2019-11-14 Richard Sandiford <richard.sandiford@arm.com>
gcc/
* target.def (get_mask_mode): Take a vector mode itself as argument,
instead of properties about the vector mode.
* doc/tm.texi: Regenerate.
* targhooks.h (default_get_mask_mode): Update to reflect new
get_mode_mask interface.
* targhooks.c (default_get_mask_mode): Likewise. Use
related_int_vector_mode.
* optabs-query.c (can_vec_mask_load_store_p): Update call
to get_mask_mode.
* tree-vect-stmts.c (check_load_store_masking): Likewise, checking
first that the original mode really is a vector.
* tree.c (build_truth_vector_type_for): Likewise.
* config/aarch64/aarch64.c (aarch64_get_mask_mode): Update for new
get_mode_mask interface.
(aarch64_expand_sve_vcond): Update call accordingly.
* config/gcn/gcn.c (gcn_vectorize_get_mask_mode): Update for new
get_mode_mask interface.
* config/i386/i386.c (ix86_get_mask_mode): Likewise.
From-SVN: r278233
Diffstat (limited to 'gcc/config')
-rw-r--r-- | gcc/config/aarch64/aarch64.c | 18 | ||||
-rw-r--r-- | gcc/config/gcn/gcn.c | 3 | ||||
-rw-r--r-- | gcc/config/i386/i386.c | 4 |
3 files changed, 10 insertions, 15 deletions
diff --git a/gcc/config/aarch64/aarch64.c b/gcc/config/aarch64/aarch64.c index b6c8d77..0870d2c 100644 --- a/gcc/config/aarch64/aarch64.c +++ b/gcc/config/aarch64/aarch64.c @@ -1776,17 +1776,13 @@ aarch64_sve_pred_mode (unsigned int elem_nbytes) /* Implement TARGET_VECTORIZE_GET_MASK_MODE. */ static opt_machine_mode -aarch64_get_mask_mode (poly_uint64 nunits, poly_uint64 nbytes) +aarch64_get_mask_mode (machine_mode mode) { - if (TARGET_SVE && known_eq (nbytes, BYTES_PER_SVE_VECTOR)) - { - unsigned int elem_nbytes = vector_element_size (nbytes, nunits); - machine_mode pred_mode; - if (aarch64_sve_pred_mode (elem_nbytes).exists (&pred_mode)) - return pred_mode; - } + unsigned int vec_flags = aarch64_classify_vector_mode (mode); + if (vec_flags & VEC_SVE_DATA) + return aarch64_sve_pred_mode (GET_MODE_UNIT_SIZE (mode)); - return default_get_mask_mode (nunits, nbytes); + return default_get_mask_mode (mode); } /* Return the SVE vector mode that has NUNITS elements of mode INNER_MODE. */ @@ -19434,9 +19430,7 @@ void aarch64_expand_sve_vcond (machine_mode data_mode, machine_mode cmp_mode, rtx *ops) { - machine_mode pred_mode - = aarch64_get_mask_mode (GET_MODE_NUNITS (cmp_mode), - GET_MODE_SIZE (cmp_mode)).require (); + machine_mode pred_mode = aarch64_get_mask_mode (cmp_mode).require (); rtx pred = gen_reg_rtx (pred_mode); if (FLOAT_MODE_P (cmp_mode)) { diff --git a/gcc/config/gcn/gcn.c b/gcc/config/gcn/gcn.c index 1a69737..20534a2 100644 --- a/gcc/config/gcn/gcn.c +++ b/gcc/config/gcn/gcn.c @@ -3816,8 +3816,7 @@ gcn_expand_builtin (tree exp, rtx target, rtx subtarget, machine_mode mode, a vector. */ opt_machine_mode -gcn_vectorize_get_mask_mode (poly_uint64 ARG_UNUSED (nunits), - poly_uint64 ARG_UNUSED (length)) +gcn_vectorize_get_mask_mode (machine_mode) { /* GCN uses a DImode bit-mask. */ return DImode; diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index ce446b2..69c8278 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -21419,8 +21419,10 @@ ix86_autovectorize_vector_sizes (vector_sizes *sizes, bool all) /* Implemenation of targetm.vectorize.get_mask_mode. */ static opt_machine_mode -ix86_get_mask_mode (poly_uint64 nunits, poly_uint64 vector_size) +ix86_get_mask_mode (machine_mode data_mode) { + unsigned vector_size = GET_MODE_SIZE (data_mode); + unsigned nunits = GET_MODE_NUNITS (data_mode); unsigned elem_size = vector_size / nunits; /* Scalar mask case. */ |