public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Properly implement flush_dcache_page in 2.4?  (Or is it possible?)
@ 2003-05-30 17:32 Jun Sun
  2003-05-30 18:09 ` Russell King
  0 siblings, 1 reply; 10+ messages in thread
From: Jun Sun @ 2003-05-30 17:32 UTC (permalink / raw)
  To: linux-kernel; +Cc: jsun, Ralf Baechle


My understanding is that if a page is mapped in both user space
and kernel space flush_dcache_page() is used to ensure those mappings
are consistent to each other.

In other words, if the page is modified in user space, kernel needs
to call flush_dcache_page() in order to see the change properly. 
Vice versa.

One immediate problem we have is that given the struct page
pointer argument to this function we have no way of knowing the user 
space virture address of that page (without searching through the whole
page table).  And worse, we might have multiple mappings of the same
page to different user processes at the different virtual addresses.

If a MIPS cpu has a virtually-indexed dcache and has cache aliasing 
problem, we need to know those user space vritual addresses
to flush this page properly.  I suspect some other CPU architectures 
should have this problem too.  True?

So my question is: how other CPU arches with the same problem
implement flush_dcache_page()?  Flushing the whole cache? Or
have a broken implementation and pretend it is OK?  :)

BTW, I assume this is not a big problem in 2.5 as we have reverse page
mapping.

Cheers.

Jun


^ permalink raw reply	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2003-05-31  9:54 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-05-30 17:32 Properly implement flush_dcache_page in 2.4? (Or is it possible?) Jun Sun
2003-05-30 18:09 ` Russell King
2003-05-30 23:00   ` Jun Sun
2003-05-30 23:14     ` Russell King
2003-05-31  0:18       ` Jun Sun
2003-05-31  7:24       ` Hugh Dickins
2003-05-31  7:52         ` Russell King
2003-05-31  8:33           ` Hugh Dickins
2003-05-31  9:19             ` Russell King
2003-05-31 10:09               ` Hugh Dickins

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox