aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/plat-mxc/include/mach/irqs.h5
-rw-r--r--arch/arm/plat-mxc/irq.c29
2 files changed, 34 insertions, 0 deletions
diff --git a/arch/arm/plat-mxc/include/mach/irqs.h b/arch/arm/plat-mxc/include/mach/irqs.h
index b55bba35e18a..b8ac91608a4f 100644
--- a/arch/arm/plat-mxc/include/mach/irqs.h
+++ b/arch/arm/plat-mxc/include/mach/irqs.h
@@ -14,4 +14,9 @@
14#include <mach/hardware.h> 14#include <mach/hardware.h>
15extern void imx_irq_set_priority(unsigned char irq, unsigned char prio); 15extern void imx_irq_set_priority(unsigned char irq, unsigned char prio);
16 16
17/* all normal IRQs can be FIQs */
18#define FIQ_START 0
19/* switch betwean IRQ and FIQ */
20extern int mxc_set_irq_fiq(unsigned int irq, unsigned int type);
21
17#endif /* __ASM_ARCH_MXC_IRQS_H__ */ 22#endif /* __ASM_ARCH_MXC_IRQS_H__ */
diff --git a/arch/arm/plat-mxc/irq.c b/arch/arm/plat-mxc/irq.c
index d862c9e5f8db..dd7021b19834 100644
--- a/arch/arm/plat-mxc/irq.c
+++ b/arch/arm/plat-mxc/irq.c
@@ -17,9 +17,11 @@
17 * MA 02110-1301, USA. 17 * MA 02110-1301, USA.
18 */ 18 */
19 19
20#include <linux/module.h>
20#include <linux/irq.h> 21#include <linux/irq.h>
21#include <linux/io.h> 22#include <linux/io.h>
22#include <mach/common.h> 23#include <mach/common.h>
24#include <asm/mach/irq.h>
23 25
24#define AVIC_BASE IO_ADDRESS(AVIC_BASE_ADDR) 26#define AVIC_BASE IO_ADDRESS(AVIC_BASE_ADDR)
25#define AVIC_INTCNTL (AVIC_BASE + 0x00) /* int control reg */ 27#define AVIC_INTCNTL (AVIC_BASE + 0x00) /* int control reg */
@@ -65,6 +67,28 @@ void imx_irq_set_priority(unsigned char irq, unsigned char prio)
65EXPORT_SYMBOL(imx_irq_set_priority); 67EXPORT_SYMBOL(imx_irq_set_priority);
66#endif 68#endif
67 69
70#ifdef CONFIG_FIQ
71int mxc_set_irq_fiq(unsigned int irq, unsigned int type)
72{
73 unsigned int irqt;
74
75 if (irq >= MXC_MAX_INT_LINES)
76 return -EINVAL;
77
78 if (irq < MXC_MAX_INT_LINES / 2) {
79 irqt = __raw_readl(AVIC_INTTYPEL) & ~(1 << irq);
80 __raw_writel(irqt | (!!type << irq), AVIC_INTTYPEL);
81 } else {
82 irq -= MXC_MAX_INT_LINES / 2;
83 irqt = __raw_readl(AVIC_INTTYPEH) & ~(1 << irq);
84 __raw_writel(irqt | (!!type << irq), AVIC_INTTYPEH);
85 }
86
87 return 0;
88}
89EXPORT_SYMBOL(mxc_set_irq_fiq);
90#endif /* CONFIG_FIQ */
91
68/* Disable interrupt number "irq" in the AVIC */ 92/* Disable interrupt number "irq" in the AVIC */
69static void mxc_mask_irq(unsigned int irq) 93static void mxc_mask_irq(unsigned int irq)
70{ 94{
@@ -119,5 +143,10 @@ void __init mxc_init_irq(void)
119 /* init architectures chained interrupt handler */ 143 /* init architectures chained interrupt handler */
120 mxc_register_gpios(); 144 mxc_register_gpios();
121 145
146#ifdef CONFIG_FIQ
147 /* Initialize FIQ */
148 init_FIQ();
149#endif
150
122 printk(KERN_INFO "MXC IRQ initialized\n"); 151 printk(KERN_INFO "MXC IRQ initialized\n");
123} 152}