Lines Matching refs:irq_data

40 	struct irq_data *irqd = irq_desc_get_irq_data(desc);  in __synchronize_hardirq()
50 while (irqd_irq_inprogress(&desc->irq_data)) in __synchronize_hardirq()
55 inprogress = irqd_irq_inprogress(&desc->irq_data); in __synchronize_hardirq()
148 if (!desc || !irqd_can_balance(&desc->irq_data) || in __irq_can_set_affinity()
149 !desc->irq_data.chip || !desc->irq_data.chip->irq_set_affinity) in __irq_can_set_affinity()
176 !irqd_affinity_is_managed(&desc->irq_data); in irq_can_set_affinity_usr()
198 static void irq_validate_effective_affinity(struct irq_data *data) in irq_validate_effective_affinity()
209 static inline void irq_validate_effective_affinity(struct irq_data *data) { } in irq_validate_effective_affinity()
212 int irq_do_set_affinity(struct irq_data *data, const struct cpumask *mask, in irq_do_set_affinity()
291 static inline int irq_set_affinity_pending(struct irq_data *data, in irq_set_affinity_pending()
301 static inline int irq_set_affinity_pending(struct irq_data *data, in irq_set_affinity_pending()
308 static int irq_try_set_affinity(struct irq_data *data, in irq_try_set_affinity()
323 static bool irq_set_affinity_deactivated(struct irq_data *data, in irq_set_affinity_deactivated()
347 int irq_set_affinity_locked(struct irq_data *data, const struct cpumask *mask, in irq_set_affinity_locked()
415 if (irqd_is_started(&desc->irq_data)) { in irq_update_affinity_desc()
421 if (irqd_affinity_is_managed(&desc->irq_data)) { in irq_update_affinity_desc()
430 activated = irqd_is_activated(&desc->irq_data); in irq_update_affinity_desc()
432 irq_domain_deactivate_irq(&desc->irq_data); in irq_update_affinity_desc()
435 irqd_set(&desc->irq_data, IRQD_AFFINITY_MANAGED); in irq_update_affinity_desc()
436 irqd_set(&desc->irq_data, IRQD_MANAGED_SHUTDOWN); in irq_update_affinity_desc()
443 irq_domain_activate_irq(&desc->irq_data, false); in irq_update_affinity_desc()
524 if (irq_move_pending(&desc->irq_data)) in irq_affinity_notify()
605 if (irqd_affinity_is_managed(&desc->irq_data) || in irq_setup_affinity()
606 irqd_has_set(&desc->irq_data, IRQD_AFFINITY_SET)) { in irq_setup_affinity()
611 irqd_clear(&desc->irq_data, IRQD_AFFINITY_SET); in irq_setup_affinity()
625 ret = irq_do_set_affinity(&desc->irq_data, &mask, false); in irq_setup_affinity()
654 struct irq_data *data; in irq_set_vcpu_affinity()
822 if (WARN(!desc->irq_data.chip, in enable_irq()
854 if (desc->irq_data.chip->irq_set_wake) in set_irq_wake_real()
855 ret = desc->irq_data.chip->irq_set_wake(&desc->irq_data, on); in set_irq_wake_real()
903 irqd_set(&desc->irq_data, IRQD_WAKEUP_STATE); in irq_set_irq_wake()
913 irqd_clear(&desc->irq_data, IRQD_WAKEUP_STATE); in irq_set_irq_wake()
948 struct irq_chip *chip = desc->irq_data.chip; in __irq_set_trigger()
963 if (!irqd_irq_masked(&desc->irq_data)) in __irq_set_trigger()
965 if (!irqd_irq_disabled(&desc->irq_data)) in __irq_set_trigger()
971 ret = chip->irq_set_type(&desc->irq_data, flags); in __irq_set_trigger()
976 irqd_clear(&desc->irq_data, IRQD_TRIGGER_MASK); in __irq_set_trigger()
977 irqd_set(&desc->irq_data, flags); in __irq_set_trigger()
981 flags = irqd_get_trigger_type(&desc->irq_data); in __irq_set_trigger()
983 irqd_clear(&desc->irq_data, IRQD_LEVEL); in __irq_set_trigger()
987 irqd_set(&desc->irq_data, IRQD_LEVEL); in __irq_set_trigger()
1098 if (unlikely(irqd_irq_inprogress(&desc->irq_data))) { in irq_finalize_oneshot()
1115 if (!desc->threads_oneshot && !irqd_irq_disabled(&desc->irq_data) && in irq_finalize_oneshot()
1116 irqd_irq_masked(&desc->irq_data)) in irq_finalize_oneshot()
1154 m = irq_data_get_effective_affinity_mask(&desc->irq_data); in irq_thread_check_affinity()
1399 struct irq_data *d = &desc->irq_data; in irq_request_resources()
1407 struct irq_data *d = &desc->irq_data; in irq_release_resources()
1416 struct irq_data *d = irq_desc_get_irq_data(desc); in irq_supports_nmi()
1432 struct irq_data *d = irq_desc_get_irq_data(desc); in irq_nmi_setup()
1440 struct irq_data *d = irq_desc_get_irq_data(desc); in irq_nmi_teardown()
1506 if (desc->irq_data.chip == &no_irq_chip) in __setup_irq()
1518 new->flags |= irqd_get_trigger_type(&desc->irq_data); in __setup_irq()
1569 if (desc->irq_data.chip->flags & IRQCHIP_ONESHOT_SAFE) in __setup_irq()
1593 new->name, irq, desc->irq_data.chip->name); in __setup_irq()
1620 new->name, irq, desc->irq_data.chip->name); in __setup_irq()
1629 if (irqd_trigger_type_was_set(&desc->irq_data)) { in __setup_irq()
1630 oldtype = irqd_get_trigger_type(&desc->irq_data); in __setup_irq()
1633 irqd_set_trigger_type(&desc->irq_data, oldtype); in __setup_irq()
1697 !(desc->irq_data.chip->flags & IRQCHIP_ONESHOT_SAFE)) { in __setup_irq()
1746 irqd_clear(&desc->irq_data, IRQD_IRQ_INPROGRESS); in __setup_irq()
1749 irqd_set(&desc->irq_data, IRQD_PER_CPU); in __setup_irq()
1764 irqd_set(&desc->irq_data, IRQD_NO_BALANCING); in __setup_irq()
1784 unsigned int omsk = irqd_get_trigger_type(&desc->irq_data); in __setup_irq()
1868 unsigned irq = desc->irq_data.irq; in __free_irq()
1986 irq_domain_deactivate_irq(&desc->irq_data); in __free_irq()
1996 irq_chip_pm_put(&desc->irq_data); in __free_irq()
2064 irq_chip_pm_put(&desc->irq_data); in __cleanup_nmi()
2192 retval = irq_chip_pm_get(&desc->irq_data); in request_threaded_irq()
2201 irq_chip_pm_put(&desc->irq_data); in request_threaded_irq()
2335 retval = irq_chip_pm_get(&desc->irq_data); in request_nmi()
2359 irq_chip_pm_put(&desc->irq_data); in request_nmi()
2381 type = irqd_get_trigger_type(&desc->irq_data); in enable_percpu_irq()
2486 irq_chip_pm_put(&desc->irq_data); in __free_percpu_irq()
2563 retval = irq_chip_pm_get(&desc->irq_data); in setup_percpu_irq()
2570 irq_chip_pm_put(&desc->irq_data); in setup_percpu_irq()
2620 retval = irq_chip_pm_get(&desc->irq_data); in __request_percpu_irq()
2629 irq_chip_pm_put(&desc->irq_data); in __request_percpu_irq()
2691 retval = irq_chip_pm_get(&desc->irq_data); in request_percpu_nmi()
2706 irq_chip_pm_put(&desc->irq_data); in request_percpu_nmi()
2789 int __irq_get_irqchip_state(struct irq_data *data, enum irqchip_irq_state which, in __irq_get_irqchip_state()
2830 struct irq_data *data; in irq_get_irqchip_state()
2863 struct irq_data *data; in irq_set_irqchip_state()