irq_work.c 703 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /*
  2. * x86 specific code for irq_work
  3. *
  4. * Copyright (C) 2010 Red Hat, Inc., Peter Zijlstra <pzijlstr@redhat.com>
  5. */
  6. #include <linux/kernel.h>
  7. #include <linux/irq_work.h>
  8. #include <linux/hardirq.h>
  9. #include <asm/apic.h>
  10. static inline void irq_work_entering_irq(void)
  11. {
  12. irq_enter();
  13. ack_APIC_irq();
  14. }
  15. static inline void __smp_irq_work_interrupt(void)
  16. {
  17. inc_irq_stat(apic_irq_work_irqs);
  18. irq_work_run();
  19. }
  20. void smp_irq_work_interrupt(struct pt_regs *regs)
  21. {
  22. irq_work_entering_irq();
  23. __smp_irq_work_interrupt();
  24. exiting_irq();
  25. }
  26. void arch_irq_work_raise(void)
  27. {
  28. #ifdef CONFIG_X86_LOCAL_APIC
  29. if (!cpu_has_apic)
  30. return;
  31. apic->send_IPI_self(IRQ_WORK_VECTOR);
  32. apic_wait_icr_idle();
  33. #endif
  34. }