[19/77] Add a smallest_int_mode_for_size helper function
authorRichard Sandiford <richard.sandiford@linaro.org>
Wed, 30 Aug 2017 11:10:44 +0000 (11:10 +0000)
committerRichard Sandiford <rsandifo@gcc.gnu.org>
Wed, 30 Aug 2017 11:10:44 +0000 (11:10 +0000)
This patch adds a wrapper around smallest_mode_for_size
for cases in which the mode class is MODE_INT.  Unlike
(int_)mode_for_size, smallest_mode_for_size always returns
a mode of the specified class, asserting if no such mode exists.
smallest_int_mode_for_size therefore returns a scalar_int_mode
rather than an opt_scalar_int_mode.

2017-08-30  Richard Sandiford  <richard.sandiford@linaro.org>
    Alan Hayward  <alan.hayward@arm.com>
    David Sherwood  <david.sherwood@arm.com>

gcc/
* machmode.h (smallest_mode_for_size): Fix formatting.
(smallest_int_mode_for_size): New function.
* cfgexpand.c (expand_debug_expr): Use smallest_int_mode_for_size
instead of smallest_mode_for_size.
* combine.c (make_extraction): Likewise.
* config/arc/arc.c (arc_expand_movmem): Likewise.
* config/arm/arm.c (arm_expand_divmod_libfunc): Likewise.
* config/i386/i386.c (ix86_get_mask_mode): Likewise.
* config/s390/s390.c (s390_expand_insv): Likewise.
* config/sparc/sparc.c (assign_int_registers): Likewise.
* config/spu/spu.c (spu_function_value): Likewise.
(spu_function_arg): Likewise.
* coverage.c (get_gcov_type): Likewise.
(get_gcov_unsigned_t): Likewise.
* dse.c (find_shift_sequence): Likewise.
* expmed.c (store_bit_field_1): Likewise.
* expr.c (convert_move): Likewise.
(store_field): Likewise.
* internal-fn.c (expand_arith_overflow): Likewise.
* optabs-query.c (get_best_extraction_insn): Likewise.
* optabs.c (expand_twoval_binop_libfunc): Likewise.
* stor-layout.c (layout_type): Likewise.
(initialize_sizetypes): Likewise.
* targhooks.c (default_get_mask_mode): Likewise.
* tree-ssa-loop-manip.c (canonicalize_loop_ivs): Likewise.

Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
Co-Authored-By: David Sherwood <david.sherwood@arm.com>
From-SVN: r251471

20 files changed:
gcc/ChangeLog
gcc/cfgexpand.c
gcc/combine.c
gcc/config/arc/arc.c
gcc/config/arm/arm.c
gcc/config/i386/i386.c
gcc/config/s390/s390.c
gcc/config/sparc/sparc.c
gcc/config/spu/spu.c
gcc/coverage.c
gcc/dse.c
gcc/expmed.c
gcc/expr.c
gcc/internal-fn.c
gcc/machmode.h
gcc/optabs-query.c
gcc/optabs.c
gcc/stor-layout.c
gcc/targhooks.c
gcc/tree-ssa-loop-manip.c

