diff options
author | Gerhard Pircher <gerhard_pircher@gmx.net> | 2009-01-23 01:51:28 -0500 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-01-28 01:15:52 -0500 |
commit | 4c456a67f501b8b15542c7c21c28812bf88f484b (patch) | |
tree | 0f1de24f488a59da4a7cc3445c89f8fe48b775aa | |
parent | 69b052e828b5ff32df7f96d6d3268a069910c663 (diff) |
powerpc/mm: Fix handling of _PAGE_COHERENT in BAT setup code
_PAGE_COHERENT is now always set in _PAGE_RAM resp. PAGE_KERNEL.
Thus it has to be masked out, if the BAT mapping should be non
cacheable or CPU_FTR_NEED_COHERENT is not set.
This will work on normal SMP setups because we force-set
CPU_FTR_NEED_COHERENT as part of CPU_FTR_COMMON on SMP.
Signed-off-by: Gerhard Pircher <gerhard_pircher@gmx.net>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
-rw-r--r-- | arch/powerpc/mm/ppc_mmu_32.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/arch/powerpc/mm/ppc_mmu_32.c b/arch/powerpc/mm/ppc_mmu_32.c index 45d925360b89..fe65c405412c 100644 --- a/arch/powerpc/mm/ppc_mmu_32.c +++ b/arch/powerpc/mm/ppc_mmu_32.c | |||
@@ -123,9 +123,9 @@ void __init setbat(int index, unsigned long virt, phys_addr_t phys, | |||
123 | int wimgxpp; | 123 | int wimgxpp; |
124 | struct ppc_bat *bat = BATS[index]; | 124 | struct ppc_bat *bat = BATS[index]; |
125 | 125 | ||
126 | if (((flags & _PAGE_NO_CACHE) == 0) && | 126 | if ((flags & _PAGE_NO_CACHE) || |
127 | cpu_has_feature(CPU_FTR_NEED_COHERENT)) | 127 | (cpu_has_feature(CPU_FTR_NEED_COHERENT) == 0)) |
128 | flags |= _PAGE_COHERENT; | 128 | flags &= ~_PAGE_COHERENT; |
129 | 129 | ||
130 | bl = (size >> 17) - 1; | 130 | bl = (size >> 17) - 1; |
131 | if (PVR_VER(mfspr(SPRN_PVR)) != 1) { | 131 | if (PVR_VER(mfspr(SPRN_PVR)) != 1) { |