From: Kito Cheng Date: Mon, 21 Feb 2022 15:14:31 +0000 (+0800) Subject: RISC-V: Maintain a string to hold the canonical order X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3a3e333f65483b864bf2624392f8aa4a88c7a498;p=binutils-gdb.git RISC-V: Maintain a string to hold the canonical order Using dummy entry in riscv_supported_std_ext cause confusing and wrongly support `b` and `k` extensions. bfd/ * elfxx-riscv.c (riscv_supported_std_ext): Drop unsupported extensions. (riscv_ext_canonical_order): New. (riscv_init_ext_order): Use riscv_ext_canonical_order rather than riscv_supported_std_ext to compute canonical order. V2 Changes: - Use `*ext` rather than `*ext != NULL` for checking is reach end of string. --- diff --git a/bfd/elfxx-riscv.c b/bfd/elfxx-riscv.c index 9f52bb545ac..27d06d2fa3d 100644 --- a/bfd/elfxx-riscv.c +++ b/bfd/elfxx-riscv.c @@ -1163,17 +1163,10 @@ static struct riscv_supported_ext riscv_supported_std_ext[] = {"q", ISA_SPEC_CLASS_20191213, 2, 2, 0 }, {"q", ISA_SPEC_CLASS_20190608, 2, 2, 0 }, {"q", ISA_SPEC_CLASS_2P2, 2, 0, 0 }, - {"l", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, {"c", ISA_SPEC_CLASS_20191213, 2, 0, 0 }, {"c", ISA_SPEC_CLASS_20190608, 2, 0, 0 }, {"c", ISA_SPEC_CLASS_2P2, 2, 0, 0 }, - {"b", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, - {"k", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, - {"j", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, - {"t", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, - {"p", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, {"v", ISA_SPEC_CLASS_DRAFT, 1, 0, 0 }, - {"n", ISA_SPEC_CLASS_NONE, RISCV_UNKNOWN_VERSION, RISCV_UNKNOWN_VERSION, 0 }, {NULL, 0, 0, 0, 0} }; @@ -1341,6 +1334,9 @@ riscv_recognized_prefixed_ext (const char *ext) return false; } +/* Canonical order for single letter extensions. */ +static const char riscv_ext_canonical_order[] = "eigmafdqlcbjktpvn"; + /* Array is used to compare the orders of standard extensions quickly. */ static int riscv_ext_order[26] = {0}; @@ -1356,16 +1352,8 @@ riscv_init_ext_order (void) /* The orders of all standard extensions are positive. */ int order = 1; - int i = 0; - while (riscv_supported_std_ext[i].name != NULL) - { - const char *ext = riscv_supported_std_ext[i].name; - riscv_ext_order[(*ext - 'a')] = order++; - i++; - while (riscv_supported_std_ext[i].name - && strcmp (ext, riscv_supported_std_ext[i].name) == 0) - i++; - } + for (const char *ext = &riscv_ext_canonical_order[0]; *ext; ++ext) + riscv_ext_order[(*ext - 'a')] = order++; /* Some of the prefixed keyword are not single letter, so we set their prefixed orders in the riscv_compare_subsets directly,