1 #ifndef _ASM_IRQDOMAIN_H
2 #define _ASM_IRQDOMAIN_H
4 #include <linux/irqdomain.h>
5 #include <asm/hw_irq.h>
7 #ifdef CONFIG_X86_LOCAL_APIC
9 /* Allocate contiguous CPU vectors */
10 X86_IRQ_ALLOC_CONTIGUOUS_VECTORS
= 0x1,
13 extern struct irq_domain
*x86_vector_domain
;
15 extern void init_irq_alloc_info(struct irq_alloc_info
*info
,
16 const struct cpumask
*mask
);
17 extern void copy_irq_alloc_info(struct irq_alloc_info
*dst
,
18 struct irq_alloc_info
*src
);
19 #endif /* CONFIG_X86_LOCAL_APIC */
21 #ifdef CONFIG_X86_IO_APIC
25 enum ioapic_domain_type
{
26 IOAPIC_DOMAIN_INVALID
,
29 IOAPIC_DOMAIN_DYNAMIC
,
32 struct ioapic_domain_cfg
{
33 enum ioapic_domain_type type
;
34 const struct irq_domain_ops
*ops
;
35 struct device_node
*dev
;
38 extern const struct irq_domain_ops mp_ioapic_irqdomain_ops
;
40 extern int mp_irqdomain_alloc(struct irq_domain
*domain
, unsigned int virq
,
41 unsigned int nr_irqs
, void *arg
);
42 extern void mp_irqdomain_free(struct irq_domain
*domain
, unsigned int virq
,
43 unsigned int nr_irqs
);
44 extern void mp_irqdomain_activate(struct irq_domain
*domain
,
45 struct irq_data
*irq_data
);
46 extern void mp_irqdomain_deactivate(struct irq_domain
*domain
,
47 struct irq_data
*irq_data
);
48 extern int mp_irqdomain_ioapic_idx(struct irq_domain
*domain
);
49 #endif /* CONFIG_X86_IO_APIC */
52 extern void arch_init_msi_domain(struct irq_domain
*domain
);
54 static inline void arch_init_msi_domain(struct irq_domain
*domain
) { }
58 extern void arch_init_htirq_domain(struct irq_domain
*domain
);
60 static inline void arch_init_htirq_domain(struct irq_domain
*domain
) { }