aboutsummaryrefslogtreecommitdiff
path: root/sim/mips/interp.c
diff options
context:
space:
mode:
authorFrank Ch. Eigler <fche@redhat.com>1998-03-30 23:56:52 +0000
committerFrank Ch. Eigler <fche@redhat.com>1998-03-30 23:56:52 +0000
commit6ed00b060706ba0b2ef7cb68bd2d0275d846e99c (patch)
tree9e2e2562a6f684f0af89a96659e09b33c0a6f64d /sim/mips/interp.c
parent0d3e84dd9271c4f580107298b952f54c4c719303 (diff)
downloadgdb-6ed00b060706ba0b2ef7cb68bd2d0275d846e99c.zip
gdb-6ed00b060706ba0b2ef7cb68bd2d0275d846e99c.tar.gz
gdb-6ed00b060706ba0b2ef7cb68bd2d0275d846e99c.tar.bz2
* Continuing sky R5900 / COP2 work. Added extra sanitize tags to hide
128-bit MIPS part. [ChangeLog] Mon Mar 30 18:41:43 1998 Frank Ch. Eigler <fche@cygnus.com> * interp.c (decode_coproc): Continuing COP2 work. (cop_[ls]q): Hide 128-bit COP2 more. * sim-main.h (COP_[LS]Q): Hide 128-bit COP2 more. [ChangeLog.sky] Mon Mar 30 18:44:15 1998 Frank Ch. Eigler <fche@cygnus.com> * sky-libvpe.c: Code too wide - ran indent on SCEI code. * sky-vu.h (vu0_busy*, vu0_macro*): New entry points for COP2 interface. * sky-vu.c (vu0_busy*, vu0_macro*): Stub functions for above.
Diffstat (limited to 'sim/mips/interp.c')
-rw-r--r--sim/mips/interp.c149
1 files changed, 95 insertions, 54 deletions
diff --git a/sim/mips/interp.c b/sim/mips/interp.c
index cd8a8af..6140938 100644
--- a/sim/mips/interp.c
+++ b/sim/mips/interp.c
@@ -3248,6 +3248,8 @@ cop_ld (SIM_DESC sd,
}
+/* start-sanitize-sky */
+#ifdef TARGET_SKY
void
cop_lq (SIM_DESC sd,
sim_cpu *cpu,
@@ -3258,11 +3260,9 @@ cop_lq (SIM_DESC sd,
{
switch (coproc_num)
{
- /* start-sanitize-sky */
case 2:
/* XXX COP2 */
break;
- /* end-sanitize-sky */
default:
sim_io_printf(sd,"COP_LQ(%d,%d,??) at PC = 0x%s : TODO (architecture specific)\n",
@@ -3272,6 +3272,8 @@ cop_lq (SIM_DESC sd,
return;
}
+#endif /* TARGET_SKY */
+/* end-sanitize-sky */
unsigned int
@@ -3334,6 +3336,8 @@ cop_sd (SIM_DESC sd,
}
+/* start-sanitize-sky */
+#ifdef TARGET_SKY
unsigned128
cop_sq (SIM_DESC sd,
sim_cpu *cpu,
@@ -3341,14 +3345,12 @@ cop_sq (SIM_DESC sd,
int coproc_num,
int coproc_reg)
{
- unsigned128 value = {0, 0};
+ unsigned128 value = U16_8(0, 0);
switch (coproc_num)
{
- /* start-sanitize-sky */
case 2:
/* XXX COP2 */
break;
- /* end-sanitize-sky */
default:
sim_io_printf(sd,"COP_SQ(%d,%d) at PC = 0x%s : TODO (architecture specific)\n",
@@ -3358,6 +3360,8 @@ cop_sq (SIM_DESC sd,
return(value);
}
+#endif /* TARGET_SKY */
+/* end-sanitize-sky */
void
@@ -3513,9 +3517,9 @@ decode_coproc (SIM_DESC sd,
int i_15_11 = (instruction >> 11) & 0x1f;
int i_15_0 = instruction & 0xffff;
int i_10_1 = (instruction >> 1) & 0x3ff;
+ int i_5_0 = instruction & 0x03f;
int interlock = instruction & 0x01;
- unsigned_4 vpe_status = sim_core_read_aligned_4 (cpu, cia, read_map, VPE0_STAT);
- int vpe_busy = (vpe_status & 0x00000001);
+ int co = (instruction >> 25) & 0x01;
/* setup for semantic.c-like actions below */
typedef unsigned_4 instruction_word;
int CIA = cia;
@@ -3535,91 +3539,128 @@ decode_coproc (SIM_DESC sd,
if(i_25_21 == 0x08 && i_20_16 == 0x00) /* BC2F */
{
address_word offset = EXTEND16(i_15_0) << 2;
- if(! vpe_busy) DELAY_SLOT(cia + 4 + offset);
+ if(! vu0_busy()) DELAY_SLOT(cia + 4 + offset);
}
else if(i_25_21 == 0x08 && i_20_16==0x02) /* BC2FL */
{
address_word offset = EXTEND16(i_15_0) << 2;
- if(! vpe_busy) DELAY_SLOT(cia + 4 + offset);
+ if(! vu0_busy()) DELAY_SLOT(cia + 4 + offset);
else NULLIFY_NEXT_INSTRUCTION();
}
else if(i_25_21 == 0x08 && i_20_16 == 0x01) /* BC2T */
{
address_word offset = EXTEND16(i_15_0) << 2;
- if(vpe_busy) DELAY_SLOT(cia + 4 + offset);
+ if(vu0_busy()) DELAY_SLOT(cia + 4 + offset);
}
else if(i_25_21 == 0x08 && i_20_16 == 0x03) /* BC2TL */
{
address_word offset = EXTEND16(i_15_0) << 2;
- if(vpe_busy) DELAY_SLOT(cia + 4 + offset);
+ if(vu0_busy()) DELAY_SLOT(cia + 4 + offset);
else NULLIFY_NEXT_INSTRUCTION();
}
else if((i_25_21 == 0x02 && i_10_1 == 0x000) || /* CFC2 */
- (i_25_21 == 0x06 && i_10_1 == 0x000)) /* CTC2 */
+ (i_25_21 == 0x01)) /* QMFC2 */
{
int rt = i_20_16;
int id = i_15_11;
- int to_vu = (i_25_21 == 0x06); /* transfer direction */
address_word vu_cr_addr; /* VU control register address */
+ unsigned_4 data;
- if(interlock)
- while(vpe_busy)
- {
- vu0_issue(sd); /* advance one clock cycle */
- vpe_status = sim_core_read_aligned_4 (cpu, cia, read_map, VPE0_STAT);
- vpe_busy = vpe_status & 0x00000001;
- }
-
- /* compute VU register address */
- vu_cr_addr = VU0_MST + (id * 16);
-
- /* read or write word */
- if(to_vu) /* CTC2 */
+ /* interlock checking */
+ if(vu0_busy_in_macro_mode()) /* busy in macro mode */
{
- unsigned_4 data = GPR[rt];
- sim_core_write_aligned_4(cpu, cia, write_map, vu_cr_addr, data);
+ /* interlock bit invalid here */
+ if(interlock)
+ ; /* XXX: warning */
+
+ /* always check data hazard */
+ while(vu0_macro_hazard_check(id))
+ vu0_issue(sd);
}
- else /* CFC2 */
+ else if(vu0_busy_in_micro_mode() && interlock)
{
- unsigned_4 data = sim_core_read_aligned_4(cpu, cia, read_map, vu_cr_addr);
- GPR[rt] = EXTEND64(data);
+ while(vu0_busy_in_micro_mode())
+ vu0_issue(sd);
}
+
+ /* compute VU register address */
+ if(i_25_21 == 0x01) /* QMFC2 */
+ vu_cr_addr = VU0_VF00 + (id * 16);
+ else /* CFC2 */
+ vu_cr_addr = VU0_MST + (id * 16);
+
+ /* read or write word */
+ data = sim_core_read_aligned_4(cpu, cia, read_map, vu_cr_addr);
+ GPR[rt] = EXTEND64(data);
}
- else if((i_25_21 == 0x01) || /* QMFC2 */
- (i_25_21 == 0x05)) /* QMTC2 */
+ else if((i_25_21 == 0x06 && i_10_1 == 0x000) || /* CTC2 */
+ (i_25_21 == 0x05)) /* QMTC2 */
{
int rt = i_20_16;
int id = i_15_11;
- int to_vu = (i_25_21 == 0x05); /* transfer direction */
address_word vu_cr_addr; /* VU control register address */
+ unsigned_4 data;
- if(interlock)
- while(vpe_busy)
- {
- vu0_issue(sd); /* advance one clock cycle */
- vpe_status = sim_core_read_aligned_4 (cpu, cia, read_map, VPE0_STAT);
- vpe_busy = vpe_status & 0x00000001;
- }
-
- /* compute VU register address */
- vu_cr_addr = VU0_VF00 + (id * 16);
-
- /* read or write word */
- if(to_vu) /* CTC2 */
+ /* interlock checking */
+ if(vu0_busy_in_macro_mode()) /* busy in macro mode */
{
- unsigned_4 data = GPR[rt];
- sim_core_write_aligned_4(cpu, cia, write_map, vu_cr_addr, data);
+ /* interlock bit invalid here */
+ if(interlock)
+ ; /* XXX: warning */
+
+ /* always check data hazard */
+ while(vu0_macro_hazard_check(id))
+ vu0_issue(sd);
}
- else /* CFC2 */
+ else if(vu0_busy_in_micro_mode())
{
- unsigned_4 data = sim_core_read_aligned_4(cpu, cia, read_map, vu_cr_addr);
- GPR[rt] = EXTEND64(data);
+ if(interlock)
+ {
+ while(! vu0_micro_interlock_released())
+ vu0_issue(sd);
+ }
}
+
+ /* compute VU register address */
+ if(i_25_21 == 0x05) /* QMTC2 */
+ vu_cr_addr = VU0_VF00 + (id * 16);
+ else /* CTC2 */
+ vu_cr_addr = VU0_MST + (id * 16);
+
+ data = GPR[rt];
+ sim_core_write_aligned_4(cpu, cia, write_map, vu_cr_addr, data);
+ }
+ else if( 0 /* XXX: ... upper ... */)
+ {
+ unsigned_4 vu_upper, vu_lower;
+ vu_upper =
+ 0x00000000 | /* bits 31 .. 25 */
+ instruction & 0x01ffffff; /* bits 24 .. 0 */
+ vu_lower = 0x8000033c; /* NOP */
+
+ while(vu0_busy_in_micro_mode())
+ vu0_issue(sd);
+
+ vu0_macro_issue(vu_upper, vu_lower);
+ }
+ else if( 0 /* XXX: ... lower ... */)
+ {
+ unsigned_4 vu_upper, vu_lower;
+ vu_upper = 0x000002ff; /* NOP */
+ vu_lower =
+ 0x10000000 | /* bits 31 .. 25 */
+ instruction & 0x01ffffff; /* bits 24 .. 0 */
+
+ while(vu0_busy_in_micro_mode())
+ vu0_issue(sd);
+
+ vu0_macro_issue(vu_upper, vu_lower);
}
- /* other COP2 instructions */
+ /* XXX */
+ /* ... other COP2 instructions ... */
else
{
- SignalException(ReservedInstruction,instruction);
+ SignalException(ReservedInstruction, instruction);
/* NOTREACHED */
}