introduce I_SYNC
[deliverable/linux.git] / include / asm-sh / irq.h
CommitLineData
1da177e4
LT
1#ifndef __ASM_SH_IRQ_H
2#define __ASM_SH_IRQ_H
3
1da177e4 4#include <asm/machvec.h>
1da177e4 5
be782df5
PM
6/*
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.
1da177e4 10 */
be782df5 11#define NR_IRQS 256
1da177e4 12
ea0f8fea
JL
13/*
14 * Convert back and forth between INTEVT and IRQ values.
15 */
3afb209a 16#ifdef CONFIG_CPU_HAS_INTEVT
ea0f8fea
JL
17#define evt2irq(evt) (((evt) >> 5) - 16)
18#define irq2evt(irq) (((irq) + 16) << 5)
3afb209a
PM
19#else
20#define evt2irq(evt) (evt)
21#define irq2evt(irq) (irq)
22#endif
ea0f8fea 23
1da177e4
LT
24/*
25 * Simple Mask Register Support
26 */
27extern void make_maskreg_irq(unsigned int irq);
28extern unsigned short *irq_mask_register;
29
0f08f338
PM
30/*
31 * PINT IRQs
32 */
33void init_IRQ_pint(void);
ea0f8fea 34void make_imask_irq(unsigned int irq);
1da177e4 35
1da177e4
LT
36static inline int generic_irq_demux(int irq)
37{
38 return irq;
39}
40
41#define irq_canonicalize(irq) (irq)
9a7ef6d5 42#define irq_demux(irq) sh_mv.mv_irq_demux(irq)
1da177e4 43
a6a31139
PM
44#ifdef CONFIG_4KSTACKS
45extern void irq_ctx_init(int cpu);
46extern void irq_ctx_exit(int cpu);
47# define __ARCH_HAS_DO_SOFTIRQ
48#else
49# define irq_ctx_init(cpu) do { } while (0)
50# define irq_ctx_exit(cpu) do { } while (0)
51#endif
52
1da177e4 53#endif /* __ASM_SH_IRQ_H */
This page took 0.33166 seconds and 5 git commands to generate.