/linux/drivers/irqchip/ |
H A D | irq-sp7021-intc.c | 81 static void sp_intc_assign_bit(u32 hwirq, void __iomem *base, bool value) in sp_intc_assign_bit() argument 87 offset = (hwirq / 32) * 4; in sp_intc_assign_bit() 93 mask |= BIT(hwirq % 32); in sp_intc_assign_bit() 95 mask &= ~BIT(hwirq % 32); in sp_intc_assign_bit() 102 u32 hwirq = d->hwirq; in sp_intc_ack_irq() local 104 if (unlikely(IS_GPIO_INT(hwirq) && TEST_STATE(hwirq, _IS_EDGE))) { // WORKAROUND in sp_intc_ack_irq() 105 sp_intc_assign_bit(hwirq, REG_INTR_POLARITY, !TEST_STATE(hwirq, _IS_LOW)); in sp_intc_ack_irq() 106 ASSIGN_STATE(hwirq, _IS_ACTIVE, true); in sp_intc_ack_irq() 109 sp_intc_assign_bit(hwirq, REG_INTR_CLEAR, 1); in sp_intc_ack_irq() 114 sp_intc_assign_bit(d->hwirq, REG_INTR_MASK, 0); in sp_intc_mask_irq() [all …]
|
H A D | irq-renesas-rzg2l.c | 93 static void rzg2l_clear_irq_int(struct rzg2l_irqc_priv *priv, unsigned int hwirq) in rzg2l_clear_irq_int() argument 95 unsigned int hw_irq = hwirq - IRQC_IRQ_START; in rzg2l_clear_irq_int() 116 static void rzg2l_clear_tint_int(struct rzg2l_irqc_priv *priv, unsigned int hwirq) in rzg2l_clear_tint_int() argument 118 u32 bit = BIT(hwirq - IRQC_TINT_START); in rzg2l_clear_tint_int() 147 unsigned int hwirq) in rzfive_irqc_mask_irq_interrupt() argument 149 u32 bit = BIT(hwirq - IRQC_IRQ_START); in rzfive_irqc_mask_irq_interrupt() 155 unsigned int hwirq) in rzfive_irqc_unmask_irq_interrupt() argument 157 u32 bit = BIT(hwirq - IRQC_IRQ_START); in rzfive_irqc_unmask_irq_interrupt() 163 unsigned int hwirq) in rzfive_irqc_mask_tint_interrupt() argument 165 u32 bit = BIT(hwirq - IRQC_TINT_START); in rzfive_irqc_mask_tint_interrupt() [all …]
|
H A D | irq-mchp-eic.c | 51 tmp = readl_relaxed(eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_mask() 53 writel_relaxed(tmp, eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_mask() 62 tmp = readl_relaxed(eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_unmask() 64 writel_relaxed(tmp, eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_unmask() 74 tmp = readl_relaxed(eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_set_type() 96 writel_relaxed(tmp, eic->base + MCHP_EIC_SCFG(d->hwirq)); in mchp_eic_irq_set_type() 103 irq_set_irq_wake(eic->irqs[d->hwirq], on); in mchp_eic_irq_set_wake() 105 eic->wakeup_source |= BIT(d->hwirq); in mchp_eic_irq_set_wake() 107 eic->wakeup_source &= ~BIT(d->hwirq); in mchp_eic_irq_set_wake() 114 unsigned int hwirq; in mchp_eic_irq_suspend() local [all …]
|
H A D | irq-mmp.c | 71 int hwirq; in icu_mask_ack_irq() local 74 hwirq = d->irq - data->virq_base; in icu_mask_ack_irq() 76 r = readl_relaxed(mmp_icu_base + (hwirq << 2)); in icu_mask_ack_irq() 79 writel_relaxed(r, mmp_icu_base + (hwirq << 2)); in icu_mask_ack_irq() 83 && (hwirq == data->clr_mfp_hwirq)) in icu_mask_ack_irq() 86 r = readl_relaxed(data->reg_mask) | (1 << hwirq); in icu_mask_ack_irq() 95 int hwirq; in icu_mask_irq() local 98 hwirq = d->irq - data->virq_base; in icu_mask_irq() 100 r = readl_relaxed(mmp_icu_base + (hwirq << 2)); in icu_mask_irq() 103 writel_relaxed(r, mmp_icu_base + (hwirq << 2)); in icu_mask_irq() [all …]
|
H A D | irq-mvebu-sei.c | 61 u32 reg_idx = SEI_IRQ_REG_IDX(d->hwirq); in mvebu_sei_ack_irq() 63 writel_relaxed(BIT(SEI_IRQ_REG_BIT(d->hwirq)), in mvebu_sei_ack_irq() 70 u32 reg, reg_idx = SEI_IRQ_REG_IDX(d->hwirq); in mvebu_sei_mask_irq() 76 reg |= BIT(SEI_IRQ_REG_BIT(d->hwirq)); in mvebu_sei_mask_irq() 84 u32 reg, reg_idx = SEI_IRQ_REG_IDX(d->hwirq); in mvebu_sei_unmask_irq() 90 reg &= ~BIT(SEI_IRQ_REG_BIT(d->hwirq)); in mvebu_sei_unmask_irq() 146 msg->data = data->hwirq + sei->caps->cp_range.first; in mvebu_sei_cp_compose_msi_msg() 201 unsigned long *hwirq, in mvebu_sei_ap_translate() argument 204 *hwirq = fwspec->param[0]; in mvebu_sei_ap_translate() 215 unsigned long hwirq; in mvebu_sei_ap_alloc() local [all …]
|
H A D | irq-pruss-intc.c | 173 * @hwirq: the system event number 178 static void pruss_intc_map(struct pruss_intc *intc, unsigned long hwirq) in pruss_intc_map() argument 186 intc->event_channel[hwirq].ref_count++; in pruss_intc_map() 188 ch = intc->event_channel[hwirq].value; in pruss_intc_map() 191 pruss_intc_update_cmr(intc, hwirq, ch); in pruss_intc_map() 193 reg_idx = hwirq / 32; in pruss_intc_map() 194 val = BIT(hwirq % 32); in pruss_intc_map() 208 hwirq, ch, host); in pruss_intc_map() 216 * @hwirq: the system event number 222 static void pruss_intc_unmap(struct pruss_intc *intc, unsigned long hwirq) in pruss_intc_unmap() argument [all …]
|
H A D | irq-partition-percpu.c | 26 unsigned int cpu, unsigned int hwirq) in partition_check_cpu() argument 28 return cpumask_test_cpu(cpu, &part->parts[hwirq].mask); in partition_check_cpu() 37 if (partition_check_cpu(part, smp_processor_id(), d->hwirq) && in partition_irq_mask() 48 if (partition_check_cpu(part, smp_processor_id(), d->hwirq) && in partition_irq_unmask() 61 if (partition_check_cpu(part, smp_processor_id(), d->hwirq) && in partition_irq_set_irqchip_state() 76 if (partition_check_cpu(part, smp_processor_id(), d->hwirq) && in partition_irq_get_irqchip_state() 101 seq_printf(p, "%5s-%lu", chip->name, data->hwirq); in partition_irq_print_chip() 118 int hwirq; in partition_handle_irq() local 122 for_each_set_bit(hwirq, part->bitmap, part->nr_parts) { in partition_handle_irq() 123 if (partition_check_cpu(part, cpu, hwirq)) in partition_handle_irq() [all …]
|
H A D | irq-ls-extirq.c | 57 irq_hw_number_t hwirq = data->hwirq; in ls_extirq_set_type() local 61 mask = 1U << (31 - hwirq); in ls_extirq_set_type() 63 mask = 1U << hwirq; in ls_extirq_set_type() 104 irq_hw_number_t hwirq; in ls_extirq_domain_alloc() local 109 hwirq = fwspec->param[0]; in ls_extirq_domain_alloc() 110 if (hwirq >= priv->nirq) in ls_extirq_domain_alloc() 113 irq_domain_set_hwirq_and_chip(domain, virq, hwirq, &ls_extirq_chip, in ls_extirq_domain_alloc() 116 return irq_domain_alloc_irqs_parent(domain, virq, 1, &priv->map[hwirq]); in ls_extirq_domain_alloc() 141 u32 hwirq, intsize, j; in ls_extirq_parse_map() local 145 hwirq = be32_to_cpup(map); in ls_extirq_parse_map() [all …]
|
H A D | irq-ti-sci-inta.c | 30 #define HWIRQ_TO_DEVID(hwirq) (((hwirq) >> (TI_SCI_DEV_ID_SHIFT)) & \ argument 32 #define HWIRQ_TO_IRQID(hwirq) ((hwirq) & (TI_SCI_IRQ_ID_MASK)) argument 47 * hwirq and vint bit. 49 * @hwirq: Hwirq of the incoming interrupt 54 u32 hwirq; member 118 static u16 ti_sci_inta_get_dev_id(struct ti_sci_inta_irq_domain *inta, u32 hwirq) in ti_sci_inta_get_dev_id() argument 120 u16 dev_id = HWIRQ_TO_DEVID(hwirq); in ti_sci_inta_get_dev_id() 163 generic_handle_domain_irq(domain, vint_desc->events[bit].hwirq); in ti_sci_inta_irq_handler() 169 * ti_sci_inta_xlate_irq() - Translate hwirq to parent's hwirq. 275 * @hwirq: hwirq of the input event [all …]
|
H A D | irq-sifive-plic.c | 97 static void __plic_toggle(void __iomem *enable_base, int hwirq, int enable) in __plic_toggle() argument 99 u32 __iomem *reg = enable_base + (hwirq / 32) * sizeof(u32); in __plic_toggle() 100 u32 hwirq_mask = 1 << (hwirq % 32); in __plic_toggle() 108 static void plic_toggle(struct plic_handler *handler, int hwirq, int enable) in plic_toggle() argument 113 __plic_toggle(handler->enable_base, hwirq, enable); in plic_toggle() 125 plic_toggle(handler, d->hwirq, enable); in plic_irq_toggle() 133 writel(1, priv->regs + PRIORITY_BASE + d->hwirq * PRIORITY_PER_ID); in plic_irq_unmask() 140 writel(0, priv->regs + PRIORITY_BASE + d->hwirq * PRIORITY_PER_ID); in plic_irq_mask() 159 plic_toggle(handler, d->hwirq, 1); in plic_irq_eoi() 160 writel(d->hwirq, handler->hart_base + CONTEXT_CLAIM); in plic_irq_eoi() [all …]
|
H A D | irq-or1k-pic.c | 28 mtspr(SPR_PICMR, mfspr(SPR_PICMR) & ~(1UL << data->hwirq)); in or1k_pic_mask() 33 mtspr(SPR_PICMR, mfspr(SPR_PICMR) | (1UL << data->hwirq)); in or1k_pic_unmask() 38 mtspr(SPR_PICSR, (1UL << data->hwirq)); in or1k_pic_ack() 43 mtspr(SPR_PICMR, mfspr(SPR_PICMR) & ~(1UL << data->hwirq)); in or1k_pic_mask_ack() 44 mtspr(SPR_PICSR, (1UL << data->hwirq)); in or1k_pic_mask_ack() 55 mtspr(SPR_PICSR, mfspr(SPR_PICSR) & ~(1UL << data->hwirq)); in or1k_pic_or1200_ack() 60 mtspr(SPR_PICMR, mfspr(SPR_PICMR) & ~(1UL << data->hwirq)); in or1k_pic_or1200_mask_ack() 61 mtspr(SPR_PICSR, mfspr(SPR_PICSR) & ~(1UL << data->hwirq)); in or1k_pic_or1200_mask_ack() 102 int hwirq; in pic_get_irq() local 104 hwirq = ffs(mfspr(SPR_PICSR) >> first); in pic_get_irq() [all …]
|
H A D | irq-econet-en751221.c | 71 static void econet_chmask(u32 hwirq, bool unmask) in econet_chmask() argument 83 shadow = econet_intc.interrupt_shadows[hwirq]; in econet_chmask() 87 hwirq = shadow; in econet_chmask() 89 if (hwirq >= 32) { in econet_chmask() 91 mask = BIT(hwirq - 32); in econet_chmask() 94 mask = BIT(hwirq); in econet_chmask() 103 econet_chmask(d->hwirq, false); in econet_intc_mask() 109 econet_chmask(d->hwirq, true); in econet_intc_unmask() 122 int hwirq; in econet_intc_handle_pending() local 125 hwirq = fls(pending) - 1; in econet_intc_handle_pending() [all …]
|
H A D | irq-sni-exiu.c | 44 writel(BIT(d->hwirq), data->base + EIREQCLR); in exiu_irq_ack() 58 writel(BIT(d->hwirq), data->base + EIREQCLR); in exiu_irq_eoi() 68 val = readl_relaxed(data->base + EIMASK) | BIT(d->hwirq); in exiu_irq_mask() 78 val = readl_relaxed(data->base + EIMASK) & ~BIT(d->hwirq); in exiu_irq_unmask() 89 writel_relaxed(BIT(d->hwirq), data->base + EIREQCLR); in exiu_irq_enable() 91 val = readl_relaxed(data->base + EIMASK) & ~BIT(d->hwirq); in exiu_irq_enable() 103 val |= BIT(d->hwirq); in exiu_irq_set_type() 105 val &= ~BIT(d->hwirq); in exiu_irq_set_type() 110 val &= ~BIT(d->hwirq); in exiu_irq_set_type() 113 val |= BIT(d->hwirq); in exiu_irq_set_type() [all …]
|
H A D | irq-riscv-intc.c | 54 if (IS_ENABLED(CONFIG_32BIT) && d->hwirq >= BITS_PER_LONG) in riscv_intc_irq_mask() 55 csr_clear(CSR_IEH, BIT(d->hwirq - BITS_PER_LONG)); in riscv_intc_irq_mask() 57 csr_clear(CSR_IE, BIT(d->hwirq)); in riscv_intc_irq_mask() 62 if (IS_ENABLED(CONFIG_32BIT) && d->hwirq >= BITS_PER_LONG) in riscv_intc_irq_unmask() 63 csr_set(CSR_IEH, BIT(d->hwirq - BITS_PER_LONG)); in riscv_intc_irq_unmask() 65 csr_set(CSR_IE, BIT(d->hwirq)); in riscv_intc_irq_unmask() 71 * Andes specific S-mode local interrupt causes (hwirq) in andes_intc_irq_mask() 75 unsigned int mask = BIT(d->hwirq % BITS_PER_LONG); in andes_intc_irq_mask() 77 if (d->hwirq < ANDES_SLI_CAUSE_BASE) in andes_intc_irq_mask() 85 unsigned int mask = BIT(d->hwirq % BITS_PER_LONG); in andes_intc_irq_unmask() [all …]
|
H A D | irq-mvebu-odmi.c | 59 if (WARN_ON(d->hwirq >= odmis_count * NODMIS_PER_FRAME)) in odmi_compose_msi_msg() 62 odmi = &odmis[d->hwirq >> NODMIS_SHIFT]; in odmi_compose_msi_msg() 63 odmin = d->hwirq & NODMIS_MASK; in odmi_compose_msi_msg() 87 unsigned int hwirq, odmin; in odmi_irq_domain_alloc() local 91 hwirq = find_first_zero_bit(odmis_bm, NODMIS_PER_FRAME * odmis_count); in odmi_irq_domain_alloc() 92 if (hwirq >= NODMIS_PER_FRAME * odmis_count) { in odmi_irq_domain_alloc() 97 __set_bit(hwirq, odmis_bm); in odmi_irq_domain_alloc() 100 odmi = &odmis[hwirq >> NODMIS_SHIFT]; in odmi_irq_domain_alloc() 101 odmin = hwirq & NODMIS_MASK; in odmi_irq_domain_alloc() 122 irq_domain_set_hwirq_and_chip(domain, virq, hwirq, in odmi_irq_domain_alloc() [all …]
|
H A D | irq-xilinx-intc.c | 67 unsigned long mask = BIT(d->hwirq); in intc_enable_or_unmask() 69 pr_debug("irq-xilinx: enable_or_unmask: %ld\n", d->hwirq); in intc_enable_or_unmask() 85 pr_debug("irq-xilinx: disable: %ld\n", d->hwirq); in intc_disable_or_mask() 86 xintc_write(irqc, CIE, BIT(d->hwirq)); in intc_disable_or_mask() 93 pr_debug("irq-xilinx: ack: %ld\n", d->hwirq); in intc_ack() 94 xintc_write(irqc, IAR, BIT(d->hwirq)); in intc_ack() 100 unsigned long mask = BIT(d->hwirq); in intc_mask_ack() 102 pr_debug("irq-xilinx: disable_and_ack: %ld\n", d->hwirq); in intc_mask_ack() 145 u32 hwirq = xintc_read(irqc, IVR); in xil_intc_irq_handler() local 147 if (hwirq == -1U) in xil_intc_irq_handler() [all …]
|
H A D | irq-sg2042-msi.c | 63 static void sg204x_msi_free_hwirq(struct sg204x_msi_chipdata *data, int hwirq, int num_req) in sg204x_msi_free_hwirq() argument 66 bitmap_release_region(data->msi_map, hwirq, get_count_order(num_req)); in sg204x_msi_free_hwirq() 72 int bit_off = d->hwirq; in sg2042_msi_irq_ack() 85 msg->data = 1 << d->hwirq; in sg2042_msi_irq_compose_msi_msg() 105 writel(0, (u32 __iomem *)data->reg_clr + d->hwirq); in sg2044_msi_irq_ack() 112 phys_addr_t doorbell = data->doorbell_addr + 4 * (d->hwirq / 32); in sg2044_msi_irq_compose_msi_msg() 116 msg->data = d->hwirq % 32; in sg2044_msi_irq_compose_msi_msg() 132 static int sg204x_msi_parent_domain_alloc(struct irq_domain *domain, unsigned int virq, int hwirq) in sg204x_msi_parent_domain_alloc() argument 141 fwspec.param[0] = data->irq_first + hwirq; in sg204x_msi_parent_domain_alloc() 156 int hwirq, err, i; in sg204x_msi_middle_domain_alloc() local [all …]
|
/linux/arch/powerpc/sysdev/ |
H A D | mpic_u3msi.c | 61 static u64 find_ht_magic_addr(struct pci_dev *pdev, unsigned int hwirq) in find_ht_magic_addr() argument 75 static u64 find_u4_magic_addr(struct pci_dev *pdev, unsigned int hwirq) in find_u4_magic_addr() argument 97 return 0xf8004000 | (hwirq << 4); in find_u4_magic_addr() 105 irq_hw_number_t hwirq; in u3msi_teardown_msi_irqs() local 108 hwirq = virq_to_hw(entry->irq); in u3msi_teardown_msi_irqs() 112 msi_bitmap_free_hwirqs(&msi_mpic->msi_bitmap, hwirq, 1); in u3msi_teardown_msi_irqs() 122 int hwirq; in u3msi_setup_msi_irqs() local 136 hwirq = msi_bitmap_alloc_hwirqs(&msi_mpic->msi_bitmap, 1); in u3msi_setup_msi_irqs() 137 if (hwirq < 0) { in u3msi_setup_msi_irqs() 138 pr_debug("u3msi: failed allocating hwirq\n"); in u3msi_setup_msi_irqs() [all …]
|
/linux/drivers/misc/rp1/ |
H A D | rp1_pci.c | 50 static void msix_cfg_set(struct rp1_dev *rp1, unsigned int hwirq, u32 value) in msix_cfg_set() argument 52 iowrite32(value, rp1->bar1 + RP1_PCIE_APBS_BASE + REG_SET + MSIX_CFG(hwirq)); in msix_cfg_set() 55 static void msix_cfg_clr(struct rp1_dev *rp1, unsigned int hwirq, u32 value) in msix_cfg_clr() argument 57 iowrite32(value, rp1->bar1 + RP1_PCIE_APBS_BASE + REG_CLR + MSIX_CFG(hwirq)); in msix_cfg_clr() 63 struct irq_data *pcie_irqd = rp1->pcie_irqds[irqd->hwirq]; in rp1_mask_irq() 71 struct irq_data *pcie_irqd = rp1->pcie_irqds[irqd->hwirq]; in rp1_unmask_irq() 79 unsigned int hwirq = (unsigned int)irqd->hwirq; in rp1_irq_set_type() local 83 dev_dbg(&rp1->pdev->dev, "MSIX IACK EN for IRQ %u\n", hwirq); in rp1_irq_set_type() 84 msix_cfg_set(rp1, hwirq, MSIX_CFG_IACK_EN); in rp1_irq_set_type() 85 rp1->level_triggered_irq[hwirq] = true; in rp1_irq_set_type() [all …]
|
/linux/arch/powerpc/platforms/85xx/ |
H A D | socrates_fpga_pic.c | 110 unsigned int irq_line, hwirq = irqd_to_hwirq(d); in socrates_fpga_pic_ack() local 113 irq_line = fpga_irqs[hwirq].irq_line; in socrates_fpga_pic_ack() 117 mask |= (1 << (hwirq + 16)); in socrates_fpga_pic_ack() 125 unsigned int hwirq = irqd_to_hwirq(d); in socrates_fpga_pic_mask() local 129 irq_line = fpga_irqs[hwirq].irq_line; in socrates_fpga_pic_mask() 133 mask &= ~(1 << hwirq); in socrates_fpga_pic_mask() 141 unsigned int hwirq = irqd_to_hwirq(d); in socrates_fpga_pic_mask_ack() local 145 irq_line = fpga_irqs[hwirq].irq_line; in socrates_fpga_pic_mask_ack() 149 mask &= ~(1 << hwirq); in socrates_fpga_pic_mask_ack() 150 mask |= (1 << (hwirq + 16)); in socrates_fpga_pic_mask_ack() [all …]
|
/linux/arch/powerpc/platforms/pasemi/ |
H A D | msi.c | 61 irq_hw_number_t hwirq; in pasemi_msi_teardown_msi_irqs() local 66 hwirq = virq_to_hw(entry->irq); in pasemi_msi_teardown_msi_irqs() 70 msi_bitmap_free_hwirqs(&msi_mpic->msi_bitmap, hwirq, ALLOC_CHUNK); in pasemi_msi_teardown_msi_irqs() 79 int hwirq; in pasemi_msi_setup_msi_irqs() local 95 hwirq = msi_bitmap_alloc_hwirqs(&msi_mpic->msi_bitmap, in pasemi_msi_setup_msi_irqs() 97 if (hwirq < 0) { in pasemi_msi_setup_msi_irqs() 98 pr_debug("pasemi_msi: failed allocating hwirq\n"); in pasemi_msi_setup_msi_irqs() 99 return hwirq; in pasemi_msi_setup_msi_irqs() 102 virq = irq_create_mapping(msi_mpic->irqhost, hwirq); in pasemi_msi_setup_msi_irqs() 104 pr_debug("pasemi_msi: failed mapping hwirq 0x%x\n", in pasemi_msi_setup_msi_irqs() [all …]
|
/linux/drivers/pci/controller/ |
H A D | pcie-iproc-msi.c | 145 static inline u32 hwirq_to_group(struct iproc_msi *msi, unsigned long hwirq) in hwirq_to_group() argument 147 return (hwirq % msi->nr_irqs); in hwirq_to_group() 151 unsigned long hwirq) in iproc_msi_addr_offset() argument 154 return hwirq_to_group(msi, hwirq) * MSI_MEM_REGION_SIZE; in iproc_msi_addr_offset() 156 return hwirq_to_group(msi, hwirq) * sizeof(u32); in iproc_msi_addr_offset() 196 static inline int hwirq_to_cpu(struct iproc_msi *msi, unsigned long hwirq) in hwirq_to_cpu() argument 198 return (hwirq % msi->nr_cpus); in hwirq_to_cpu() 202 unsigned long hwirq) in hwirq_to_canonical_hwirq() 204 return (hwirq - hwirq_to_cpu(msi, hwirq)); in hwirq_to_canonical_hwirq() 215 curr_cpu = hwirq_to_cpu(msi, data->hwirq); in iproc_msi_irq_set_affinity() [all …]
|
/linux/kernel/irq/ |
H A D | irqdomain.c | 588 irq_hw_number_t hwirq) in irq_domain_clear_mapping() argument 595 if (hwirq < domain->revmap_size) in irq_domain_clear_mapping() 596 rcu_assign_pointer(domain->revmap[hwirq], NULL); in irq_domain_clear_mapping() 598 radix_tree_delete(&domain->revmap_tree, hwirq); in irq_domain_clear_mapping() 602 irq_hw_number_t hwirq, in irq_domain_set_mapping() argument 614 if (hwirq < domain->revmap_size) in irq_domain_set_mapping() 615 rcu_assign_pointer(domain->revmap[hwirq], irq_data); in irq_domain_set_mapping() 617 radix_tree_insert(&domain->revmap_tree, hwirq, irq_data); in irq_domain_set_mapping() 623 irq_hw_number_t hwirq; in irq_domain_disassociate() local 629 hwirq = irq_data->hwirq; in irq_domain_disassociate() [all …]
|
/linux/arch/arm/mach-imx/ |
H A D | gpc.c | 91 unsigned int idx = d->hwirq / 32; in imx_gpc_irq_set_wake() 94 mask = 1 << d->hwirq % 32; in imx_gpc_irq_set_wake() 125 void imx_gpc_hwirq_unmask(unsigned int hwirq) in imx_gpc_hwirq_unmask() argument 130 reg = gpc_base + GPC_IMR1 + hwirq / 32 * 4; in imx_gpc_hwirq_unmask() 132 val &= ~(1 << hwirq % 32); in imx_gpc_hwirq_unmask() 136 void imx_gpc_hwirq_mask(unsigned int hwirq) in imx_gpc_hwirq_mask() argument 141 reg = gpc_base + GPC_IMR1 + hwirq / 32 * 4; in imx_gpc_hwirq_mask() 143 val |= 1 << (hwirq % 32); in imx_gpc_hwirq_mask() 149 imx_gpc_hwirq_unmask(d->hwirq); in imx_gpc_irq_unmask() 155 imx_gpc_hwirq_mask(d->hwirq); in imx_gpc_irq_mask() [all …]
|
/linux/drivers/gpio/ |
H A D | gpio-lpc18xx.c | 78 irq_hw_number_t hwirq = irqd_to_hwirq(d); in lpc18xx_gpio_pin_ic_mask() local 83 lpc18xx_gpio_pin_ic_set(ic, d->hwirq, in lpc18xx_gpio_pin_ic_mask() 87 lpc18xx_gpio_pin_ic_set(ic, d->hwirq, in lpc18xx_gpio_pin_ic_mask() 94 gpiochip_disable_irq(ic->gpio, hwirq); in lpc18xx_gpio_pin_ic_mask() 101 irq_hw_number_t hwirq = irqd_to_hwirq(d); in lpc18xx_gpio_pin_ic_unmask() local 103 gpiochip_enable_irq(ic->gpio, hwirq); in lpc18xx_gpio_pin_ic_unmask() 108 lpc18xx_gpio_pin_ic_set(ic, d->hwirq, in lpc18xx_gpio_pin_ic_unmask() 112 lpc18xx_gpio_pin_ic_set(ic, d->hwirq, in lpc18xx_gpio_pin_ic_unmask() 128 lpc18xx_gpio_pin_ic_set(ic, d->hwirq, in lpc18xx_gpio_pin_ic_eoi() 143 lpc18xx_gpio_pin_ic_isel(ic, d->hwirq, true); in lpc18xx_gpio_pin_ic_set_type() [all …]
|