|
@@ -149,9 +149,17 @@ void __update_cache(struct vm_area_struct *vma, unsigned long address,
|
|
|
return;
|
|
|
page = pfn_to_page(pfn);
|
|
|
if (page_mapping(page) && Page_dcache_dirty(page)) {
|
|
|
- addr = (unsigned long) page_address(page);
|
|
|
+ if (PageHighMem(page))
|
|
|
+ addr = (unsigned long)kmap_atomic(page);
|
|
|
+ else
|
|
|
+ addr = (unsigned long)page_address(page);
|
|
|
+
|
|
|
if (exec || pages_do_alias(addr, address & PAGE_MASK))
|
|
|
flush_data_cache_page(addr);
|
|
|
+
|
|
|
+ if (PageHighMem(page))
|
|
|
+ __kunmap_atomic((void *)addr);
|
|
|
+
|
|
|
ClearPageDcacheDirty(page);
|
|
|
}
|
|
|
}
|