diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2005-11-07 03:58:28 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-11-07 10:53:28 -0500 |
| commit | 0d6d82b6712c808e461090dd483f111f72b3b38b (patch) | |
| tree | b1450b08d1eb638865921d0b1020af0b579f7435 /arch/sh | |
| parent | 65463b73b14ed43368dc5961a6c3dcb0d98cfe1f (diff) | |
[PATCH] sh: Use pfn_valid() for lazy dcache write-back on SH7705
SH7705 in extended cache mode has some left-over VALID_PAGE() cruft that it
checks when doing lazy dcache write-back. This has been gone for some time
(the last bits were in the discontig code, which should now also be gone --
this also fixes up a build error in the non-discontig case).
pfn_valid() gives the desired behaviour, so we switch to that.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/sh')
| -rw-r--r-- | arch/sh/mm/tlb-sh3.c | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/arch/sh/mm/tlb-sh3.c b/arch/sh/mm/tlb-sh3.c index 7a0d5c10bf20..46b09e26e082 100644 --- a/arch/sh/mm/tlb-sh3.c +++ b/arch/sh/mm/tlb-sh3.c | |||
| @@ -40,12 +40,17 @@ void update_mmu_cache(struct vm_area_struct * vma, | |||
| 40 | return; | 40 | return; |
| 41 | 41 | ||
| 42 | #if defined(CONFIG_SH7705_CACHE_32KB) | 42 | #if defined(CONFIG_SH7705_CACHE_32KB) |
| 43 | struct page *page; | 43 | { |
| 44 | page = pte_page(pte); | 44 | struct page *page = pte_page(pte); |
| 45 | if (VALID_PAGE(page) && !test_bit(PG_mapped, &page->flags)) { | 45 | unsigned long pfn = pte_pfn(pte); |
| 46 | unsigned long phys = pte_val(pte) & PTE_PHYS_MASK; | 46 | |
| 47 | __flush_wback_region((void *)P1SEGADDR(phys), PAGE_SIZE); | 47 | if (pfn_valid(pfn) && !test_bit(PG_mapped, &page->flags)) { |
| 48 | __set_bit(PG_mapped, &page->flags); | 48 | unsigned long phys = pte_val(pte) & PTE_PHYS_MASK; |
| 49 | |||
| 50 | __flush_wback_region((void *)P1SEGADDR(phys), | ||
| 51 | PAGE_SIZE); | ||
| 52 | __set_bit(PG_mapped, &page->flags); | ||
| 53 | } | ||
| 49 | } | 54 | } |
| 50 | #endif | 55 | #endif |
| 51 | 56 | ||
| @@ -80,7 +85,7 @@ void __flush_tlb_page(unsigned long asid, unsigned long page) | |||
| 80 | */ | 85 | */ |
| 81 | addr = MMU_TLB_ADDRESS_ARRAY | (page & 0x1F000); | 86 | addr = MMU_TLB_ADDRESS_ARRAY | (page & 0x1F000); |
| 82 | data = (page & 0xfffe0000) | asid; /* VALID bit is off */ | 87 | data = (page & 0xfffe0000) | asid; /* VALID bit is off */ |
| 83 | 88 | ||
| 84 | if ((cpu_data->flags & CPU_HAS_MMU_PAGE_ASSOC)) { | 89 | if ((cpu_data->flags & CPU_HAS_MMU_PAGE_ASSOC)) { |
| 85 | addr |= MMU_PAGE_ASSOC_BIT; | 90 | addr |= MMU_PAGE_ASSOC_BIT; |
| 86 | ways = 1; /* we already know the way .. */ | 91 | ways = 1; /* we already know the way .. */ |
