aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2013-02-12 08:00:31 -0500
committerMark Brown <broonie@opensource.wolfsonmicro.com>2013-03-26 10:26:03 -0400
commit03409071ce2751ca124f35edebe4bcad52de22c2 (patch)
treea4f4f13fafcf8f34d0dc6b67e2ef662c13152f99
parent8bb9660418e05bb1845ac1a2428444d78e322cc7 (diff)
extcon: arizona: Factor out magic application
We have a very similar sequence doing magic writes in several places (one of which missed an update to interlock with the CODEC driver) so factor it out into a function. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r--drivers/extcon/extcon-arizona.c91
1 files changed, 36 insertions, 55 deletions
diff --git a/drivers/extcon/extcon-arizona.c b/drivers/extcon/extcon-arizona.c
index dc357a4051f6..896a923546e0 100644
--- a/drivers/extcon/extcon-arizona.c
+++ b/drivers/extcon/extcon-arizona.c
@@ -100,6 +100,39 @@ static const char *arizona_cable[] = {
100 NULL, 100 NULL,
101}; 101};
102 102
103static void arizona_extcon_do_magic(struct arizona_extcon_info *info,
104 unsigned int magic)
105{
106 struct arizona *arizona = info->arizona;
107 unsigned int val;
108 int ret;
109
110 mutex_lock(&arizona->dapm->card->dapm_mutex);
111
112 ret = regmap_read(arizona->regmap, ARIZONA_OUTPUT_ENABLES_1, &val);
113 if (ret != 0) {
114 dev_err(arizona->dev, "Failed to read output enables: %d\n",
115 ret);
116 val = 0;
117 }
118
119 if (!(val & (ARIZONA_OUT1L_ENA | ARIZONA_OUT1R_ENA))) {
120 ret = regmap_update_bits(arizona->regmap, 0x225, 0x4000,
121 magic);
122 if (ret != 0)
123 dev_warn(arizona->dev, "Failed to do magic: %d\n",
124 ret);
125
126 ret = regmap_update_bits(arizona->regmap, 0x226, 0x4000,
127 magic);
128 if (ret != 0)
129 dev_warn(arizona->dev, "Failed to do magic: %d\n",
130 ret);
131 }
132
133 mutex_unlock(&arizona->dapm->card->dapm_mutex);
134}
135
103static void arizona_extcon_set_mode(struct arizona_extcon_info *info, int mode) 136static void arizona_extcon_set_mode(struct arizona_extcon_info *info, int mode)
104{ 137{
105 struct arizona *arizona = info->arizona; 138 struct arizona *arizona = info->arizona;
@@ -484,7 +517,6 @@ static irqreturn_t arizona_hpdet_irq(int irq, void *data)
484 struct arizona *arizona = info->arizona; 517 struct arizona *arizona = info->arizona;
485 int id_gpio = arizona->pdata.hpdet_id_gpio; 518 int id_gpio = arizona->pdata.hpdet_id_gpio;
486 int report = ARIZONA_CABLE_HEADPHONE; 519 int report = ARIZONA_CABLE_HEADPHONE;
487 unsigned int val;
488 int ret, reading; 520 int ret, reading;
489 521
490 mutex_lock(&info->lock); 522 mutex_lock(&info->lock);
@@ -539,28 +571,7 @@ static irqreturn_t arizona_hpdet_irq(int irq, void *data)
539 dev_err(arizona->dev, "Failed to report HP/line: %d\n", 571 dev_err(arizona->dev, "Failed to report HP/line: %d\n",
540 ret); 572 ret);
541 573
542 mutex_lock(&arizona->dapm->card->dapm_mutex); 574 arizona_extcon_do_magic(info, 0);
543
544 ret = regmap_read(arizona->regmap, ARIZONA_OUTPUT_ENABLES_1, &val);
545 if (ret != 0) {
546 dev_err(arizona->dev, "Failed to read output enables: %d\n",
547 ret);
548 val = 0;
549 }
550
551 if (!(val & (ARIZONA_OUT1L_ENA | ARIZONA_OUT1R_ENA))) {
552 ret = regmap_update_bits(arizona->regmap, 0x225, 0x4000, 0);
553 if (ret != 0)
554 dev_warn(arizona->dev, "Failed to undo magic: %d\n",
555 ret);
556
557 ret = regmap_update_bits(arizona->regmap, 0x226, 0x4000, 0);
558 if (ret != 0)
559 dev_warn(arizona->dev, "Failed to undo magic: %d\n",
560 ret);
561 }
562
563 mutex_unlock(&arizona->dapm->card->dapm_mutex);
564 575
565done: 576done:
566 if (id_gpio) 577 if (id_gpio)
@@ -606,13 +617,7 @@ static void arizona_identify_headphone(struct arizona_extcon_info *info)
606 if (info->mic) 617 if (info->mic)
607 arizona_stop_mic(info); 618 arizona_stop_mic(info);
608 619
609 ret = regmap_update_bits(arizona->regmap, 0x225, 0x4000, 0x4000); 620 arizona_extcon_do_magic(info, 0x4000);
610 if (ret != 0)
611 dev_warn(arizona->dev, "Failed to do magic: %d\n", ret);
612
613 ret = regmap_update_bits(arizona->regmap, 0x226, 0x4000, 0x4000);
614 if (ret != 0)
615 dev_warn(arizona->dev, "Failed to do magic: %d\n", ret);
616 621
617 ret = regmap_update_bits(arizona->regmap, 622 ret = regmap_update_bits(arizona->regmap,
618 ARIZONA_ACCESSORY_DETECT_MODE_1, 623 ARIZONA_ACCESSORY_DETECT_MODE_1,
@@ -653,7 +658,6 @@ err:
653static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info) 658static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info)
654{ 659{
655 struct arizona *arizona = info->arizona; 660 struct arizona *arizona = info->arizona;
656 unsigned int val;
657 int ret; 661 int ret;
658 662
659 dev_dbg(arizona->dev, "Starting identification via HPDET\n"); 663 dev_dbg(arizona->dev, "Starting identification via HPDET\n");
@@ -665,30 +669,7 @@ static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info)
665 669
666 arizona_extcon_pulse_micbias(info); 670 arizona_extcon_pulse_micbias(info);
667 671
668 mutex_lock(&arizona->dapm->card->dapm_mutex); 672 arizona_extcon_do_magic(info, 0x4000);
669
670 ret = regmap_read(arizona->regmap, ARIZONA_OUTPUT_ENABLES_1, &val);
671 if (ret != 0) {
672 dev_err(arizona->dev, "Failed to read output enables: %d\n",
673 ret);
674 val = 0;
675 }
676
677 if (!(val & (ARIZONA_OUT1L_ENA | ARIZONA_OUT1R_ENA))) {
678 ret = regmap_update_bits(arizona->regmap, 0x225, 0x4000,
679 0x4000);
680 if (ret != 0)
681 dev_warn(arizona->dev, "Failed to do magic: %d\n",
682 ret);
683
684 ret = regmap_update_bits(arizona->regmap, 0x226, 0x4000,
685 0x4000);
686 if (ret != 0)
687 dev_warn(arizona->dev, "Failed to do magic: %d\n",
688 ret);
689 }
690
691 mutex_unlock(&arizona->dapm->card->dapm_mutex);
692 673
693 ret = regmap_update_bits(arizona->regmap, 674 ret = regmap_update_bits(arizona->regmap,
694 ARIZONA_ACCESSORY_DETECT_MODE_1, 675 ARIZONA_ACCESSORY_DETECT_MODE_1,