aboutsummaryrefslogtreecommitdiff
path: root/sim
diff options
context:
space:
mode:
Diffstat (limited to 'sim')
-rw-r--r--sim/v850/ChangeLog9
-rw-r--r--sim/v850/Makefile.in2
-rw-r--r--sim/v850/simops.c286
3 files changed, 133 insertions, 164 deletions
diff --git a/sim/v850/ChangeLog b/sim/v850/ChangeLog
index 5e979d8..1320ab3 100644
--- a/sim/v850/ChangeLog
+++ b/sim/v850/ChangeLog
@@ -1,3 +1,12 @@
+Tue Sep 16 15:14:01 1997 Andrew Cagney <cagney@b1.cygnus.com>
+
+ * simops.c (trace_pc, trace_name, trace_values, trace_num_values):
+ New static globals.
+ (trace_input): Just save pc, name and values for trace_output.
+ (trace_output): Write trace values to a buffer. Use
+ trace_one_insn to print trace info and buffer.
+ (SIZE_OPERANDS, SIZE_LOCATION): Delete.
+
Tue Sep 16 09:02:00 1997 Andrew Cagney <cagney@b1.cygnus.com>
* sim-main.h (struct _sim_cpu): Add psw_mask so that reserved bits
diff --git a/sim/v850/Makefile.in b/sim/v850/Makefile.in
index ad3355b..8100e8b 100644
--- a/sim/v850/Makefile.in
+++ b/sim/v850/Makefile.in
@@ -108,7 +108,7 @@ clean-igen:
../igen/igen:
cd ../igen && $(MAKE)
-IGEN_TRACE= # -G trace-rule-selection -G trace-rule-rejection -G trace-entries
+IGEN_TRACE= -G omit-line-numbers # -G trace-rule-selection -G trace-rule-rejection -G trace-entries
IGEN_INSN=$(srcdir)/v850.igen
IGEN_DC=$(srcdir)/v850-dc
tmp-igen: $(IGEN_INSN) $(IGEN_DC) ../igen/igen
diff --git a/sim/v850/simops.c b/sim/v850/simops.c
index 93b0407..583d1a5 100644
--- a/sim/v850/simops.c
+++ b/sim/v850/simops.c
@@ -56,20 +56,18 @@ int type3_regs[15] = { 2, 1, 0, 27, 26, 25, 24, 31, 30, 29, 28, 23, 22, 20, 21};
#ifdef DEBUG
#ifndef SIZE_INSTRUCTION
-#define SIZE_INSTRUCTION 6
-#endif
-
-#ifndef SIZE_OPERANDS
-#define SIZE_OPERANDS 16
+#define SIZE_INSTRUCTION 18
#endif
#ifndef SIZE_VALUES
#define SIZE_VALUES 11
#endif
-#ifndef SIZE_LOCATION
-#define SIZE_LOCATION 40
-#endif
+
+static unsigned32 trace_values[3];
+static int trace_num_values;
+static unsigned32 trace_pc;
+static char *trace_name;
void
@@ -78,61 +76,12 @@ trace_input (name, type, size)
enum op_types type;
int size;
{
- char buf[1024];
- char *p;
- uint32 values[3];
- int num_values, i;
- const char *filename;
- const char *functionname;
- unsigned int linenumber;
if (!TRACE_ALU_P (STATE_CPU (simulator, 0)))
return;
- buf[0] = '\0';
-
- if (STATE_TEXT_SECTION (simulator)
- && PC >= STATE_TEXT_START (simulator)
- && PC < STATE_TEXT_END (simulator))
- {
- filename = (const char *)0;
- functionname = (const char *)0;
- linenumber = 0;
- if (bfd_find_nearest_line (STATE_PROG_BFD (simulator),
- STATE_TEXT_SECTION (simulator),
- (struct symbol_cache_entry **)0,
- PC - STATE_TEXT_START (simulator),
- &filename, &functionname, &linenumber))
- {
- p = buf;
- if (linenumber)
- {
- sprintf (p, "Line %5d ", linenumber);
- p += strlen (p);
- }
-
- if (functionname)
- {
- sprintf (p, "Func %s ", functionname);
- p += strlen (p);
- }
- else if (filename)
- {
- char *q = (char *) strrchr (filename, '/');
- sprintf (p, "File %s ", (q) ? q+1 : filename);
- p += strlen (p);
- }
-
- if (*p == ' ')
- *p = '\0';
- }
- }
-
- trace_printf (simulator, STATE_CPU (simulator, 0),
- "0x%.8x: %-*.*s %-*s",
- (unsigned)PC,
- SIZE_LOCATION, SIZE_LOCATION, buf,
- SIZE_INSTRUCTION, name);
+ trace_pc = PC;
+ trace_name = name;
switch (type)
{
@@ -140,13 +89,13 @@ trace_input (name, type, size)
case OP_UNKNOWN:
case OP_NONE:
case OP_TRAP:
- num_values = 0;
+ trace_num_values = 0;
break;
case OP_REG:
case OP_REG_REG_MOVE:
- values[0] = State.regs[OP[0]];
- num_values = 1;
+ trace_values[0] = State.regs[OP[0]];
+ trace_num_values = 1;
break;
/* start-sanitize-v850e */
@@ -154,167 +103,178 @@ trace_input (name, type, size)
/* end-sanitize-v850e */
case OP_REG_REG:
case OP_REG_REG_CMP:
- values[0] = State.regs[OP[1]];
- values[1] = State.regs[OP[0]];
- num_values = 2;
+ trace_values[0] = State.regs[OP[1]];
+ trace_values[1] = State.regs[OP[0]];
+ trace_num_values = 2;
break;
case OP_IMM_REG:
case OP_IMM_REG_CMP:
- values[0] = SEXT5 (OP[0]);
- values[1] = OP[1];
- num_values = 2;
+ trace_values[0] = SEXT5 (OP[0]);
+ trace_values[1] = OP[1];
+ trace_num_values = 2;
break;
case OP_IMM_REG_MOVE:
- values[0] = SEXT5 (OP[0]);
- num_values = 1;
+ trace_values[0] = SEXT5 (OP[0]);
+ trace_num_values = 1;
break;
case OP_COND_BR:
- values[0] = State.pc;
- values[1] = SEXT9 (OP[0]);
- values[2] = PSW;
- num_values = 3;
+ trace_values[0] = State.pc;
+ trace_values[1] = SEXT9 (OP[0]);
+ trace_values[2] = PSW;
+ trace_num_values = 3;
break;
case OP_LOAD16:
- values[0] = OP[1] * size;
- values[1] = State.regs[30];
- num_values = 2;
+ trace_values[0] = OP[1] * size;
+ trace_values[1] = State.regs[30];
+ trace_num_values = 2;
break;
case OP_STORE16:
- values[0] = State.regs[OP[0]];
- values[1] = OP[1] * size;
- values[2] = State.regs[30];
- num_values = 3;
+ trace_values[0] = State.regs[OP[0]];
+ trace_values[1] = OP[1] * size;
+ trace_values[2] = State.regs[30];
+ trace_num_values = 3;
break;
case OP_LOAD32:
- values[0] = EXTEND16 (OP[2]);
- values[1] = State.regs[OP[0]];
- num_values = 2;
+ trace_values[0] = EXTEND16 (OP[2]);
+ trace_values[1] = State.regs[OP[0]];
+ trace_num_values = 2;
break;
case OP_STORE32:
- values[0] = State.regs[OP[1]];
- values[1] = EXTEND16 (OP[2]);
- values[2] = State.regs[OP[0]];
- num_values = 3;
+ trace_values[0] = State.regs[OP[1]];
+ trace_values[1] = EXTEND16 (OP[2]);
+ trace_values[2] = State.regs[OP[0]];
+ trace_num_values = 3;
break;
case OP_JUMP:
- values[0] = SEXT22 (OP[0]);
- values[1] = State.pc;
- num_values = 2;
+ trace_values[0] = SEXT22 (OP[0]);
+ trace_values[1] = State.pc;
+ trace_num_values = 2;
break;
case OP_IMM_REG_REG:
- values[0] = EXTEND16 (OP[0]) << size;
- values[1] = State.regs[OP[1]];
- num_values = 2;
+ trace_values[0] = EXTEND16 (OP[0]) << size;
+ trace_values[1] = State.regs[OP[1]];
+ trace_num_values = 2;
break;
case OP_UIMM_REG_REG:
- values[0] = (OP[0] & 0xffff) << size;
- values[1] = State.regs[OP[1]];
- num_values = 2;
+ trace_values[0] = (OP[0] & 0xffff) << size;
+ trace_values[1] = State.regs[OP[1]];
+ trace_num_values = 2;
break;
case OP_BIT:
- num_values = 0;
+ trace_num_values = 0;
break;
case OP_EX1:
- values[0] = PSW;
- num_values = 1;
+ trace_values[0] = PSW;
+ trace_num_values = 1;
break;
case OP_EX2:
- num_values = 0;
+ trace_num_values = 0;
break;
case OP_LDSR:
- values[0] = State.regs[OP[0]];
- num_values = 1;
+ trace_values[0] = State.regs[OP[0]];
+ trace_num_values = 1;
break;
case OP_STSR:
- values[0] = State.sregs[OP[1]];
- num_values = 1;
+ trace_values[0] = State.sregs[OP[1]];
+ trace_num_values = 1;
}
- for (i = 0; i < num_values; i++)
- trace_printf (simulator, STATE_CPU (simulator, 0),
- "%*s0x%.8lx", SIZE_VALUES - 10, "", values[i]);
-
- while (i++ < 3)
- trace_printf (simulator, STATE_CPU (simulator, 0),
- "%*s", SIZE_VALUES, "");
}
void
trace_output (result)
enum op_types result;
{
- if (TRACE_ALU_P (STATE_CPU (simulator, 0)))
- {
- switch (result)
- {
- default:
- case OP_UNKNOWN:
- case OP_NONE:
- case OP_TRAP:
- case OP_REG:
- case OP_REG_REG_CMP:
- case OP_IMM_REG_CMP:
- case OP_COND_BR:
- case OP_STORE16:
- case OP_STORE32:
- case OP_BIT:
- case OP_EX2:
- break;
-
- case OP_LOAD16:
- case OP_STSR:
- trace_printf (simulator, STATE_CPU (simulator, 0),
- " :: 0x%.8lx", (unsigned long)State.regs[OP[0]]);
- break;
+ char buf[1000];
+ char *chp;
- case OP_REG_REG:
- case OP_REG_REG_MOVE:
- case OP_IMM_REG:
- case OP_IMM_REG_MOVE:
- case OP_LOAD32:
- case OP_EX1:
- trace_printf (simulator, STATE_CPU (simulator, 0),
- " :: 0x%.8lx", (unsigned long)State.regs[OP[1]]);
- break;
-
- case OP_IMM_REG_REG:
- case OP_UIMM_REG_REG:
- trace_printf (simulator, STATE_CPU (simulator, 0),
- " :: 0x%.8lx", (unsigned long)State.regs[OP[2]]);
- break;
+ if (!TRACE_ALU_P (STATE_CPU (simulator, 0)))
+ return;
- case OP_JUMP:
- if (OP[1] != 0)
- trace_printf (simulator, STATE_CPU (simulator, 0),
- " :: 0x%.8lx", (unsigned long)State.regs[OP[1]]);
- break;
+ buf[0] = '\0';
+ chp = buf;
- case OP_LDSR:
- trace_printf (simulator, STATE_CPU (simulator, 0),
- " :: 0x%.8lx", (unsigned long)State.sregs[OP[1]]);
- break;
- }
+ /* write out the values saved during the trace_input call */
+ {
+ int i;
+ for (i = 0; i < trace_num_values; i++)
+ {
+ sprintf (chp, "%*s0x%.8lx", SIZE_VALUES - 10, "", trace_values[i]);
+ chp = strchr (chp, '\0');
+ }
+ while (i++ < 3)
+ {
+ sprintf (chp, "%*s", SIZE_VALUES, "");
+ chp = strchr (chp, '\0');
+ }
+ }
- trace_printf (simulator, STATE_CPU (simulator, 0),
- "\n");
+ switch (result)
+ {
+ default:
+ case OP_UNKNOWN:
+ case OP_NONE:
+ case OP_TRAP:
+ case OP_REG:
+ case OP_REG_REG_CMP:
+ case OP_IMM_REG_CMP:
+ case OP_COND_BR:
+ case OP_STORE16:
+ case OP_STORE32:
+ case OP_BIT:
+ case OP_EX2:
+ break;
+
+ case OP_LOAD16:
+ case OP_STSR:
+ sprintf (chp, " :: 0x%.8lx", (unsigned long)State.regs[OP[0]]);
+ break;
+
+ case OP_REG_REG:
+ case OP_REG_REG_MOVE:
+ case OP_IMM_REG:
+ case OP_IMM_REG_MOVE:
+ case OP_LOAD32:
+ case OP_EX1:
+ sprintf (chp, " :: 0x%.8lx", (unsigned long)State.regs[OP[1]]);
+ break;
+
+ case OP_IMM_REG_REG:
+ case OP_UIMM_REG_REG:
+ sprintf (chp, " :: 0x%.8lx", (unsigned long)State.regs[OP[2]]);
+ break;
+
+ case OP_JUMP:
+ if (OP[1] != 0)
+ sprintf (chp, " :: 0x%.8lx", (unsigned long)State.regs[OP[1]]);
+ break;
+
+ case OP_LDSR:
+ sprintf (chp, " :: 0x%.8lx", (unsigned long)State.sregs[OP[1]]);
+ break;
}
-}
+
+ trace_one_insn (simulator, STATE_CPU (simulator, 0), trace_pc,
+ TRACE_LINENUM_P (STATE_CPU (simulator, 0)),
+ "simops", __LINE__, "alu",
+ "%-*s -%s", SIZE_INSTRUCTION, trace_name, buf);
+}
#endif