2 * linux/include/asm-arm/arch-arc/irq.h
4 * Copyright (C) 1996 Russell King
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
11 * 24-09-1996 RMK Created
12 * 10-10-1996 RMK Brought up to date with arch-sa110eval
13 * 22-10-1996 RMK Changed interrupt numbers & uses new inb/outb macros
14 * 11-01-1998 RMK Added mask_and_ack_irq
15 * 22-08-1998 RMK Restructured IRQ routines
17 #include <linux/config.h>
18 #include <asm/hardware/ioc.h>
21 #ifdef CONFIG_ARCH_ARC
25 #define a_clf() do { } while (0)
26 #define a_stf() do { } while (0)
29 #define fixup_irq(x) (x)
31 static void arc_mask_irq_ack_a(unsigned int irq)
33 unsigned int val, mask;
37 val = ioc_readb(IOC_IRQMASKA);
38 ioc_writeb(val & ~mask, IOC_IRQMASKA);
39 ioc_writeb(mask, IOC_IRQCLRA);
43 static void arc_mask_irq_a(unsigned int irq)
45 unsigned int val, mask;
49 val = ioc_readb(IOC_IRQMASKA);
50 ioc_writeb(val & ~mask, IOC_IRQMASKA);
54 static void arc_unmask_irq_a(unsigned int irq)
56 unsigned int val, mask;
60 val = ioc_readb(IOC_IRQMASKA);
61 ioc_writeb(val | mask, IOC_IRQMASKA);
65 static void arc_mask_irq_b(unsigned int irq)
67 unsigned int val, mask;
69 mask = 1 << (irq & 7);
70 val = ioc_readb(IOC_IRQMASKB);
71 ioc_writeb(val & ~mask, IOC_IRQMASKB);
74 static void arc_unmask_irq_b(unsigned int irq)
76 unsigned int val, mask;
78 mask = 1 << (irq & 7);
79 val = ioc_readb(IOC_IRQMASKB);
80 ioc_writeb(val | mask, IOC_IRQMASKB);
83 static void arc_mask_irq_fiq(unsigned int irq)
85 unsigned int val, mask;
87 mask = 1 << (irq & 7);
88 val = ioc_readb(IOC_FIQMASK);
89 ioc_writeb(val & ~mask, IOC_FIQMASK);
92 static void arc_unmask_irq_fiq(unsigned int irq)
94 unsigned int val, mask;
96 mask = 1 << (irq & 7);
97 val = ioc_readb(IOC_FIQMASK);
98 ioc_writeb(val | mask, IOC_FIQMASK);
101 static __inline__ void irq_init_irq(void)
105 ioc_writeb(0, IOC_IRQMASKA);
106 ioc_writeb(0, IOC_IRQMASKB);
107 ioc_writeb(0, IOC_FIQMASK);
109 for (irq = 0; irq < NR_IRQS; irq++) {
112 irq_desc[irq].probe_ok = 1;
113 irq_desc[irq].valid = 1;
114 irq_desc[irq].mask_ack = arc_mask_irq_ack_a;
115 irq_desc[irq].mask = arc_mask_irq_a;
116 irq_desc[irq].unmask = arc_unmask_irq_a;
120 irq_desc[irq].noautoenable = 1;
121 irq_desc[irq].valid = 1;
122 irq_desc[irq].mask_ack = arc_mask_irq_ack_a;
123 irq_desc[irq].mask = arc_mask_irq_a;
124 irq_desc[irq].unmask = arc_unmask_irq_a;
128 irq_desc[irq].probe_ok = 1;
130 irq_desc[irq].valid = 1;
131 irq_desc[irq].mask_ack = arc_mask_irq_b;
132 irq_desc[irq].mask = arc_mask_irq_b;
133 irq_desc[irq].unmask = arc_unmask_irq_b;
137 irq_desc[irq].valid = 1;
138 irq_desc[irq].mask_ack = arc_mask_irq_fiq;
139 irq_desc[irq].mask = arc_mask_irq_fiq;
140 irq_desc[irq].unmask = arc_unmask_irq_fiq;
145 irq_desc[IRQ_KEYBOARDTX].noautoenable = 1;