hardirq.h 846 B

1234567891011121314151617181920212223242526272829
  1. #ifndef _ASM_POWERPC_HARDIRQ_H
  2. #define _ASM_POWERPC_HARDIRQ_H
  3. #ifdef __KERNEL__
  4. #include <asm/irq.h>
  5. #include <asm/bug.h>
  6. /* The __last_jiffy_stamp field is needed to ensure that no decrementer
  7. * interrupt is lost on SMP machines. Since on most CPUs it is in the same
  8. * cache line as local_irq_count, it is cheap to access and is also used on UP
  9. * for uniformity.
  10. */
  11. typedef struct {
  12. unsigned int __softirq_pending; /* set_bit is used on this */
  13. unsigned int __last_jiffy_stamp;
  14. } ____cacheline_aligned irq_cpustat_t;
  15. #include <linux/irq_cpustat.h> /* Standard mappings for irq_cpustat_t above */
  16. #define last_jiffy_stamp(cpu) __IRQ_STAT((cpu), __last_jiffy_stamp)
  17. static inline void ack_bad_irq(int irq)
  18. {
  19. printk(KERN_CRIT "illegal vector %d received!\n", irq);
  20. BUG();
  21. }
  22. #endif /* __KERNEL__ */
  23. #endif /* _ASM_POWERPC_HARDIRQ_H */