aboutsummaryrefslogtreecommitdiff
path: root/opcodes/cgen-asm.c
diff options
context:
space:
mode:
Diffstat (limited to 'opcodes/cgen-asm.c')
-rw-r--r--opcodes/cgen-asm.c38
1 files changed, 27 insertions, 11 deletions
diff --git a/opcodes/cgen-asm.c b/opcodes/cgen-asm.c
index 14c830ad..5427aaa 100644
--- a/opcodes/cgen-asm.c
+++ b/opcodes/cgen-asm.c
@@ -32,8 +32,9 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "opcode/cgen.h"
/* Operand parsing callback. */
-const char * (*cgen_asm_parse_operand_fn)
- PARAMS ((const char **, int, int, enum cgen_asm_result *, bfd_vma *));
+const char * (*cgen_parse_operand_fn)
+ PARAMS ((enum cgen_parse_operand_type, const char **, int, int,
+ enum cgen_parse_operand_result *, bfd_vma *));
/* This is not published as part of the public interface so we don't
declare this in cgen.h. */
@@ -42,6 +43,8 @@ extern CGEN_OPCODE_DATA *cgen_current_opcode_data;
/* Assembler instruction hash table. */
static CGEN_INSN_LIST **asm_hash_table;
+/* Called once at startup and whenever machine/endian change. */
+
void
cgen_asm_init ()
{
@@ -52,6 +55,16 @@ cgen_asm_init ()
}
}
+/* Called whenever starting to parse an insn. */
+
+void
+cgen_init_parse_operand ()
+{
+ /* This tells the callback to re-initialize. */
+ (void) (*cgen_parse_operand_fn) (CGEN_PARSE_OPERAND_INIT, NULL, 0, 0,
+ NULL, NULL);
+}
+
/* Build the assembler instruction hash table. */
static void
@@ -177,11 +190,12 @@ cgen_parse_signed_integer (strp, opindex, min, max, valuep)
long *valuep;
{
long value;
- enum cgen_asm_result result;
+ enum cgen_parse_operand_result result;
const char *errmsg;
- errmsg = (*cgen_asm_parse_operand_fn) (strp, opindex, BFD_RELOC_NONE,
- &result, &value);
+ errmsg = (*cgen_parse_operand_fn) (CGEN_PARSE_OPERAND_INTEGER, strp,
+ opindex, BFD_RELOC_NONE,
+ &result, &value);
/* FIXME: Examine `result'. */
if (!errmsg)
{
@@ -202,11 +216,12 @@ cgen_parse_unsigned_integer (strp, opindex, min, max, valuep)
unsigned long *valuep;
{
unsigned long value;
- enum cgen_asm_result result;
+ enum cgen_parse_operand_result result;
const char *errmsg;
- errmsg = (*cgen_asm_parse_operand_fn) (strp, opindex, BFD_RELOC_NONE,
- &result, &value);
+ errmsg = (*cgen_parse_operand_fn) (CGEN_PARSE_OPERAND_INTEGER, strp,
+ opindex, BFD_RELOC_NONE,
+ &result, &value);
/* FIXME: Examine `result'. */
if (!errmsg)
{
@@ -227,11 +242,12 @@ cgen_parse_address (strp, opindex, opinfo, valuep)
long *valuep;
{
long value;
- enum cgen_asm_result result;
+ enum cgen_parse_operand_result result;
const char *errmsg;
- errmsg = (*cgen_asm_parse_operand_fn) (strp, opindex, opinfo,
- &result, &value);
+ errmsg = (*cgen_parse_operand_fn) (CGEN_PARSE_OPERAND_ADDRESS, strp,
+ opindex, opinfo,
+ &result, &value);
/* FIXME: Examine `result'. */
if (!errmsg)
{