mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-08 14:23:19 +00:00
Updates for the X86 APIC:
- Make the quirk for non-maskable MSI interrupts in the affinity setter functional again. It was broken by a MSI core code update, which restructured the code in a way that the quirk flag was not longer set correctly. Trying to restore the core logic caused a deeper inspection and it turned out that the extra quirk flag is not required at all because it's the inverse of the reservation mode bit, which only can be set when the MSI interrupt is maskable. So the trivial fix is to use the reservation mode check in the affinity setter function and remove almost 40 lines of code related to the no-mask quirk flag. - Cure a Kconfig dependency issue which causes compile fails by correcting the conditionals in the affected heaer files. - Clean up coding style in the UV APIC driver. -----BEGIN PGP SIGNATURE----- iQJHBAABCgAxFiEEQp8+kY+LLUocC4bMphj1TA10mKEFAmU+w2ETHHRnbHhAbGlu dXRyb25peC5kZQAKCRCmGPVMDXSYodRIEACugQpAiND53Cz9MTJE1XWGheBn8n+y WZtbVckK9LXHfnf99dtigtq3ycPBg2Mx/pItT1c71iN/NyVPNCC/3mM+ntP53etX 06v7VoIgRpF+GRQsIbjvVfBkKWS3G5zqHq6hazE0lcPhPEiOIMSBcusSQaA3C3sp BT23rrx/59JKCb/187pum0Obx+n1oH+MG91wJ1v0zNOGgfx1u5gBPyKDZ0JAsMPx r05991Lp4K80ooEsk/PKgpcZuPZD3QRwFDLHJwh2ITjsC22ItOnhN/c/1J8MZtk9 5YBaIzy+vyQd+nksqmDtB48FD0ioW/WLUR5zV9MMpD3RQAGgrxQmXeTqScu/j8tn I4QZGi80HZSWLwFjWL2DoAw5LHZDh8ksxIYZBHE+8LHx0ymyX+7//naZnNFn9cXM K5orouZFQi+dvfD7MAla73fiibPs6cHjGzRKfsfNlLBNNj+/ffcEolLlKGhEX9fx R1w7gbtNs/RDnfoa45cvmez8UxJB5zei7l2HWbSecR2DDTQ9aGfEU/0NEr9muBzK cuZIpmgD09VvS84jCxdYbaXA5Cau3NLOE5Os6UN9Wa3dUjWP5PArWkc8RzxP3Bgx PANtytesqJ9YeDDg9SyylPw6d3EYNldtFZDXlD32K2O2SDmUZxxJa+0og8K9YNJN aIUcqiSaYhg5rQ== =2lhV -----END PGP SIGNATURE----- Merge tag 'x86-apic-2023-10-29-v2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull x86 APIC updates from Thomas Gleixner: - Make the quirk for non-maskable MSI interrupts in the affinity setter functional again. It was broken by a MSI core code update, which restructured the code in a way that the quirk flag was not longer set correctly. Trying to restore the core logic caused a deeper inspection and it turned out that the extra quirk flag is not required at all because it's the inverse of the reservation mode bit, which only can be set when the MSI interrupt is maskable. So the trivial fix is to use the reservation mode check in the affinity setter function and remove almost 40 lines of code related to the no-mask quirk flag. - Cure a Kconfig dependency issue which causes compile failures by correcting the conditionals in the affected header files. - Clean up coding style in the UV APIC driver. * tag 'x86-apic-2023-10-29-v2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: x86/apic/msi: Fix misconfigured non-maskable MSI quirk x86/msi: Fix compile error caused by CONFIG_GENERIC_MSI_IRQ=y && !CONFIG_X86_LOCAL_APIC x86/platform/uv/apic: Clean up inconsistent indenting
This commit is contained in:
commit
943af0e73a
@ -28,7 +28,7 @@
|
||||
#include <asm/irq.h>
|
||||
#include <asm/sections.h>
|
||||
|
||||
#ifdef CONFIG_X86_LOCAL_APIC
|
||||
#ifdef CONFIG_IRQ_DOMAIN_HIERARCHY
|
||||
struct irq_data;
|
||||
struct pci_dev;
|
||||
struct msi_desc;
|
||||
@ -105,10 +105,10 @@ static inline void irq_complete_move(struct irq_cfg *c) { }
|
||||
#endif
|
||||
|
||||
extern void apic_ack_edge(struct irq_data *data);
|
||||
#else /* CONFIG_X86_LOCAL_APIC */
|
||||
#else /* CONFIG_IRQ_DOMAIN_HIERARCHY */
|
||||
static inline void lock_vector_lock(void) {}
|
||||
static inline void unlock_vector_lock(void) {}
|
||||
#endif /* CONFIG_X86_LOCAL_APIC */
|
||||
#endif /* CONFIG_IRQ_DOMAIN_HIERARCHY */
|
||||
|
||||
/* Statistics */
|
||||
extern atomic_t irq_err_count;
|
||||
|
@ -55,14 +55,14 @@ msi_set_affinity(struct irq_data *irqd, const struct cpumask *mask, bool force)
|
||||
* caused by the non-atomic update of the address/data pair.
|
||||
*
|
||||
* Direct update is possible when:
|
||||
* - The MSI is maskable (remapped MSI does not use this code path)).
|
||||
* The quirk bit is not set in this case.
|
||||
* - The MSI is maskable (remapped MSI does not use this code path).
|
||||
* The reservation mode bit is set in this case.
|
||||
* - The new vector is the same as the old vector
|
||||
* - The old vector is MANAGED_IRQ_SHUTDOWN_VECTOR (interrupt starts up)
|
||||
* - The interrupt is not yet started up
|
||||
* - The new destination CPU is the same as the old destination CPU
|
||||
*/
|
||||
if (!irqd_msi_nomask_quirk(irqd) ||
|
||||
if (!irqd_can_reserve(irqd) ||
|
||||
cfg->vector == old_cfg.vector ||
|
||||
old_cfg.vector == MANAGED_IRQ_SHUTDOWN_VECTOR ||
|
||||
!irqd_is_started(irqd) ||
|
||||
@ -215,8 +215,6 @@ static bool x86_init_dev_msi_info(struct device *dev, struct irq_domain *domain,
|
||||
if (WARN_ON_ONCE(domain != real_parent))
|
||||
return false;
|
||||
info->chip->irq_set_affinity = msi_set_affinity;
|
||||
/* See msi_set_affinity() for the gory details */
|
||||
info->flags |= MSI_FLAG_NOMASK_QUIRK;
|
||||
break;
|
||||
case DOMAIN_BUS_DMAR:
|
||||
case DOMAIN_BUS_AMDVI:
|
||||
|
@ -110,7 +110,7 @@ static void __init early_get_pnodeid(void)
|
||||
} else if (UVH_RH_GAM_ADDR_MAP_CONFIG) {
|
||||
union uvh_rh_gam_addr_map_config_u m_n_config;
|
||||
|
||||
m_n_config.v = uv_early_read_mmr(UVH_RH_GAM_ADDR_MAP_CONFIG);
|
||||
m_n_config.v = uv_early_read_mmr(UVH_RH_GAM_ADDR_MAP_CONFIG);
|
||||
uv_cpuid.n_skt = m_n_config.s.n_skt;
|
||||
if (is_uv(UV3))
|
||||
uv_cpuid.m_skt = m_n_config.s3.m_skt;
|
||||
|
@ -52,7 +52,7 @@ unsigned long hpet_address;
|
||||
u8 hpet_blockid; /* OS timer block num */
|
||||
bool hpet_msi_disable;
|
||||
|
||||
#ifdef CONFIG_GENERIC_MSI_IRQ
|
||||
#if defined(CONFIG_X86_LOCAL_APIC) && defined(CONFIG_GENERIC_MSI_IRQ)
|
||||
static DEFINE_PER_CPU(struct hpet_channel *, cpu_hpet_channel);
|
||||
static struct irq_domain *hpet_domain;
|
||||
#endif
|
||||
@ -469,7 +469,7 @@ static void __init hpet_legacy_clockevent_register(struct hpet_channel *hc)
|
||||
/*
|
||||
* HPET MSI Support
|
||||
*/
|
||||
#ifdef CONFIG_GENERIC_MSI_IRQ
|
||||
#if defined(CONFIG_X86_LOCAL_APIC) && defined(CONFIG_GENERIC_MSI_IRQ)
|
||||
static void hpet_msi_unmask(struct irq_data *data)
|
||||
{
|
||||
struct hpet_channel *hc = irq_data_get_irq_handler_data(data);
|
||||
|
@ -215,8 +215,6 @@ struct irq_data {
|
||||
* IRQD_SINGLE_TARGET - IRQ allows only a single affinity target
|
||||
* IRQD_DEFAULT_TRIGGER_SET - Expected trigger already been set
|
||||
* IRQD_CAN_RESERVE - Can use reservation mode
|
||||
* IRQD_MSI_NOMASK_QUIRK - Non-maskable MSI quirk for affinity change
|
||||
* required
|
||||
* IRQD_HANDLE_ENFORCE_IRQCTX - Enforce that handle_irq_*() is only invoked
|
||||
* from actual interrupt context.
|
||||
* IRQD_AFFINITY_ON_ACTIVATE - Affinity is set on activation. Don't call
|
||||
@ -247,11 +245,10 @@ enum {
|
||||
IRQD_SINGLE_TARGET = BIT(24),
|
||||
IRQD_DEFAULT_TRIGGER_SET = BIT(25),
|
||||
IRQD_CAN_RESERVE = BIT(26),
|
||||
IRQD_MSI_NOMASK_QUIRK = BIT(27),
|
||||
IRQD_HANDLE_ENFORCE_IRQCTX = BIT(28),
|
||||
IRQD_AFFINITY_ON_ACTIVATE = BIT(29),
|
||||
IRQD_IRQ_ENABLED_ON_SUSPEND = BIT(30),
|
||||
IRQD_RESEND_WHEN_IN_PROGRESS = BIT(31),
|
||||
IRQD_HANDLE_ENFORCE_IRQCTX = BIT(27),
|
||||
IRQD_AFFINITY_ON_ACTIVATE = BIT(28),
|
||||
IRQD_IRQ_ENABLED_ON_SUSPEND = BIT(29),
|
||||
IRQD_RESEND_WHEN_IN_PROGRESS = BIT(30),
|
||||
};
|
||||
|
||||
#define __irqd_to_state(d) ACCESS_PRIVATE((d)->common, state_use_accessors)
|
||||
@ -426,21 +423,6 @@ static inline bool irqd_can_reserve(struct irq_data *d)
|
||||
return __irqd_to_state(d) & IRQD_CAN_RESERVE;
|
||||
}
|
||||
|
||||
static inline void irqd_set_msi_nomask_quirk(struct irq_data *d)
|
||||
{
|
||||
__irqd_to_state(d) |= IRQD_MSI_NOMASK_QUIRK;
|
||||
}
|
||||
|
||||
static inline void irqd_clr_msi_nomask_quirk(struct irq_data *d)
|
||||
{
|
||||
__irqd_to_state(d) &= ~IRQD_MSI_NOMASK_QUIRK;
|
||||
}
|
||||
|
||||
static inline bool irqd_msi_nomask_quirk(struct irq_data *d)
|
||||
{
|
||||
return __irqd_to_state(d) & IRQD_MSI_NOMASK_QUIRK;
|
||||
}
|
||||
|
||||
static inline void irqd_set_affinity_on_activate(struct irq_data *d)
|
||||
{
|
||||
__irqd_to_state(d) |= IRQD_AFFINITY_ON_ACTIVATE;
|
||||
|
@ -547,12 +547,6 @@ enum {
|
||||
MSI_FLAG_ALLOC_SIMPLE_MSI_DESCS = (1 << 5),
|
||||
/* Free MSI descriptors */
|
||||
MSI_FLAG_FREE_MSI_DESCS = (1 << 6),
|
||||
/*
|
||||
* Quirk to handle MSI implementations which do not provide
|
||||
* masking. Currently known to affect x86, but has to be partially
|
||||
* handled in the core MSI code.
|
||||
*/
|
||||
MSI_FLAG_NOMASK_QUIRK = (1 << 7),
|
||||
|
||||
/* Mask for the generic functionality */
|
||||
MSI_GENERIC_FLAGS_MASK = GENMASK(15, 0),
|
||||
|
@ -121,7 +121,6 @@ static const struct irq_bit_descr irqdata_states[] = {
|
||||
BIT_MASK_DESCR(IRQD_AFFINITY_ON_ACTIVATE),
|
||||
BIT_MASK_DESCR(IRQD_MANAGED_SHUTDOWN),
|
||||
BIT_MASK_DESCR(IRQD_CAN_RESERVE),
|
||||
BIT_MASK_DESCR(IRQD_MSI_NOMASK_QUIRK),
|
||||
|
||||
BIT_MASK_DESCR(IRQD_FORWARDED_TO_VCPU),
|
||||
|
||||
|
@ -1204,7 +1204,6 @@ static int msi_handle_pci_fail(struct irq_domain *domain, struct msi_desc *desc,
|
||||
|
||||
#define VIRQ_CAN_RESERVE 0x01
|
||||
#define VIRQ_ACTIVATE 0x02
|
||||
#define VIRQ_NOMASK_QUIRK 0x04
|
||||
|
||||
static int msi_init_virq(struct irq_domain *domain, int virq, unsigned int vflags)
|
||||
{
|
||||
@ -1213,8 +1212,6 @@ static int msi_init_virq(struct irq_domain *domain, int virq, unsigned int vflag
|
||||
|
||||
if (!(vflags & VIRQ_CAN_RESERVE)) {
|
||||
irqd_clr_can_reserve(irqd);
|
||||
if (vflags & VIRQ_NOMASK_QUIRK)
|
||||
irqd_set_msi_nomask_quirk(irqd);
|
||||
|
||||
/*
|
||||
* If the interrupt is managed but no CPU is available to
|
||||
@ -1275,15 +1272,8 @@ static int __msi_domain_alloc_irqs(struct device *dev, struct irq_domain *domain
|
||||
* Interrupt can use a reserved vector and will not occupy
|
||||
* a real device vector until the interrupt is requested.
|
||||
*/
|
||||
if (msi_check_reservation_mode(domain, info, dev)) {
|
||||
if (msi_check_reservation_mode(domain, info, dev))
|
||||
vflags |= VIRQ_CAN_RESERVE;
|
||||
/*
|
||||
* MSI affinity setting requires a special quirk (X86) when
|
||||
* reservation mode is active.
|
||||
*/
|
||||
if (info->flags & MSI_FLAG_NOMASK_QUIRK)
|
||||
vflags |= VIRQ_NOMASK_QUIRK;
|
||||
}
|
||||
|
||||
xa_for_each_range(xa, idx, desc, ctrl->first, ctrl->last) {
|
||||
if (!msi_desc_match(desc, MSI_DESC_NOTASSOCIATED))
|
||||
|
Loading…
Reference in New Issue
Block a user