
Pull x86 mm updates from Ingo Molnar: "Misc changes: - Unexport various PAT primitives - Unexport per-CPU tlbstate and uninline TLB helpers" * tag 'x86-mm-2020-06-05' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (23 commits) x86/tlb/uv: Add a forward declaration for struct flush_tlb_info x86/cpu: Export native_write_cr4() only when CONFIG_LKTDM=m x86/tlb: Restrict access to tlbstate xen/privcmd: Remove unneeded asm/tlb.h include x86/tlb: Move PCID helpers where they are used x86/tlb: Uninline nmi_uaccess_okay() x86/tlb: Move cr4_set_bits_and_update_boot() to the usage site x86/tlb: Move paravirt_tlb_remove_table() to the usage site x86/tlb: Move __flush_tlb_all() out of line x86/tlb: Move flush_tlb_others() out of line x86/tlb: Move __flush_tlb_one_kernel() out of line x86/tlb: Move __flush_tlb_one_user() out of line x86/tlb: Move __flush_tlb_global() out of line x86/tlb: Move __flush_tlb() out of line x86/alternatives: Move temporary_mm helpers into C x86/cr4: Sanitize CR4.PCE update x86/cpu: Uninline CR4 accessors x86/tlb: Uninline __get_current_cr3_fast() x86/mm: Use pgprotval_t in protval_4k_2_large() and protval_large_2_4k() x86/mm: Unexport __cachemode2pte_tbl ...
57 lines
1.5 KiB
C
57 lines
1.5 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, UV_NON_UNIQUE_APIC};
|
|
|
|
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);
|
|
extern const struct cpumask *uv_flush_tlb_others(const struct cpumask *cpumask,
|
|
const struct flush_tlb_info *info);
|
|
|
|
#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 */
|