mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-13 14:40:22 +00:00
FreeBSD right now support 32 CPUs on all the architectures at least.
With the arrival of 128+ cores it is necessary to handle more than that. One of the first thing to change is the support for cpumask_t that needs to handle more than 32 bits masking (which happens now). Some places, however, still assume that cpumask_t is a 32 bits mask. Fix that situation by using always correctly cpumask_t when needed. While here, remove the part under STOP_NMI for the Xen support as it is broken in any case. Additively make ipi_nmi_pending as static. Reviewed by: jhb, kmacy Tested by: Giovanni Trematerra <giovanni dot trematerra at gmail dot com>
This commit is contained in:
parent
b7ced94c8c
commit
120b18d86f
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=192114
@ -114,9 +114,9 @@ volatile int smp_tlb_wait;
|
|||||||
extern inthand_t IDTVEC(fast_syscall), IDTVEC(fast_syscall32);
|
extern inthand_t IDTVEC(fast_syscall), IDTVEC(fast_syscall32);
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
#ifdef STOP_NMI
|
||||||
volatile cpumask_t ipi_nmi_pending;
|
static volatile cpumask_t ipi_nmi_pending;
|
||||||
|
|
||||||
static void ipi_nmi_selected(u_int32_t cpus);
|
static void ipi_nmi_selected(cpumask_t cpus);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1016,7 +1016,7 @@ smp_tlb_shootdown(u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
smp_targeted_tlb_shootdown(u_int mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
smp_targeted_tlb_shootdown(cpumask_t mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
int ncpu, othercpus;
|
int ncpu, othercpus;
|
||||||
|
|
||||||
@ -1090,7 +1090,7 @@ smp_invlpg_range(vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invltlb(u_int mask)
|
smp_masked_invltlb(cpumask_t mask)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1099,7 +1099,7 @@ smp_masked_invltlb(u_int mask)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
smp_masked_invlpg(cpumask_t mask, vm_offset_t addr)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1108,7 +1108,7 @@ smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg_range(u_int mask, vm_offset_t addr1, vm_offset_t addr2)
|
smp_masked_invlpg_range(cpumask_t mask, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1143,7 +1143,7 @@ ipi_bitmap_handler(struct trapframe frame)
|
|||||||
* send an IPI to a set of cpus.
|
* send an IPI to a set of cpus.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ipi_selected(u_int32_t cpus, u_int ipi)
|
ipi_selected(cpumask_t cpus, u_int ipi)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
u_int bitmap = 0;
|
u_int bitmap = 0;
|
||||||
@ -1206,8 +1206,8 @@ ipi_all_but_self(u_int ipi)
|
|||||||
|
|
||||||
#define BEFORE_SPIN 1000000
|
#define BEFORE_SPIN 1000000
|
||||||
|
|
||||||
void
|
static void
|
||||||
ipi_nmi_selected(u_int32_t cpus)
|
ipi_nmi_selected(cpumask_t cpus)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
register_t icrlo;
|
register_t icrlo;
|
||||||
@ -1331,7 +1331,7 @@ SYSINIT(start_aps, SI_SUB_SMP, SI_ORDER_FIRST, release_aps, NULL);
|
|||||||
static int
|
static int
|
||||||
sysctl_hlt_cpus(SYSCTL_HANDLER_ARGS)
|
sysctl_hlt_cpus(SYSCTL_HANDLER_ARGS)
|
||||||
{
|
{
|
||||||
u_int mask;
|
cpumask_t mask;
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
mask = hlt_cpus_mask;
|
mask = hlt_cpus_mask;
|
||||||
|
@ -52,19 +52,19 @@ void cpu_add(u_int apic_id, char boot_cpu);
|
|||||||
void cpustop_handler(void);
|
void cpustop_handler(void);
|
||||||
void cpususpend_handler(void);
|
void cpususpend_handler(void);
|
||||||
void init_secondary(void);
|
void init_secondary(void);
|
||||||
void ipi_selected(u_int cpus, u_int ipi);
|
void ipi_selected(cpumask_t cpus, u_int ipi);
|
||||||
void ipi_all_but_self(u_int ipi);
|
void ipi_all_but_self(u_int ipi);
|
||||||
void ipi_bitmap_handler(struct trapframe frame);
|
void ipi_bitmap_handler(struct trapframe frame);
|
||||||
u_int mp_bootaddress(u_int);
|
u_int mp_bootaddress(u_int);
|
||||||
int mp_grab_cpu_hlt(void);
|
int mp_grab_cpu_hlt(void);
|
||||||
void smp_cache_flush(void);
|
void smp_cache_flush(void);
|
||||||
void smp_invlpg(vm_offset_t addr);
|
void smp_invlpg(vm_offset_t addr);
|
||||||
void smp_masked_invlpg(u_int mask, vm_offset_t addr);
|
void smp_masked_invlpg(cpumask_t mask, vm_offset_t addr);
|
||||||
void smp_invlpg_range(vm_offset_t startva, vm_offset_t endva);
|
void smp_invlpg_range(vm_offset_t startva, vm_offset_t endva);
|
||||||
void smp_masked_invlpg_range(u_int mask, vm_offset_t startva,
|
void smp_masked_invlpg_range(cpumask_t mask, vm_offset_t startva,
|
||||||
vm_offset_t endva);
|
vm_offset_t endva);
|
||||||
void smp_invltlb(void);
|
void smp_invltlb(void);
|
||||||
void smp_masked_invltlb(u_int mask);
|
void smp_masked_invltlb(cpumask_t mask);
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
#ifdef STOP_NMI
|
||||||
int ipi_nmi_handler(void);
|
int ipi_nmi_handler(void);
|
||||||
|
@ -75,6 +75,5 @@ extern int get_thread_id(void);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define ASSERT_ALWAYS(EX) ((EX)?((void)0):assfail(#EX, __FILE__, __LINE__))
|
#define ASSERT_ALWAYS(EX) ((EX)?((void)0):assfail(#EX, __FILE__, __LINE__))
|
||||||
#define debug_stop_all_cpus(param) /* param is "cpumask_t *" */
|
|
||||||
|
|
||||||
#endif /* __XFS_SUPPORT_DEBUG_H__ */
|
#endif /* __XFS_SUPPORT_DEBUG_H__ */
|
||||||
|
@ -155,9 +155,9 @@ vm_offset_t smp_tlb_addr2;
|
|||||||
volatile int smp_tlb_wait;
|
volatile int smp_tlb_wait;
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
#ifdef STOP_NMI
|
||||||
volatile cpumask_t ipi_nmi_pending;
|
static volatile cpumask_t ipi_nmi_pending;
|
||||||
|
|
||||||
static void ipi_nmi_selected(u_int32_t cpus);
|
static void ipi_nmi_selected(cpumask_t cpus);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef COUNT_IPIS
|
#ifdef COUNT_IPIS
|
||||||
@ -1146,7 +1146,7 @@ smp_tlb_shootdown(u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
smp_targeted_tlb_shootdown(u_int mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
smp_targeted_tlb_shootdown(cpumask_t mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
int ncpu, othercpus;
|
int ncpu, othercpus;
|
||||||
|
|
||||||
@ -1231,7 +1231,7 @@ smp_invlpg_range(vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invltlb(u_int mask)
|
smp_masked_invltlb(cpumask_t mask)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1243,7 +1243,7 @@ smp_masked_invltlb(u_int mask)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
smp_masked_invlpg(cpumask_t mask, vm_offset_t addr)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1255,7 +1255,7 @@ smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg_range(u_int mask, vm_offset_t addr1, vm_offset_t addr2)
|
smp_masked_invlpg_range(cpumask_t mask, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1303,7 +1303,7 @@ ipi_bitmap_handler(struct trapframe frame)
|
|||||||
* send an IPI to a set of cpus.
|
* send an IPI to a set of cpus.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ipi_selected(u_int32_t cpus, u_int ipi)
|
ipi_selected(cpumask_t cpus, u_int ipi)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
u_int bitmap = 0;
|
u_int bitmap = 0;
|
||||||
@ -1367,7 +1367,7 @@ ipi_all_but_self(u_int ipi)
|
|||||||
#define BEFORE_SPIN 1000000
|
#define BEFORE_SPIN 1000000
|
||||||
|
|
||||||
void
|
void
|
||||||
ipi_nmi_selected(u_int32_t cpus)
|
ipi_nmi_selected(cpumask_t cpus)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
register_t icrlo;
|
register_t icrlo;
|
||||||
@ -1456,7 +1456,7 @@ SYSINIT(start_aps, SI_SUB_SMP, SI_ORDER_FIRST, release_aps, NULL);
|
|||||||
static int
|
static int
|
||||||
sysctl_hlt_cpus(SYSCTL_HANDLER_ARGS)
|
sysctl_hlt_cpus(SYSCTL_HANDLER_ARGS)
|
||||||
{
|
{
|
||||||
u_int mask;
|
cpumask_t mask;
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
mask = hlt_cpus_mask;
|
mask = hlt_cpus_mask;
|
||||||
|
@ -1624,7 +1624,7 @@ pmap_allocpte(pmap_t pmap, vm_offset_t va, int flags)
|
|||||||
* Deal with a SMP shootdown of other users of the pmap that we are
|
* Deal with a SMP shootdown of other users of the pmap that we are
|
||||||
* trying to dispose of. This can be a bit hairy.
|
* trying to dispose of. This can be a bit hairy.
|
||||||
*/
|
*/
|
||||||
static u_int *lazymask;
|
static cpumask_t *lazymask;
|
||||||
static u_int lazyptd;
|
static u_int lazyptd;
|
||||||
static volatile u_int lazywait;
|
static volatile u_int lazywait;
|
||||||
|
|
||||||
@ -1633,7 +1633,7 @@ void pmap_lazyfix_action(void);
|
|||||||
void
|
void
|
||||||
pmap_lazyfix_action(void)
|
pmap_lazyfix_action(void)
|
||||||
{
|
{
|
||||||
u_int mymask = PCPU_GET(cpumask);
|
cpumask_t mymask = PCPU_GET(cpumask);
|
||||||
|
|
||||||
#ifdef COUNT_IPIS
|
#ifdef COUNT_IPIS
|
||||||
(*ipi_lazypmap_counts[PCPU_GET(cpuid)])++;
|
(*ipi_lazypmap_counts[PCPU_GET(cpuid)])++;
|
||||||
@ -1645,7 +1645,7 @@ pmap_lazyfix_action(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pmap_lazyfix_self(u_int mymask)
|
pmap_lazyfix_self(cpumask_t mymask)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (rcr3() == lazyptd)
|
if (rcr3() == lazyptd)
|
||||||
@ -1657,8 +1657,7 @@ pmap_lazyfix_self(u_int mymask)
|
|||||||
static void
|
static void
|
||||||
pmap_lazyfix(pmap_t pmap)
|
pmap_lazyfix(pmap_t pmap)
|
||||||
{
|
{
|
||||||
u_int mymask;
|
cpumask_t mymask, mask;
|
||||||
u_int mask;
|
|
||||||
u_int spins;
|
u_int spins;
|
||||||
|
|
||||||
while ((mask = pmap->pm_active) != 0) {
|
while ((mask = pmap->pm_active) != 0) {
|
||||||
|
@ -69,12 +69,12 @@ u_int mp_bootaddress(u_int);
|
|||||||
int mp_grab_cpu_hlt(void);
|
int mp_grab_cpu_hlt(void);
|
||||||
void smp_cache_flush(void);
|
void smp_cache_flush(void);
|
||||||
void smp_invlpg(vm_offset_t addr);
|
void smp_invlpg(vm_offset_t addr);
|
||||||
void smp_masked_invlpg(u_int mask, vm_offset_t addr);
|
void smp_masked_invlpg(cpumask_t mask, vm_offset_t addr);
|
||||||
void smp_invlpg_range(vm_offset_t startva, vm_offset_t endva);
|
void smp_invlpg_range(vm_offset_t startva, vm_offset_t endva);
|
||||||
void smp_masked_invlpg_range(u_int mask, vm_offset_t startva,
|
void smp_masked_invlpg_range(cpumask_t mask, vm_offset_t startva,
|
||||||
vm_offset_t endva);
|
vm_offset_t endva);
|
||||||
void smp_invltlb(void);
|
void smp_invltlb(void);
|
||||||
void smp_masked_invltlb(u_int mask);
|
void smp_masked_invltlb(cpumask_t mask);
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
#ifdef STOP_NMI
|
||||||
int ipi_nmi_handler(void);
|
int ipi_nmi_handler(void);
|
||||||
|
@ -993,7 +993,7 @@ smp_tlb_shootdown(u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
smp_targeted_tlb_shootdown(u_int mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
smp_targeted_tlb_shootdown(cpumask_t mask, u_int vector, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
int ncpu, othercpus;
|
int ncpu, othercpus;
|
||||||
struct _call_data data;
|
struct _call_data data;
|
||||||
@ -1072,7 +1072,7 @@ smp_invlpg_range(vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invltlb(u_int mask)
|
smp_masked_invltlb(cpumask_t mask)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1081,7 +1081,7 @@ smp_masked_invltlb(u_int mask)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
smp_masked_invlpg(cpumask_t mask, vm_offset_t addr)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1090,7 +1090,7 @@ smp_masked_invlpg(u_int mask, vm_offset_t addr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
smp_masked_invlpg_range(u_int mask, vm_offset_t addr1, vm_offset_t addr2)
|
smp_masked_invlpg_range(cpumask_t mask, vm_offset_t addr1, vm_offset_t addr2)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (smp_started) {
|
if (smp_started) {
|
||||||
@ -1102,7 +1102,7 @@ smp_masked_invlpg_range(u_int mask, vm_offset_t addr1, vm_offset_t addr2)
|
|||||||
* send an IPI to a set of cpus.
|
* send an IPI to a set of cpus.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ipi_selected(uint32_t cpus, u_int ipi)
|
ipi_selected(cpumask_t cpus, u_int ipi)
|
||||||
{
|
{
|
||||||
int cpu;
|
int cpu;
|
||||||
u_int bitmap = 0;
|
u_int bitmap = 0;
|
||||||
@ -1114,12 +1114,6 @@ ipi_selected(uint32_t cpus, u_int ipi)
|
|||||||
ipi = IPI_BITMAP_VECTOR;
|
ipi = IPI_BITMAP_VECTOR;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
|
||||||
if (ipi == IPI_STOP && stop_cpus_with_nmi) {
|
|
||||||
ipi_nmi_selected(cpus);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
CTR3(KTR_SMP, "%s: cpus: %x ipi: %x", __func__, cpus, ipi);
|
CTR3(KTR_SMP, "%s: cpus: %x ipi: %x", __func__, cpus, ipi);
|
||||||
while ((cpu = ffs(cpus)) != 0) {
|
while ((cpu = ffs(cpus)) != 0) {
|
||||||
cpu--;
|
cpu--;
|
||||||
@ -1160,56 +1154,6 @@ ipi_all_but_self(u_int ipi)
|
|||||||
ipi_selected(PCPU_GET(other_cpus), ipi);
|
ipi_selected(PCPU_GET(other_cpus), ipi);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef STOP_NMI
|
|
||||||
/*
|
|
||||||
* send NMI IPI to selected CPUs
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define BEFORE_SPIN 1000000
|
|
||||||
|
|
||||||
void
|
|
||||||
ipi_nmi_selected(u_int32_t cpus)
|
|
||||||
{
|
|
||||||
int cpu;
|
|
||||||
register_t icrlo;
|
|
||||||
|
|
||||||
icrlo = APIC_DELMODE_NMI | APIC_DESTMODE_PHY | APIC_LEVEL_ASSERT
|
|
||||||
| APIC_TRIGMOD_EDGE;
|
|
||||||
|
|
||||||
CTR2(KTR_SMP, "%s: cpus: %x nmi", __func__, cpus);
|
|
||||||
|
|
||||||
atomic_set_int(&ipi_nmi_pending, cpus);
|
|
||||||
|
|
||||||
while ((cpu = ffs(cpus)) != 0) {
|
|
||||||
cpu--;
|
|
||||||
cpus &= ~(1 << cpu);
|
|
||||||
|
|
||||||
KASSERT(cpu_apic_ids[cpu] != -1,
|
|
||||||
("IPI NMI to non-existent CPU %d", cpu));
|
|
||||||
|
|
||||||
/* Wait for an earlier IPI to finish. */
|
|
||||||
if (!lapic_ipi_wait(BEFORE_SPIN))
|
|
||||||
panic("ipi_nmi_selected: previous IPI has not cleared");
|
|
||||||
|
|
||||||
lapic_ipi_raw(icrlo, cpu_apic_ids[cpu]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
ipi_nmi_handler(void)
|
|
||||||
{
|
|
||||||
int cpumask = PCPU_GET(cpumask);
|
|
||||||
|
|
||||||
if (!(ipi_nmi_pending & cpumask))
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
atomic_clear_int(&ipi_nmi_pending, cpumask);
|
|
||||||
cpustop_handler();
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* STOP_NMI */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Handle an IPI_STOP by saving our current context and spinning until we
|
* Handle an IPI_STOP by saving our current context and spinning until we
|
||||||
* are resumed.
|
* are resumed.
|
||||||
|
Loading…
Reference in New Issue
Block a user