aboutsummaryrefslogtreecommitdiff
path: root/opcodes/tic4x-dis.c
diff options
context:
space:
mode:
Diffstat (limited to 'opcodes/tic4x-dis.c')
-rw-r--r--opcodes/tic4x-dis.c113
1 files changed, 81 insertions, 32 deletions
diff --git a/opcodes/tic4x-dis.c b/opcodes/tic4x-dis.c
index eff4ebb..9eda876 100644
--- a/opcodes/tic4x-dis.c
+++ b/opcodes/tic4x-dis.c
@@ -49,8 +49,41 @@ indirect_t;
static int c4x_version = 0;
static int c4x_dp = 0;
+static int c4x_pc_offset
+ PARAMS ((unsigned int));
+static int c4x_print_char
+ PARAMS ((struct disassemble_info *, char));
+static int c4x_print_str
+ PARAMS ((struct disassemble_info *, char *));
+static int c4x_print_register
+ PARAMS ((struct disassemble_info *, unsigned long));
+static int c4x_print_addr
+ PARAMS ((struct disassemble_info *, unsigned long));
+static int c4x_print_relative
+ PARAMS ((struct disassemble_info *, unsigned long, long, unsigned long));
+void c4x_print_ftoa
+ PARAMS ((unsigned int, FILE *, fprintf_ftype));
+static int c4x_print_direct
+ PARAMS ((struct disassemble_info *, unsigned long));
+static int c4x_print_immed
+ PARAMS ((struct disassemble_info *, immed_t, unsigned long));
+static int c4x_print_cond
+ PARAMS ((struct disassemble_info *, unsigned int));
+static int c4x_print_indirect
+ PARAMS ((struct disassemble_info *, indirect_t, unsigned long));
+static int c4x_print_op
+ PARAMS ((struct disassemble_info *, unsigned long, c4x_inst_t *, unsigned long));
+static void c4x_hash_opcode
+ PARAMS ((c4x_inst_t **, const c4x_inst_t *));
+static int c4x_disassemble
+ PARAMS ((unsigned long, unsigned long, struct disassemble_info *));
+int print_insn_tic4x
+ PARAMS ((bfd_vma, struct disassemble_info *));
+
+
static int
-c4x_pc_offset (unsigned int op)
+c4x_pc_offset (op)
+ unsigned int op;
{
/* Determine the PC offset for a C[34]x instruction.
This could be simplified using some boolean algebra
@@ -107,7 +140,9 @@ c4x_pc_offset (unsigned int op)
}
static int
-c4x_print_char (struct disassemble_info * info, char ch)
+c4x_print_char (info, ch)
+ struct disassemble_info * info;
+ char ch;
{
if (info != NULL)
(*info->fprintf_func) (info->stream, "%c", ch);
@@ -115,7 +150,9 @@ c4x_print_char (struct disassemble_info * info, char ch)
}
static int
-c4x_print_str (struct disassemble_info *info, char *str)
+c4x_print_str (info, str)
+ struct disassemble_info *info;
+ char *str;
{
if (info != NULL)
(*info->fprintf_func) (info->stream, "%s", str);
@@ -123,8 +160,9 @@ c4x_print_str (struct disassemble_info *info, char *str)
}
static int
-c4x_print_register (struct disassemble_info *info,
- unsigned long regno)
+c4x_print_register (info, regno)
+ struct disassemble_info *info;
+ unsigned long regno;
{
static c4x_register_t **registertable = NULL;
unsigned int i;
@@ -151,8 +189,9 @@ c4x_print_register (struct disassemble_info *info,
}
static int
-c4x_print_addr (struct disassemble_info *info,
- unsigned long addr)
+c4x_print_addr (info, addr)
+ struct disassemble_info *info;
+ unsigned long addr;
{
if (info != NULL)
(*info->print_address_func)(addr, info);
@@ -160,17 +199,19 @@ c4x_print_addr (struct disassemble_info *info,
}
static int
-c4x_print_relative (struct disassemble_info *info,
- unsigned long pc,
- long offset,
- unsigned long opcode)
+c4x_print_relative (info, pc, offset, opcode)
+ struct disassemble_info *info;
+ unsigned long pc;
+ long offset;
+ unsigned long opcode;
{
return c4x_print_addr (info, pc + offset + c4x_pc_offset (opcode));
}
static int
-c4x_print_direct (struct disassemble_info *info,
- unsigned long arg)
+c4x_print_direct (info, arg)
+ struct disassemble_info *info;
+ unsigned long arg;
{
if (info != NULL)
{
@@ -183,9 +224,10 @@ c4x_print_direct (struct disassemble_info *info,
/* FIXME: make the floating point stuff not rely on host
floating point arithmetic. */
void
-c4x_print_ftoa (unsigned int val,
- FILE *stream,
- int (*pfunc)())
+c4x_print_ftoa (val, stream, pfunc)
+ unsigned int val;
+ FILE *stream;
+ fprintf_ftype pfunc;
{
int e;
int s;
@@ -208,9 +250,10 @@ c4x_print_ftoa (unsigned int val,
}
static int
-c4x_print_immed (struct disassemble_info *info,
- immed_t type,
- unsigned long arg)
+c4x_print_immed (info, type, arg)
+ struct disassemble_info *info;
+ immed_t type;
+ unsigned long arg;
{
int s;
int f;
@@ -266,8 +309,9 @@ c4x_print_immed (struct disassemble_info *info,
}
static int
-c4x_print_cond (struct disassemble_info *info,
- unsigned int cond)
+c4x_print_cond (info, cond)
+ struct disassemble_info *info;
+ unsigned int cond;
{
static c4x_cond_t **condtable = NULL;
unsigned int i;
@@ -286,9 +330,10 @@ c4x_print_cond (struct disassemble_info *info,
}
static int
-c4x_print_indirect (struct disassemble_info *info,
- indirect_t type,
- unsigned long arg)
+c4x_print_indirect (info, type, arg)
+ struct disassemble_info *info;
+ indirect_t type;
+ unsigned long arg;
{
unsigned int aregno;
unsigned int modn;
@@ -349,9 +394,11 @@ c4x_print_indirect (struct disassemble_info *info,
}
static int
-c4x_print_op (struct disassemble_info *info,
- unsigned long instruction,
- c4x_inst_t *p, unsigned long pc)
+c4x_print_op (info, instruction, p, pc)
+ struct disassemble_info *info;
+ unsigned long instruction;
+ c4x_inst_t *p;
+ unsigned long pc;
{
int val;
char *s;
@@ -578,8 +625,9 @@ c4x_print_op (struct disassemble_info *info,
}
static void
-c4x_hash_opcode (c4x_inst_t **optable,
- const c4x_inst_t *inst)
+c4x_hash_opcode (optable, inst)
+ c4x_inst_t **optable;
+ const c4x_inst_t *inst;
{
int j;
int opcode = inst->opcode >> (32 - C4X_HASH_SIZE);
@@ -609,9 +657,10 @@ c4x_hash_opcode (c4x_inst_t **optable,
The function returns the length of this instruction in words. */
static int
-c4x_disassemble (unsigned long pc,
- unsigned long instruction,
- struct disassemble_info *info)
+c4x_disassemble (pc, instruction, info)
+ unsigned long pc;
+ unsigned long instruction;
+ struct disassemble_info *info;
{
static c4x_inst_t **optable = NULL;
c4x_inst_t *p;