Commit 1a86dcb3 authored by Charles Keepax's avatar Charles Keepax Committed by Lee Jones

mfd: arizona: Add defines for IRQs on the main Arizona IRQ domain

Signed-off-by: default avatarCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
parent 003db34e
...@@ -26,6 +26,9 @@ ...@@ -26,6 +26,9 @@
#include "arizona.h" #include "arizona.h"
#define ARIZONA_AOD_IRQ_INDEX 0
#define ARIZONA_MAIN_IRQ_INDEX 1
static int arizona_map_irq(struct arizona *arizona, int irq) static int arizona_map_irq(struct arizona *arizona, int irq)
{ {
int ret; int ret;
...@@ -319,7 +322,8 @@ int arizona_irq_init(struct arizona *arizona) ...@@ -319,7 +322,8 @@ int arizona_irq_init(struct arizona *arizona)
if (aod) { if (aod) {
ret = regmap_add_irq_chip(arizona->regmap, ret = regmap_add_irq_chip(arizona->regmap,
irq_create_mapping(arizona->virq, 0), irq_create_mapping(arizona->virq,
ARIZONA_AOD_IRQ_INDEX),
IRQF_ONESHOT, 0, aod, IRQF_ONESHOT, 0, aod,
&arizona->aod_irq_chip); &arizona->aod_irq_chip);
if (ret != 0) { if (ret != 0) {
...@@ -330,7 +334,8 @@ int arizona_irq_init(struct arizona *arizona) ...@@ -330,7 +334,8 @@ int arizona_irq_init(struct arizona *arizona)
} }
ret = regmap_add_irq_chip(arizona->regmap, ret = regmap_add_irq_chip(arizona->regmap,
irq_create_mapping(arizona->virq, 1), irq_create_mapping(arizona->virq,
ARIZONA_MAIN_IRQ_INDEX),
IRQF_ONESHOT, 0, irq, IRQF_ONESHOT, 0, irq,
&arizona->irq_chip); &arizona->irq_chip);
if (ret != 0) { if (ret != 0) {
...@@ -396,10 +401,12 @@ int arizona_irq_init(struct arizona *arizona) ...@@ -396,10 +401,12 @@ int arizona_irq_init(struct arizona *arizona)
err_boot_done: err_boot_done:
free_irq(arizona->irq, arizona); free_irq(arizona->irq, arizona);
err_main_irq: err_main_irq:
regmap_del_irq_chip(irq_find_mapping(arizona->virq, 1), regmap_del_irq_chip(irq_find_mapping(arizona->virq,
ARIZONA_MAIN_IRQ_INDEX),
arizona->irq_chip); arizona->irq_chip);
err_aod: err_aod:
regmap_del_irq_chip(irq_find_mapping(arizona->virq, 0), regmap_del_irq_chip(irq_find_mapping(arizona->virq,
ARIZONA_AOD_IRQ_INDEX),
arizona->aod_irq_chip); arizona->aod_irq_chip);
err: err:
return ret; return ret;
...@@ -411,9 +418,11 @@ int arizona_irq_exit(struct arizona *arizona) ...@@ -411,9 +418,11 @@ int arizona_irq_exit(struct arizona *arizona)
arizona_free_irq(arizona, ARIZONA_IRQ_CTRLIF_ERR, arizona); arizona_free_irq(arizona, ARIZONA_IRQ_CTRLIF_ERR, arizona);
arizona_free_irq(arizona, ARIZONA_IRQ_BOOT_DONE, arizona); arizona_free_irq(arizona, ARIZONA_IRQ_BOOT_DONE, arizona);
regmap_del_irq_chip(irq_find_mapping(arizona->virq, 1), regmap_del_irq_chip(irq_find_mapping(arizona->virq,
ARIZONA_MAIN_IRQ_INDEX),
arizona->irq_chip); arizona->irq_chip);
regmap_del_irq_chip(irq_find_mapping(arizona->virq, 0), regmap_del_irq_chip(irq_find_mapping(arizona->virq,
ARIZONA_AOD_IRQ_INDEX),
arizona->aod_irq_chip); arizona->aod_irq_chip);
free_irq(arizona->irq, arizona); free_irq(arizona->irq, arizona);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment