[parisc-linux] Re: RFC: mmap patch
David S. Miller
davem@redhat.com
Fri, 07 Mar 2003 22:29:45 -0800 (PST)
From: grundler@dsl2.external.hp.com (Grant Grundler)
Date: Fri, 7 Mar 2003 23:30:43 -0700
I don't pretend to understand the issues with virtual tags and
linux VM design, I just want to encourage the discussion since
I'd really like to see SMP work right on parisc.
If you flush caches exactly what sparc64 does in 2.5.x, and you do
have a virtually indexed, physically tagged cache, you should have no
correctness. I've stressed that port to no end (in particular the LTP
suite has a great mmap/read/write coherency tester), and if there are
holes I'd like to know about them :-)
The sparc64 port only flushes when absolutely necessary.
The most crucial area to get efficient flushing is the
{copy,clear}_user_page implementation. If you use temporary kernel
mappings mapped at virtual addresses matching the virtual color that
the user's mappings will have, this avoids virtually ALL of the
flushing for anonymous pages. I haven't noticed too many ports pick
up this trick even though I mention it in cachetlb.txt.
On sparc64 I even save the original TLB entries before the flush
and restore them afterwards, so there is no TLB traffic as a result
of doing these temp mappings.