Commit f1f7ea35 authored by Russell King's avatar Russell King

[ARM] Optimise __flush_dcache_page calls.

parent 10e15af6
...@@ -13,13 +13,11 @@ ...@@ -13,13 +13,11 @@
#include <asm/cacheflush.h> #include <asm/cacheflush.h>
static void __flush_dcache_page(struct page *page) static void __flush_dcache_page(struct address_space *mapping, struct page *page)
{ {
struct address_space *mapping = page_mapping(page);
struct mm_struct *mm = current->active_mm; struct mm_struct *mm = current->active_mm;
struct vm_area_struct *mpnt; struct vm_area_struct *mpnt;
struct prio_tree_iter iter; struct prio_tree_iter iter;
unsigned long offset;
pgoff_t pgoff; pgoff_t pgoff;
__cpuc_flush_dcache_page(page_address(page)); __cpuc_flush_dcache_page(page_address(page));
...@@ -35,6 +33,8 @@ static void __flush_dcache_page(struct page *page) ...@@ -35,6 +33,8 @@ static void __flush_dcache_page(struct page *page)
flush_dcache_mmap_lock(mapping); flush_dcache_mmap_lock(mapping);
vma_prio_tree_foreach(mpnt, &iter, &mapping->i_mmap, pgoff, pgoff) { vma_prio_tree_foreach(mpnt, &iter, &mapping->i_mmap, pgoff, pgoff) {
unsigned long offset;
/* /*
* If this VMA is not in our MM, we can ignore it. * If this VMA is not in our MM, we can ignore it.
*/ */
...@@ -55,6 +55,6 @@ void flush_dcache_page(struct page *page) ...@@ -55,6 +55,6 @@ void flush_dcache_page(struct page *page)
if (mapping && !mapping_mapped(mapping)) if (mapping && !mapping_mapped(mapping))
set_bit(PG_dcache_dirty, &page->flags); set_bit(PG_dcache_dirty, &page->flags);
else else
__flush_dcache_page(page); __flush_dcache_page(mapping, page);
} }
EXPORT_SYMBOL(flush_dcache_page); EXPORT_SYMBOL(flush_dcache_page);
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