[ARM] Feroceon: add highmem support to L2 cache handling code
authorNicolas Pitre <nico@cam.org>
Fri, 12 Sep 2008 20:11:51 +0000 (16:11 -0400)
committerNicolas Pitre <nico@cam.org>
Mon, 16 Mar 2009 01:01:21 +0000 (21:01 -0400)
commit1bb772679ffb0ba1ff1d40d8c6b855ab029f177d
treec76eb84a6f8df764f0c8e13d84964968c3ab10b7
parent58edb515724f9e63e569536d01ac8d8f8ddb367a
[ARM] Feroceon: add highmem support to L2 cache handling code

The choice is between looping over the physical range and performing
single cache line operations, or to map highmem pages somewhere, as
cache range ops are possible only on virtual addresses.

Because L2 range ops are much faster, we go with the later by factoring
the physical-to-virtual address conversion and use a fixmap entry for it
in the HIGHMEM case.

Possible future optimizations to avoid the pte setup cost:

 - do the pte setup for highmem pages only

 - determine a threshold for doing a line-by-line processing on physical
   addresses when the range is small

Signed-off-by: Nicolas Pitre <nico@marvell.com>
arch/arm/include/asm/kmap_types.h
arch/arm/mm/cache-feroceon-l2.c