162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci#ifndef _ASM_IRQDOMAIN_H
362306a36Sopenharmony_ci#define _ASM_IRQDOMAIN_H
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci#include <linux/irqdomain.h>
662306a36Sopenharmony_ci#include <asm/hw_irq.h>
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifdef CONFIG_X86_LOCAL_APIC
962306a36Sopenharmony_cienum {
1062306a36Sopenharmony_ci	X86_IRQ_ALLOC_LEGACY				= 0x1,
1162306a36Sopenharmony_ci};
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ciextern int x86_fwspec_is_ioapic(struct irq_fwspec *fwspec);
1462306a36Sopenharmony_ciextern int x86_fwspec_is_hpet(struct irq_fwspec *fwspec);
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciextern struct irq_domain *x86_vector_domain;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciextern void init_irq_alloc_info(struct irq_alloc_info *info,
1962306a36Sopenharmony_ci				const struct cpumask *mask);
2062306a36Sopenharmony_ciextern void copy_irq_alloc_info(struct irq_alloc_info *dst,
2162306a36Sopenharmony_ci				struct irq_alloc_info *src);
2262306a36Sopenharmony_ci#endif /* CONFIG_X86_LOCAL_APIC */
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci#ifdef CONFIG_X86_IO_APIC
2562306a36Sopenharmony_cistruct device_node;
2662306a36Sopenharmony_cistruct irq_data;
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_cienum ioapic_domain_type {
2962306a36Sopenharmony_ci	IOAPIC_DOMAIN_INVALID,
3062306a36Sopenharmony_ci	IOAPIC_DOMAIN_LEGACY,
3162306a36Sopenharmony_ci	IOAPIC_DOMAIN_STRICT,
3262306a36Sopenharmony_ci	IOAPIC_DOMAIN_DYNAMIC,
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_cistruct ioapic_domain_cfg {
3662306a36Sopenharmony_ci	enum ioapic_domain_type		type;
3762306a36Sopenharmony_ci	const struct irq_domain_ops	*ops;
3862306a36Sopenharmony_ci	struct device_node		*dev;
3962306a36Sopenharmony_ci};
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ciextern const struct irq_domain_ops mp_ioapic_irqdomain_ops;
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ciextern int mp_irqdomain_alloc(struct irq_domain *domain, unsigned int virq,
4462306a36Sopenharmony_ci			      unsigned int nr_irqs, void *arg);
4562306a36Sopenharmony_ciextern void mp_irqdomain_free(struct irq_domain *domain, unsigned int virq,
4662306a36Sopenharmony_ci			      unsigned int nr_irqs);
4762306a36Sopenharmony_ciextern int mp_irqdomain_activate(struct irq_domain *domain,
4862306a36Sopenharmony_ci				 struct irq_data *irq_data, bool reserve);
4962306a36Sopenharmony_ciextern void mp_irqdomain_deactivate(struct irq_domain *domain,
5062306a36Sopenharmony_ci				    struct irq_data *irq_data);
5162306a36Sopenharmony_ciextern int mp_irqdomain_ioapic_idx(struct irq_domain *domain);
5262306a36Sopenharmony_ci#endif /* CONFIG_X86_IO_APIC */
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci#ifdef CONFIG_PCI_MSI
5562306a36Sopenharmony_civoid x86_create_pci_msi_domain(void);
5662306a36Sopenharmony_cistruct irq_domain *native_create_pci_msi_domain(void);
5762306a36Sopenharmony_ciextern struct irq_domain *x86_pci_msi_default_domain;
5862306a36Sopenharmony_ci#else
5962306a36Sopenharmony_cistatic inline void x86_create_pci_msi_domain(void) { }
6062306a36Sopenharmony_ci#define native_create_pci_msi_domain	NULL
6162306a36Sopenharmony_ci#define x86_pci_msi_default_domain	NULL
6262306a36Sopenharmony_ci#endif
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci#endif
65