Commit fa92722e authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by Andrew Morton

xtensa: remove uses of PG_arch_1 on individual pages

Since switching to the new page table range API, we disregard the
PG_arch_1 (aka dcache dirty) flag on tail pages, and only pay attention to
it on the folio.  Fix these two missed spots where we were setting it on
arbitrary pages.

Link: https://lkml.kernel.org/r/20240326171045.410737-3-willy@infradead.orgReported-by: default avatarSvetly Todorov <svetly.todorov@memverge.com>
Signed-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: Svetly Todorov <svetly.todorov@memverge.com>	[xtensa]
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent f4b66809
...@@ -87,12 +87,13 @@ static inline void *coherent_kvaddr(struct page *page, unsigned long base, ...@@ -87,12 +87,13 @@ static inline void *coherent_kvaddr(struct page *page, unsigned long base,
void clear_user_highpage(struct page *page, unsigned long vaddr) void clear_user_highpage(struct page *page, unsigned long vaddr)
{ {
struct folio *folio = page_folio(page);
unsigned long paddr; unsigned long paddr;
void *kvaddr = coherent_kvaddr(page, TLBTEMP_BASE_1, vaddr, &paddr); void *kvaddr = coherent_kvaddr(page, TLBTEMP_BASE_1, vaddr, &paddr);
preempt_disable(); preempt_disable();
kmap_invalidate_coherent(page, vaddr); kmap_invalidate_coherent(page, vaddr);
set_bit(PG_arch_1, &page->flags); set_bit(PG_arch_1, folio_flags(folio, 0));
clear_page_alias(kvaddr, paddr); clear_page_alias(kvaddr, paddr);
preempt_enable(); preempt_enable();
} }
...@@ -101,6 +102,7 @@ EXPORT_SYMBOL(clear_user_highpage); ...@@ -101,6 +102,7 @@ EXPORT_SYMBOL(clear_user_highpage);
void copy_user_highpage(struct page *dst, struct page *src, void copy_user_highpage(struct page *dst, struct page *src,
unsigned long vaddr, struct vm_area_struct *vma) unsigned long vaddr, struct vm_area_struct *vma)
{ {
struct folio *folio = page_folio(dst);
unsigned long dst_paddr, src_paddr; unsigned long dst_paddr, src_paddr;
void *dst_vaddr = coherent_kvaddr(dst, TLBTEMP_BASE_1, vaddr, void *dst_vaddr = coherent_kvaddr(dst, TLBTEMP_BASE_1, vaddr,
&dst_paddr); &dst_paddr);
...@@ -109,7 +111,7 @@ void copy_user_highpage(struct page *dst, struct page *src, ...@@ -109,7 +111,7 @@ void copy_user_highpage(struct page *dst, struct page *src,
preempt_disable(); preempt_disable();
kmap_invalidate_coherent(dst, vaddr); kmap_invalidate_coherent(dst, vaddr);
set_bit(PG_arch_1, &dst->flags); set_bit(PG_arch_1, folio_flags(folio, 0));
copy_page_alias(dst_vaddr, src_vaddr, dst_paddr, src_paddr); copy_page_alias(dst_vaddr, src_vaddr, dst_paddr, src_paddr);
preempt_enable(); preempt_enable();
} }
......
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