nds32: Flush the cache of the page at vmaddr instead of kaddr in flush_anon_page
authorVincent Chen <vincentc@andestech.com>
Mon, 14 May 2018 08:56:53 +0000 (16:56 +0800)
committerGreentime Hu <greentime@andestech.com>
Wed, 23 May 2018 05:26:22 +0000 (13:26 +0800)
According to Documentation/cachetlb.txt, the cache of the page at vmaddr
shall be flushed in flush_anon_page instead of the cache of the page at
page_address(page).

Signed-off-by: Vincent Chen <vincentc@andestech.com>
Reviewed-by: Greentime Hu <greentime@andestech.com>
Signed-off-by: Greentime Hu <greentime@andestech.com>
arch/nds32/mm/cacheflush.c

index 02f25ee39c1d3f7af33000ea914a4721a1abf14d..ae31cd2c21be3903d01a15bb7b3a90db90a09916 100644 (file)
@@ -274,7 +274,7 @@ void copy_from_user_page(struct vm_area_struct *vma, struct page *page,
 void flush_anon_page(struct vm_area_struct *vma,
                     struct page *page, unsigned long vaddr)
 {
-       unsigned long flags;
+       unsigned long kaddr, flags, ktmp;
        if (!PageAnon(page))
                return;
 
@@ -284,7 +284,12 @@ void flush_anon_page(struct vm_area_struct *vma,
        local_irq_save(flags);
        if (vma->vm_flags & VM_EXEC)
                cpu_icache_inval_page(vaddr & PAGE_MASK);
-       cpu_dcache_wbinval_page((unsigned long)page_address(page));
+       kaddr = (unsigned long)page_address(page);
+       if (aliasing(vaddr, kaddr)) {
+               ktmp = kremap0(vaddr, page_to_phys(page));
+               cpu_dcache_wbinval_page(ktmp);
+               kunmap01(ktmp);
+       }
        local_irq_restore(flags);
 }