Commit c8eae71d authored by Ralf Baechle's avatar Ralf Baechle

[MIPS] 20K: Handle WAIT related bugs according to errata information

We used to avoid the WAIT entirely on the 20K but really only need to do
this on early revs of the 20K.  Without this a 20K was a bit of a
power hog.  Well, in the lower power power hog category ;-)
Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent b0c10b9f
...@@ -137,7 +137,6 @@ static inline void check_wait(void) ...@@ -137,7 +137,6 @@ static inline void check_wait(void)
case CPU_4KEC: case CPU_4KEC:
case CPU_4KSC: case CPU_4KSC:
case CPU_5KC: case CPU_5KC:
/* case CPU_20KC:*/
case CPU_24K: case CPU_24K:
case CPU_25KF: case CPU_25KF:
case CPU_34K: case CPU_34K:
...@@ -156,6 +155,17 @@ static inline void check_wait(void) ...@@ -156,6 +155,17 @@ static inline void check_wait(void)
if (allow_au1k_wait) if (allow_au1k_wait)
cpu_wait = au1k_wait; cpu_wait = au1k_wait;
break; break;
case CPU_20KC:
/*
* WAIT on Rev1.0 has E1, E2, E3 and E16.
* WAIT on Rev2.0 and Rev3.0 has E16.
* Rev3.1 WAIT is nop, why bother
*/
if ((c->processor_id & 0xff) <= 0x64)
break;
cpu_wait = r4k_wait;
break;
case CPU_RM9000: case CPU_RM9000:
if ((c->processor_id & 0x00ff) >= 0x40) if ((c->processor_id & 0x00ff) >= 0x40)
cpu_wait = r4k_wait; cpu_wait = r4k_wait;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment