[AARCH64][GAS] Fix two -Wstack-usage warnings.
authorRenlin Li <renlin.li@arm.com>
Thu, 9 Jun 2016 09:08:08 +0000 (10:08 +0100)
committerRenlin Li <renlin.li@arm.com>
Thu, 9 Jun 2016 09:08:08 +0000 (10:08 +0100)
Warning triggerd by gcc 5 with -O0 flag.
error: stack usage might be unbounded [-Werror=stack-usage=]

gas/

2016-06-08  Renlin Li  <renlin.li@arm.com>

* config/tc-aarch64.c (print_operands): Substitute size.
(output_operand_error_record): Likewise.

gas/ChangeLog
gas/config/tc-aarch64.c

index c3b2436d8aaed03c18838d93aa2144a7e8571530..38d0041b523c0b91ae521fd93ade48103822cdf4 100644 (file)
@@ -1,3 +1,8 @@
+2016-06-08  Renlin Li  <renlin.li@arm.com>
+
+       * config/tc-aarch64.c (print_operands): Substitute size.
+       (output_operand_error_record): Likewise.
+
 2016-06-07  Alan Modra  <amodra@gmail.com>
 
        * config/tc-ppc.c (PPC_APUINFO_ISEL, PPC_APUINFO_PMR,
index 00a931e9279a8a32112df3ec381b7b6e7149be14..774494f83b1a5ad120880dac6605afbbdff0620a 100644 (file)
@@ -4231,8 +4231,7 @@ print_operands (char *buf, const aarch64_opcode *opcode,
 
   for (i = 0; i < AARCH64_MAX_OPND_NUM; ++i)
     {
-      const size_t size = 128;
-      char str[size];
+      char str[128];
 
       /* We regard the opcode operand info more, however we also look into
         the inst->operands to support the disassembling of the optional
@@ -4244,7 +4243,7 @@ print_operands (char *buf, const aarch64_opcode *opcode,
        break;
 
       /* Generate the operand string in STR.  */
-      aarch64_print_operand (str, size, 0, opcode, opnds, i, NULL, NULL);
+      aarch64_print_operand (str, sizeof (str), 0, opcode, opnds, i, NULL, NULL);
 
       /* Delimiter.  */
       if (str[0] != '\0')
@@ -4350,8 +4349,7 @@ output_operand_error_record (const operand_error_record *record, char *str)
          size_t len = strlen (get_mnemonic_name (str));
          int i, qlf_idx;
          bfd_boolean result;
-         const size_t size = 2048;
-         char buf[size];
+         char buf[2048];
          aarch64_inst *inst_base = &inst.base;
          const aarch64_opnd_qualifier_seq_t *qualifiers_list;
 
@@ -4381,7 +4379,7 @@ output_operand_error_record (const operand_error_record *record, char *str)
 
          /* Print the hint.  */
          output_info (_("   did you mean this?"));
-         snprintf (buf, size, "\t%s", get_mnemonic_name (str));
+         snprintf (buf, sizeof (buf), "\t%s", get_mnemonic_name (str));
          print_operands (buf, opcode, inst_base->operands);
          output_info (_("   %s"), buf);
 
@@ -4402,7 +4400,7 @@ output_operand_error_record (const operand_error_record *record, char *str)
              if (i != qlf_idx)
                {
                  /* Mnemonics name.  */
-                 snprintf (buf, size, "\t%s", get_mnemonic_name (str));
+                 snprintf (buf, sizeof (buf), "\t%s", get_mnemonic_name (str));
 
                  /* Assign the qualifiers.  */
                  assign_qualifier_sequence (inst_base, *qualifiers_list);