diff options
author | Takashi Iwai <tiwai@suse.de> | 2010-05-20 06:00:43 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2010-05-20 06:00:43 -0400 |
commit | d71f4cece4bd97d05592836202fc04ff2e7817e3 (patch) | |
tree | 6c877c7a938758b1323d9c97d46b9c536e618c69 /drivers/mfd/wm831x-irq.c | |
parent | 19008bdacb9f7841166ebafe0aef361ee582ffbf (diff) | |
parent | ad8332c1302bcb4f80d593fd3eb477be9d7f5604 (diff) |
Merge branch 'topic/asoc' into for-linus
Conflicts:
sound/soc/codecs/ad1938.c
Diffstat (limited to 'drivers/mfd/wm831x-irq.c')
-rw-r--r-- | drivers/mfd/wm831x-irq.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/drivers/mfd/wm831x-irq.c b/drivers/mfd/wm831x-irq.c index 30132769711..4c1122ceb44 100644 --- a/drivers/mfd/wm831x-irq.c +++ b/drivers/mfd/wm831x-irq.c | |||
@@ -21,6 +21,7 @@ | |||
21 | 21 | ||
22 | #include <linux/mfd/wm831x/core.h> | 22 | #include <linux/mfd/wm831x/core.h> |
23 | #include <linux/mfd/wm831x/pdata.h> | 23 | #include <linux/mfd/wm831x/pdata.h> |
24 | #include <linux/mfd/wm831x/gpio.h> | ||
24 | #include <linux/mfd/wm831x/irq.h> | 25 | #include <linux/mfd/wm831x/irq.h> |
25 | 26 | ||
26 | #include <linux/delay.h> | 27 | #include <linux/delay.h> |
@@ -388,12 +389,41 @@ static void wm831x_irq_mask(unsigned int irq) | |||
388 | wm831x->irq_masks_cur[irq_data->reg - 1] |= irq_data->mask; | 389 | wm831x->irq_masks_cur[irq_data->reg - 1] |= irq_data->mask; |
389 | } | 390 | } |
390 | 391 | ||
392 | static int wm831x_irq_set_type(unsigned int irq, unsigned int type) | ||
393 | { | ||
394 | struct wm831x *wm831x = get_irq_chip_data(irq); | ||
395 | int val; | ||
396 | |||
397 | irq = irq - wm831x->irq_base; | ||
398 | |||
399 | if (irq < WM831X_IRQ_GPIO_1 || irq > WM831X_IRQ_GPIO_11) | ||
400 | return -EINVAL; | ||
401 | |||
402 | switch (type) { | ||
403 | case IRQ_TYPE_EDGE_BOTH: | ||
404 | val = WM831X_GPN_INT_MODE; | ||
405 | break; | ||
406 | case IRQ_TYPE_EDGE_RISING: | ||
407 | val = WM831X_GPN_POL; | ||
408 | break; | ||
409 | case IRQ_TYPE_EDGE_FALLING: | ||
410 | val = 0; | ||
411 | break; | ||
412 | default: | ||
413 | return -EINVAL; | ||
414 | } | ||
415 | |||
416 | return wm831x_set_bits(wm831x, WM831X_GPIO1_CONTROL + irq, | ||
417 | WM831X_GPN_INT_MODE | WM831X_GPN_POL, val); | ||
418 | } | ||
419 | |||
391 | static struct irq_chip wm831x_irq_chip = { | 420 | static struct irq_chip wm831x_irq_chip = { |
392 | .name = "wm831x", | 421 | .name = "wm831x", |
393 | .bus_lock = wm831x_irq_lock, | 422 | .bus_lock = wm831x_irq_lock, |
394 | .bus_sync_unlock = wm831x_irq_sync_unlock, | 423 | .bus_sync_unlock = wm831x_irq_sync_unlock, |
395 | .mask = wm831x_irq_mask, | 424 | .mask = wm831x_irq_mask, |
396 | .unmask = wm831x_irq_unmask, | 425 | .unmask = wm831x_irq_unmask, |
426 | .set_type = wm831x_irq_set_type, | ||
397 | }; | 427 | }; |
398 | 428 | ||
399 | /* The processing of the primary interrupt occurs in a thread so that | 429 | /* The processing of the primary interrupt occurs in a thread so that |