blob: d319baaf4fbdf21a20b65cb659dcfaefd93d5f91 [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 Mundtbe782df2007-03-12 14:09:35 +090011#define NR_IRQS 256
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
Linus Torvalds1da177e2005-04-16 15:20:36 -070013/*
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090014 * Convert back and forth between INTEVT and IRQ values.
15 */
Paul Mundt3afb2092007-03-14 13:03:35 +090016#ifdef CONFIG_CPU_HAS_INTEVT
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090017#define evt2irq(evt) (((evt) >> 5) - 16)
18#define irq2evt(irq) (((irq) + 16) << 5)
Paul Mundt3afb2092007-03-14 13:03:35 +090019#else
20#define evt2irq(evt) (evt)
21#define irq2evt(irq) (irq)
22#endif
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090023
24/*
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 * Simple Mask Register Support
26 */
27extern void make_maskreg_irq(unsigned int irq);
28extern unsigned short *irq_mask_register;
29
30/*
Paul Mundt0f08f332006-09-27 17:03:56 +090031 * PINT IRQs
32 */
33void init_IRQ_pint(void);
Jamie Lenehanea0f8fe2006-12-06 12:05:02 +090034void make_imask_irq(unsigned int irq);
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
Linus Torvalds1da177e2005-04-16 15:20:36 -070036static inline int generic_irq_demux(int irq)
37{
38 return irq;
39}
40
41#define irq_canonicalize(irq) (irq)
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 Mundtc7a49dd2008-02-13 20:16:47 +090056#ifdef CONFIG_CPU_SH5
Paul Mundtf15cbe62008-07-29 08:09:44 +090057#include <cpu/irq.h>
Paul Mundtc7a49dd2008-02-13 20:16:47 +090058#endif
59
Linus Torvalds1da177e2005-04-16 15:20:36 -070060#endif /* __ASM_SH_IRQ_H */