From: Srinivasa Rao Mandadapu <srivasam@codeaurora.org>
To: Stephen Boyd <swboyd@chromium.org>,
agross@kernel.org, alsa-devel@alsa-project.org,
bgoswami@codeaurora.org, bjorn.andersson@linaro.org,
broonie@kernel.org, devicetree@vger.kernel.org,
judyhsiao@chromium.org, lgirdwood@gmail.com,
linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org,
perex@perex.cz, plai@codeaurora.org, robh+dt@kernel.org,
rohitkr@codeaurora.org, srinivas.kandagatla@linaro.org,
tiwai@suse.com
Cc: Venkata Prasad Potturu <potturu@codeaurora.org>
Subject: Re: [PATCH v2] ASoC: codecs: MBHC: Add support for special headset
Date: Thu, 18 Nov 2021 16:21:09 +0530 [thread overview]
Message-ID: <38575d20-8e3f-2ba2-800d-e4b9b8ee0b68@codeaurora.org> (raw)
In-Reply-To: <CAE-0n52n7nscLfqt8-7+UmXdEh2suDNC-ywPRUZL8FdPONbhZQ@mail.gmail.com>
On 11/16/2021 5:06 AM, Stephen Boyd wrote:
Thanks for Your time Stephen!!!
As this patch is already accepted, will post your review comments as
additional patch.
> Quoting Srinivasa Rao Mandadapu (2021-11-14 23:11:28)
>> diff --git a/sound/soc/codecs/wcd-mbhc-v2.c b/sound/soc/codecs/wcd-mbhc-v2.c
>> index 405128c..d6545e4 100644
>> --- a/sound/soc/codecs/wcd-mbhc-v2.c
>> +++ b/sound/soc/codecs/wcd-mbhc-v2.c
>> @@ -1022,6 +1022,56 @@ static int wcd_mbhc_get_plug_from_adc(struct wcd_mbhc *mbhc, int adc_result)
>> return plug_type;
>> }
>>
>> +static int wcd_mbhc_get_spl_hs_thres(struct wcd_mbhc *mbhc)
>> +{
>> + int hs_threshold, micbias_mv;
>> +
>> + micbias_mv = wcd_mbhc_get_micbias(mbhc);
>> + if (mbhc->cfg->hs_thr && mbhc->cfg->micb_mv != WCD_MBHC_ADC_MICBIAS_MV) {
>> + if (mbhc->cfg->micb_mv == micbias_mv)
>> + hs_threshold = mbhc->cfg->hs_thr;
>> + else
>> + hs_threshold = (mbhc->cfg->hs_thr * micbias_mv) / mbhc->cfg->micb_mv;
>> + } else {
>> + hs_threshold = ((WCD_MBHC_ADC_HS_THRESHOLD_MV * micbias_mv) /
>> + WCD_MBHC_ADC_MICBIAS_MV);
>> + }
>> + return hs_threshold;
>> +}
>> +
>> +static bool wcd_mbhc_check_for_spl_headset(struct wcd_mbhc *mbhc)
>> +{
>> + bool is_spl_hs = false;
>> + int output_mv, hs_threshold, hph_threshold;
>> +
>> + if (!mbhc->mbhc_cb->mbhc_micb_ctrl_thr_mic)
>> + return false;
>> +
>> + /* Bump up MIC_BIAS2 to 2.7V */
>> + mbhc->mbhc_cb->mbhc_micb_ctrl_thr_mic(mbhc->component, MIC_BIAS_2, true);
>> + usleep_range(10000, 10100);
>> +
>> + output_mv = wcd_measure_adc_once(mbhc, MUX_CTL_IN2P);
>> + hs_threshold = wcd_mbhc_get_spl_hs_thres(mbhc);
>> + hph_threshold = wcd_mbhc_adc_get_hph_thres(mbhc);
>> +
>> + if (output_mv > hs_threshold || output_mv < hph_threshold) {
>> + if (mbhc->force_linein == true)
> Just 'if (mbhc->force_linein)'
>
> Also, if this is false, then false is set above. So checking for
> mbhc->force_linein is useless.
Okay. Will check and do changes.
>
>> + is_spl_hs = false;
>> + } else {
>> + is_spl_hs = true;
>> + }
>> +
>> + /* Back MIC_BIAS2 to 1.8v if the type is not special headset */
>> + if (!is_spl_hs) {
>> + mbhc->mbhc_cb->mbhc_micb_ctrl_thr_mic(mbhc->component, MIC_BIAS_2, false);
>> + /* Add 10ms delay for micbias to settle */
>> + usleep_range(10000, 10100);
>> + }
>> +
>> + return is_spl_hs;
>> +}
>> +
>> static void wcd_correct_swch_plug(struct work_struct *work)
>> {
>> struct wcd_mbhc *mbhc;
>> @@ -1029,12 +1079,14 @@ static void wcd_correct_swch_plug(struct work_struct *work)
>> enum wcd_mbhc_plug_type plug_type = MBHC_PLUG_TYPE_INVALID;
>> unsigned long timeout;
>> int pt_gnd_mic_swap_cnt = 0;
>> - int output_mv, cross_conn, hs_threshold, try = 0;
>> + int output_mv, cross_conn, hs_threshold, try = 0, micbias_mv;
>> + bool is_spl_hs = false;
>> bool is_pa_on;
>>
>> mbhc = container_of(work, struct wcd_mbhc, correct_plug_swch);
>> component = mbhc->component;
>>
>> + micbias_mv = wcd_mbhc_get_micbias(mbhc);
>> hs_threshold = wcd_mbhc_adc_get_hs_thres(mbhc);
>>
>> /* Mask ADC COMPLETE interrupt */
>> @@ -1097,6 +1149,16 @@ static void wcd_correct_swch_plug(struct work_struct *work)
>> plug_type = wcd_mbhc_get_plug_from_adc(mbhc, output_mv);
>> is_pa_on = wcd_mbhc_read_field(mbhc, WCD_MBHC_HPH_PA_EN);
>>
>> + if ((output_mv > hs_threshold) && (!is_spl_hs)) {
> Please drop useless parenthesis
Okay.
>
>> + is_spl_hs = wcd_mbhc_check_for_spl_headset(mbhc);
>> + output_mv = wcd_measure_adc_once(mbhc, MUX_CTL_IN2P);
>> +
>> + if (is_spl_hs) {
>> + hs_threshold = (hs_threshold * wcd_mbhc_get_micbias(mbhc)) /
>> + micbias_mv;
> Same. It may be good to split it to two assignments to clarify
> overflow/underflow.
Okay.
>
>> + }
>> + }
>> +
>> if ((output_mv <= hs_threshold) && !is_pa_on) {
>> /* Check for cross connection*/
>> cross_conn = wcd_check_cross_conn(mbhc);
>> @@ -1122,14 +1184,19 @@ static void wcd_correct_swch_plug(struct work_struct *work)
>> }
>> }
>>
>> - if (output_mv > hs_threshold) /* cable is extension cable */
>> + /* cable is extension cable */
>> + if (output_mv > hs_threshold || mbhc->force_linein == true)
> Drop the == true please.
Okay.
>
>> plug_type = MBHC_PLUG_TYPE_HIGH_HPH;
>> }
>>
>> wcd_mbhc_bcs_enable(mbhc, plug_type, true);
>>
>> - if (plug_type == MBHC_PLUG_TYPE_HIGH_HPH)
>> - wcd_mbhc_write_field(mbhc, WCD_MBHC_ELECT_ISRC_EN, 1);
>> + if (plug_type == MBHC_PLUG_TYPE_HIGH_HPH) {
>> + if (is_spl_hs)
>> + plug_type = MBHC_PLUG_TYPE_HEADSET;
>> + else
>> + wcd_mbhc_write_field(mbhc, WCD_MBHC_ELECT_ISRC_EN, 1);
>> + }
>>
>> wcd_mbhc_write_field(mbhc, WCD_MBHC_ADC_MODE, 0);
>> wcd_mbhc_write_field(mbhc, WCD_MBHC_ADC_EN, 0);
--
Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center, Inc.,
is a member of Code Aurora Forum, a Linux Foundation Collaborative Project.
prev parent reply other threads:[~2021-11-18 10:51 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-11-15 7:11 [PATCH v2] ASoC: codecs: MBHC: Add support for special headset Srinivasa Rao Mandadapu
2021-11-15 16:55 ` Mark Brown
2021-11-15 23:35 ` Mark Brown
2021-11-15 23:36 ` Stephen Boyd
2021-11-18 10:51 ` Srinivasa Rao Mandadapu [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=38575d20-8e3f-2ba2-800d-e4b9b8ee0b68@codeaurora.org \
--to=srivasam@codeaurora.org \
--cc=agross@kernel.org \
--cc=alsa-devel@alsa-project.org \
--cc=bgoswami@codeaurora.org \
--cc=bjorn.andersson@linaro.org \
--cc=broonie@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=judyhsiao@chromium.org \
--cc=lgirdwood@gmail.com \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=perex@perex.cz \
--cc=plai@codeaurora.org \
--cc=potturu@codeaurora.org \
--cc=robh+dt@kernel.org \
--cc=rohitkr@codeaurora.org \
--cc=srinivas.kandagatla@linaro.org \
--cc=swboyd@chromium.org \
--cc=tiwai@suse.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).