| /Linux-v6.6/drivers/pci/controller/ | 
| D | pcie-iproc-msi.c | 9 #include <linux/msi.h>34 /* Size of each MSI address region */
 52  * struct iproc_msi_grp - iProc MSI group
 54  * One MSI group is allocated per GIC interrupt, serviced by one iProc MSI
 57  * @msi: pointer to iProc MSI data
 62 	struct iproc_msi *msi;  member
 68  * struct iproc_msi - iProc event queue based MSI
 70  * Only meant to be used on platforms without MSI support integrated into the
 74  * @reg_offsets: MSI register offsets
 75  * @grps: MSI groups
 [all …]
 
 | 
| D | pcie-altera-msi.c | 3  * Altera PCIe MSI support15 #include <linux/msi.h>
 41 static inline void msi_writel(struct altera_msi *msi, const u32 value,  in msi_writel()  argument
 44 	writel_relaxed(value, msi->csr_base + reg);  in msi_writel()
 47 static inline u32 msi_readl(struct altera_msi *msi, const u32 reg)  in msi_readl()  argument
 49 	return readl_relaxed(msi->csr_base + reg);  in msi_readl()
 55 	struct altera_msi *msi;  in altera_msi_isr()  local
 61 	msi = irq_desc_get_handler_data(desc);  in altera_msi_isr()
 63 	while ((status = msi_readl(msi, MSI_STATUS)) != 0) {  in altera_msi_isr()
 64 		for_each_set_bit(bit, &status, msi->num_of_vectors) {  in altera_msi_isr()
 [all …]
 
 | 
| D | pci-xgene-msi.c | 3  * APM X-Gene MSI Driver13 #include <linux/msi.h>
 27 	struct xgene_msi	*msi;  member
 48 	.name		= "X-Gene1 MSI",
 62  * X-Gene v1 has 16 groups of MSI termination registers MSInIRx, where
 85  * Each index register supports 16 MSI vectors (0..15) to generate interrupt.
 86  * There are total 16 GIC IRQs assigned for these 16 groups of MSI termination
 89  * Each MSI termination group has 1 MSIINTn register (n is 0..15) to indicate
 90  * the MSI pending status caused by 1 of its 8 index registers.
 94 static u32 xgene_msi_ir_read(struct xgene_msi *msi,  in xgene_msi_ir_read()  argument
 [all …]
 
 | 
| D | pcie-brcmstb.c | 20 #include <linux/msi.h>156 /* MSI target addresses */
 243 	int			nr; /* No. of MSI available, depends on chip */
 257 	struct brcm_msi		*msi;  member
 435 	.name            = "BRCM STB PCIe MSI",
 451 	struct brcm_msi *msi;  in brcm_pcie_msi_isr()  local
 456 	msi = irq_desc_get_handler_data(desc);  in brcm_pcie_msi_isr()
 457 	dev = msi->dev;  in brcm_pcie_msi_isr()
 459 	status = readl(msi->intr_base + MSI_INT_STATUS);  in brcm_pcie_msi_isr()
 460 	status >>= msi->legacy_shift;  in brcm_pcie_msi_isr()
 [all …]
 
 | 
| /Linux-v6.6/Documentation/devicetree/bindings/pci/ | 
| D | pci-msi.txt | 2 relationship between PCI devices and MSI controllers.18 Requester ID. A mechanism is required to associate a device with both the MSI
 22 For generic MSI bindings, see
 23 Documentation/devicetree/bindings/interrupt-controller/msi.txt.
 32 - msi-map: Maps a Requester ID to an MSI controller and associated
 33   msi-specifier data. The property is an arbitrary number of tuples of
 34   (rid-base,msi-controller,msi-base,length), where:
 38   * msi-controller is a single phandle to an MSI controller
 40   * msi-base is an msi-specifier describing the msi-specifier produced for the
 47   the listed msi-controller, with the msi-specifier (r - rid-base + msi-base).
 [all …]
 
 | 
| D | xgene-pci-msi.txt | 1 * AppliedMicro X-Gene v1 PCIe MSI controller5 - compatible: should be "apm,xgene1-msi" to identify
 6 	      X-Gene v1 PCIe MSI controller block.
 7 - msi-controller: indicates that this is an X-Gene v1 PCIe MSI controller node
 9        registers. These registers include the MSI termination address and data
 10        registers as well as the MSI interrupt status registers.
 16 Each PCIe node needs to have property msi-parent that points to an MSI
 23 	+ MSI node:
 24 	msi@79000000 {
 25 		compatible = "apm,xgene1-msi";
 [all …]
 
 | 
| /Linux-v6.6/arch/powerpc/sysdev/ | 
| D | fsl_msi.c | 11 #include <linux/msi.h>37 #define msi_hwirq(msi, msir_index, intr_index) \  argument
 38 		((msir_index) << (msi)->srs_shift | \
 39 		 ((intr_index) << (msi)->ibs_shift))
 61  * in the cascade interrupt. So, this MSI interrupt has been acked
 76 	seq_printf(p, " fsl-msi-%d", cascade_virq);  in fsl_msi_print_chip()
 150 	/* If the msi-address-64 property exists, then use it */  in fsl_compose_msi_msg()
 151 	reg = of_get_property(hose->dn, "msi-address-64", &len);  in fsl_compose_msi_msg()
 162 	 * that neither MSI nor MSI-X can work fine.  in fsl_compose_msi_msg()
 163 	 * This is a workaround to allow MSI-X to function  in fsl_compose_msi_msg()
 [all …]
 
 | 
| /Linux-v6.6/Documentation/devicetree/bindings/interrupt-controller/ | 
| D | msi.txt | 1 This document describes the generic device tree binding for MSI controllers and9 those busses to the MSI controllers which they are capable of using,
 17   they can address. An MSI controller may feature a number of doorbells.
 22   MSI controllers may have restrictions on permitted payloads.
 28   MSI controller and device rather than a property of either in isolation).
 31 MSI controllers:
 34 An MSI controller signals interrupts to a CPU when a write is made to an MMIO
 35 address by some master. An MSI controller may feature a number of doorbells.
 40 - msi-controller: Identifies the node as an MSI controller.
 45 - #msi-cells: The number of cells in an msi-specifier, required if not zero.
 [all …]
 
 | 
| D | loongson,pch-msi.yaml | 4 $id: http://devicetree.org/schemas/interrupt-controller/loongson,pch-msi.yaml#7 title: Loongson PCH MSI Controller
 14   transforming interrupts from PCIe MSI into HyperTransport vectorized
 19     const: loongson,pch-msi-1.0
 24   loongson,msi-base-vec:
 27       to PCH MSI.
 32   loongson,msi-num-vecs:
 35       to PCH MSI.
 40   msi-controller: true
 45   - msi-controller
 [all …]
 
 | 
| D | fsl,ls-scfg-msi.txt | 1 * Freescale Layerscape SCFG PCIe MSI controller5 - compatible: should be "fsl,<soc-name>-msi" to identify
 6 	      Layerscape PCIe MSI controller block such as:
 7               "fsl,ls1021a-msi"
 8               "fsl,ls1043a-msi"
 9               "fsl,ls1046a-msi"
 10               "fsl,ls1043a-v1.1-msi"
 11               "fsl,ls1012a-msi"
 12 - msi-controller: indicates that this is a PCIe MSI controller node
 20 Each PCIe node needs to have property msi-parent that points to
 [all …]
 
 | 
| D | fsl,mu-msi.yaml | 4 $id: http://devicetree.org/schemas/interrupt-controller/fsl,mu-msi.yaml#7 title: Freescale/NXP i.MX Messaging Unit (MU) work as msi controller
 25   MU can work as msi interrupt controller to do doorbell
 28   - $ref: /schemas/interrupt-controller/msi-controller.yaml#
 33       - fsl,imx6sx-mu-msi
 34       - fsl,imx7ulp-mu-msi
 35       - fsl,imx8ulp-mu-msi
 36       - fsl,imx8ulp-mu-msi-s4
 67   msi-controller: true
 69   "#msi-cells":
 [all …]
 
 | 
| D | msi-controller.yaml | 4 $id: http://devicetree.org/schemas/interrupt-controller/msi-controller.yaml#7 title: MSI controller
 13   An MSI controller signals interrupts to a CPU when a write is made
 14   to an MMIO address by some master. An MSI controller may feature a
 18   "#msi-cells":
 20       The number of cells in an msi-specifier, required if not zero.
 26       The meaning of the msi-specifier is defined by the device tree
 27       binding of the specific MSI controller.
 30   msi-controller:
 32       Identifies the node as an MSI controller.
 [all …]
 
 | 
| /Linux-v6.6/include/linux/ | 
| D | msi.h | 6  * This header file contains MSI data structures and functions which are9  *	- PCI/MSI core code
 10  *	- MSI interrupt domain implementations
 12  *	  dealing with low level MSI details.
 15  * especially storing MSI descriptor pointers in random code is considered
 30 #include <asm/msi.h>
 56  * msi_msg - Representation of a MSI message
 57  * @address_lo:		Low 32 bits of msi message address
 59  * @address_hi:		High 32 bits of msi message address
 62  * @data:		MSI message data (usually 16 bits)
 [all …]
 
 | 
| /Linux-v6.6/arch/arm64/kvm/vgic/ | 
| D | vgic-irqfd.c | 55 		e->msi.address_lo = ue->u.msi.address_lo;  in kvm_set_routing_entry()56 		e->msi.address_hi = ue->u.msi.address_hi;  in kvm_set_routing_entry()
 57 		e->msi.data = ue->u.msi.data;  in kvm_set_routing_entry()
 58 		e->msi.flags = ue->flags;  in kvm_set_routing_entry()
 59 		e->msi.devid = ue->u.msi.devid;  in kvm_set_routing_entry()
 70 			     struct kvm_msi *msi)  in kvm_populate_msi()  argument
 72 	msi->address_lo = e->msi.address_lo;  in kvm_populate_msi()
 73 	msi->address_hi = e->msi.address_hi;  in kvm_populate_msi()
 74 	msi->data = e->msi.data;  in kvm_populate_msi()
 75 	msi->flags = e->msi.flags;  in kvm_populate_msi()
 [all …]
 
 | 
| /Linux-v6.6/Documentation/PCI/ | 
| D | msi-howto.rst | 5 The MSI Driver Guide HOWTO16 the advantages of using MSI over traditional interrupt mechanisms, how
 17 to change your driver to use MSI or MSI-X and some basic diagnostics to
 27 The MSI capability was first specified in PCI 2.2 and was later enhanced
 28 in PCI 3.0 to allow each interrupt to be masked individually.  The MSI-X
 30 per device than MSI and allows interrupts to be independently configured.
 32 Devices may support both MSI and MSI-X, but only one can be enabled at
 73 driver has to set up the device to use MSI or MSI-X.  Not all machines
 80 To support MSI or MSI-X, the kernel must be built with the CONFIG_PCI_MSI
 86 Using MSI
 [all …]
 
 | 
| /Linux-v6.6/Documentation/devicetree/bindings/powerpc/fsl/ | 
| D | msi-pic.txt | 1 * Freescale MSI interrupt controller5   The first is "fsl,CHIP-msi", where CHIP is the processor(mpc8610, mpc8572,
 6   etc.) and the second is "fsl,mpic-msi" or "fsl,ipic-msi" or
 7   "fsl,mpic-msi-v4.3" depending on the parent type and version. If mpic
 8   version is 4.3, the number of MSI registers is increased to 16, MSIIR1 is
 9   provided to access these 16 registers, and compatible "fsl,mpic-msi-v4.3"
 17   region must be added because different MSI group has different MSIIR1 offset.
 21   be set as edge sensitive.  If msi-available-ranges is present, only
 25 - msi-available-ranges: use <start count> style section to define which
 26   msi interrupt can be used in the 256 msi interrupts. This property is
 [all …]
 
 | 
| /Linux-v6.6/drivers/pci/msi/ | 
| D | api.c | 3  * PCI MSI/MSI-X — Exported APIs for device drivers14 #include "msi.h"
 17  * pci_enable_msi() - Enable MSI interrupt mode on device
 20  * Legacy device driver API to enable MSI interrupts mode on device and
 40  * pci_disable_msi() - Disable MSI interrupt mode on device
 43  * Legacy device driver API to disable MSI interrupt mode on device,
 64  * pci_msix_vec_count() - Get number of MSI-X interrupt vectors on device
 67  * Return: number of MSI-X interrupt vectors available on this device
 68  * (i.e., the device's MSI-X capability structure "table size"), -EINVAL
 69  * if the device is not MSI-X capable, other errnos otherwise.
 [all …]
 
 | 
| D | irqdomain.c | 3  * PCI Message Signaled Interrupt (MSI) - irqdomain support9 #include "msi.h"
 36  * pci_msi_domain_write_msg - Helper to write MSI message to PCI config space
 37  * @irq_data:	Pointer to interrupt data of the MSI interrupt
 45 	 * For MSI-X desc->irq is always equal to irq_data->irq. For  in pci_msi_domain_write_msg()
 46 	 * MSI only the first interrupt of MULTI MSI passes the test.  in pci_msi_domain_write_msg()
 53  * pci_msi_domain_calc_hwirq - Generate a unique ID for an MSI source
 54  * @desc:	Pointer to the MSI descriptor
 104  * pci_msi_create_irq_domain - Create a MSI interrupt domain
 106  * @info:	MSI domain info
 [all …]
 
 | 
| /Linux-v6.6/drivers/pci/controller/mobiveil/ | 
| D | pcie-mobiveil-host.c | 19 #include <linux/msi.h>88 	struct mobiveil_msi *msi = &rp->msi;  in mobiveil_pcie_isr()  local
 95 	 * The core provides a single interrupt for both INTx/MSI messages.  in mobiveil_pcie_isr()
 96 	 * So we'll read both INTx and MSI status  in mobiveil_pcie_isr()
 134 	/* read extra MSI status register */  in mobiveil_pcie_isr()
 137 	/* handle MSI interrupts */  in mobiveil_pcie_isr()
 143 		 * once we pop not only the MSI data but also address  in mobiveil_pcie_isr()
 144 		 * from MSI hardware FIFO. So keeping these following  in mobiveil_pcie_isr()
 151 		dev_dbg(dev, "MSI registers, data: %08x, addr: %08x:%08x\n",  in mobiveil_pcie_isr()
 154 		generic_handle_domain_irq(msi->dev_domain, msi_data);  in mobiveil_pcie_isr()
 [all …]
 
 | 
| /Linux-v6.6/drivers/base/ | 
| D | platform-msi.c | 3  * MSI framework for platform devices13 #include <linux/msi.h>
 21  * and the callback to write the MSI message.
 41 	u32 devid = desc->dev->msi.data->platform_data->devid;  in platform_msi_calc_hwirq()
 87 	desc->dev->msi.data->platform_data->write_msg(desc, msg);  in platform_msi_write_msg()
 111  * platform_msi_create_irq_domain - Create a platform MSI interrupt domain
 113  * @info:	MSI domain info
 116  * Updates the domain and chip ops and creates a platform MSI
 152 	 * accordingly (which would impact the max number of MSI  in platform_msi_alloc_priv_data()
 155 	if (!dev->msi.domain || !write_msi_msg || !nvec || nvec > MAX_DEV_MSIS)  in platform_msi_alloc_priv_data()
 [all …]
 
 | 
| /Linux-v6.6/arch/mips/pci/ | 
| D | msi-octeon.c | 10 #include <linux/msi.h>23  * Each bit in msi_free_irq_bitmask represents a MSI interrupt that is
 31  * is used so we can disable all of the MSI interrupts when a device
 43  * Number of MSI IRQs used. This variable is set up in
 49  * arch_setup_msi_irq() - setup MSI IRQs for a device
 50  * @dev:    Device requesting MSI interrupts
 51  * @desc:   MSI descriptor
 53  * Called when a driver requests MSI interrupts instead of the
 55  * for MSI devices that support them. A device can override this by
 56  * programming the MSI control bits [6:4] before calling
 [all …]
 
 | 
| /Linux-v6.6/drivers/ntb/ | 
| D | msi.c | 6 #include <linux/msi.h>19  * ntb_msi_init() - Initialize the MSI context
 23  * It initializes the context for MSI operations and maps
 45 	ntb->msi = devm_kzalloc(&ntb->dev, struct_size(ntb->msi, peer_mws, peers),  in ntb_msi_init()
 47 	if (!ntb->msi)  in ntb_msi_init()
 50 	ntb->msi->desc_changed = desc_changed;  in ntb_msi_init()
 60 		ntb->msi->peer_mws[i] = devm_ioremap(&ntb->dev, mw_phys_addr,  in ntb_msi_init()
 62 		if (!ntb->msi->peer_mws[i]) {  in ntb_msi_init()
 72 		if (ntb->msi->peer_mws[i])  in ntb_msi_init()
 73 			devm_iounmap(&ntb->dev, ntb->msi->peer_mws[i]);  in ntb_msi_init()
 [all …]
 
 | 
| /Linux-v6.6/arch/riscv/kvm/ | 
| D | vm.c | 71 	struct kvm_msi msi;  in kvm_set_msi()  local76 	msi.address_lo = e->msi.address_lo;  in kvm_set_msi()
 77 	msi.address_hi = e->msi.address_hi;  in kvm_set_msi()
 78 	msi.data = e->msi.data;  in kvm_set_msi()
 79 	msi.flags = e->msi.flags;  in kvm_set_msi()
 80 	msi.devid = e->msi.devid;  in kvm_set_msi()
 82 	return kvm_riscv_aia_inject_msi(kvm, &msi);  in kvm_set_msi()
 135 		e->msi.address_lo = ue->u.msi.address_lo;  in kvm_set_routing_entry()
 136 		e->msi.address_hi = ue->u.msi.address_hi;  in kvm_set_routing_entry()
 137 		e->msi.data = ue->u.msi.data;  in kvm_set_routing_entry()
 [all …]
 
 | 
| /Linux-v6.6/Documentation/PCI/endpoint/ | 
| D | pci-test-howto.rst | 79 to change the vendorid and the number of MSI interrupts used by the function158 	SET IRQ TYPE TO MSI:            OKAY
 191 	SET IRQ TYPE TO MSI-X:          OKAY
 192 	MSI-X1:         OKAY
 193 	MSI-X2:         OKAY
 194 	MSI-X3:         OKAY
 195 	MSI-X4:         OKAY
 196 	MSI-X5:         OKAY
 197 	MSI-X6:         OKAY
 198 	MSI-X7:         OKAY
 [all …]
 
 | 
| /Linux-v6.6/kernel/irq/ | 
| D | msi.c | 15 #include <linux/msi.h>23  * struct msi_ctrl - MSI internal management control structure
 28  *		than the range due to PCI/multi-MSI.
 87 	struct msi_device_data *md = dev->msi.data;  in msi_insert_desc()
 123  * msi_domain_insert_msi_desc - Allocate and initialize a MSI descriptor and
 128  * @init_desc:	Pointer to an MSI descriptor to initialize the new descriptor
 137 	lockdep_assert_held(&dev->msi.data->mutex);  in msi_domain_insert_msi_desc()
 168 			 (dev->msi.domain &&  in msi_ctrl_valid()
 169 			  !dev->msi.data->__domains[ctrl->domid].domain)))  in msi_ctrl_valid()
 186 	lockdep_assert_held(&dev->msi.data->mutex);  in msi_domain_free_descs()
 [all …]
 
 |