mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2026-04-24 10:49:54 +02:00
695949d8b1
The GICv5 architecture implements the Interrupt Wire Bridge (IWB) in order to support wired interrupts that cannot be connected directly to an IRS and instead uses the ITS to translate a wire event into an IRQ signal. Add the wired-to-MSI IWB driver to manage IWB wired interrupts. An IWB is connected to an ITS and it has its own deviceID for all interrupt wires that it manages; the IWB input wire number must be exposed to the ITS as an eventID with a 1:1 mapping. This eventID is not programmable and therefore requires a new msi_alloc_info_t flag to make sure the ITS driver does not allocate an eventid for the wire but rather it uses the msi_alloc_info_t.hwirq number to gather the ITS eventID. Co-developed-by: Sascha Bischoff <sascha.bischoff@arm.com> Signed-off-by: Sascha Bischoff <sascha.bischoff@arm.com> Co-developed-by: Timothy Hayes <timothy.hayes@arm.com> Signed-off-by: Timothy Hayes <timothy.hayes@arm.com> Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org> Reviewed-by: Marc Zyngier <maz@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Marc Zyngier <maz@kernel.org> Link: https://lore.kernel.org/r/20250703-gicv5-host-v7-29-12e71f1b3528@kernel.org Signed-off-by: Marc Zyngier <maz@kernel.org>
43 lines
1.1 KiB
C
43 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __ASM_GENERIC_MSI_H
|
|
#define __ASM_GENERIC_MSI_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#ifdef CONFIG_GENERIC_MSI_IRQ
|
|
|
|
#ifndef NUM_MSI_ALLOC_SCRATCHPAD_REGS
|
|
# define NUM_MSI_ALLOC_SCRATCHPAD_REGS 2
|
|
#endif
|
|
|
|
struct msi_desc;
|
|
|
|
/**
|
|
* struct msi_alloc_info - Default structure for MSI interrupt allocation.
|
|
* @desc: Pointer to msi descriptor
|
|
* @hwirq: Associated hw interrupt number in the domain
|
|
* @scratchpad: Storage for implementation specific scratch data
|
|
*
|
|
* Architectures can provide their own implementation by not including
|
|
* asm-generic/msi.h into their arch specific header file.
|
|
*/
|
|
typedef struct msi_alloc_info {
|
|
struct msi_desc *desc;
|
|
irq_hw_number_t hwirq;
|
|
unsigned long flags;
|
|
union {
|
|
unsigned long ul;
|
|
void *ptr;
|
|
} scratchpad[NUM_MSI_ALLOC_SCRATCHPAD_REGS];
|
|
} msi_alloc_info_t;
|
|
|
|
/* Device generating MSIs is proxying for another device */
|
|
#define MSI_ALLOC_FLAGS_PROXY_DEVICE (1UL << 0)
|
|
#define MSI_ALLOC_FLAGS_FIXED_MSG_DATA (1UL << 1)
|
|
|
|
#define GENERIC_MSI_DOMAIN_OPS 1
|
|
|
|
#endif /* CONFIG_GENERIC_MSI_IRQ */
|
|
|
|
#endif
|