Commit 411fadd6 authored by Helge Deller's avatar Helge Deller

parisc: Avoid flushing cache on cache-less machines

Avoid flushing caches in __flush_cache_page() and __purge_cache_page()
if the machine hasn't data or instruction caches - as e.g. in qemu.
Signed-off-by: default avatarHelge Deller <deller@gmx.de>
parent 9b046d02
...@@ -315,6 +315,8 @@ static inline void ...@@ -315,6 +315,8 @@ static inline void
__flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr, __flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr,
unsigned long physaddr) unsigned long physaddr)
{ {
if (!static_branch_likely(&parisc_has_cache))
return;
preempt_disable(); preempt_disable();
flush_dcache_page_asm(physaddr, vmaddr); flush_dcache_page_asm(physaddr, vmaddr);
if (vma->vm_flags & VM_EXEC) if (vma->vm_flags & VM_EXEC)
...@@ -326,6 +328,8 @@ static inline void ...@@ -326,6 +328,8 @@ static inline void
__purge_cache_page(struct vm_area_struct *vma, unsigned long vmaddr, __purge_cache_page(struct vm_area_struct *vma, unsigned long vmaddr,
unsigned long physaddr) unsigned long physaddr)
{ {
if (!static_branch_likely(&parisc_has_cache))
return;
preempt_disable(); preempt_disable();
purge_dcache_page_asm(physaddr, vmaddr); purge_dcache_page_asm(physaddr, vmaddr);
if (vma->vm_flags & VM_EXEC) if (vma->vm_flags & VM_EXEC)
......
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