mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 39297dde73
			
		
	
	
		39297dde73
		
	
	
	
	
		
			
			The Broadcast Assist Unit (BAU) TLB shootdown handler is being rewritten to become the UV BAU APIC driver. It is designed to speed up sending IPIs to selective CPUs within the system. Remove the current TLB shutdown handler (tlb_uv.c) file and a couple of kernel hooks in the interim. Signed-off-by: Mike Travis <mike.travis@hpe.com> Signed-off-by: Borislav Petkov <bp@suse.de> Reviewed-by: Dimitri Sivanich <dimitri.sivanich@hpe.com> Link: https://lkml.kernel.org/r/20201005203929.148656-2-mike.travis@hpe.com
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _ASM_X86_UV_UV_H
 | |
| #define _ASM_X86_UV_UV_H
 | |
| 
 | |
| #include <asm/tlbflush.h>
 | |
| 
 | |
| enum uv_system_type {UV_NONE, UV_LEGACY_APIC, UV_X2APIC};
 | |
| 
 | |
| struct cpumask;
 | |
| struct mm_struct;
 | |
| struct flush_tlb_info;
 | |
| 
 | |
| #ifdef CONFIG_X86_UV
 | |
| #include <linux/efi.h>
 | |
| 
 | |
| #define	UV_PROC_NODE	"sgi_uv"
 | |
| 
 | |
| static inline int uv(int uvtype)
 | |
| {
 | |
| 	/* uv(0) is "any" */
 | |
| 	if (uvtype >= 0 && uvtype <= 30)
 | |
| 		return 1 << uvtype;
 | |
| 	return 1;
 | |
| }
 | |
| 
 | |
| extern unsigned long uv_systab_phys;
 | |
| 
 | |
| extern enum uv_system_type get_uv_system_type(void);
 | |
| static inline bool is_early_uv_system(void)
 | |
| {
 | |
| 	return uv_systab_phys && uv_systab_phys != EFI_INVALID_TABLE_ADDR;
 | |
| }
 | |
| extern int is_uv_system(void);
 | |
| extern int is_uv_hubbed(int uvtype);
 | |
| extern void uv_cpu_init(void);
 | |
| extern void uv_nmi_init(void);
 | |
| extern void uv_system_init(void);
 | |
| 
 | |
| #else	/* !X86_UV */
 | |
| 
 | |
| static inline enum uv_system_type get_uv_system_type(void) { return UV_NONE; }
 | |
| static inline bool is_early_uv_system(void)	{ return 0; }
 | |
| static inline int is_uv_system(void)	{ return 0; }
 | |
| static inline int is_uv_hubbed(int uv)	{ return 0; }
 | |
| static inline void uv_cpu_init(void)	{ }
 | |
| static inline void uv_system_init(void)	{ }
 | |
| static inline const struct cpumask *
 | |
| uv_flush_tlb_others(const struct cpumask *cpumask,
 | |
| 		    const struct flush_tlb_info *info)
 | |
| { return cpumask; }
 | |
| 
 | |
| #endif	/* X86_UV */
 | |
| 
 | |
| #endif	/* _ASM_X86_UV_UV_H */
 |