On Fri, May 02, 2003 at 04:56:44PM -0700, Jimmy Zhang wrote:
> It is pretty simple to make the WHOLE kseg0 cached or uncached. However,
> I only want part of kseg0 uncached.
> I must uncache that region because it gives me too much trouble with DMA
> data, however, I don't want to uncache the whole kseg0 segment in order
> to get better performance. Kseg0 is not mapped through TLB, so it seems
> I can't achieve my goal through TLB.
> Cite from the book See Mips Run, "if you feel that your system needs to
> make uncached references to cacheable memory, then I strongly recommand
> that you divide memory into regions that are always accessed uncached
> and regions that are always accessed through the cache - and don't let
> them overlap. " But how ?
By not using KSEG0 for all your data. As you figured the caching mode only
can only modifed for the entire KSEG0. And because some part of your
code such as exception handlers will always run in KSEG0 you never want
to switch KSEG0 to uncached. Easy solution, KSEG1 maps the same address
space as KSEG0 but is always uncached. The usual warning applies, using
uncached memory is a bad idea in most cases.