blob: 16d3fa211962809c4e879d049dbdb5dde4049702 [file] [log] [blame]
H. Peter Anvin1965aae2008-10-22 22:26:29 -07001#ifndef _ASM_X86_IRQ_H
2#define _ASM_X86_IRQ_H
Thomas Gleixner22067d42008-05-02 22:14:44 +02003/*
4 * (C) 1992, 1993 Linus Torvalds, (C) 1997 Ingo Molnar
5 *
6 * IRQ/IPI changes taken from work by Thomas Radke
7 * <tomsoft@informatik.tu-chemnitz.de>
8 */
9
10#include <asm/apicdef.h>
11#include <asm/irq_vectors.h>
12
13static inline int irq_canonicalize(int irq)
14{
15 return ((irq == 2) ? 9 : irq);
16}
17
Christoph Hellwig79748912010-06-28 14:15:54 +020018#ifdef CONFIG_X86_32
19extern void irq_ctx_init(int cpu);
Thomas Gleixner22067d42008-05-02 22:14:44 +020020#else
21# define irq_ctx_init(cpu) do { } while (0)
Thomas Gleixner22067d42008-05-02 22:14:44 +020022#endif
23
Christoph Hellwig79748912010-06-28 14:15:54 +020024#define __ARCH_HAS_DO_SOFTIRQ
25
Thomas Gleixner90a22822015-12-31 16:30:53 +000026struct irq_desc;
27
Thomas Gleixner22067d42008-05-02 22:14:44 +020028#ifdef CONFIG_HOTPLUG_CPU
29#include <linux/cpumask.h>
Prarit Bhargavada6139e2014-01-13 06:51:01 -050030extern int check_irq_vectors_for_cpu_disable(void);
Mike Travisd7b381b2008-12-16 17:33:58 -080031extern void fixup_irqs(void);
Thomas Gleixner90a22822015-12-31 16:30:53 +000032extern void irq_force_complete_move(struct irq_desc *desc);
Thomas Gleixner22067d42008-05-02 22:14:44 +020033#endif
34
Feng Wuf6b3c72c2015-05-19 17:07:16 +080035#ifdef CONFIG_HAVE_KVM
36extern void kvm_set_posted_intr_wakeup_handler(void (*handler)(void));
37#endif
38
Dimitri Sivanich4a4de9c2009-10-14 09:22:57 -050039extern void (*x86_platform_ipi_callback)(void);
Thomas Gleixner22067d42008-05-02 22:14:44 +020040extern void native_init_IRQ(void);
Thomas Gleixnera782a7e2015-08-02 20:38:27 +000041
Thomas Gleixnera782a7e2015-08-02 20:38:27 +000042extern bool handle_irq(struct irq_desc *desc, struct pt_regs *regs);
Thomas Gleixner22067d42008-05-02 22:14:44 +020043
Andi Kleen1d9090e2013-08-05 15:02:37 -070044extern __visible unsigned int do_IRQ(struct pt_regs *regs);
Jeremy Fitzhardinge7c1d7cd2009-02-06 14:09:41 -080045
Thomas Gleixner22067d42008-05-02 22:14:44 +020046/* Interrupt vector management */
47extern DECLARE_BITMAP(used_vectors, NR_VECTORS);
Yinghai Lub77b8812008-12-19 15:23:44 -080048extern int vector_used_by_percpu_irq(unsigned int vector);
Thomas Gleixner22067d42008-05-02 22:14:44 +020049
Thomas Gleixnerd9112f42009-08-20 09:41:38 +020050extern void init_ISA_irqs(void);
51
Michel Lespinasseb52e0a72013-06-06 04:41:15 -070052#ifdef CONFIG_X86_LOCAL_APIC
Chris Metcalf9a01c3e2016-10-07 17:02:45 -070053void arch_trigger_cpumask_backtrace(const struct cpumask *mask,
54 bool exclude_self);
55#define arch_trigger_cpumask_backtrace arch_trigger_cpumask_backtrace
Michel Lespinasseb52e0a72013-06-06 04:41:15 -070056#endif
57
H. Peter Anvin1965aae2008-10-22 22:26:29 -070058#endif /* _ASM_X86_IRQ_H */