aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/parisc/include/asm/cacheflush.h2
-rw-r--r--arch/parisc/include/asm/page.h3
-rw-r--r--arch/parisc/kernel/cache.c14
3 files changed, 16 insertions, 3 deletions
diff --git a/arch/parisc/include/asm/cacheflush.h b/arch/parisc/include/asm/cacheflush.h
index 2f9b751878ba..de65f66ea64e 100644
--- a/arch/parisc/include/asm/cacheflush.h
+++ b/arch/parisc/include/asm/cacheflush.h
@@ -132,7 +132,6 @@ void mark_rodata_ro(void);
132static inline void *kmap(struct page *page) 132static inline void *kmap(struct page *page)
133{ 133{
134 might_sleep(); 134 might_sleep();
135 flush_dcache_page(page);
136 return page_address(page); 135 return page_address(page);
137} 136}
138 137
@@ -144,7 +143,6 @@ static inline void kunmap(struct page *page)
144static inline void *kmap_atomic(struct page *page) 143static inline void *kmap_atomic(struct page *page)
145{ 144{
146 pagefault_disable(); 145 pagefault_disable();
147 flush_dcache_page(page);
148 return page_address(page); 146 return page_address(page);
149} 147}
150 148
diff --git a/arch/parisc/include/asm/page.h b/arch/parisc/include/asm/page.h
index c53fc63149e8..637fe031aa84 100644
--- a/arch/parisc/include/asm/page.h
+++ b/arch/parisc/include/asm/page.h
@@ -29,7 +29,8 @@ struct page;
29void clear_page_asm(void *page); 29void clear_page_asm(void *page);
30void copy_page_asm(void *to, void *from); 30void copy_page_asm(void *to, void *from);
31#define clear_user_page(vto, vaddr, page) clear_page_asm(vto) 31#define clear_user_page(vto, vaddr, page) clear_page_asm(vto)
32#define copy_user_page(vto, vfrom, vaddr, page) copy_page_asm(vto, vfrom) 32void copy_user_page(void *vto, void *vfrom, unsigned long vaddr,
33 struct page *pg);
33 34
34/* #define CONFIG_PARISC_TMPALIAS */ 35/* #define CONFIG_PARISC_TMPALIAS */
35 36
diff --git a/arch/parisc/kernel/cache.c b/arch/parisc/kernel/cache.c
index a72545554a31..ac87a40502e6 100644
--- a/arch/parisc/kernel/cache.c
+++ b/arch/parisc/kernel/cache.c
@@ -388,6 +388,20 @@ void flush_kernel_dcache_page_addr(void *addr)
388} 388}
389EXPORT_SYMBOL(flush_kernel_dcache_page_addr); 389EXPORT_SYMBOL(flush_kernel_dcache_page_addr);
390 390
391void copy_user_page(void *vto, void *vfrom, unsigned long vaddr,
392 struct page *pg)
393{
394 /* Copy using kernel mapping. No coherency is needed (all in
395 kunmap) for the `to' page. However, the `from' page needs to
396 be flushed through a mapping equivalent to the user mapping
397 before it can be accessed through the kernel mapping. */
398 preempt_disable();
399 flush_dcache_page_asm(__pa(vfrom), vaddr);
400 preempt_enable();
401 copy_page_asm(vto, vfrom);
402}
403EXPORT_SYMBOL(copy_user_page);
404
391void purge_tlb_entries(struct mm_struct *mm, unsigned long addr) 405void purge_tlb_entries(struct mm_struct *mm, unsigned long addr)
392{ 406{
393 unsigned long flags; 407 unsigned long flags;