Subject: IDT MIPS_RC32364 support
To: None <port-mips@netbsd.org>
From: Chuck Cranor <chuck@research.att.com>
List: port-mips
Date: 08/29/2000 22:05:15
hi-
one of the groups here is looking at supporting the IDT MIPS_RC32364
core. (c.f. http://www.idt.com/products/pages/Processors-79RC32364.html)
the 32364 has a R4000'ish MMU, except that it doesn't support 64 bit
instructions. specifically, the differences are:
- the "Context", "BadVaddr", and "EntryHi" registers are all 32 bits
on the 32364 (rather than 64 bits as on the R4000)
- the 32364 does not have an "XContext" register
- 64-bit instructions such as "ld" and "dmfc0" are not implemented on
the 32364
the question is what to do with locore_mips3.S. clearly, the non-standard
use of "XContext" isn't going to work on the 32364. also, all the
64 bit instructions (e.g. dmtc0/dmfc0/ld) are going to have to go away
as well.
possible plans of action include:
- create a new locore file for the 32364 (selected at compile time)
or
- #ifdef the locore_mips3.S (also compile time)
or
- get rid of the non-standard XContext usage, and use self modifying
code to downgrade the dmtc0/dmfc0 instructions to mtc0/mfc0 (run time)
or
- something else?
are there any preferences on which direction to go in?
also, in the current locore_mips3.S, is it necessary to use
64 bit instrucions on 32 bit cp0 registers? (e.g. in the
mips3_TLBMiss vector "dmtc0" is used to write to MIPS_COP_0_TLB_LO1
which is a 32 bit register as far as i know ... why not use
"mtc0" instead?).
chuck