 90f08e399d
			
		
	
	
	90f08e399d
	
	
	
		
			
			Rework the sparc mmu_gather usage to conform to the new world order :-) Sparc mmu_gather does two things: - tracks vaddrs to unhash - tracks pages to free Split these two things like powerpc has done and keep the vaddrs in per-cpu data structures and flush them on context switch. The remaining bits can then use the generic mmu_gather. Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> Acked-by: David Miller <davem@davemloft.net> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: Russell King <rmk@arm.linux.org.uk> Cc: Paul Mundt <lethal@linux-sh.org> Cc: Jeff Dike <jdike@addtoit.com> Cc: Richard Weinberger <richard@nod.at> Cc: Tony Luck <tony.luck@intel.com> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Hugh Dickins <hughd@google.com> Cc: Mel Gorman <mel@csn.ul.ie> Cc: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Cc: Nick Piggin <npiggin@kernel.dk> Cc: Namhyung Kim <namhyung@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _SPARC64_TLBFLUSH_H
 | |
| #define _SPARC64_TLBFLUSH_H
 | |
| 
 | |
| #include <linux/mm.h>
 | |
| #include <asm/mmu_context.h>
 | |
| 
 | |
| /* TSB flush operations. */
 | |
| 
 | |
| #define TLB_BATCH_NR	192
 | |
| 
 | |
| struct tlb_batch {
 | |
| 	struct mm_struct *mm;
 | |
| 	unsigned long tlb_nr;
 | |
| 	unsigned long vaddrs[TLB_BATCH_NR];
 | |
| };
 | |
| 
 | |
| extern void flush_tsb_kernel_range(unsigned long start, unsigned long end);
 | |
| extern void flush_tsb_user(struct tlb_batch *tb);
 | |
| 
 | |
| /* 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()
 | |
| 
 | |
| /* Local cpu only.  */
 | |
| extern void __flush_tlb_all(void);
 | |
| 
 | |
| extern void __flush_tlb_kernel_range(unsigned long start, unsigned long end);
 | |
| 
 | |
| #ifndef CONFIG_SMP
 | |
| 
 | |
| #define flush_tlb_kernel_range(start,end) \
 | |
| do {	flush_tsb_kernel_range(start,end); \
 | |
| 	__flush_tlb_kernel_range(start,end); \
 | |
| } while (0)
 | |
| 
 | |
| #else /* CONFIG_SMP */
 | |
| 
 | |
| extern void smp_flush_tlb_kernel_range(unsigned long start, unsigned long end);
 | |
| 
 | |
| #define flush_tlb_kernel_range(start, end) \
 | |
| do {	flush_tsb_kernel_range(start,end); \
 | |
| 	smp_flush_tlb_kernel_range(start, end); \
 | |
| } while (0)
 | |
| 
 | |
| #endif /* ! CONFIG_SMP */
 | |
| 
 | |
| #endif /* _SPARC64_TLBFLUSH_H */
 |