mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-27 04:52:05 +08:00
744875dfdc
This commit is a follow on to: commit182421c9d2
Date: Tue Oct 11 15:02:08 2022 +0100 sim/ppc: fixes for arguments to printf style functions where commit182421c9d2
addressed issues with printf format arguments that were causing the compiler to give an error, this commit addresses issues that caused the compiler to emit a warning. This commit is mostly either changing the format string to match the argument, or in some cases, excess, unused arguments are removed.
152 lines
4.4 KiB
C
152 lines
4.4 KiB
C
/* This file is part of the program psim.
|
|
|
|
Copyright (C) 1994-1997, Andrew Cagney <cagney@highland.com.au>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
/* load the opcode stat structure */
|
|
|
|
#include "misc.h"
|
|
#include "lf.h"
|
|
#include "table.h"
|
|
#include "ld-decode.h"
|
|
|
|
|
|
enum {
|
|
op_options,
|
|
op_first,
|
|
op_last,
|
|
op_force_first,
|
|
op_force_last,
|
|
op_force_expansion,
|
|
op_special_mask,
|
|
op_special_value,
|
|
op_special_constant,
|
|
nr_decode_fields,
|
|
};
|
|
|
|
static const name_map decode_type_map[] = {
|
|
{ "normal", normal_decode_rule },
|
|
{ "expand-forced", expand_forced_rule },
|
|
{ "boolean", boolean_rule },
|
|
{ NULL, normal_decode_rule },
|
|
};
|
|
|
|
static const name_map decode_gen_map[] = {
|
|
{ "array", array_gen },
|
|
{ "switch", switch_gen },
|
|
{ "padded-switch", padded_switch_gen },
|
|
{ "goto-switch", goto_switch_gen },
|
|
{ NULL, -1 },
|
|
};
|
|
|
|
static const name_map decode_slash_map[] = {
|
|
{ "variable-slash", 0 },
|
|
{ "constant-slash", 1 },
|
|
{ NULL },
|
|
};
|
|
|
|
|
|
static decode_gen_type overriding_gen_type = invalid_gen;
|
|
|
|
void
|
|
force_decode_gen_type(const char *type)
|
|
{
|
|
overriding_gen_type = name2i(type, decode_gen_map);
|
|
}
|
|
|
|
|
|
decode_table *
|
|
load_decode_table(const char *file_name,
|
|
int hi_bit_nr)
|
|
{
|
|
table *file = table_open(file_name, nr_decode_fields, 0);
|
|
table_entry *entry;
|
|
decode_table *table = NULL;
|
|
decode_table **curr_rule = &table;
|
|
while ((entry = table_entry_read(file)) != NULL) {
|
|
decode_table *new_rule = ZALLOC(decode_table);
|
|
new_rule->type = name2i(entry->fields[op_options], decode_type_map);
|
|
new_rule->gen = (overriding_gen_type != invalid_gen
|
|
? overriding_gen_type
|
|
: name2i(entry->fields[op_options], decode_gen_map));
|
|
new_rule->force_slash = name2i(entry->fields[op_options], decode_slash_map);
|
|
new_rule->first = target_a2i(hi_bit_nr, entry->fields[op_first]);
|
|
new_rule->last = target_a2i(hi_bit_nr, entry->fields[op_last]);
|
|
new_rule->force_first = (strlen(entry->fields[op_force_first])
|
|
? target_a2i(hi_bit_nr, entry->fields[op_force_first])
|
|
: new_rule->last + 1);
|
|
new_rule->force_last = (strlen(entry->fields[op_force_last])
|
|
? target_a2i(hi_bit_nr, entry->fields[op_force_last])
|
|
: new_rule->first - 1);
|
|
new_rule->force_expansion = entry->fields[op_force_expansion];
|
|
new_rule->special_mask = a2i(entry->fields[op_special_mask]);
|
|
new_rule->special_value = a2i(entry->fields[op_special_value]);
|
|
new_rule->special_constant = a2i(entry->fields[op_special_constant]);
|
|
*curr_rule = new_rule;
|
|
curr_rule = &new_rule->next;
|
|
}
|
|
return table;
|
|
}
|
|
|
|
|
|
void
|
|
dump_decode_rule(decode_table *rule,
|
|
int indent)
|
|
{
|
|
dumpf(indent, "((decode_table*)%p\n", rule);
|
|
if (rule) {
|
|
dumpf(indent, " (type %s)\n", i2name(rule->type, decode_type_map));
|
|
dumpf(indent, " (gen %s)\n", i2name(rule->gen, decode_gen_map));
|
|
dumpf(indent, " (force_slash %d)\n", rule->force_slash);
|
|
dumpf(indent, " (first %d)\n", rule->first);
|
|
dumpf(indent, " (last %d)\n", rule->last);
|
|
dumpf(indent, " (force_first %d)\n", rule->force_first);
|
|
dumpf(indent, " (force_last %d)\n", rule->force_last);
|
|
dumpf(indent, " (force_expansion \"%s\")\n", rule->force_expansion);
|
|
dumpf(indent, " (special_mask 0x%x)\n", rule->special_mask);
|
|
dumpf(indent, " (special_value 0x%x)\n", rule->special_value);
|
|
dumpf(indent, " (special_constant 0x%x)\n", rule->special_constant);
|
|
dumpf(indent, " (next %p)\n", rule->next);
|
|
}
|
|
dumpf(indent, " )\n");
|
|
}
|
|
|
|
|
|
#ifdef MAIN
|
|
|
|
static void
|
|
dump_decode_rules(decode_table *rule,
|
|
int indent)
|
|
{
|
|
while (rule) {
|
|
dump_decode_rule(rule, indent);
|
|
rule = rule->next;
|
|
}
|
|
}
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
decode_table *rules;
|
|
if (argc != 3)
|
|
error("Usage: decode <decode-file> <hi-bit-nr>\n");
|
|
rules = load_decode_table(argv[1], a2i(argv[2]));
|
|
dump_decode_rules(rules, 0);
|
|
return 0;
|
|
}
|
|
#endif
|