The errata, unfortunately, doen't say.
It does say that the suggested workaround is to use the TLBP operation
to look for a matching but invalid entry, and then branch to the
invalid handler if necessary.
It also says that the CP0 Cause, EPC, BadVaddr and ENHI will wold the
values for the dstream TLB exception. In other words, it's all set up
for the invalid exception, but it jumps to the refill exception
Matthew D. Dharm Senior Software Designer
Momentum Computer Inc. 1815 Aston Ave. Suite 107
(760) 431-8663 X-115 Carlsbad, CA 92008-7310
Momentum Works For You www.momenco.com
> -----Original Message-----
> From: Justin Carlson [mailto:firstname.lastname@example.org]
> Sent: Wednesday, January 30, 2002 12:45 PM
> To: Matthew Dharm
> Cc: email@example.com
> Subject: RE: Does Linux invalidate TLB entries?
> On Wed, 2002-01-30 at 14:33, Matthew Dharm wrote:
> > Damn. The entire line of processors from the RM7000 to the 7000A,
> > 7000B, 7061A, and 7065A all have a bug which involves invalid TLB
> > entries.
> > I've sent the errata to Ralf only for review. Basically, under
> > certain circumstances the processor will take the "TLB refill"
> > exception vector instead of the "TLB invalid" vector.
> What's the behavior if the invalid entry is not fixed up
> and we replay
> the offending instruction? If there's a guarantee that it
> won't take
> the wrong vector repeatedly, then this would be trivial to
> fix (and may
> not need one at all for correctness).