diff options
Diffstat (limited to 'drivers/irqchip')
-rw-r--r-- | drivers/irqchip/irq-sunxi-nmi.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/drivers/irqchip/irq-sunxi-nmi.c b/drivers/irqchip/irq-sunxi-nmi.c index 4ef178078e5b..0820f67cc9a7 100644 --- a/drivers/irqchip/irq-sunxi-nmi.c +++ b/drivers/irqchip/irq-sunxi-nmi.c | |||
@@ -50,6 +50,12 @@ static struct sunxi_sc_nmi_reg_offs sun6i_reg_offs = { | |||
50 | .enable = 0x34, | 50 | .enable = 0x34, |
51 | }; | 51 | }; |
52 | 52 | ||
53 | static struct sunxi_sc_nmi_reg_offs sun9i_reg_offs = { | ||
54 | .ctrl = 0x00, | ||
55 | .pend = 0x08, | ||
56 | .enable = 0x04, | ||
57 | }; | ||
58 | |||
53 | static inline void sunxi_sc_nmi_write(struct irq_chip_generic *gc, u32 off, | 59 | static inline void sunxi_sc_nmi_write(struct irq_chip_generic *gc, u32 off, |
54 | u32 val) | 60 | u32 val) |
55 | { | 61 | { |
@@ -207,3 +213,10 @@ static int __init sun7i_sc_nmi_irq_init(struct device_node *node, | |||
207 | return sunxi_sc_nmi_irq_init(node, &sun7i_reg_offs); | 213 | return sunxi_sc_nmi_irq_init(node, &sun7i_reg_offs); |
208 | } | 214 | } |
209 | IRQCHIP_DECLARE(sun7i_sc_nmi, "allwinner,sun7i-a20-sc-nmi", sun7i_sc_nmi_irq_init); | 215 | IRQCHIP_DECLARE(sun7i_sc_nmi, "allwinner,sun7i-a20-sc-nmi", sun7i_sc_nmi_irq_init); |
216 | |||
217 | static int __init sun9i_nmi_irq_init(struct device_node *node, | ||
218 | struct device_node *parent) | ||
219 | { | ||
220 | return sunxi_sc_nmi_irq_init(node, &sun9i_reg_offs); | ||
221 | } | ||
222 | IRQCHIP_DECLARE(sun9i_nmi, "allwinner,sun9i-a80-nmi", sun9i_nmi_irq_init); | ||