Commit | Line | Data |
---|---|---|
da3601a5 GU |
1 | /* |
2 | * intc2.c -- support for the 2nd INTC controller of the 5249 | |
3 | * | |
4 | * (C) Copyright 2009, Greg Ungerer <gerg@snapgear.com> | |
5 | * | |
6 | * This file is subject to the terms and conditions of the GNU General Public | |
7 | * License. See the file COPYING in the main directory of this archive | |
8 | * for more details. | |
9 | */ | |
10 | ||
11 | #include <linux/types.h> | |
12 | #include <linux/init.h> | |
13 | #include <linux/kernel.h> | |
14 | #include <linux/interrupt.h> | |
15 | #include <linux/irq.h> | |
16 | #include <linux/io.h> | |
17 | #include <asm/coldfire.h> | |
18 | #include <asm/mcfsim.h> | |
19 | ||
e474563e | 20 | static void intc2_irq_gpio_mask(struct irq_data *d) |
da3601a5 GU |
21 | { |
22 | u32 imr; | |
041a89a4 | 23 | imr = readl(MCFSIM2_GPIOINTENABLE); |
5a4acf3e | 24 | imr &= ~(0x1 << (d->irq - MCF_IRQ_GPIO0)); |
041a89a4 | 25 | writel(imr, MCFSIM2_GPIOINTENABLE); |
da3601a5 GU |
26 | } |
27 | ||
e474563e | 28 | static void intc2_irq_gpio_unmask(struct irq_data *d) |
da3601a5 GU |
29 | { |
30 | u32 imr; | |
041a89a4 | 31 | imr = readl(MCFSIM2_GPIOINTENABLE); |
5a4acf3e | 32 | imr |= (0x1 << (d->irq - MCF_IRQ_GPIO0)); |
041a89a4 | 33 | writel(imr, MCFSIM2_GPIOINTENABLE); |
da3601a5 GU |
34 | } |
35 | ||
e474563e | 36 | static void intc2_irq_gpio_ack(struct irq_data *d) |
da3601a5 | 37 | { |
5a4acf3e | 38 | writel(0x1 << (d->irq - MCF_IRQ_GPIO0), MCFSIM2_GPIOINTCLEAR); |
da3601a5 GU |
39 | } |
40 | ||
41 | static struct irq_chip intc2_irq_gpio_chip = { | |
42 | .name = "CF-INTC2", | |
e474563e TG |
43 | .irq_mask = intc2_irq_gpio_mask, |
44 | .irq_unmask = intc2_irq_gpio_unmask, | |
45 | .irq_ack = intc2_irq_gpio_ack, | |
da3601a5 GU |
46 | }; |
47 | ||
48 | static int __init mcf_intc2_init(void) | |
49 | { | |
50 | int irq; | |
51 | ||
52 | /* GPIO interrupt sources */ | |
5a4acf3e | 53 | for (irq = MCF_IRQ_GPIO0; (irq <= MCF_IRQ_GPIO7); irq++) { |
0b98b163 TG |
54 | irq_set_chip(irq, &intc2_irq_gpio_chip); |
55 | irq_set_handler(irq, handle_edge_irq); | |
86d306c9 | 56 | } |
da3601a5 GU |
57 | |
58 | return 0; | |
59 | } | |
60 | ||
61 | arch_initcall(mcf_intc2_init); |