Commit f9e2bdfd authored by Paul Mundt's avatar Paul Mundt

sh: Factor in cpu id for selection of cache colour fixmap.

In the SMP VIPT case the page copy/clear ops still perform colouring,
care needs to be taken that CPUs don't end up stepping on each other,
so we give them a bit of room to work with.

At the same time, we reduce the worst-case colouring given that these
pages are always consumed.
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent c4845a4b
...@@ -14,9 +14,9 @@ ...@@ -14,9 +14,9 @@
#define _ASM_FIXMAP_H #define _ASM_FIXMAP_H
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/threads.h>
#include <asm/page.h> #include <asm/page.h>
#ifdef CONFIG_HIGHMEM #ifdef CONFIG_HIGHMEM
#include <linux/threads.h>
#include <asm/kmap_types.h> #include <asm/kmap_types.h>
#endif #endif
...@@ -46,9 +46,9 @@ ...@@ -46,9 +46,9 @@
* fix-mapped? * fix-mapped?
*/ */
enum fixed_addresses { enum fixed_addresses {
#define FIX_N_COLOURS 16 #define FIX_N_COLOURS 8
FIX_CMAP_BEGIN, FIX_CMAP_BEGIN,
FIX_CMAP_END = FIX_CMAP_BEGIN + FIX_N_COLOURS, FIX_CMAP_END = FIX_CMAP_BEGIN + (FIX_N_COLOURS * NR_CPUS),
FIX_UNCACHED, FIX_UNCACHED,
#ifdef CONFIG_HIGHMEM #ifdef CONFIG_HIGHMEM
FIX_KMAP_BEGIN, /* reserved pte's for temporary kernel mappings */ FIX_KMAP_BEGIN, /* reserved pte's for temporary kernel mappings */
......
...@@ -39,7 +39,9 @@ void *kmap_coherent(struct page *page, unsigned long addr) ...@@ -39,7 +39,9 @@ void *kmap_coherent(struct page *page, unsigned long addr)
pagefault_disable(); pagefault_disable();
idx = FIX_CMAP_END - idx = FIX_CMAP_END -
((addr & current_cpu_data.dcache.alias_mask) >> PAGE_SHIFT); (((addr >> PAGE_SHIFT) & (FIX_N_COLOURS - 1)) +
(FIX_N_COLOURS * smp_processor_id()));
vaddr = __fix_to_virt(idx); vaddr = __fix_to_virt(idx);
BUG_ON(!pte_none(*(kmap_coherent_pte - idx))); BUG_ON(!pte_none(*(kmap_coherent_pte - idx)));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment