irq_chipRegular
4.4: ✅struct irq_chip {
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
long unsigned int flags;
};
4.8: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
4.10: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
4.13: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
4.15: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
4.18: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
5.0: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
long unsigned int flags;
};
5.3: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.4: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.8: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.11: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.13: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.15: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
5.19: ✅struct irq_chip {
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
6.2: ✅struct irq_chip {
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
6.5: ✅struct irq_chip {
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
6.8: ✅struct irq_chip {
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
arm64: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
armhf: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
ppc64el: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
riscv64: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
aws: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
azure: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
gcp: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
lowlatency: ✅struct irq_chip {
struct device *parent_device;
const char *name;
unsigned int (*irq_startup)(struct irq_data *);
void (*irq_shutdown)(struct irq_data *);
void (*irq_enable)(struct irq_data *);
void (*irq_disable)(struct irq_data *);
void (*irq_ack)(struct irq_data *);
void (*irq_mask)(struct irq_data *);
void (*irq_mask_ack)(struct irq_data *);
void (*irq_unmask)(struct irq_data *);
void (*irq_eoi)(struct irq_data *);
int (*irq_set_affinity)(struct irq_data *, const struct cpumask *, bool);
int (*irq_retrigger)(struct irq_data *);
int (*irq_set_type)(struct irq_data *, unsigned int);
int (*irq_set_wake)(struct irq_data *, unsigned int);
void (*irq_bus_lock)(struct irq_data *);
void (*irq_bus_sync_unlock)(struct irq_data *);
void (*irq_cpu_online)(struct irq_data *);
void (*irq_cpu_offline)(struct irq_data *);
void (*irq_suspend)(struct irq_data *);
void (*irq_resume)(struct irq_data *);
void (*irq_pm_shutdown)(struct irq_data *);
void (*irq_calc_mask)(struct irq_data *);
void (*irq_print_chip)(struct irq_data *, struct seq_file *);
int (*irq_request_resources)(struct irq_data *);
void (*irq_release_resources)(struct irq_data *);
void (*irq_compose_msi_msg)(struct irq_data *, struct msi_msg *);
void (*irq_write_msi_msg)(struct irq_data *, struct msi_msg *);
int (*irq_get_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool *);
int (*irq_set_irqchip_state)(struct irq_data *, enum irqchip_irq_state, bool);
int (*irq_set_vcpu_affinity)(struct irq_data *, void *);
void (*ipi_send_single)(struct irq_data *, unsigned int);
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *);
int (*irq_nmi_setup)(struct irq_data *);
void (*irq_nmi_teardown)(struct irq_data *);
long unsigned int flags;
};
Regular
4.4 and 4.8 ⚠️struct device *parent_device
void (*ipi_send_single)(struct irq_data *, unsigned int)
void (*ipi_send_mask)(struct irq_data *, const struct cpumask *)
4.8 and 4.10 ✅
4.10 and 4.13 ✅
4.13 and 4.15 ✅
4.15 and 4.18 ✅
4.18 and 5.0 ✅
5.0 and 5.3 ⚠️int (*irq_nmi_setup)(struct irq_data *)
void (*irq_nmi_teardown)(struct irq_data *)
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ✅
5.15 and 5.19 ⚠️struct device *parent_device
void (*irq_cpu_online)(struct irq_data *)
void (*irq_cpu_offline)(struct irq_data *)
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ✅
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