From 24525eb3cbb2fafed58141a5ea869fb5c8aa2eb6 Mon Sep 17 00:00:00 2001 From: Richard Fitzgerald Date: Fri, 4 Aug 2017 11:12:53 +0100 Subject: [PATCH] extcon: madera: Add a separate variable for short circuit impedance Add a separate variable to store the short circuit impedance leaving the hpdet_short_circuit_imp to reflect the value set through device tree. Change-Id: I7c919cabc4c9edbb943719bfc944cb30b6af4907 Signed-off-by: Richard Fitzgerald --- drivers/extcon/extcon-madera.c | 23 ++++++++++++++--------- include/linux/extcon/extcon-madera.h | 2 ++ 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/drivers/extcon/extcon-madera.c b/drivers/extcon/extcon-madera.c index 42f8c8918555..852fd726d1d2 100644 --- a/drivers/extcon/extcon-madera.c +++ b/drivers/extcon/extcon-madera.c @@ -730,8 +730,9 @@ static void madera_extcon_hp_clamp(struct madera_extcon *info, bool clamp) } /* Restore the desired state while not doing the clamp */ - if (!clamp && (madera_hohm_to_ohm(madera->hp_impedance_x100[0]) > - info->pdata->hpdet_short_circuit_imp) && !ep_sel) { + if (!clamp && + (madera->hp_impedance_x100[0]) > info->hpdet_short_x100) && + !ep_sel) { ret = regmap_update_bits(madera->regmap, MADERA_OUTPUT_ENABLES_1, (MADERA_OUT1L_ENA | @@ -1352,7 +1353,6 @@ static int madera_tune_headphone(struct madera_extcon *info, int reading) { struct madera *madera = info->madera; const struct madera_hp_tuning *tuning; - unsigned int short_imp = info->pdata->hpdet_short_circuit_imp; int n_tunings; int i, ret; @@ -1380,7 +1380,7 @@ static int madera_tune_headphone(struct madera_extcon *info, int reading) return 0; } - if (reading <= madera_ohm_to_hohm(short_imp)) { + if (reading <= info->hpdet_short_x100) { /* Headphones are always off here so just mark them */ dev_warn(info->dev, "Possible HP short, disabling\n"); return 0; @@ -2904,7 +2904,7 @@ static int madera_extcon_probe(struct platform_device *pdev) struct madera_extcon *info; unsigned int debounce_val, analog_val; int jack_irq_fall, jack_irq_rise; - int ret, mode, i, hpdet_short; + int ret, mode, i, hpdet_short_measured; /* quick exit if Madera irqchip driver hasn't completed probe */ if (!madera->irq_dev) { @@ -2991,15 +2991,20 @@ static int madera_extcon_probe(struct platform_device *pdev) if (!pdata->enabled || pdata->output == 0) return -ENODEV; /* no accdet output configured */ - hpdet_short = pdata->hpdet_short_circuit_imp + - madera_hohm_to_ohm(pdata->hpdet_ext_res_x100); + info->hpdet_short_x100 = + madera_ohm_to_hohm(pdata->hpdet_short_circuit_imp); - if (hpdet_short < MADERA_HP_SHORT_IMPEDANCE_MIN) { + /* Actual measured short is increased by external resistance */ + hpdet_short_measured = pdata->hpdet_short_circuit_imp + + madera_hohm_to_ohm(pdata->hpdet_ext_res_x100); + + if (hpdet_short_measured < MADERA_HP_SHORT_IMPEDANCE_MIN) { dev_warn(info->dev, "Increasing HP short circuit impedance from %d to %d\n", pdata->hpdet_short_circuit_imp, MADERA_HP_SHORT_IMPEDANCE_MIN); - pdata->hpdet_short_circuit_imp = MADERA_HP_SHORT_IMPEDANCE_MIN; + info->hpdet_short_x100 = + madera_ohm_to_hohm(MADERA_HP_SHORT_IMPEDANCE_MIN); } info->micvdd = devm_regulator_get(&pdev->dev, "MICVDD"); diff --git a/include/linux/extcon/extcon-madera.h b/include/linux/extcon/extcon-madera.h index 407c6df7d46e..0307cefafe1b 100644 --- a/include/linux/extcon/extcon-madera.h +++ b/include/linux/extcon/extcon-madera.h @@ -80,6 +80,8 @@ struct madera_extcon { unsigned int hpdet_init_range; const struct madera_hpdet_trims *hpdet_trims; + unsigned int hpdet_short_x100; + int micd_mode; const struct madera_micd_config *micd_modes; int num_micd_modes; -- 2.20.1