irq_work.c 731 B

12345678910111213141516171819202122232425262728293031323334
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * x86 specific code for irq_work
  4. *
  5. * Copyright (C) 2010 Red Hat, Inc., Peter Zijlstra
  6. */
  7. #include <linux/kernel.h>
  8. #include <linux/irq_work.h>
  9. #include <linux/hardirq.h>
  10. #include <asm/apic.h>
  11. #include <asm/trace/irq_vectors.h>
  12. #include <linux/interrupt.h>
  13. #ifdef CONFIG_X86_LOCAL_APIC
  14. __visible void __irq_entry smp_irq_work_interrupt(struct pt_regs *regs)
  15. {
  16. ipi_entering_ack_irq();
  17. trace_irq_work_entry(IRQ_WORK_VECTOR);
  18. inc_irq_stat(apic_irq_work_irqs);
  19. irq_work_run();
  20. trace_irq_work_exit(IRQ_WORK_VECTOR);
  21. exiting_irq();
  22. }
  23. void arch_irq_work_raise(void)
  24. {
  25. if (!arch_irq_work_has_interrupt())
  26. return;
  27. apic->send_IPI_self(IRQ_WORK_VECTOR);
  28. apic_wait_icr_idle();
  29. }
  30. #endif