Home
last modified time | relevance | path

Searched refs:virq (Results 1 – 6 of 6) sorted by relevance

/kernel/irq/
Dirqdomain.c574 static int irq_domain_associate_locked(struct irq_domain *domain, unsigned int virq, in irq_domain_associate_locked() argument
577 struct irq_data *irq_data = irq_get_irq_data(virq); in irq_domain_associate_locked()
583 if (WARN(!irq_data, "error: virq%i is not allocated", virq)) in irq_domain_associate_locked()
585 if (WARN(irq_data->domain, "error: virq%i is already associated", virq)) in irq_domain_associate_locked()
591 ret = domain->ops->map(domain, virq, hwirq); in irq_domain_associate_locked()
600 domain->name, hwirq, virq, ret); in irq_domain_associate_locked()
611 irq_clear_status_flags(virq, IRQ_NOREQUEST); in irq_domain_associate_locked()
616 int irq_domain_associate(struct irq_domain *domain, unsigned int virq, in irq_domain_associate() argument
622 ret = irq_domain_associate_locked(domain, virq, hwirq); in irq_domain_associate()
658 unsigned int virq; in irq_create_direct_mapping() local
[all …]
Dipi.c28 int virq, i; in irq_reserve_ipi() local
78 virq = irq_domain_alloc_descs(-1, nr_irqs, 0, NUMA_NO_NODE, NULL); in irq_reserve_ipi()
79 if (virq <= 0) { in irq_reserve_ipi()
84 virq = __irq_domain_alloc_irqs(domain, virq, nr_irqs, NUMA_NO_NODE, in irq_reserve_ipi()
87 if (virq <= 0) { in irq_reserve_ipi()
93 data = irq_get_irq_data(virq + i); in irq_reserve_ipi()
96 irq_set_status_flags(virq + i, IRQ_NO_BALANCING); in irq_reserve_ipi()
98 return virq; in irq_reserve_ipi()
101 irq_free_descs(virq, nr_irqs); in irq_reserve_ipi()
313 int ipi_send_single(unsigned int virq, unsigned int cpu) in ipi_send_single() argument
[all …]
Dgeneric-chip.c384 int irq_map_generic_chip(struct irq_domain *d, unsigned int virq, in irq_map_generic_chip() argument
387 struct irq_data *data = irq_domain_get_irq_data(d, virq); in irq_map_generic_chip()
421 irq_set_lockdep_class(virq, &irq_nested_lock_class, in irq_map_generic_chip()
429 irq_domain_set_info(d, virq, hw_irq, chip, gc, ct->handler, NULL, NULL); in irq_map_generic_chip()
430 irq_modify_status(virq, dgc->irq_flags_to_clear, dgc->irq_flags_to_set); in irq_map_generic_chip()
434 void irq_unmap_generic_chip(struct irq_domain *d, unsigned int virq) in irq_unmap_generic_chip() argument
436 struct irq_data *data = irq_domain_get_irq_data(d, virq); in irq_unmap_generic_chip()
449 irq_domain_set_info(d, virq, hw_irq, &no_irq_chip, NULL, NULL, NULL, in irq_unmap_generic_chip()
547 unsigned int i, virq; in irq_remove_generic_chip() local
563 virq = irq_find_mapping(gc->domain, gc->irq_base + i); in irq_remove_generic_chip()
[all …]
Dmsi.c684 static int msi_domain_alloc(struct irq_domain *domain, unsigned int virq, in msi_domain_alloc() argument
696 ret = irq_domain_alloc_irqs_parent(domain, virq, nr_irqs, arg); in msi_domain_alloc()
702 ret = ops->msi_init(domain, info, virq + i, hwirq + i, arg); in msi_domain_alloc()
706 ops->msi_free(domain, info, virq + i); in msi_domain_alloc()
708 irq_domain_free_irqs_top(domain, virq, nr_irqs); in msi_domain_alloc()
716 static void msi_domain_free(struct irq_domain *domain, unsigned int virq, in msi_domain_free() argument
724 info->ops->msi_free(domain, info, virq + i); in msi_domain_free()
726 irq_domain_free_irqs_top(domain, virq, nr_irqs); in msi_domain_free()
757 unsigned int virq, irq_hw_number_t hwirq, in msi_domain_ops_init() argument
760 irq_domain_set_hwirq_and_chip(domain, virq, hwirq, info->chip, in msi_domain_ops_init()
[all …]
Dirq_sim.c118 unsigned int virq, irq_hw_number_t hw) in irq_sim_domain_map() argument
127 irq_set_chip(virq, &irq_sim_irqchip); in irq_sim_domain_map()
128 irq_set_chip_data(virq, irq_ctx); in irq_sim_domain_map()
129 irq_set_handler(virq, handle_simple_irq); in irq_sim_domain_map()
130 irq_modify_status(virq, IRQ_NOREQUEST | IRQ_NOAUTOEN, IRQ_NOPROBE); in irq_sim_domain_map()
136 static void irq_sim_domain_unmap(struct irq_domain *domain, unsigned int virq) in irq_sim_domain_unmap() argument
141 irqd = irq_domain_get_irq_data(domain, virq); in irq_sim_domain_unmap()
144 irq_set_handler(virq, NULL); in irq_sim_domain_unmap()
Dipi-mux.c98 static int ipi_mux_domain_alloc(struct irq_domain *d, unsigned int virq, in ipi_mux_domain_alloc() argument
104 irq_set_percpu_devid(virq + i); in ipi_mux_domain_alloc()
105 irq_domain_set_info(d, virq + i, i, &ipi_mux_chip, NULL, in ipi_mux_domain_alloc()