diff options
-rw-r--r-- | drivers/mfd/Makefile | 1 | ||||
-rw-r--r-- | drivers/mfd/da9052-core.c | 271 | ||||
-rw-r--r-- | drivers/mfd/da9052-irq.c | 288 | ||||
-rw-r--r-- | include/linux/mfd/da9052/da9052.h | 10 |
4 files changed, 307 insertions, 263 deletions
diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile index a30c49ecdd95..632cce09e407 100644 --- a/drivers/mfd/Makefile +++ b/drivers/mfd/Makefile | |||
@@ -90,6 +90,7 @@ obj-$(CONFIG_UCB1400_CORE) += ucb1400_core.o | |||
90 | 90 | ||
91 | obj-$(CONFIG_PMIC_DA903X) += da903x.o | 91 | obj-$(CONFIG_PMIC_DA903X) += da903x.o |
92 | 92 | ||
93 | obj-$(CONFIG_PMIC_DA9052) += da9052-irq.o | ||
93 | obj-$(CONFIG_PMIC_DA9052) += da9052-core.o | 94 | obj-$(CONFIG_PMIC_DA9052) += da9052-core.o |
94 | obj-$(CONFIG_MFD_DA9052_SPI) += da9052-spi.o | 95 | obj-$(CONFIG_MFD_DA9052_SPI) += da9052-spi.o |
95 | obj-$(CONFIG_MFD_DA9052_I2C) += da9052-i2c.o | 96 | obj-$(CONFIG_MFD_DA9052_I2C) += da9052-i2c.o |
diff --git a/drivers/mfd/da9052-core.c b/drivers/mfd/da9052-core.c index c96cdbc0daff..2153f9bba9ef 100644 --- a/drivers/mfd/da9052-core.c +++ b/drivers/mfd/da9052-core.c | |||
@@ -15,7 +15,6 @@ | |||
15 | #include <linux/delay.h> | 15 | #include <linux/delay.h> |
16 | #include <linux/input.h> | 16 | #include <linux/input.h> |
17 | #include <linux/interrupt.h> | 17 | #include <linux/interrupt.h> |
18 | #include <linux/irq.h> | ||
19 | #include <linux/mfd/core.h> | 18 | #include <linux/mfd/core.h> |
20 | #include <linux/slab.h> | 19 | #include <linux/slab.h> |
21 | #include <linux/module.h> | 20 | #include <linux/module.h> |
@@ -24,16 +23,6 @@ | |||
24 | #include <linux/mfd/da9052/pdata.h> | 23 | #include <linux/mfd/da9052/pdata.h> |
25 | #include <linux/mfd/da9052/reg.h> | 24 | #include <linux/mfd/da9052/reg.h> |
26 | 25 | ||
27 | #define DA9052_NUM_IRQ_REGS 4 | ||
28 | #define DA9052_IRQ_MASK_POS_1 0x01 | ||
29 | #define DA9052_IRQ_MASK_POS_2 0x02 | ||
30 | #define DA9052_IRQ_MASK_POS_3 0x04 | ||
31 | #define DA9052_IRQ_MASK_POS_4 0x08 | ||
32 | #define DA9052_IRQ_MASK_POS_5 0x10 | ||
33 | #define DA9052_IRQ_MASK_POS_6 0x20 | ||
34 | #define DA9052_IRQ_MASK_POS_7 0x40 | ||
35 | #define DA9052_IRQ_MASK_POS_8 0x80 | ||
36 | |||
37 | static bool da9052_reg_readable(struct device *dev, unsigned int reg) | 26 | static bool da9052_reg_readable(struct device *dev, unsigned int reg) |
38 | { | 27 | { |
39 | switch (reg) { | 28 | switch (reg) { |
@@ -425,15 +414,6 @@ err: | |||
425 | } | 414 | } |
426 | EXPORT_SYMBOL_GPL(da9052_adc_manual_read); | 415 | EXPORT_SYMBOL_GPL(da9052_adc_manual_read); |
427 | 416 | ||
428 | static irqreturn_t da9052_auxadc_irq(int irq, void *irq_data) | ||
429 | { | ||
430 | struct da9052 *da9052 = irq_data; | ||
431 | |||
432 | complete(&da9052->done); | ||
433 | |||
434 | return IRQ_HANDLED; | ||
435 | } | ||
436 | |||
437 | int da9052_adc_read_temp(struct da9052 *da9052) | 417 | int da9052_adc_read_temp(struct da9052 *da9052) |
438 | { | 418 | { |
439 | int tbat; | 419 | int tbat; |
@@ -447,74 +427,6 @@ int da9052_adc_read_temp(struct da9052 *da9052) | |||
447 | } | 427 | } |
448 | EXPORT_SYMBOL_GPL(da9052_adc_read_temp); | 428 | EXPORT_SYMBOL_GPL(da9052_adc_read_temp); |
449 | 429 | ||
450 | static struct resource da9052_rtc_resource = { | ||
451 | .name = "ALM", | ||
452 | .start = DA9052_IRQ_ALARM, | ||
453 | .end = DA9052_IRQ_ALARM, | ||
454 | .flags = IORESOURCE_IRQ, | ||
455 | }; | ||
456 | |||
457 | static struct resource da9052_onkey_resource = { | ||
458 | .name = "ONKEY", | ||
459 | .start = DA9052_IRQ_NONKEY, | ||
460 | .end = DA9052_IRQ_NONKEY, | ||
461 | .flags = IORESOURCE_IRQ, | ||
462 | }; | ||
463 | |||
464 | static struct resource da9052_bat_resources[] = { | ||
465 | { | ||
466 | .name = "BATT TEMP", | ||
467 | .start = DA9052_IRQ_TBAT, | ||
468 | .end = DA9052_IRQ_TBAT, | ||
469 | .flags = IORESOURCE_IRQ, | ||
470 | }, | ||
471 | { | ||
472 | .name = "DCIN DET", | ||
473 | .start = DA9052_IRQ_DCIN, | ||
474 | .end = DA9052_IRQ_DCIN, | ||
475 | .flags = IORESOURCE_IRQ, | ||
476 | }, | ||
477 | { | ||
478 | .name = "DCIN REM", | ||
479 | .start = DA9052_IRQ_DCINREM, | ||
480 | .end = DA9052_IRQ_DCINREM, | ||
481 | .flags = IORESOURCE_IRQ, | ||
482 | }, | ||
483 | { | ||
484 | .name = "VBUS DET", | ||
485 | .start = DA9052_IRQ_VBUS, | ||
486 | .end = DA9052_IRQ_VBUS, | ||
487 | .flags = IORESOURCE_IRQ, | ||
488 | }, | ||
489 | { | ||
490 | .name = "VBUS REM", | ||
491 | .start = DA9052_IRQ_VBUSREM, | ||
492 | .end = DA9052_IRQ_VBUSREM, | ||
493 | .flags = IORESOURCE_IRQ, | ||
494 | }, | ||
495 | { | ||
496 | .name = "CHG END", | ||
497 | .start = DA9052_IRQ_CHGEND, | ||
498 | .end = DA9052_IRQ_CHGEND, | ||
499 | .flags = IORESOURCE_IRQ, | ||
500 | }, | ||
501 | }; | ||
502 | |||
503 | static struct resource da9052_tsi_resources[] = { | ||
504 | { | ||
505 | .name = "PENDWN", | ||
506 | .start = DA9052_IRQ_PENDOWN, | ||
507 | .end = DA9052_IRQ_PENDOWN, | ||
508 | .flags = IORESOURCE_IRQ, | ||
509 | }, | ||
510 | { | ||
511 | .name = "TSIRDY", | ||
512 | .start = DA9052_IRQ_TSIREADY, | ||
513 | .end = DA9052_IRQ_TSIREADY, | ||
514 | .flags = IORESOURCE_IRQ, | ||
515 | }, | ||
516 | }; | ||
517 | |||
518 | static struct mfd_cell __devinitdata da9052_subdev_info[] = { | 430 | static struct mfd_cell __devinitdata da9052_subdev_info[] = { |
519 | { | 431 | { |
520 | .name = "da9052-regulator", | 432 | .name = "da9052-regulator", |
@@ -574,13 +486,9 @@ static struct mfd_cell __devinitdata da9052_subdev_info[] = { | |||
574 | }, | 486 | }, |
575 | { | 487 | { |
576 | .name = "da9052-onkey", | 488 | .name = "da9052-onkey", |
577 | .resources = &da9052_onkey_resource, | ||
578 | .num_resources = 1, | ||
579 | }, | 489 | }, |
580 | { | 490 | { |
581 | .name = "da9052-rtc", | 491 | .name = "da9052-rtc", |
582 | .resources = &da9052_rtc_resource, | ||
583 | .num_resources = 1, | ||
584 | }, | 492 | }, |
585 | { | 493 | { |
586 | .name = "da9052-gpio", | 494 | .name = "da9052-gpio", |
@@ -602,160 +510,15 @@ static struct mfd_cell __devinitdata da9052_subdev_info[] = { | |||
602 | }, | 510 | }, |
603 | { | 511 | { |
604 | .name = "da9052-tsi", | 512 | .name = "da9052-tsi", |
605 | .resources = da9052_tsi_resources, | ||
606 | .num_resources = ARRAY_SIZE(da9052_tsi_resources), | ||
607 | }, | 513 | }, |
608 | { | 514 | { |
609 | .name = "da9052-bat", | 515 | .name = "da9052-bat", |
610 | .resources = da9052_bat_resources, | ||
611 | .num_resources = ARRAY_SIZE(da9052_bat_resources), | ||
612 | }, | 516 | }, |
613 | { | 517 | { |
614 | .name = "da9052-watchdog", | 518 | .name = "da9052-watchdog", |
615 | }, | 519 | }, |
616 | }; | 520 | }; |
617 | 521 | ||
618 | static struct regmap_irq da9052_irqs[] = { | ||
619 | [DA9052_IRQ_DCIN] = { | ||
620 | .reg_offset = 0, | ||
621 | .mask = DA9052_IRQ_MASK_POS_1, | ||
622 | }, | ||
623 | [DA9052_IRQ_VBUS] = { | ||
624 | .reg_offset = 0, | ||
625 | .mask = DA9052_IRQ_MASK_POS_2, | ||
626 | }, | ||
627 | [DA9052_IRQ_DCINREM] = { | ||
628 | .reg_offset = 0, | ||
629 | .mask = DA9052_IRQ_MASK_POS_3, | ||
630 | }, | ||
631 | [DA9052_IRQ_VBUSREM] = { | ||
632 | .reg_offset = 0, | ||
633 | .mask = DA9052_IRQ_MASK_POS_4, | ||
634 | }, | ||
635 | [DA9052_IRQ_VDDLOW] = { | ||
636 | .reg_offset = 0, | ||
637 | .mask = DA9052_IRQ_MASK_POS_5, | ||
638 | }, | ||
639 | [DA9052_IRQ_ALARM] = { | ||
640 | .reg_offset = 0, | ||
641 | .mask = DA9052_IRQ_MASK_POS_6, | ||
642 | }, | ||
643 | [DA9052_IRQ_SEQRDY] = { | ||
644 | .reg_offset = 0, | ||
645 | .mask = DA9052_IRQ_MASK_POS_7, | ||
646 | }, | ||
647 | [DA9052_IRQ_COMP1V2] = { | ||
648 | .reg_offset = 0, | ||
649 | .mask = DA9052_IRQ_MASK_POS_8, | ||
650 | }, | ||
651 | [DA9052_IRQ_NONKEY] = { | ||
652 | .reg_offset = 1, | ||
653 | .mask = DA9052_IRQ_MASK_POS_1, | ||
654 | }, | ||
655 | [DA9052_IRQ_IDFLOAT] = { | ||
656 | .reg_offset = 1, | ||
657 | .mask = DA9052_IRQ_MASK_POS_2, | ||
658 | }, | ||
659 | [DA9052_IRQ_IDGND] = { | ||
660 | .reg_offset = 1, | ||
661 | .mask = DA9052_IRQ_MASK_POS_3, | ||
662 | }, | ||
663 | [DA9052_IRQ_CHGEND] = { | ||
664 | .reg_offset = 1, | ||
665 | .mask = DA9052_IRQ_MASK_POS_4, | ||
666 | }, | ||
667 | [DA9052_IRQ_TBAT] = { | ||
668 | .reg_offset = 1, | ||
669 | .mask = DA9052_IRQ_MASK_POS_5, | ||
670 | }, | ||
671 | [DA9052_IRQ_ADC_EOM] = { | ||
672 | .reg_offset = 1, | ||
673 | .mask = DA9052_IRQ_MASK_POS_6, | ||
674 | }, | ||
675 | [DA9052_IRQ_PENDOWN] = { | ||
676 | .reg_offset = 1, | ||
677 | .mask = DA9052_IRQ_MASK_POS_7, | ||
678 | }, | ||
679 | [DA9052_IRQ_TSIREADY] = { | ||
680 | .reg_offset = 1, | ||
681 | .mask = DA9052_IRQ_MASK_POS_8, | ||
682 | }, | ||
683 | [DA9052_IRQ_GPI0] = { | ||
684 | .reg_offset = 2, | ||
685 | .mask = DA9052_IRQ_MASK_POS_1, | ||
686 | }, | ||
687 | [DA9052_IRQ_GPI1] = { | ||
688 | .reg_offset = 2, | ||
689 | .mask = DA9052_IRQ_MASK_POS_2, | ||
690 | }, | ||
691 | [DA9052_IRQ_GPI2] = { | ||
692 | .reg_offset = 2, | ||
693 | .mask = DA9052_IRQ_MASK_POS_3, | ||
694 | }, | ||
695 | [DA9052_IRQ_GPI3] = { | ||
696 | .reg_offset = 2, | ||
697 | .mask = DA9052_IRQ_MASK_POS_4, | ||
698 | }, | ||
699 | [DA9052_IRQ_GPI4] = { | ||
700 | .reg_offset = 2, | ||
701 | .mask = DA9052_IRQ_MASK_POS_5, | ||
702 | }, | ||
703 | [DA9052_IRQ_GPI5] = { | ||
704 | .reg_offset = 2, | ||
705 | .mask = DA9052_IRQ_MASK_POS_6, | ||
706 | }, | ||
707 | [DA9052_IRQ_GPI6] = { | ||
708 | .reg_offset = 2, | ||
709 | .mask = DA9052_IRQ_MASK_POS_7, | ||
710 | }, | ||
711 | [DA9052_IRQ_GPI7] = { | ||
712 | .reg_offset = 2, | ||
713 | .mask = DA9052_IRQ_MASK_POS_8, | ||
714 | }, | ||
715 | [DA9052_IRQ_GPI8] = { | ||
716 | .reg_offset = 3, | ||
717 | .mask = DA9052_IRQ_MASK_POS_1, | ||
718 | }, | ||
719 | [DA9052_IRQ_GPI9] = { | ||
720 | .reg_offset = 3, | ||
721 | .mask = DA9052_IRQ_MASK_POS_2, | ||
722 | }, | ||
723 | [DA9052_IRQ_GPI10] = { | ||
724 | .reg_offset = 3, | ||
725 | .mask = DA9052_IRQ_MASK_POS_3, | ||
726 | }, | ||
727 | [DA9052_IRQ_GPI11] = { | ||
728 | .reg_offset = 3, | ||
729 | .mask = DA9052_IRQ_MASK_POS_4, | ||
730 | }, | ||
731 | [DA9052_IRQ_GPI12] = { | ||
732 | .reg_offset = 3, | ||
733 | .mask = DA9052_IRQ_MASK_POS_5, | ||
734 | }, | ||
735 | [DA9052_IRQ_GPI13] = { | ||
736 | .reg_offset = 3, | ||
737 | .mask = DA9052_IRQ_MASK_POS_6, | ||
738 | }, | ||
739 | [DA9052_IRQ_GPI14] = { | ||
740 | .reg_offset = 3, | ||
741 | .mask = DA9052_IRQ_MASK_POS_7, | ||
742 | }, | ||
743 | [DA9052_IRQ_GPI15] = { | ||
744 | .reg_offset = 3, | ||
745 | .mask = DA9052_IRQ_MASK_POS_8, | ||
746 | }, | ||
747 | }; | ||
748 | |||
749 | static struct regmap_irq_chip da9052_regmap_irq_chip = { | ||
750 | .name = "da9052_irq", | ||
751 | .status_base = DA9052_EVENT_A_REG, | ||
752 | .mask_base = DA9052_IRQ_MASK_A_REG, | ||
753 | .ack_base = DA9052_EVENT_A_REG, | ||
754 | .num_regs = DA9052_NUM_IRQ_REGS, | ||
755 | .irqs = da9052_irqs, | ||
756 | .num_irqs = ARRAY_SIZE(da9052_irqs), | ||
757 | }; | ||
758 | |||
759 | struct regmap_config da9052_regmap_config = { | 522 | struct regmap_config da9052_regmap_config = { |
760 | .reg_bits = 8, | 523 | .reg_bits = 8, |
761 | .val_bits = 8, | 524 | .val_bits = 8, |
@@ -769,15 +532,10 @@ struct regmap_config da9052_regmap_config = { | |||
769 | }; | 532 | }; |
770 | EXPORT_SYMBOL_GPL(da9052_regmap_config); | 533 | EXPORT_SYMBOL_GPL(da9052_regmap_config); |
771 | 534 | ||
772 | static int da9052_map_irq(struct da9052 *da9052, int irq) | ||
773 | { | ||
774 | return regmap_irq_get_virq(da9052->irq_data, irq); | ||
775 | } | ||
776 | |||
777 | int __devinit da9052_device_init(struct da9052 *da9052, u8 chip_id) | 535 | int __devinit da9052_device_init(struct da9052 *da9052, u8 chip_id) |
778 | { | 536 | { |
779 | struct da9052_pdata *pdata = da9052->dev->platform_data; | 537 | struct da9052_pdata *pdata = da9052->dev->platform_data; |
780 | int ret, i; | 538 | int ret; |
781 | 539 | ||
782 | mutex_init(&da9052->auxadc_lock); | 540 | mutex_init(&da9052->auxadc_lock); |
783 | init_completion(&da9052->done); | 541 | init_completion(&da9052->done); |
@@ -787,22 +545,12 @@ int __devinit da9052_device_init(struct da9052 *da9052, u8 chip_id) | |||
787 | 545 | ||
788 | da9052->chip_id = chip_id; | 546 | da9052->chip_id = chip_id; |
789 | 547 | ||
790 | ret = regmap_add_irq_chip(da9052->regmap, da9052->chip_irq, | 548 | ret = da9052_irq_init(da9052); |
791 | IRQF_TRIGGER_LOW | IRQF_ONESHOT, | 549 | if (ret != 0) { |
792 | -1, &da9052_regmap_irq_chip, | 550 | dev_err(da9052->dev, "da9052_irq_init failed: %d\n", ret); |
793 | &da9052->irq_data); | 551 | return ret; |
794 | if (ret < 0) { | ||
795 | dev_err(da9052->dev, "regmap_add_irq_chip failed: %d\n", ret); | ||
796 | goto regmap_err; | ||
797 | } | 552 | } |
798 | 553 | ||
799 | i = da9052_map_irq(da9052, DA9052_IRQ_ADC_EOM); | ||
800 | ret = request_threaded_irq(i, NULL, da9052_auxadc_irq, | ||
801 | IRQF_TRIGGER_LOW | IRQF_ONESHOT, | ||
802 | "adc-irq", da9052); | ||
803 | if (ret != 0) | ||
804 | dev_err(da9052->dev, "DA9052 ADC IRQ failed ret=%d\n", ret); | ||
805 | |||
806 | ret = mfd_add_devices(da9052->dev, -1, da9052_subdev_info, | 554 | ret = mfd_add_devices(da9052->dev, -1, da9052_subdev_info, |
807 | ARRAY_SIZE(da9052_subdev_info), NULL, 0, NULL); | 555 | ARRAY_SIZE(da9052_subdev_info), NULL, 0, NULL); |
808 | if (ret) { | 556 | if (ret) { |
@@ -813,18 +561,15 @@ int __devinit da9052_device_init(struct da9052 *da9052, u8 chip_id) | |||
813 | return 0; | 561 | return 0; |
814 | 562 | ||
815 | err: | 563 | err: |
816 | free_irq(da9052_map_irq(da9052, DA9052_IRQ_ADC_EOM), da9052); | 564 | da9052_irq_exit(da9052); |
817 | regmap_del_irq_chip(da9052->chip_irq, da9052->irq_data); | 565 | |
818 | mfd_remove_devices(da9052->dev); | ||
819 | regmap_err: | ||
820 | return ret; | 566 | return ret; |
821 | } | 567 | } |
822 | 568 | ||
823 | void da9052_device_exit(struct da9052 *da9052) | 569 | void da9052_device_exit(struct da9052 *da9052) |
824 | { | 570 | { |
825 | free_irq(da9052_map_irq(da9052, DA9052_IRQ_ADC_EOM), da9052); | ||
826 | regmap_del_irq_chip(da9052->chip_irq, da9052->irq_data); | ||
827 | mfd_remove_devices(da9052->dev); | 571 | mfd_remove_devices(da9052->dev); |
572 | da9052_irq_exit(da9052); | ||
828 | } | 573 | } |
829 | 574 | ||
830 | MODULE_AUTHOR("David Dajun Chen <dchen@diasemi.com>"); | 575 | MODULE_AUTHOR("David Dajun Chen <dchen@diasemi.com>"); |
diff --git a/drivers/mfd/da9052-irq.c b/drivers/mfd/da9052-irq.c new file mode 100644 index 000000000000..57ae7841f536 --- /dev/null +++ b/drivers/mfd/da9052-irq.c | |||
@@ -0,0 +1,288 @@ | |||
1 | /* | ||
2 | * DA9052 interrupt support | ||
3 | * | ||
4 | * Author: Fabio Estevam <fabio.estevam@freescale.com> | ||
5 | * Based on arizona-irq.c, which is: | ||
6 | * | ||
7 | * Copyright 2012 Wolfson Microelectronics plc | ||
8 | * | ||
9 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
10 | * | ||
11 | * This program is free software; you can redistribute it and/or modify | ||
12 | * it under the terms of the GNU General Public License version 2 as | ||
13 | * published by the Free Software Foundation. | ||
14 | */ | ||
15 | |||
16 | #include <linux/device.h> | ||
17 | #include <linux/delay.h> | ||
18 | #include <linux/input.h> | ||
19 | #include <linux/interrupt.h> | ||
20 | #include <linux/irq.h> | ||
21 | #include <linux/irqdomain.h> | ||
22 | #include <linux/slab.h> | ||
23 | #include <linux/module.h> | ||
24 | |||
25 | #include <linux/mfd/da9052/da9052.h> | ||
26 | #include <linux/mfd/da9052/reg.h> | ||
27 | |||
28 | #define DA9052_NUM_IRQ_REGS 4 | ||
29 | #define DA9052_IRQ_MASK_POS_1 0x01 | ||
30 | #define DA9052_IRQ_MASK_POS_2 0x02 | ||
31 | #define DA9052_IRQ_MASK_POS_3 0x04 | ||
32 | #define DA9052_IRQ_MASK_POS_4 0x08 | ||
33 | #define DA9052_IRQ_MASK_POS_5 0x10 | ||
34 | #define DA9052_IRQ_MASK_POS_6 0x20 | ||
35 | #define DA9052_IRQ_MASK_POS_7 0x40 | ||
36 | #define DA9052_IRQ_MASK_POS_8 0x80 | ||
37 | |||
38 | static struct regmap_irq da9052_irqs[] = { | ||
39 | [DA9052_IRQ_DCIN] = { | ||
40 | .reg_offset = 0, | ||
41 | .mask = DA9052_IRQ_MASK_POS_1, | ||
42 | }, | ||
43 | [DA9052_IRQ_VBUS] = { | ||
44 | .reg_offset = 0, | ||
45 | .mask = DA9052_IRQ_MASK_POS_2, | ||
46 | }, | ||
47 | [DA9052_IRQ_DCINREM] = { | ||
48 | .reg_offset = 0, | ||
49 | .mask = DA9052_IRQ_MASK_POS_3, | ||
50 | }, | ||
51 | [DA9052_IRQ_VBUSREM] = { | ||
52 | .reg_offset = 0, | ||
53 | .mask = DA9052_IRQ_MASK_POS_4, | ||
54 | }, | ||
55 | [DA9052_IRQ_VDDLOW] = { | ||
56 | .reg_offset = 0, | ||
57 | .mask = DA9052_IRQ_MASK_POS_5, | ||
58 | }, | ||
59 | [DA9052_IRQ_ALARM] = { | ||
60 | .reg_offset = 0, | ||
61 | .mask = DA9052_IRQ_MASK_POS_6, | ||
62 | }, | ||
63 | [DA9052_IRQ_SEQRDY] = { | ||
64 | .reg_offset = 0, | ||
65 | .mask = DA9052_IRQ_MASK_POS_7, | ||
66 | }, | ||
67 | [DA9052_IRQ_COMP1V2] = { | ||
68 | .reg_offset = 0, | ||
69 | .mask = DA9052_IRQ_MASK_POS_8, | ||
70 | }, | ||
71 | [DA9052_IRQ_NONKEY] = { | ||
72 | .reg_offset = 1, | ||
73 | .mask = DA9052_IRQ_MASK_POS_1, | ||
74 | }, | ||
75 | [DA9052_IRQ_IDFLOAT] = { | ||
76 | .reg_offset = 1, | ||
77 | .mask = DA9052_IRQ_MASK_POS_2, | ||
78 | }, | ||
79 | [DA9052_IRQ_IDGND] = { | ||
80 | .reg_offset = 1, | ||
81 | .mask = DA9052_IRQ_MASK_POS_3, | ||
82 | }, | ||
83 | [DA9052_IRQ_CHGEND] = { | ||
84 | .reg_offset = 1, | ||
85 | .mask = DA9052_IRQ_MASK_POS_4, | ||
86 | }, | ||
87 | [DA9052_IRQ_TBAT] = { | ||
88 | .reg_offset = 1, | ||
89 | .mask = DA9052_IRQ_MASK_POS_5, | ||
90 | }, | ||
91 | [DA9052_IRQ_ADC_EOM] = { | ||
92 | .reg_offset = 1, | ||
93 | .mask = DA9052_IRQ_MASK_POS_6, | ||
94 | }, | ||
95 | [DA9052_IRQ_PENDOWN] = { | ||
96 | .reg_offset = 1, | ||
97 | .mask = DA9052_IRQ_MASK_POS_7, | ||
98 | }, | ||
99 | [DA9052_IRQ_TSIREADY] = { | ||
100 | .reg_offset = 1, | ||
101 | .mask = DA9052_IRQ_MASK_POS_8, | ||
102 | }, | ||
103 | [DA9052_IRQ_GPI0] = { | ||
104 | .reg_offset = 2, | ||
105 | .mask = DA9052_IRQ_MASK_POS_1, | ||
106 | }, | ||
107 | [DA9052_IRQ_GPI1] = { | ||
108 | .reg_offset = 2, | ||
109 | .mask = DA9052_IRQ_MASK_POS_2, | ||
110 | }, | ||
111 | [DA9052_IRQ_GPI2] = { | ||
112 | .reg_offset = 2, | ||
113 | .mask = DA9052_IRQ_MASK_POS_3, | ||
114 | }, | ||
115 | [DA9052_IRQ_GPI3] = { | ||
116 | .reg_offset = 2, | ||
117 | .mask = DA9052_IRQ_MASK_POS_4, | ||
118 | }, | ||
119 | [DA9052_IRQ_GPI4] = { | ||
120 | .reg_offset = 2, | ||
121 | .mask = DA9052_IRQ_MASK_POS_5, | ||
122 | }, | ||
123 | [DA9052_IRQ_GPI5] = { | ||
124 | .reg_offset = 2, | ||
125 | .mask = DA9052_IRQ_MASK_POS_6, | ||
126 | }, | ||
127 | [DA9052_IRQ_GPI6] = { | ||
128 | .reg_offset = 2, | ||
129 | .mask = DA9052_IRQ_MASK_POS_7, | ||
130 | }, | ||
131 | [DA9052_IRQ_GPI7] = { | ||
132 | .reg_offset = 2, | ||
133 | .mask = DA9052_IRQ_MASK_POS_8, | ||
134 | }, | ||
135 | [DA9052_IRQ_GPI8] = { | ||
136 | .reg_offset = 3, | ||
137 | .mask = DA9052_IRQ_MASK_POS_1, | ||
138 | }, | ||
139 | [DA9052_IRQ_GPI9] = { | ||
140 | .reg_offset = 3, | ||
141 | .mask = DA9052_IRQ_MASK_POS_2, | ||
142 | }, | ||
143 | [DA9052_IRQ_GPI10] = { | ||
144 | .reg_offset = 3, | ||
145 | .mask = DA9052_IRQ_MASK_POS_3, | ||
146 | }, | ||
147 | [DA9052_IRQ_GPI11] = { | ||
148 | .reg_offset = 3, | ||
149 | .mask = DA9052_IRQ_MASK_POS_4, | ||
150 | }, | ||
151 | [DA9052_IRQ_GPI12] = { | ||
152 | .reg_offset = 3, | ||
153 | .mask = DA9052_IRQ_MASK_POS_5, | ||
154 | }, | ||
155 | [DA9052_IRQ_GPI13] = { | ||
156 | .reg_offset = 3, | ||
157 | .mask = DA9052_IRQ_MASK_POS_6, | ||
158 | }, | ||
159 | [DA9052_IRQ_GPI14] = { | ||
160 | .reg_offset = 3, | ||
161 | .mask = DA9052_IRQ_MASK_POS_7, | ||
162 | }, | ||
163 | [DA9052_IRQ_GPI15] = { | ||
164 | .reg_offset = 3, | ||
165 | .mask = DA9052_IRQ_MASK_POS_8, | ||
166 | }, | ||
167 | }; | ||
168 | |||
169 | static struct regmap_irq_chip da9052_regmap_irq_chip = { | ||
170 | .name = "da9052_irq", | ||
171 | .status_base = DA9052_EVENT_A_REG, | ||
172 | .mask_base = DA9052_IRQ_MASK_A_REG, | ||
173 | .ack_base = DA9052_EVENT_A_REG, | ||
174 | .num_regs = DA9052_NUM_IRQ_REGS, | ||
175 | .irqs = da9052_irqs, | ||
176 | .num_irqs = ARRAY_SIZE(da9052_irqs), | ||
177 | }; | ||
178 | |||
179 | static int da9052_map_irq(struct da9052 *da9052, int irq) | ||
180 | { | ||
181 | return regmap_irq_get_virq(da9052->irq_data, irq); | ||
182 | } | ||
183 | |||
184 | int da9052_enable_irq(struct da9052 *da9052, int irq) | ||
185 | { | ||
186 | irq = da9052_map_irq(da9052, irq); | ||
187 | if (irq < 0) | ||
188 | return irq; | ||
189 | |||
190 | enable_irq(irq); | ||
191 | |||
192 | return 0; | ||
193 | } | ||
194 | EXPORT_SYMBOL_GPL(da9052_enable_irq); | ||
195 | |||
196 | int da9052_disable_irq(struct da9052 *da9052, int irq) | ||
197 | { | ||
198 | irq = da9052_map_irq(da9052, irq); | ||
199 | if (irq < 0) | ||
200 | return irq; | ||
201 | |||
202 | disable_irq(irq); | ||
203 | |||
204 | return 0; | ||
205 | } | ||
206 | EXPORT_SYMBOL_GPL(da9052_disable_irq); | ||
207 | |||
208 | int da9052_disable_irq_nosync(struct da9052 *da9052, int irq) | ||
209 | { | ||
210 | irq = da9052_map_irq(da9052, irq); | ||
211 | if (irq < 0) | ||
212 | return irq; | ||
213 | |||
214 | disable_irq_nosync(irq); | ||
215 | |||
216 | return 0; | ||
217 | } | ||
218 | EXPORT_SYMBOL_GPL(da9052_disable_irq_nosync); | ||
219 | |||
220 | int da9052_request_irq(struct da9052 *da9052, int irq, char *name, | ||
221 | irq_handler_t handler, void *data) | ||
222 | { | ||
223 | irq = da9052_map_irq(da9052, irq); | ||
224 | if (irq < 0) | ||
225 | return irq; | ||
226 | |||
227 | return request_threaded_irq(irq, NULL, handler, | ||
228 | IRQF_TRIGGER_LOW | IRQF_ONESHOT, | ||
229 | name, data); | ||
230 | } | ||
231 | EXPORT_SYMBOL_GPL(da9052_request_irq); | ||
232 | |||
233 | void da9052_free_irq(struct da9052 *da9052, int irq, void *data) | ||
234 | { | ||
235 | irq = da9052_map_irq(da9052, irq); | ||
236 | if (irq < 0) | ||
237 | return; | ||
238 | |||
239 | free_irq(irq, data); | ||
240 | } | ||
241 | EXPORT_SYMBOL_GPL(da9052_free_irq); | ||
242 | |||
243 | static irqreturn_t da9052_auxadc_irq(int irq, void *irq_data) | ||
244 | { | ||
245 | struct da9052 *da9052 = irq_data; | ||
246 | |||
247 | complete(&da9052->done); | ||
248 | |||
249 | return IRQ_HANDLED; | ||
250 | } | ||
251 | |||
252 | int da9052_irq_init(struct da9052 *da9052) | ||
253 | { | ||
254 | int ret; | ||
255 | |||
256 | ret = regmap_add_irq_chip(da9052->regmap, da9052->chip_irq, | ||
257 | IRQF_TRIGGER_LOW | IRQF_ONESHOT, | ||
258 | -1, &da9052_regmap_irq_chip, | ||
259 | &da9052->irq_data); | ||
260 | if (ret < 0) { | ||
261 | dev_err(da9052->dev, "regmap_add_irq_chip failed: %d\n", ret); | ||
262 | goto regmap_err; | ||
263 | } | ||
264 | |||
265 | ret = da9052_request_irq(da9052, DA9052_IRQ_ADC_EOM, "adc-irq", | ||
266 | da9052_auxadc_irq, da9052); | ||
267 | |||
268 | if (ret != 0) { | ||
269 | dev_err(da9052->dev, "DA9052_IRQ_ADC_EOM failed: %d\n", ret); | ||
270 | goto request_irq_err; | ||
271 | } | ||
272 | |||
273 | return 0; | ||
274 | |||
275 | request_irq_err: | ||
276 | regmap_del_irq_chip(da9052->chip_irq, da9052->irq_data); | ||
277 | regmap_err: | ||
278 | return ret; | ||
279 | |||
280 | } | ||
281 | |||
282 | int da9052_irq_exit(struct da9052 *da9052) | ||
283 | { | ||
284 | da9052_free_irq(da9052, DA9052_IRQ_ADC_EOM , da9052); | ||
285 | regmap_del_irq_chip(da9052->chip_irq, da9052->irq_data); | ||
286 | |||
287 | return 0; | ||
288 | } | ||
diff --git a/include/linux/mfd/da9052/da9052.h b/include/linux/mfd/da9052/da9052.h index 0507c4c21a7d..86dd93de6ff2 100644 --- a/include/linux/mfd/da9052/da9052.h +++ b/include/linux/mfd/da9052/da9052.h | |||
@@ -146,4 +146,14 @@ void da9052_device_exit(struct da9052 *da9052); | |||
146 | 146 | ||
147 | extern struct regmap_config da9052_regmap_config; | 147 | extern struct regmap_config da9052_regmap_config; |
148 | 148 | ||
149 | int da9052_irq_init(struct da9052 *da9052); | ||
150 | int da9052_irq_exit(struct da9052 *da9052); | ||
151 | int da9052_request_irq(struct da9052 *da9052, int irq, char *name, | ||
152 | irq_handler_t handler, void *data); | ||
153 | void da9052_free_irq(struct da9052 *da9052, int irq, void *data); | ||
154 | |||
155 | int da9052_enable_irq(struct da9052 *da9052, int irq); | ||
156 | int da9052_disable_irq(struct da9052 *da9052, int irq); | ||
157 | int da9052_disable_irq_nosync(struct da9052 *da9052, int irq); | ||
158 | |||
149 | #endif /* __MFD_DA9052_DA9052_H */ | 159 | #endif /* __MFD_DA9052_DA9052_H */ |