| .. | .. |
|---|
| 9 | 9 | #include <linux/irq_work.h> |
|---|
| 10 | 10 | #include <linux/hardirq.h> |
|---|
| 11 | 11 | #include <asm/apic.h> |
|---|
| 12 | +#include <asm/idtentry.h> |
|---|
| 12 | 13 | #include <asm/trace/irq_vectors.h> |
|---|
| 13 | 14 | #include <linux/interrupt.h> |
|---|
| 14 | 15 | |
|---|
| 15 | 16 | #ifdef CONFIG_X86_LOCAL_APIC |
|---|
| 16 | | -__visible void __irq_entry smp_irq_work_interrupt(struct pt_regs *regs) |
|---|
| 17 | +DEFINE_IDTENTRY_SYSVEC(sysvec_irq_work) |
|---|
| 17 | 18 | { |
|---|
| 18 | | - ipi_entering_ack_irq(); |
|---|
| 19 | + ack_APIC_irq(); |
|---|
| 19 | 20 | trace_irq_work_entry(IRQ_WORK_VECTOR); |
|---|
| 20 | 21 | inc_irq_stat(apic_irq_work_irqs); |
|---|
| 21 | 22 | irq_work_run(); |
|---|
| 22 | 23 | trace_irq_work_exit(IRQ_WORK_VECTOR); |
|---|
| 23 | | - exiting_irq(); |
|---|
| 24 | 24 | } |
|---|
| 25 | 25 | |
|---|
| 26 | 26 | void arch_irq_work_raise(void) |
|---|