Subject: Vr4131 cache configuration
To: None <port-mips@netbsd.org>
From: TAKEMURA Shin <takemura@netbsd.org>
List: port-mips
Date: 12/16/2001 23:40:36
Hi,
I'm working on NEC's new MIPS CPU Vr4131.
Vr4131 has 2-way set-associative cache though Vr4131's
processor revision number on COP0 is same as other
Vr41xx which has direct-mapped cache. So, you must
distinguish Vr4131 from other Vr41xx in mips_config_cache().
You can use highest bit of MIPS_PRID_REV field.
I've made the patch (attached). I'd like to commit the patch
if no one objects.
Takemura
sys/arch/mips/mips/cache.c:
mips_config_cache(void)
{
/*
* Configure primary caches.
*/
switch (MIPS_PRID_IMPL(cpu_id)) {
<snipped>
case MIPS_R4000:
case MIPS_R4100:
case MIPS_R4300:
+ #ifdef MIPS3_4100
+ /*
+ * Vr4131 has cpu_id=0x0c80
+ * and R4600 style 2-way set-associative cache
+ */
+ if (!(MIPS_PRID_IMPL(cpu_id) == MIPS_R4100 &&
+ (MIPS_PRID_REV(cpu_id) & 0x80))) {
+ #endif
mips_picache_ways = 1;
mips_pdcache_ways = 1;
<snipped>
/* Virtually-indexed cache; no use for colors. */
break;
+ #ifdef MIPS3_4100
+ }
+ /* fall through if CPU is Vr4131 */
+ #endif
case MIPS_R4600:
case MIPS_RM5200:
mips_picache_ways = 2;
mips_pdcache_ways = 2;
EOF