aboutsummaryrefslogtreecommitdiff
path: root/opcodes/cgen-asm.c
diff options
context:
space:
mode:
authorDavid Edelsohn <dje.gcc@gmail.com>1997-04-10 23:39:51 +0000
committerDavid Edelsohn <dje.gcc@gmail.com>1997-04-10 23:39:51 +0000
commita394e3262fa7a03f9ca4e198044de683999457f0 (patch)
treeb8d35764f7760acf7b2fcf1205e95557a3936d0f /opcodes/cgen-asm.c
parent9b64639572ebb4b82fad10ae783f5351ef30a4a4 (diff)
downloadgdb-a394e3262fa7a03f9ca4e198044de683999457f0.zip
gdb-a394e3262fa7a03f9ca4e198044de683999457f0.tar.gz
gdb-a394e3262fa7a03f9ca4e198044de683999457f0.tar.bz2
* cgen-asm.c (cgen_parse_operand_fn): New global.
(cgen_parse_{{,un}signed_integer,address}): Update call to cgen_parse_operand_fn. (cgen_init_parse_operand): New function. * m32r-asm.c (parse_insn_normal): cgen_init_parse_operand renamed from cgen_asm_init_parse. (m32r_cgen_assemble_insn): New operand `errmsg'. Delete call to as_bad, return error message to caller. (m32r_cgen_asm_hash_keywords): #if 0 out.
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)
{