2005-04-16 15:20:36 -07:00
# ifndef _SPARC64_TLBFLUSH_H
# define _SPARC64_TLBFLUSH_H
# include <linux/config.h>
# include <linux/mm.h>
# include <asm/mmu_context.h>
2006-01-31 18:29:18 -08:00
/* TSB flush operations. */
struct mmu_gather ;
extern void flush_tsb_kernel_range ( unsigned long start , unsigned long end ) ;
extern void flush_tsb_user ( struct mmu_gather * mp ) ;
2005-04-16 15:20:36 -07:00
/* TLB flush operations. */
extern void flush_tlb_pending ( void ) ;
# define flush_tlb_range(vma,start,end) \
do { ( void ) ( start ) ; flush_tlb_pending ( ) ; } while ( 0 )
# define flush_tlb_page(vma,addr) flush_tlb_pending()
# define flush_tlb_mm(mm) flush_tlb_pending()
2006-01-31 18:29:18 -08:00
/* Local cpu only. */
2005-04-16 15:20:36 -07:00
extern void __flush_tlb_all ( void ) ;
2006-01-31 18:29:18 -08:00
2005-04-16 15:20:36 -07:00
extern void __flush_tlb_page ( unsigned long context , unsigned long page , unsigned long r ) ;
extern void __flush_tlb_kernel_range ( unsigned long start , unsigned long end ) ;
# ifndef CONFIG_SMP
# define flush_tlb_kernel_range(start,end) \
2006-01-31 18:29:18 -08:00
do { flush_tsb_kernel_range ( start , end ) ; \
__flush_tlb_kernel_range ( start , end ) ; \
} while ( 0 )
2005-04-16 15:20:36 -07:00
# else /* CONFIG_SMP */
extern void smp_flush_tlb_kernel_range ( unsigned long start , unsigned long end ) ;
# define flush_tlb_kernel_range(start, end) \
2006-01-31 18:29:18 -08:00
do { flush_tsb_kernel_range ( start , end ) ; \
smp_flush_tlb_kernel_range ( start , end ) ; \
} while ( 0 )
2005-04-16 15:20:36 -07:00
# endif /* ! CONFIG_SMP */
2006-01-31 18:29:18 -08:00
static inline void flush_tlb_pgtables ( struct mm_struct * mm , unsigned long start , unsigned long end )
{
/* We don't use virtual page tables for TLB miss processing
* any more . Nowadays we use the TSB .
*/
}
2005-04-16 15:20:36 -07:00
# endif /* _SPARC64_TLBFLUSH_H */