index 065999764605659475e6f6e84f8b41ab081d4f70..15ec88d4eba96cea1d3812761ad90b6eca01a555 100644 (file)
@@ -1,3 +1,33 @@
+2017-08-30  Richard Sandiford  <richard.sandiford@linaro.org>
+           Alan Hayward  <alan.hayward@arm.com>
+           David Sherwood  <david.sherwood@arm.com>
+
+       * machmode.h (smallest_mode_for_size): Fix formatting.
+       (smallest_int_mode_for_size): New function.
+       * cfgexpand.c (expand_debug_expr): Use smallest_int_mode_for_size
+       instead of smallest_mode_for_size.
+       * combine.c (make_extraction): Likewise.
+       * config/arc/arc.c (arc_expand_movmem): Likewise.
+       * config/arm/arm.c (arm_expand_divmod_libfunc): Likewise.
+       * config/i386/i386.c (ix86_get_mask_mode): Likewise.
+       * config/s390/s390.c (s390_expand_insv): Likewise.
+       * config/sparc/sparc.c (assign_int_registers): Likewise.
+       * config/spu/spu.c (spu_function_value): Likewise.
+       (spu_function_arg): Likewise.
+       * coverage.c (get_gcov_type): Likewise.
+       (get_gcov_unsigned_t): Likewise.
+       * dse.c (find_shift_sequence): Likewise.
+       * expmed.c (store_bit_field_1): Likewise.
+       * expr.c (convert_move): Likewise.
+       (store_field): Likewise.
+       * internal-fn.c (expand_arith_overflow): Likewise.
+       * optabs-query.c (get_best_extraction_insn): Likewise.
+       * optabs.c (expand_twoval_binop_libfunc): Likewise.
+       * stor-layout.c (layout_type): Likewise.
+       (initialize_sizetypes): Likewise.
+       * targhooks.c (default_get_mask_mode): Likewise.
+       * tree-ssa-loop-manip.c (canonicalize_loop_ivs): Likewise.
+
 2017-08-30  Richard Sandiford  <richard.sandiford@linaro.org>
             Alan Hayward  <alan.hayward@arm.com>
             David Sherwood  <david.sherwood@arm.com>
