2019-05-27 08:55:01 +02:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2005-04-16 15:20:36 -07:00
/*
2005-11-04 10:20:27 +11:00
* TLB shootdown specifics for powerpc
2005-04-16 15:20:36 -07:00
*
2005-11-04 10:20:27 +11:00
* Copyright ( C ) 2002 Anton Blanchard , IBM Corp .
2005-04-16 15:20:36 -07:00
* Copyright ( C ) 2002 Paul Mackerras , IBM Corp .
*/
2005-11-04 10:20:27 +11:00
# ifndef _ASM_POWERPC_TLB_H
# define _ASM_POWERPC_TLB_H
2005-12-16 22:43:46 +01:00
# ifdef __KERNEL__
2005-04-16 15:20:36 -07:00
2005-11-04 10:20:27 +11:00
# ifndef __powerpc64__
2020-06-08 21:32:38 -07:00
# include <linux/pgtable.h>
2005-11-04 10:20:27 +11:00
# endif
# ifndef __powerpc64__
2005-04-16 15:20:36 -07:00
# include <asm/page.h>
# include <asm/mmu.h>
2005-11-04 10:20:27 +11:00
# endif
2005-04-16 15:20:36 -07:00
2007-10-02 13:30:04 -07:00
# include <linux/pagemap.h>
2014-10-29 10:03:09 +00:00
# define __tlb_remove_tlb_entry __tlb_remove_tlb_entry
2005-11-04 10:20:27 +11:00
2018-09-04 13:18:15 +02:00
# define tlb_flush tlb_flush
2005-04-16 15:20:36 -07:00
extern void tlb_flush ( struct mmu_gather * tlb ) ;
2020-02-03 17:36:49 -08:00
/*
* book3s :
* Hash does not use the linux page - tables , so we can avoid
* the TLB invalidate for page - table freeing , Radix otoh does use the
* page - tables and needs the TLBI .
*
* nohash :
* We still do TLB invalidate in the __pte_free_tlb routine before we
* add the page table pages to mmu gather table batch .
*/
# define tlb_needs_table_invalidate() radix_enabled()
2005-04-16 15:20:36 -07:00
/* Get the generic bits... */
# include <asm-generic/tlb.h>
static inline void __tlb_remove_tlb_entry ( struct mmu_gather * tlb , pte_t * ptep ,
2009-07-23 23:15:28 +00:00
unsigned long address )
2005-04-16 15:20:36 -07:00
{
2018-11-17 10:25:02 +00:00
# ifdef CONFIG_PPC_BOOK3S_32
2005-04-16 15:20:36 -07:00
if ( pte_val ( * ptep ) & _PAGE_HASHPTE )
flush_hash_entry ( tlb - > mm , ptep , address ) ;
2009-07-23 23:15:28 +00:00
# endif
2005-04-16 15:20:36 -07:00
}
2016-07-13 15:06:39 +05:30
# ifdef CONFIG_SMP
static inline int mm_is_core_local ( struct mm_struct * mm )
{
return cpumask_subset ( mm_cpumask ( mm ) ,
topology_sibling_cpumask ( smp_processor_id ( ) ) ) ;
}
2016-10-24 08:50:43 +05:30
2017-07-24 14:28:02 +10:00
# ifdef CONFIG_PPC_BOOK3S_64
static inline int mm_is_thread_local ( struct mm_struct * mm )
{
if ( atomic_read ( & mm - > context . active_cpus ) > 1 )
return false ;
return cpumask_test_cpu ( smp_processor_id ( ) , mm_cpumask ( mm ) ) ;
}
# else /* CONFIG_PPC_BOOK3S_64 */
2016-10-24 08:50:43 +05:30
static inline int mm_is_thread_local ( struct mm_struct * mm )
{
return cpumask_equal ( mm_cpumask ( mm ) ,
cpumask_of ( smp_processor_id ( ) ) ) ;
}
2017-07-24 14:28:02 +10:00
# endif /* !CONFIG_PPC_BOOK3S_64 */
2016-10-24 08:50:43 +05:30
2017-07-24 14:28:02 +10:00
# else /* CONFIG_SMP */
2016-07-13 15:06:39 +05:30
static inline int mm_is_core_local ( struct mm_struct * mm )
{
return 1 ;
}
2016-10-24 08:50:43 +05:30
static inline int mm_is_thread_local ( struct mm_struct * mm )
{
return 1 ;
}
2016-07-13 15:06:39 +05:30
# endif
2021-07-07 18:10:18 -07:00
# define arch_supports_page_table_move arch_supports_page_table_move
static inline bool arch_supports_page_table_move ( void )
{
return radix_enabled ( ) ;
}
2005-12-16 22:43:46 +01:00
# endif /* __KERNEL__ */
2005-11-04 10:20:27 +11:00
# endif /* __ASM_POWERPC_TLB_H */