cgen: increase buffer for hash_insn_list
authorAlan Modra <amodra@gmail.com>
Thu, 12 May 2022 02:14:04 +0000 (11:44 +0930)
committerAlan Modra <amodra@gmail.com>
Thu, 12 May 2022 02:19:45 +0000 (11:49 +0930)
As was done for hash_insn_array in commit d3d1cc7b13b4.

* cgen-dis.c (hash_insn_list): Increase size of buf.  Assert
size is large enough.

opcodes/cgen-dis.c

index 4137e39bd383279cb2081d82c9ec9b0c2728d757..993deeb26b4e49b2e4d6b7a89fde1c4f8bce5602 100644 (file)
@@ -153,8 +153,9 @@ hash_insn_list (CGEN_CPU_DESC cd,
   for (ilist = insns; ilist != NULL; ilist = ilist->next, ++ hentbuf)
     {
       unsigned int hash;
-      char buf[4];
+      char buf[8];
       unsigned long value;
+      size_t size;
 
       if (! (* cd->dis_hash_p) (ilist->insn))
        continue;
@@ -163,10 +164,9 @@ hash_insn_list (CGEN_CPU_DESC cd,
         to hash on, so set both up.  */
 
       value = CGEN_INSN_BASE_VALUE (ilist->insn);
-      bfd_put_bits((bfd_vma) value,
-                  buf,
-                  CGEN_INSN_MASK_BITSIZE (ilist->insn),
-                  big_p);
+      size = CGEN_INSN_MASK_BITSIZE (ilist->insn);
+      OPCODES_ASSERT (size <= sizeof (buf) * 8);
+      bfd_put_bits ((bfd_vma) value, buf, size, big_p);
       hash = (* cd->dis_hash) (buf, value);
       add_insn_to_hash_chain (hentbuf, ilist->insn, htable, hash);
     }