blob: df8e1500527cedfe88267f6c9a590994acc0e9ad [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __ASM_SH_IRQ_H
2#define __ASM_SH_IRQ_H
3
Linus Torvalds1da177e2005-04-16 15:20:36 -07004#include <asm/machvec.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07005
Paul Mundtbe782df2007-03-12 14:09:35 +09006/*
7 * A sane default based on a reasonable vector table size, platforms are
8 * advised to cap this at the hard limit that they're interested in
9 * through the machvec.
Linus Torvalds1da177e2005-04-16 15:20:36 -070010 */
Paul Mundt62fad392009-05-22 13:50:18 +090011#define NR_IRQS 256
12#define NR_IRQS_LEGACY 8 /* Legacy external IRQ0-7 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
Linus Torvalds1da177e2005-04-16 15:20:36 -070014/*
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090015 * Convert back and forth between INTEVT and IRQ values.
16 */
Paul Mundt3afb2092007-03-14 13:03:35 +090017#ifdef CONFIG_CPU_HAS_INTEVT
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090018#define evt2irq(evt) (((evt) >> 5) - 16)
19#define irq2evt(irq) (((irq) + 16) << 5)
Paul Mundt3afb2092007-03-14 13:03:35 +090020#else
21#define evt2irq(evt) (evt)
22#define irq2evt(irq) (irq)
23#endif
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090024
25/*
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 * Simple Mask Register Support
27 */
28extern void make_maskreg_irq(unsigned int irq);
29extern unsigned short *irq_mask_register;
30
31/*
Paul Mundt0f08f332006-09-27 17:03:56 +090032 * PINT IRQs
33 */
34void init_IRQ_pint(void);
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090035void make_imask_irq(unsigned int irq);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
Linus Torvalds1da177e2005-04-16 15:20:36 -070037static inline int generic_irq_demux(int irq)
38{
39 return irq;
40}
41
Paul Mundt9a7ef6d2006-11-20 13:55:34 +090042#define irq_demux(irq) sh_mv.mv_irq_demux(irq)
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
Paul Mundtfa439722008-09-04 18:53:58 +090044void init_IRQ(void);
45asmlinkage int do_IRQ(unsigned int irq, struct pt_regs *regs);
46
Paul Mundt110ed282007-11-02 12:16:51 +090047#ifdef CONFIG_IRQSTACKS
Paul Mundta6a311392006-09-27 18:22:14 +090048extern void irq_ctx_init(int cpu);
49extern void irq_ctx_exit(int cpu);
50# define __ARCH_HAS_DO_SOFTIRQ
51#else
52# define irq_ctx_init(cpu) do { } while (0)
53# define irq_ctx_exit(cpu) do { } while (0)
54#endif
55
Paul Mundtf8f06bc2009-06-14 23:21:54 +090056#include <asm-generic/irq.h>
Paul Mundtc7a49dd2008-02-13 20:16:47 +090057#ifdef CONFIG_CPU_SH5
Paul Mundtf15cbe62008-07-29 08:09:44 +090058#include <cpu/irq.h>
Paul Mundtc7a49dd2008-02-13 20:16:47 +090059#endif
60
Linus Torvalds1da177e2005-04-16 15:20:36 -070061#endif /* __ASM_SH_IRQ_H */