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/targhooks.c | |
parent | e8738f4e9686203451fd11f05b268b8a31b95ebd (diff) |
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/targhooks.c')
-rw-r--r-- | gcc/targhooks.c | 16 |
1 files changed, 2 insertions, 14 deletions
diff --git a/gcc/targhooks.c b/gcc/targhooks.c index dcecd81e54d..f6c7a0c8676 100644 --- a/gcc/targhooks.c +++ b/gcc/targhooks.c @@ -1328,21 +1328,9 @@ default_vectorize_related_mode (machine_mode vector_mode, /* By default a vector of integers is used as a mask. */ opt_machine_mode -default_get_mask_mode (poly_uint64 nunits, poly_uint64 vector_size) +default_get_mask_mode (machine_mode mode) { - unsigned int elem_size = vector_element_size (vector_size, nunits); - scalar_int_mode elem_mode - = smallest_int_mode_for_size (elem_size * BITS_PER_UNIT); - machine_mode vector_mode; - - gcc_assert (known_eq (elem_size * nunits, vector_size)); - - if (mode_for_vector (elem_mode, nunits).exists (&vector_mode) - && VECTOR_MODE_P (vector_mode) - && targetm.vector_mode_supported_p (vector_mode)) - return vector_mode; - - return opt_machine_mode (); + return related_int_vector_mode (mode); } /* By default consider masked stores to be expensive. */ |