Lines Matching refs:hwirq
478 irq_hw_number_t hwirq) in irq_domain_clear_mapping() argument
480 if (hwirq < domain->revmap_size) { in irq_domain_clear_mapping()
481 domain->linear_revmap[hwirq] = 0; in irq_domain_clear_mapping()
484 radix_tree_delete(&domain->revmap_tree, hwirq); in irq_domain_clear_mapping()
490 irq_hw_number_t hwirq, in irq_domain_set_mapping() argument
493 if (hwirq < domain->revmap_size) { in irq_domain_set_mapping()
494 domain->linear_revmap[hwirq] = irq_data->irq; in irq_domain_set_mapping()
497 radix_tree_insert(&domain->revmap_tree, hwirq, irq_data); in irq_domain_set_mapping()
505 irq_hw_number_t hwirq; in irq_domain_disassociate() local
511 hwirq = irq_data->hwirq; in irq_domain_disassociate()
526 irq_data->hwirq = 0; in irq_domain_disassociate()
530 irq_domain_clear_mapping(domain, hwirq); in irq_domain_disassociate()
534 irq_hw_number_t hwirq) in irq_domain_associate() argument
539 if (WARN(hwirq >= domain->hwirq_max, in irq_domain_associate()
540 "error: hwirq 0x%x is too large for %s\n", (int)hwirq, domain->name)) in irq_domain_associate()
548 irq_data->hwirq = hwirq; in irq_domain_associate()
551 ret = domain->ops->map(domain, virq, hwirq); in irq_domain_associate()
560 domain->name, hwirq, virq, ret); in irq_domain_associate()
563 irq_data->hwirq = 0; in irq_domain_associate()
574 irq_domain_set_mapping(domain, hwirq, irq_data); in irq_domain_associate()
651 irq_hw_number_t hwirq) in irq_create_mapping() argument
656 pr_debug("irq_create_mapping(0x%p, 0x%lx)\n", domain, hwirq); in irq_create_mapping()
662 WARN(1, "%s(, %lx) called with NULL domain\n", __func__, hwirq); in irq_create_mapping()
670 virq = irq_find_mapping(domain, hwirq); in irq_create_mapping()
677 virq = irq_domain_alloc_descs(-1, 1, hwirq, of_node_to_nid(of_node), NULL); in irq_create_mapping()
683 if (irq_domain_associate(domain, virq, hwirq)) { in irq_create_mapping()
689 hwirq, of_node_full_name(of_node), virq); in irq_create_mapping()
732 irq_hw_number_t *hwirq, unsigned int *type) in irq_domain_translate() argument
736 return d->ops->translate(d, fwspec, hwirq, type); in irq_domain_translate()
741 hwirq, type); in irq_domain_translate()
744 *hwirq = fwspec->param[0]; in irq_domain_translate()
765 irq_hw_number_t hwirq; in irq_create_fwspec_mapping() local
783 if (irq_domain_translate(domain, fwspec, &hwirq, &type)) in irq_create_fwspec_mapping()
797 virq = irq_find_mapping(domain, hwirq); in irq_create_fwspec_mapping()
821 hwirq, of_node_full_name(to_of_node(fwspec->fwnode))); in irq_create_fwspec_mapping()
831 virq = irq_create_mapping(domain, hwirq); in irq_create_fwspec_mapping()
894 irq_hw_number_t hwirq) in irq_find_mapping() argument
904 if (hwirq < domain->revmap_direct_max_irq) { in irq_find_mapping()
905 data = irq_domain_get_irq_data(domain, hwirq); in irq_find_mapping()
906 if (data && data->hwirq == hwirq) in irq_find_mapping()
907 return hwirq; in irq_find_mapping()
911 if (hwirq < domain->revmap_size) in irq_find_mapping()
912 return domain->linear_revmap[hwirq]; in irq_find_mapping()
915 data = radix_tree_lookup(&domain->revmap_tree, hwirq); in irq_find_mapping()
1010 int irq_domain_alloc_descs(int virq, unsigned int cnt, irq_hw_number_t hwirq, in irq_domain_alloc_descs() argument
1019 hint = hwirq % nr_irqs; in irq_domain_alloc_descs()
1079 irq_domain_set_mapping(domain, data->hwirq, data); in irq_domain_insert_irq()
1100 irq_hw_number_t hwirq = data->hwirq; in irq_domain_remove_irq() local
1103 irq_domain_clear_mapping(domain, hwirq); in irq_domain_remove_irq()
1195 irq_hw_number_t hwirq, struct irq_chip *chip, in irq_domain_set_hwirq_and_chip() argument
1203 irq_data->hwirq = hwirq; in irq_domain_set_hwirq_and_chip()
1223 irq_hw_number_t hwirq, struct irq_chip *chip, in irq_domain_set_info() argument
1227 irq_domain_set_hwirq_and_chip(domain, virq, hwirq, chip, chip_data); in irq_domain_set_info()
1239 irq_data->hwirq = 0; in irq_domain_reset_irq_data()
1380 if (d->hwirq < d->domain->revmap_size) in irq_domain_fix_revmap()
1385 slot = radix_tree_lookup_slot(&d->domain->revmap_tree, d->hwirq); in irq_domain_fix_revmap()
1453 root_irq_data->hwirq = 0; in irq_domain_push_irq()
1466 irq_domain_set_mapping(domain, root_irq_data->hwirq, root_irq_data); in irq_domain_push_irq()
1528 irq_domain_clear_mapping(domain, root_irq_data->hwirq); in irq_domain_pop_irq()
1722 irq_hw_number_t hwirq, struct irq_chip *chip, in irq_domain_set_info() argument