Commit ec94b9b2 authored by Aneesh Kumar K.V's avatar Aneesh Kumar K.V Committed by Michael Ellerman

powerpc/mm: Add PG_dcache_clean to indicate dcache clean state

This just add a better name for PG_arch_1. No functional change in this patch.
Signed-off-by: default avatarAneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20210203045812.234439-2-aneesh.kumar@linux.ibm.com
parent c7ba2d63
...@@ -8,6 +8,12 @@ ...@@ -8,6 +8,12 @@
#include <asm/cputable.h> #include <asm/cputable.h>
#include <asm/cpu_has_feature.h> #include <asm/cpu_has_feature.h>
/*
* This flag is used to indicate that the page pointed to by a pte is clean
* and does not require cleaning before returning it to the user.
*/
#define PG_dcache_clean PG_arch_1
#ifdef CONFIG_PPC_BOOK3S_64 #ifdef CONFIG_PPC_BOOK3S_64
/* /*
* Book3s has no ptesync after setting a pte, so without this ptesync it's * Book3s has no ptesync after setting a pte, so without this ptesync it's
......
...@@ -881,9 +881,9 @@ static inline void kvmppc_mmu_flush_icache(kvm_pfn_t pfn) ...@@ -881,9 +881,9 @@ static inline void kvmppc_mmu_flush_icache(kvm_pfn_t pfn)
/* Clear i-cache for new pages */ /* Clear i-cache for new pages */
page = pfn_to_page(pfn); page = pfn_to_page(pfn);
if (!test_bit(PG_arch_1, &page->flags)) { if (!test_bit(PG_dcache_clean, &page->flags)) {
flush_dcache_icache_page(page); flush_dcache_icache_page(page);
set_bit(PG_arch_1, &page->flags); set_bit(PG_dcache_clean, &page->flags);
} }
} }
......
...@@ -1144,10 +1144,10 @@ unsigned int hash_page_do_lazy_icache(unsigned int pp, pte_t pte, int trap) ...@@ -1144,10 +1144,10 @@ unsigned int hash_page_do_lazy_icache(unsigned int pp, pte_t pte, int trap)
page = pte_page(pte); page = pte_page(pte);
/* page is dirty */ /* page is dirty */
if (!test_bit(PG_arch_1, &page->flags) && !PageReserved(page)) { if (!test_bit(PG_dcache_clean, &page->flags) && !PageReserved(page)) {
if (trap == 0x400) { if (trap == 0x400) {
flush_dcache_icache_page(page); flush_dcache_icache_page(page);
set_bit(PG_arch_1, &page->flags); set_bit(PG_dcache_clean, &page->flags);
} else } else
pp |= HPTE_R_N; pp |= HPTE_R_N;
} }
......
...@@ -489,8 +489,8 @@ void flush_dcache_page(struct page *page) ...@@ -489,8 +489,8 @@ void flush_dcache_page(struct page *page)
if (cpu_has_feature(CPU_FTR_COHERENT_ICACHE)) if (cpu_has_feature(CPU_FTR_COHERENT_ICACHE))
return; return;
/* avoid an atomic op if possible */ /* avoid an atomic op if possible */
if (test_bit(PG_arch_1, &page->flags)) if (test_bit(PG_dcache_clean, &page->flags))
clear_bit(PG_arch_1, &page->flags); clear_bit(PG_dcache_clean, &page->flags);
} }
EXPORT_SYMBOL(flush_dcache_page); EXPORT_SYMBOL(flush_dcache_page);
......
...@@ -82,9 +82,9 @@ static pte_t set_pte_filter_hash(pte_t pte) ...@@ -82,9 +82,9 @@ static pte_t set_pte_filter_hash(pte_t pte)
struct page *pg = maybe_pte_to_page(pte); struct page *pg = maybe_pte_to_page(pte);
if (!pg) if (!pg)
return pte; return pte;
if (!test_bit(PG_arch_1, &pg->flags)) { if (!test_bit(PG_dcache_clean, &pg->flags)) {
flush_dcache_icache_page(pg); flush_dcache_icache_page(pg);
set_bit(PG_arch_1, &pg->flags); set_bit(PG_dcache_clean, &pg->flags);
} }
} }
return pte; return pte;
...@@ -117,13 +117,13 @@ static inline pte_t set_pte_filter(pte_t pte) ...@@ -117,13 +117,13 @@ static inline pte_t set_pte_filter(pte_t pte)
return pte; return pte;
/* If the page clean, we move on */ /* If the page clean, we move on */
if (test_bit(PG_arch_1, &pg->flags)) if (test_bit(PG_dcache_clean, &pg->flags))
return pte; return pte;
/* If it's an exec fault, we flush the cache and make it clean */ /* If it's an exec fault, we flush the cache and make it clean */
if (is_exec_fault()) { if (is_exec_fault()) {
flush_dcache_icache_page(pg); flush_dcache_icache_page(pg);
set_bit(PG_arch_1, &pg->flags); set_bit(PG_dcache_clean, &pg->flags);
return pte; return pte;
} }
...@@ -162,12 +162,12 @@ static pte_t set_access_flags_filter(pte_t pte, struct vm_area_struct *vma, ...@@ -162,12 +162,12 @@ static pte_t set_access_flags_filter(pte_t pte, struct vm_area_struct *vma,
goto bail; goto bail;
/* If the page is already clean, we move on */ /* If the page is already clean, we move on */
if (test_bit(PG_arch_1, &pg->flags)) if (test_bit(PG_dcache_clean, &pg->flags))
goto bail; goto bail;
/* Clean the page and set PG_arch_1 */ /* Clean the page and set PG_dcache_clean */
flush_dcache_icache_page(pg); flush_dcache_icache_page(pg);
set_bit(PG_arch_1, &pg->flags); set_bit(PG_dcache_clean, &pg->flags);
bail: bail:
return pte_mkexec(pte); return pte_mkexec(pte);
......
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