index f6e306e35fb1d49b8580854efd31f77f9916e1ec..7a90b0e8799ed165bc7764ee7f1456cb28418198 100644 (file)
@@ -4497,7 +4497,7 @@ expand_debug_expr (tree exp)
          {
            if (mode1 == VOIDmode)
              /* Bitfield.  */
-             mode1 = smallest_mode_for_size (bitsize, MODE_INT);
+             mode1 = smallest_int_mode_for_size (bitsize);
            if (bitpos >= BITS_PER_UNIT)
              {
                op0 = adjust_address_nv (op0, mode1, bitpos / BITS_PER_UNIT);
index f792a93b0c513b0906d90dc8cb3d518e78421899..44e378a160c752bf50cab14f191bc6274f82136d 100644 (file)
@@ -7598,7 +7598,7 @@ make_extraction (machine_mode mode, rtx inner, HOST_WIDE_INT pos,
     {
       /* Be careful not to go beyond the extracted object and maintain the
         natural alignment of the memory.  */
-      wanted_inner_mode = smallest_mode_for_size (len, MODE_INT);
+      wanted_inner_mode = smallest_int_mode_for_size (len);
       while (pos % GET_MODE_BITSIZE (wanted_inner_mode) + len
             > GET_MODE_BITSIZE (wanted_inner_mode))
        wanted_inner_mode = GET_MODE_WIDER_MODE (wanted_inner_mode).require ();
index c072bda257b1069234a5557acc7cd18badfe0630..1f5c6dfe9b99e769ff5f788123892b9f3a57ade5 100644 (file)
@@ -7972,7 +7972,7 @@ arc_expand_movmem (rtx *operands)
 
       while (piece > size)
        piece >>= 1;
-      mode = smallest_mode_for_size (piece * BITS_PER_UNIT, MODE_INT);
+      mode = smallest_int_mode_for_size (piece * BITS_PER_UNIT);
       /* If we don't re-use temporaries, the scheduler gets carried away,
         and the register pressure gets unnecessarily high.  */
       if (0 && tmpx[i] && GET_MODE (tmpx[i]) == mode)
index 982ea7e49a5ab525627f5d4d82e2597ac1b6e46f..e66cfa651b5304476ec9f016eab890ac9bd19755 100644 (file)
@@ -31097,8 +31097,8 @@ arm_expand_divmod_libfunc (rtx libfunc, machine_mode mode,
   if (mode == SImode)
     gcc_assert (!TARGET_IDIV);
 
-  machine_mode libval_mode = smallest_mode_for_size (2 * GET_MODE_BITSIZE (mode),
-                                                    MODE_INT);
+  scalar_int_mode libval_mode
+    = smallest_int_mode_for_size (2 * GET_MODE_BITSIZE (mode));
 
   rtx libval = emit_library_call_value (libfunc, NULL_RTX, LCT_CONST,
                                        libval_mode, 2,
index c574c9573a5d9c038c9482e721de39a5c21822d4..be83381692efb28873a3a9651ab7b083baf2db29 100644 (file)
@@ -51580,11 +51580,11 @@ ix86_get_mask_mode (unsigned nunits, unsigned vector_size)
       || (TARGET_AVX512VL && (vector_size == 32 || vector_size == 16)))
     {
       if (elem_size == 4 || elem_size == 8 || TARGET_AVX512BW)
-       return smallest_mode_for_size (nunits, MODE_INT);
+       return smallest_int_mode_for_size (nunits);
     }
 
-  machine_mode elem_mode
-    = smallest_mode_for_size (elem_size * BITS_PER_UNIT, MODE_INT);
+  scalar_int_mode elem_mode
+    = smallest_int_mode_for_size (elem_size * BITS_PER_UNIT);
 
   gcc_assert (elem_size * nunits == vector_size);
 
index b5c0bd13f3b30890e802bd6d510cac8843f66df1..e4d14fbc01d8d72055ab146ef659103d95962b44 100644 (file)
@@ -6185,7 +6185,7 @@ s390_expand_insv (rtx dest, rtx op1, rtx op2, rtx src)
       return true;
     }
 
-  smode = smallest_mode_for_size (bitsize, MODE_INT);
+  smode = smallest_int_mode_for_size (bitsize);
   smode_bsize = GET_MODE_BITSIZE (smode);
   mode_bsize = GET_MODE_BITSIZE (mode);
 
index c6efe19c2a8881190b79f80e284a18e84935c744..a3e7e46a514826b709b6ab8a0f40554618cf8f4d 100644 (file)
@@ -6771,8 +6771,8 @@ assign_int_registers (HOST_WIDE_INT bitpos, assign_data_t *data)
      the latter case we may pick up unwanted bits.  It's not a problem
      at the moment but may wish to revisit.  */
   if (intoffset % BITS_PER_WORD != 0)
-    mode = smallest_mode_for_size (BITS_PER_WORD - intoffset % BITS_PER_WORD,
-                                  MODE_INT);
+    mode = smallest_int_mode_for_size (BITS_PER_WORD
+                                      - intoffset % BITS_PER_WORD);
   else
     mode = word_mode;
 
index dfa777e48a81bc50f8b3c2c5512b0bac5b8a6cba..b917609bb601a306b1431e6500672058afc97244 100644 (file)
@@ -3810,8 +3810,7 @@ spu_function_value (const_tree type, const_tree func ATTRIBUTE_UNUSED)
        {
          if (byte_size < 4)
            byte_size = 4;
-         smode =
-           smallest_mode_for_size (byte_size * BITS_PER_UNIT, MODE_INT);
+         smode = smallest_int_mode_for_size (byte_size * BITS_PER_UNIT);
          RTVEC_ELT (v, n) =
            gen_rtx_EXPR_LIST (VOIDmode,
                               gen_rtx_REG (smode, FIRST_RETURN_REGNUM + n),
@@ -3849,7 +3848,7 @@ spu_function_arg (cumulative_args_t cum_v,
       rtx gr_reg;
       if (byte_size < 4)
        byte_size = 4;
-      smode = smallest_mode_for_size (byte_size * BITS_PER_UNIT, MODE_INT);
+      smode = smallest_int_mode_for_size (byte_size * BITS_PER_UNIT);
       gr_reg = gen_rtx_EXPR_LIST (VOIDmode,
                                  gen_rtx_REG (smode, FIRST_ARG_REGNUM + *cum),
                                  const0_rtx);
index ed469107e3e6750da53a0a39dd3e002efde5e792..8a56a677f157427d9b03ec18e129b2df20df9990 100644 (file)
@@ -143,8 +143,8 @@ static void coverage_obj_finish (vec<constructor_elt, va_gc> *);
 tree
 get_gcov_type (void)
 {
-  machine_mode mode
-    = smallest_mode_for_size (LONG_LONG_TYPE_SIZE > 32 ? 64 : 32, MODE_INT);
+  scalar_int_mode mode
+    = smallest_int_mode_for_size (LONG_LONG_TYPE_SIZE > 32 ? 64 : 32);
   return lang_hooks.types.type_for_mode (mode, false);
 }
 
@@ -153,7 +153,7 @@ get_gcov_type (void)
 static tree
 get_gcov_unsigned_t (void)
 {
-  machine_mode mode = smallest_mode_for_size (32, MODE_INT);
+  scalar_int_mode mode = smallest_int_mode_for_size (32);
   return lang_hooks.types.type_for_mode (mode, true);
 }
 \f
index aa1c766d1f44adc814f6fbd7ce6754e0a2f6fd7c..e6643321887270a28b33db80f68ac7bb47a20aa1 100644 (file)
--- a/gcc/dse.c
+++ b/gcc/dse.c
@@ -1573,7 +1573,7 @@ find_shift_sequence (int access_size,
                     int shift, bool speed, bool require_cst)
 {
   machine_mode store_mode = GET_MODE (store_info->mem);
-  machine_mode new_mode;
+  scalar_int_mode new_mode;
   rtx read_reg = NULL;
 
   /* Some machines like the x86 have shift insns for each size of
@@ -1583,14 +1583,15 @@ find_shift_sequence (int access_size,
      justify the value we want to read but is available in one insn on
      the machine.  */
 
-  FOR_EACH_MODE_FROM (new_mode,
-                     smallest_mode_for_size (access_size * BITS_PER_UNIT,
-                                             MODE_INT))
+  opt_scalar_int_mode new_mode_iter;
+  FOR_EACH_MODE_FROM (new_mode_iter,
+                     smallest_int_mode_for_size (access_size * BITS_PER_UNIT))
     {
       rtx target, new_reg, new_lhs;
       rtx_insn *shift_seq, *insn;
       int cost;
 
+      new_mode = new_mode_iter.require ();
       if (GET_MODE_BITSIZE (new_mode) > BITS_PER_WORD)
        break;
 
index b24b6d1a31dcba0107635bc86d3c5b8c13c9f3a6..f7ac82145de3b5e3f4d8cd385b57bed88e5507f4 100644 (file)
@@ -900,7 +900,7 @@ store_bit_field_1 (rtx str_rtx, unsigned HOST_WIDE_INT bitsize,
         is not allowed.  */
       fieldmode = GET_MODE (value);
       if (fieldmode == VOIDmode)
-       fieldmode = smallest_mode_for_size (nwords * BITS_PER_WORD, MODE_INT);
+       fieldmode = smallest_int_mode_for_size (nwords * BITS_PER_WORD);
 
       last = get_last_insn ();
       for (i = 0; i < nwords; i++)
index b9a0b06962f8a09baf2dfe5a86481c5624544d3c..776c71904951b0b403487b387adc19111726dfb7 100644 (file)
@@ -346,8 +346,8 @@ convert_move (rtx to, rtx from, int unsignedp)
      xImode for all MODE_PARTIAL_INT modes they use, but no others.  */
   if (GET_MODE_CLASS (to_mode) == MODE_PARTIAL_INT)
     {
-      machine_mode full_mode
-       = smallest_mode_for_size (GET_MODE_BITSIZE (to_mode), MODE_INT);
+      scalar_int_mode full_mode
+       = smallest_int_mode_for_size (GET_MODE_BITSIZE (to_mode));
 
       gcc_assert (convert_optab_handler (trunc_optab, to_mode, full_mode)
                  != CODE_FOR_nothing);
@@ -361,8 +361,8 @@ convert_move (rtx to, rtx from, int unsignedp)
   if (GET_MODE_CLASS (from_mode) == MODE_PARTIAL_INT)
     {
       rtx new_from;
-      machine_mode full_mode
-       = smallest_mode_for_size (GET_MODE_BITSIZE (from_mode), MODE_INT);
+      scalar_int_mode full_mode
+       = smallest_int_mode_for_size (GET_MODE_BITSIZE (from_mode));
       convert_optab ctab = unsignedp ? zext_optab : sext_optab;
       enum insn_code icode;
 
@@ -6848,8 +6848,8 @@ store_field (rtx target, HOST_WIDE_INT bitsize, HOST_WIDE_INT bitpos,
       if (GET_CODE (temp) == PARALLEL)
        {
          HOST_WIDE_INT size = int_size_in_bytes (TREE_TYPE (exp));
-         machine_mode temp_mode
-           = smallest_mode_for_size (size * BITS_PER_UNIT, MODE_INT);
+         scalar_int_mode temp_mode
+           = smallest_int_mode_for_size (size * BITS_PER_UNIT);
          rtx temp_target = gen_reg_rtx (temp_mode);
          emit_group_store (temp_target, temp, TREE_TYPE (exp), size);
          temp = temp_target;
@@ -6920,7 +6920,7 @@ store_field (rtx target, HOST_WIDE_INT bitsize, HOST_WIDE_INT bitpos,
         word size, we need to load the value (see again store_bit_field).  */
       if (GET_MODE (temp) == BLKmode && bitsize <= BITS_PER_WORD)
        {
-         machine_mode temp_mode = smallest_mode_for_size (bitsize, MODE_INT);
+         scalar_int_mode temp_mode = smallest_int_mode_for_size (bitsize);
          temp = extract_bit_field (temp, bitsize, 0, 1, NULL_RTX, temp_mode,
                                    temp_mode, false, NULL);
        }
index 017a469f2be53a171fe161db4398257cf3fffc5c..2c243fdf44ae02dd10ee0c816bb7e44aeba63449 100644 (file)
@@ -2173,7 +2173,7 @@ expand_arith_overflow (enum tree_code code, gimple *stmt)
       if (orig_precres == precres && precop <= BITS_PER_WORD)
        {
          int p = MAX (min_precision, precop);
-         machine_mode m = smallest_mode_for_size (p, MODE_INT);
+         scalar_int_mode m = smallest_int_mode_for_size (p);
          tree optype = build_nonstandard_integer_type (GET_MODE_PRECISION (m),
                                                        uns0_p && uns1_p
                                                        && unsr_p);
@@ -2215,7 +2215,7 @@ expand_arith_overflow (enum tree_code code, gimple *stmt)
       if (orig_precres == precres)
        {
          int p = MAX (prec0, prec1);
-         machine_mode m = smallest_mode_for_size (p, MODE_INT);
+         scalar_int_mode m = smallest_int_mode_for_size (p);
          tree optype = build_nonstandard_integer_type (GET_MODE_PRECISION (m),
                                                        uns0_p && uns1_p
                                                        && unsr_p);
index 590f10036a1e191ae0c4b53222b38b312a9fdfdf..6fd10b42a8f39192a9d18a5d1155654b8b619d98 100644 (file)
@@ -588,9 +588,16 @@ float_mode_for_size (unsigned int size)
 
 /* Similar to mode_for_size, but find the smallest mode for a given width.  */
 
-extern machine_mode smallest_mode_for_size (unsigned int,
-                                                enum mode_class);
+extern machine_mode smallest_mode_for_size (unsigned int, enum mode_class);
 
+/* Find the narrowest integer mode that contains at least SIZE bits.
+   Such a mode must exist.  */
+
+inline scalar_int_mode
+smallest_int_mode_for_size (unsigned int size)
+{
+  return as_a <scalar_int_mode> (smallest_mode_for_size (size, MODE_INT));
+}
 
 /* Return an integer mode of exactly the same size as the input mode.  */
 
index 021d8160cf420ca73bc3cdbb1be75f5b765a34be..48b1250bda24fda4443aa2f1b343636c6092fc32 100644 (file)
@@ -193,13 +193,15 @@ get_best_extraction_insn (extraction_insn *insn,
                          unsigned HOST_WIDE_INT struct_bits,
                          machine_mode field_mode)
 {
-  machine_mode mode = smallest_mode_for_size (struct_bits, MODE_INT);
-  FOR_EACH_MODE_FROM (mode, mode)
+  opt_scalar_int_mode mode_iter;
+  FOR_EACH_MODE_FROM (mode_iter, smallest_int_mode_for_size (struct_bits))
     {
+      scalar_int_mode mode = mode_iter.require ();
       if (get_extraction_insn (insn, pattern, type, mode))
        {
-         FOR_EACH_MODE_FROM (mode, mode)
+         FOR_EACH_MODE_FROM (mode_iter, mode)
            {
+             mode = mode_iter.require ();
              if (GET_MODE_SIZE (mode) > GET_MODE_SIZE (field_mode)
                  || TRULY_NOOP_TRUNCATION_MODES_P (insn->field_mode,
                                                    field_mode))
index 1d854b604afb52f7943db921b51ddc588f99ff87..ee3b4e9cfaa52ba921d3210bcb0aaebdf169f5eb 100644 (file)
@@ -2084,8 +2084,7 @@ expand_twoval_binop_libfunc (optab binoptab, rtx op0, rtx op1,
 
   /* The value returned by the library function will have twice as
      many bits as the nominal MODE.  */
-  libval_mode = smallest_mode_for_size (2 * GET_MODE_BITSIZE (mode),
-                                       MODE_INT);
+  libval_mode = smallest_int_mode_for_size (2 * GET_MODE_BITSIZE (mode));
   start_sequence ();
   libval = emit_library_call_value (libfunc, NULL_RTX, LCT_CONST,
                                    libval_mode, 2,
index f1a601be13c44efbab75d2833a2a79d58a19bdeb..76d0075507f1abf9cd8b728ff8f33fa4f377e315 100644 (file)
@@ -2194,12 +2194,15 @@ layout_type (tree type)
     case BOOLEAN_TYPE:
     case INTEGER_TYPE:
     case ENUMERAL_TYPE:
-      SET_TYPE_MODE (type,
-                    smallest_mode_for_size (TYPE_PRECISION (type), MODE_INT));
-      TYPE_SIZE (type) = bitsize_int (GET_MODE_BITSIZE (TYPE_MODE (type)));
-      /* Don't set TYPE_PRECISION here, as it may be set by a bitfield.  */
-      TYPE_SIZE_UNIT (type) = size_int (GET_MODE_SIZE (TYPE_MODE (type)));
-      break;
+      {
+       scalar_int_mode mode
+         = smallest_int_mode_for_size (TYPE_PRECISION (type));
+       SET_TYPE_MODE (type, mode);
+       TYPE_SIZE (type) = bitsize_int (GET_MODE_BITSIZE (mode));
+       /* Don't set TYPE_PRECISION here, as it may be set by a bitfield.  */
+       TYPE_SIZE_UNIT (type) = size_int (GET_MODE_SIZE (mode));
+       break;
+      }
 
     case REAL_TYPE:
       {
@@ -2608,8 +2611,7 @@ initialize_sizetypes (void)
 
   bprecision
     = MIN (precision + LOG2_BITS_PER_UNIT + 1, MAX_FIXED_MODE_SIZE);
-  bprecision
-    = GET_MODE_PRECISION (smallest_mode_for_size (bprecision, MODE_INT));
+  bprecision = GET_MODE_PRECISION (smallest_int_mode_for_size (bprecision));
   if (bprecision > HOST_BITS_PER_DOUBLE_INT)
     bprecision = HOST_BITS_PER_DOUBLE_INT;
 
@@ -2624,17 +2626,18 @@ initialize_sizetypes (void)
   TYPE_UNSIGNED (bitsizetype) = 1;
 
   /* Now layout both types manually.  */
-  SET_TYPE_MODE (sizetype, smallest_mode_for_size (precision, MODE_INT));
+  scalar_int_mode mode = smallest_int_mode_for_size (precision);
+  SET_TYPE_MODE (sizetype, mode);
   SET_TYPE_ALIGN (sizetype, GET_MODE_ALIGNMENT (TYPE_MODE (sizetype)));
   TYPE_SIZE (sizetype) = bitsize_int (precision);
-  TYPE_SIZE_UNIT (sizetype) = size_int (GET_MODE_SIZE (TYPE_MODE (sizetype)));
+  TYPE_SIZE_UNIT (sizetype) = size_int (GET_MODE_SIZE (mode));
   set_min_and_max_values_for_integral_type (sizetype, precision, UNSIGNED);
 
-  SET_TYPE_MODE (bitsizetype, smallest_mode_for_size (bprecision, MODE_INT));
+  mode = smallest_int_mode_for_size (bprecision);
+  SET_TYPE_MODE (bitsizetype, mode);
   SET_TYPE_ALIGN (bitsizetype, GET_MODE_ALIGNMENT (TYPE_MODE (bitsizetype)));
   TYPE_SIZE (bitsizetype) = bitsize_int (bprecision);
-  TYPE_SIZE_UNIT (bitsizetype)
-    = size_int (GET_MODE_SIZE (TYPE_MODE (bitsizetype)));
+  TYPE_SIZE_UNIT (bitsizetype) = size_int (GET_MODE_SIZE (mode));
   set_min_and_max_values_for_integral_type (bitsizetype, bprecision, UNSIGNED);
 
   /* Create the signed variants of *sizetype.  */
index 2b7f27fdf0d253aed19a57e48105f60f5d806e79..72e199f44ff73a81adb87ff850c9e34acab0ba12 100644 (file)
@@ -1180,8 +1180,8 @@ machine_mode
 default_get_mask_mode (unsigned nunits, unsigned vector_size)
 {
   unsigned elem_size = vector_size / nunits;
-  machine_mode elem_mode
-    = smallest_mode_for_size (elem_size * BITS_PER_UNIT, MODE_INT);
+  scalar_int_mode elem_mode
+    = smallest_int_mode_for_size (elem_size * BITS_PER_UNIT);
   machine_mode vector_mode;
 
   gcc_assert (elem_size * nunits == vector_size);
index 5488044b18f5572fc27f8d752ee0bd7765b1cae5..d6ba305e8fd2d2af54f9c7a9e34488163c71439c 100644 (file)
@@ -1506,7 +1506,6 @@ canonicalize_loop_ivs (struct loop *loop, tree *nit, bool bump_in_latch)
   gcond *stmt;
   edge exit = single_dom_exit (loop);
   gimple_seq stmts;
-  machine_mode mode;
   bool unsigned_p = false;
 
   for (psi = gsi_start_phis (loop->header);
@@ -1533,7 +1532,7 @@ canonicalize_loop_ivs (struct loop *loop, tree *nit, bool bump_in_latch)
       precision = TYPE_PRECISION (type);
     }
 
-  mode = smallest_mode_for_size (precision, MODE_INT);
+  scalar_int_mode mode = smallest_int_mode_for_size (precision);
   precision = GET_MODE_PRECISION (mode);
   type = build_nonstandard_integer_type (precision, unsigned_p);