| /linux/drivers/vfio/platform/ |
| H A D | vfio_platform_irq.c | 49 if (!(vdev->irqs[index].flags & VFIO_IRQ_INFO_MASKABLE)) in vfio_platform_set_irq_mask() 56 return vfio_virqfd_enable((void *) &vdev->irqs[index], in vfio_platform_set_irq_mask() 59 &vdev->irqs[index].mask, fd); in vfio_platform_set_irq_mask() 61 vfio_virqfd_disable(&vdev->irqs[index].mask); in vfio_platform_set_irq_mask() 66 vfio_platform_mask(&vdev->irqs[index]); in vfio_platform_set_irq_mask() 72 vfio_platform_mask(&vdev->irqs[index]); in vfio_platform_set_irq_mask() 109 if (!(vdev->irqs[index].flags & VFIO_IRQ_INFO_MASKABLE)) in vfio_platform_set_irq_unmask() 116 return vfio_virqfd_enable((void *) &vdev->irqs[index], in vfio_platform_set_irq_unmask() 119 &vdev->irqs[index].unmask, in vfio_platform_set_irq_unmask() 122 vfio_virqfd_disable(&vdev->irqs[index].unmask); in vfio_platform_set_irq_unmask() [all …]
|
| /linux/drivers/bus/fsl-mc/ |
| H A D | fsl-mc-allocator.c | 347 * ID. A block of IRQs is pre-allocated and maintained in a pool 353 * It allocates a block of IRQs from the GIC-ITS. 415 * It frees the IRQs that were allocated to the pool, back to the GIC-ITS. 441 * Allocate the IRQs required by a given fsl-mc device. 449 struct fsl_mc_device_irq **irqs = NULL; in fsl_mc_allocate_irqs() local 453 if (mc_dev->irqs) in fsl_mc_allocate_irqs() 471 "Not able to allocate %u irqs for device\n", irq_count); in fsl_mc_allocate_irqs() 475 irqs = devm_kcalloc(&mc_dev->dev, irq_count, sizeof(irqs[0]), in fsl_mc_allocate_irqs() 477 if (!irqs) in fsl_mc_allocate_irqs() 488 irqs[i] = to_fsl_mc_irq(resource); in fsl_mc_allocate_irqs() [all …]
|
| /linux/drivers/misc/ |
| H A D | hi6421v600-irq.c | 3 * Device driver for irqs in HISI PMIC IC 23 unsigned int *irqs; member 52 * IRQ number for the power key button and mask for both UP and DOWN IRQs 61 * registers are used by the irqs. 68 * The IRQs are mapped as: 108 /* Mark pending IRQs as handled */ in hi6421v600_irq_handler() 116 * If both powerkey down and up IRQs are received, in hi6421v600_irq_handler() 119 generic_handle_irq_safe(priv->irqs[POWERKEY_DOWN]); in hi6421v600_irq_handler() 120 generic_handle_irq_safe(priv->irqs[POWERKEY_UP]); in hi6421v600_irq_handler() 128 generic_handle_irq_safe(priv->irqs[offset + i * BITS_PER_BYTE]); in hi6421v600_irq_handler() [all …]
|
| /linux/include/linux/mfd/ |
| H A D | rohm-bd96801.h | 78 /* ERRB IRQs */ 80 /* Reg 0x52, 0x53, 0x54 - ERRB system IRQs */ 101 /* Reg 0x55 BUCK1 ERR IRQs */ 107 /* Reg 0x56 BUCK2 ERR IRQs */ 113 /* Reg 0x57 BUCK3 ERR IRQs */ 119 /* Reg 0x58 BUCK4 ERR IRQs */ 125 /* Reg 0x59 LDO5 ERR IRQs */ 131 /* Reg 0x5a LDO6 ERR IRQs */ 137 /* Reg 0x5b LDO7 ERR IRQs */ 144 /* INTB IRQs */
|
| H A D | rohm-bd96802.h | 9 * IRQs. 15 /* ERRB IRQs */ 17 /* Reg 0x52, 0x53, 0x54 - ERRB system IRQs */ 36 /* Reg 0x55 BUCK1 ERR IRQs */ 42 /* Reg 0x56 BUCK2 ERR IRQs */ 49 /* INTB IRQs */
|
| H A D | intel_soc_pmic_mrfld.h | 50 /* Level 1 IRQs */ 60 /* Level 2 IRQs: power button */ 64 /* Level 2 IRQs: ADC */ 71 /* Level 2 IRQs: charger */
|
| /linux/drivers/base/ |
| H A D | auxiliary_sysfs.c | 21 .name = "irqs", 38 xa_init(&auxdev->sysfs.irqs); in auxiliary_irq_dir_prepare() 51 * unique irqs of the auxiliary devices. The driver must not invoke this API 73 ret = xa_insert(&auxdev->sysfs.irqs, irq, info, GFP_KERNEL); in auxiliary_device_sysfs_irq_add() 83 xa_store(&auxdev->sysfs.irqs, irq, no_free_ptr(info), GFP_KERNEL); in auxiliary_device_sysfs_irq_add() 87 xa_erase(&auxdev->sysfs.irqs, irq); in auxiliary_device_sysfs_irq_add() 102 struct auxiliary_irq_info *info __free(kfree) = xa_load(&auxdev->sysfs.irqs, irq); in auxiliary_device_sysfs_irq_remove() 111 xa_erase(&auxdev->sysfs.irqs, irq); in auxiliary_device_sysfs_irq_remove()
|
| /linux/drivers/irqchip/ |
| H A D | irq-nvic.c | 33 * Each bank handles 32 irqs. Only the 16th (= last) bank handles only 34 * 16 irqs. 76 unsigned int irqs, i, numbanks; in nvic_of_init() local 89 irqs = numbanks * 32; in nvic_of_init() 90 if (irqs > NVIC_MAX_IRQ) in nvic_of_init() 91 irqs = NVIC_MAX_IRQ; in nvic_of_init() 94 irq_domain_create_linear(of_fwnode_handle(node), irqs, &nvic_irq_domain_ops, NULL); in nvic_of_init() 131 for (i = 0; i < irqs; i += 4) in nvic_of_init()
|
| H A D | irq-bcm6345-l1.c | 19 * 0x1000_0028: CPU0_W0_STATUS IRQs 31-63 20 * 0x1000_002c: CPU0_W1_STATUS IRQs 0-31 23 * 0x1000_0038: CPU1_W0_STATUS IRQs 31-63 24 * 0x1000_003c: CPU1_W1_STATUS IRQs 0-31 31 * 0x1000_0030: CPU0_W0_STATUS IRQs 96-127 32 * 0x1000_0034: CPU0_W1_STATUS IRQs 64-95 33 * 0x1000_0038: CPU0_W2_STATUS IRQs 32-63 34 * 0x1000_003c: CPU0_W3_STATUS IRQs 0-31 39 * 0x1000_0050: CPU1_W0_STATUS IRQs 96-127 40 * 0x1000_0054: CPU1_W1_STATUS IRQs 64-95 [all …]
|
| H A D | irq-ingenic-tcu.c | 93 int ret, irqs; in ingenic_tcu_irq_init() local 105 irqs = of_property_count_elems_of_size(np, "interrupts", sizeof(u32)); in ingenic_tcu_irq_init() 106 if (irqs < 0 || irqs > ARRAY_SIZE(tcu->parent_irqs)) { in ingenic_tcu_irq_init() 112 tcu->nb_parent_irqs = irqs; in ingenic_tcu_irq_init() 143 /* Mask all IRQs by default */ in ingenic_tcu_irq_init() 156 for (i = 0; i < irqs; i++) { in ingenic_tcu_irq_init()
|
| /linux/Documentation/devicetree/bindings/interrupt-controller/ |
| H A D | st,stih407-irq-syscfg.yaml | 7 title: STMicroelectronics STi System Configuration Controlled IRQs 14 Management), and PL310 L2 Cache IRQs are controlled using System 26 description: Array of IRQs to enable. 40 description: External IRQs can be inverted at will. This property inverts 41 these three IRQs using bitwise logic, each one being encoded respectively
|
| H A D | mrvl,intc.yaml | 22 - mrvl,intc-nr-irqs 86 mrvl,intc-nr-irqs: 111 mrvl,intc-nr-irqs = <64>; 121 mrvl,intc-nr-irqs = <2>;
|
| /linux/drivers/pcmcia/ |
| H A D | sa1111_generic.c | 141 int i, ret = 0, irqs[NUM_IRQS]; in sa1111_pcmcia_add() local 148 irqs[i] = sa1111_get_irq(dev, i); in sa1111_pcmcia_add() 149 if (irqs[i] <= 0) in sa1111_pcmcia_add() 150 return irqs[i] ? : -ENXIO; in sa1111_pcmcia_add() 166 s->soc.socket.pci_irq = irqs[IDX_IRQ_S1_READY_NINT]; in sa1111_pcmcia_add() 167 s->soc.stat[SOC_STAT_CD].irq = irqs[IDX_IRQ_S1_CD_VALID]; in sa1111_pcmcia_add() 169 s->soc.stat[SOC_STAT_BVD1].irq = irqs[IDX_IRQ_S1_BVD1_STSCHG]; in sa1111_pcmcia_add() 172 s->soc.socket.pci_irq = irqs[IDX_IRQ_S0_READY_NINT]; in sa1111_pcmcia_add() 173 s->soc.stat[SOC_STAT_CD].irq = irqs[IDX_IRQ_S0_CD_VALID]; in sa1111_pcmcia_add() 175 s->soc.stat[SOC_STAT_BVD1].irq = irqs[IDX_IRQ_S0_BVD1_STSCHG]; in sa1111_pcmcia_add()
|
| /linux/drivers/pci/controller/ |
| H A D | vmd.c | 114 * struct vmd_irq_list - list of driver requested IRQs mapping to a VMD vector 117 * @count: number of child IRQs assigned to this vector; used to track 135 struct vmd_irq_list *irqs; member 153 struct vmd_irq_list *irqs) in index_from_irqs() argument 155 return irqs - vmd->irqs; in index_from_irqs() 159 * Drivers managing a device in a VMD domain allocate their own IRQs as before, 238 return &vmd->irqs[vmd->first_vec]; in vmd_next_irq() 248 return &vmd->irqs[vmd->first_vec]; in vmd_next_irq() 254 if (vmd->irqs[i].count < vmd->irqs[best].count) in vmd_next_irq() 256 vmd->irqs[best].count++; in vmd_next_irq() [all …]
|
| /linux/Documentation/power/ |
| H A D | suspend-and-interrupts.rst | 9 Suspending and Resuming Device IRQs 12 Device interrupt request lines (IRQs) are generally disabled during system 21 interrupt handlers for shared IRQs that device drivers implementing them were 29 Device IRQs are re-enabled during system resume, right before the "early" phase 91 not executed for system wakeup IRQs. They are only executed for IRQF_NO_SUSPEND 92 IRQs at that time, but those IRQs should not be configured for system wakeup 126 Second, both enable_irq_wake() and IRQF_NO_SUSPEND apply to entire IRQs and not 133 must be able to discern spurious IRQs from genuine wakeup events (signalling
|
| /linux/arch/arc/kernel/ |
| H A D | intc-arcv2.c | 17 unsigned int pad:3, firq:1, prio:4, exts:8, irqs:8, ver:8; member 19 unsigned int ver:8, irqs:8, exts:8, prio:4, firq:1, pad:3; 61 * Linux by default uses lower prio 1 for most irqs, reserving 0 for in arc_init_IRQ() 79 for (i = NR_EXCEPTIONS; i < irq_bcr.irqs + NR_EXCEPTIONS; i++) { in arc_init_IRQ() 84 * Only mask cpu private IRQs here. in arc_init_IRQ() 136 * core intc IRQs [16, 23]: in arcv2_irq_map() 168 nr_cpu_irqs = irq_bcr.irqs + NR_EXCEPTIONS; in init_onchip_IRQ()
|
| H A D | intc-compact.c | 22 * -Optionally, setup the High priority Interrupts as Level 2 IRQs 32 * Write to register, even if no LV2 IRQs configured to reset it in arc_init_IRQ() 59 * To reduce platform code, we assume all IRQs directly hooked-up into intc. 60 * Platforms with external intc, hence cascaded IRQs, are free to over-ride 146 * soft ISR are low priority jobs which can be very slow, thus all IRQs 149 * still we must re-enable both L1 and L2 IRQs
|
| /linux/arch/arm/mach-sa1100/include/mach/ |
| H A D | irqs.h | 3 * arch/arm/mach-sa1100/include/mach/irqs.h 9 * 2001/11/14 RMK Cleaned up and standardised a lot of the IRQs. 78 * within sensible limits. IRQs 61 to 76 are available. 87 * allocate their IRQs above NR_IRQS. 89 * LoCoMo has 4 additional IRQs, but is not sparse IRQ aware, and so has
|
| /linux/drivers/gpio/ |
| H A D | gpio-reg.c | 28 const int *irqs; member 114 int irq = r->irqs[offset]; in gpio_reg_to_irq() 132 * @irqs: array of %num ints describing the interrupt mapping for each 145 const char *const *names, struct irq_domain *irqdom, const int *irqs) in gpio_reg_init() argument 167 if (irqs) in gpio_reg_init() 175 r->irqs = irqs; in gpio_reg_init()
|
| /linux/drivers/pci/pcie/ |
| H A D | portdrv.c | 108 * @irqs: Array of interrupt vectors to populate 113 static int pcie_port_enable_irq_vec(struct pci_dev *dev, int *irqs, int mask) in pcie_port_enable_irq_vec() argument 155 irqs[PCIE_PORT_SERVICE_PME_SHIFT] = pcie_irq; in pcie_port_enable_irq_vec() 156 irqs[PCIE_PORT_SERVICE_HP_SHIFT] = pcie_irq; in pcie_port_enable_irq_vec() 157 irqs[PCIE_PORT_SERVICE_BWCTRL_SHIFT] = pcie_irq; in pcie_port_enable_irq_vec() 161 irqs[PCIE_PORT_SERVICE_AER_SHIFT] = pci_irq_vector(dev, aer); in pcie_port_enable_irq_vec() 164 irqs[PCIE_PORT_SERVICE_DPC_SHIFT] = pci_irq_vector(dev, dpc); in pcie_port_enable_irq_vec() 170 * pcie_init_service_irqs - initialize irqs for PCI Express port services 172 * @irqs: Array of irqs to populate 177 static int pcie_init_service_irqs(struct pci_dev *dev, int *irqs, int mask) in pcie_init_service_irqs() argument [all …]
|
| /linux/drivers/mfd/ |
| H A D | tps65912-core.c | 24 /* INT_STS IRQs */ 33 /* INT_STS2 IRQs */ 42 /* INT_STS3 IRQs */ 51 /* INT_STS4 IRQs */ 62 .irqs = tps65912_irqs,
|
| /linux/sound/soc/sdca/ |
| H A D | sdca_interrupts.c | 75 .irqs = regmap_irqs, 267 info->irqs[sdca_irq].irq = irq; in sdca_irq_request_locked() 285 info->irqs[sdca_irq].irq = 0; in sdca_irq_free_locked() 407 if (info->irqs[irq].irq) { in get_interrupt_data() 412 return &info->irqs[irq]; in get_interrupt_data() 484 * sdca_irq_populate - Request all the individual IRQs for an SDCA Function 566 * sdca_irq_cleanup - Free all the individual IRQs for an SDCA Function 582 struct sdca_interrupt *interrupt = &info->irqs[i]; in sdca_irq_cleanup() 619 for (i = 0; i < ARRAY_SIZE(info->irqs); i++) in sdca_irq_allocate() 620 info->irqs[ in sdca_irq_allocate() [all...] |
| /linux/drivers/net/ethernet/intel/ice/ |
| H A D | ice_irq.c | 240 * ice_virt_get_irqs - get irqs for SR-IOV usacase 242 * @needed: number of irqs to get 249 * use this irqs 267 * ice_virt_free_irqs - free irqs used by the VF 270 * @irqs: number of irqs to free 272 void ice_virt_free_irqs(struct ice_pf *pf, u32 index, u32 irqs) in ice_virt_free_irqs() argument 275 irqs); in ice_virt_free_irqs()
|
| /linux/Documentation/arch/arm/ |
| H A D | interrupts.rst | 18 The 2.5 kernels will be having major changes to the way IRQs are handled. 39 SA1111 IRQ handler, SA1111 IRQs can hold off SMC9196 IRQs indefinitely. 50 SA11x0 IRQs are handled by two separate "chip" structures, one for 81 - required. May be the same function as mask for IRQs 89 IRQs that use this 'irqchip'. Generally expected to re-trigger 167 hardware based. Mixing level-based and edge-based IRQs on the same
|
| /linux/tools/testing/selftests/kvm/s390/ |
| H A D | resets.c | 71 int irqs; in assert_noirq() local 75 irqs = __vcpu_ioctl(vcpu, KVM_S390_GET_IRQ_STATE, &irq_state); in assert_noirq() 77 * irqs contains the number of retrieved interrupts. Any interrupt in assert_noirq() 81 TEST_ASSERT(irqs >= 0, "Could not fetch IRQs: errno %d", errno); in assert_noirq() 82 TEST_ASSERT(!irqs, "IRQ pending"); in assert_noirq() 194 int irqs; in inject_irq() local 201 irqs = __vcpu_ioctl(vcpu, KVM_S390_SET_IRQ_STATE, &irq_state); in inject_irq() 202 TEST_ASSERT(irqs >= 0, "Error injecting EMERGENCY IRQ errno %d", errno); in inject_irq()
|