From: Sasha Levin <sashal@kernel.org>
To: patches@lists.linux.dev, stable@vger.kernel.org
Cc: Jack Yu <jack.yu@realtek.com>, Mark Brown <broonie@kernel.org>,
Sasha Levin <sashal@kernel.org>,
oder_chiou@realtek.com
Subject: [PATCH AUTOSEL 6.16-6.1] ASoC: rt5682s: Adjust SAR ADC button mode to fix noise issue
Date: Mon, 22 Sep 2025 13:57:43 -0400 [thread overview]
Message-ID: <20250922175751.3747114-12-sashal@kernel.org> (raw)
In-Reply-To: <20250922175751.3747114-1-sashal@kernel.org>
From: Jack Yu <jack.yu@realtek.com>
[ Upstream commit 1dd28fd86c3fa4e395031dd6f2ba920242107010 ]
Adjust register settings for SAR adc button detection mode
to fix noise issue in headset.
Signed-off-by: Jack Yu <jack.yu@realtek.com>
Link: https://patch.msgid.link/766cd1d2dd7a403ba65bb4cc44845f71@realtek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
LLM Generated explanations, may be completely bogus:
## Backport Status: YES (with caveats)
After conducting an exhaustive investigation of this commit, including
deep analysis of the rt5682s driver history, bug reports, technical
implementation, and regression risks, I recommend this commit **should
be backported** to stable kernels, but with important considerations.
### Why This Should Be Backported:
1. **Fixes a Real User-Facing Bug**: The commit addresses an audible
"Zizi" noise issue that occurs when systems resume from sleep with
headsets connected - a common scenario that significantly degrades
audio quality.
2. **Meets Stable Criteria**:
- Fixes a real bug that bothers people (audible noise corruption)
- Small, contained change (~30 lines modified)
- Limited to a single driver file (rt5682s.c)
- Authored and tested by Realtek (the codec manufacturer)
- Reviewed and signed-off by Mark Brown (ALSA subsystem maintainer)
3. **Widespread Impact**: Affects multiple device types including:
- Chromebooks with Qualcomm/MediaTek processors
- Various x86 laptops with RT5682S codec
- Devices commonly used in education/enterprise where audio quality
is critical
4. **Root Cause Fix**: Addresses the underlying register configuration
issue rather than working around symptoms.
### Important Caveats and Risks:
1. **Power Consumption Trade-off**: The fix changes from power-saving
mode (`SAR_BUTDET_POW_SAV`) to normal mode (`SAR_BUTDET_POW_NORM`),
which will increase idle power consumption when headsets are
connected. This could impact battery life on mobile devices.
2. **Button Detection Changes**: Disabling fast-off mode (`FAST_OFF_EN`
→ `FAST_OFF_DIS`) and inverting polarity (`POL_FAST_OFF_HIGH` →
`POL_FAST_OFF_LOW`) may affect button press timing and detection
reliability, particularly for rapid button sequences.
3. **No Explicit Stable Tag**: The original commit lacks a "Cc: stable"
tag, suggesting it wasn't initially considered for backporting.
### Recommendation:
Given that this fixes a significant audio quality issue that directly
impacts user experience, and the changes are well-contained within a
single codec driver, the benefits outweigh the risks. The power
consumption increase is an acceptable trade-off for eliminating audible
noise that makes audio unusable in certain scenarios.
**Backport with these conditions**:
- Include in release notes that power consumption may increase slightly
with connected headsets
- Recommend thorough testing on affected platforms before deployment
- Monitor for any button detection regression reports post-backport
The fix is particularly important for Chromebooks and educational
devices where audio quality during video calls and multimedia learning
is essential.
sound/soc/codecs/rt5682s.c | 17 +++++++++--------
1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/sound/soc/codecs/rt5682s.c b/sound/soc/codecs/rt5682s.c
index 73c4b3c31f8c4..d44f7574631dc 100644
--- a/sound/soc/codecs/rt5682s.c
+++ b/sound/soc/codecs/rt5682s.c
@@ -653,14 +653,15 @@ static void rt5682s_sar_power_mode(struct snd_soc_component *component, int mode
switch (mode) {
case SAR_PWR_SAVING:
snd_soc_component_update_bits(component, RT5682S_CBJ_CTRL_3,
- RT5682S_CBJ_IN_BUF_MASK, RT5682S_CBJ_IN_BUF_DIS);
+ RT5682S_CBJ_IN_BUF_MASK, RT5682S_CBJ_IN_BUF_EN);
snd_soc_component_update_bits(component, RT5682S_CBJ_CTRL_1,
- RT5682S_MB1_PATH_MASK | RT5682S_MB2_PATH_MASK,
- RT5682S_CTRL_MB1_REG | RT5682S_CTRL_MB2_REG);
+ RT5682S_MB1_PATH_MASK | RT5682S_MB2_PATH_MASK |
+ RT5682S_VREF_POW_MASK, RT5682S_CTRL_MB1_FSM |
+ RT5682S_CTRL_MB2_FSM | RT5682S_VREF_POW_FSM);
snd_soc_component_update_bits(component, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_BUTDET_MASK | RT5682S_SAR_BUTDET_POW_MASK |
RT5682S_SAR_SEL_MB1_2_CTL_MASK, RT5682S_SAR_BUTDET_DIS |
- RT5682S_SAR_BUTDET_POW_SAV | RT5682S_SAR_SEL_MB1_2_MANU);
+ RT5682S_SAR_BUTDET_POW_NORM | RT5682S_SAR_SEL_MB1_2_MANU);
usleep_range(5000, 5500);
snd_soc_component_update_bits(component, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_BUTDET_MASK, RT5682S_SAR_BUTDET_EN);
@@ -688,7 +689,7 @@ static void rt5682s_sar_power_mode(struct snd_soc_component *component, int mode
snd_soc_component_update_bits(component, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_BUTDET_MASK | RT5682S_SAR_BUTDET_POW_MASK |
RT5682S_SAR_SEL_MB1_2_CTL_MASK, RT5682S_SAR_BUTDET_DIS |
- RT5682S_SAR_BUTDET_POW_SAV | RT5682S_SAR_SEL_MB1_2_MANU);
+ RT5682S_SAR_BUTDET_POW_NORM | RT5682S_SAR_SEL_MB1_2_MANU);
break;
default:
dev_err(component->dev, "Invalid SAR Power mode: %d\n", mode);
@@ -725,7 +726,7 @@ static void rt5682s_disable_push_button_irq(struct snd_soc_component *component)
snd_soc_component_update_bits(component, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_BUTDET_MASK | RT5682S_SAR_BUTDET_POW_MASK |
RT5682S_SAR_SEL_MB1_2_CTL_MASK, RT5682S_SAR_BUTDET_DIS |
- RT5682S_SAR_BUTDET_POW_SAV | RT5682S_SAR_SEL_MB1_2_MANU);
+ RT5682S_SAR_BUTDET_POW_NORM | RT5682S_SAR_SEL_MB1_2_MANU);
}
/**
@@ -786,7 +787,7 @@ static int rt5682s_headset_detect(struct snd_soc_component *component, int jack_
jack_type = SND_JACK_HEADSET;
snd_soc_component_write(component, RT5682S_SAR_IL_CMD_3, 0x024c);
snd_soc_component_update_bits(component, RT5682S_CBJ_CTRL_1,
- RT5682S_FAST_OFF_MASK, RT5682S_FAST_OFF_EN);
+ RT5682S_FAST_OFF_MASK, RT5682S_FAST_OFF_DIS);
snd_soc_component_update_bits(component, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_SEL_MB1_2_MASK, val << RT5682S_SAR_SEL_MB1_2_SFT);
rt5682s_enable_push_button_irq(component);
@@ -966,7 +967,7 @@ static int rt5682s_set_jack_detect(struct snd_soc_component *component,
RT5682S_EMB_JD_MASK | RT5682S_DET_TYPE |
RT5682S_POL_FAST_OFF_MASK | RT5682S_MIC_CAP_MASK,
RT5682S_EMB_JD_EN | RT5682S_DET_TYPE |
- RT5682S_POL_FAST_OFF_HIGH | RT5682S_MIC_CAP_HS);
+ RT5682S_POL_FAST_OFF_LOW | RT5682S_MIC_CAP_HS);
regmap_update_bits(rt5682s->regmap, RT5682S_SAR_IL_CMD_1,
RT5682S_SAR_POW_MASK, RT5682S_SAR_POW_EN);
regmap_update_bits(rt5682s->regmap, RT5682S_GPIO_CTRL_1,
--
2.51.0
prev parent reply other threads:[~2025-09-22 17:58 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-22 17:57 [PATCH AUTOSEL 6.16-6.1] btrfs: ref-verify: handle damaged extent root tree Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-6.12] platform/x86/amd/pmf: Support new ACPI ID AMDI0108 Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16] gpiolib: acpi: Ignore touchpad wakeup on GPD G1619-05 Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16] platform/x86: oxpec: Add support for OneXPlayer X1Pro EVA-02 Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-6.6] ASoC: qcom: sc8280xp: Enable DAI format configuration for MI2S interfaces Sasha Levin
2025-09-23 7:17 ` Johan Hovold
2025-09-25 1:09 ` Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-6.6] ASoC: amd: acp: Adjust pdm gain value Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16] drm/amdgpu/gfx11: Add Cleaner Shader Support for GFX11.0.1/11.0.4 GPUs Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-5.4] perf subcmd: avoid crash in exclude_cmds when excludes is empty Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16] ASoC: rt712: avoid skipping the blind write Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-6.6] platform/x86/amd/pmc: Add MECHREVO Yilong15Pro to spurious_8042 list Sasha Levin
2025-09-22 17:57 ` [PATCH AUTOSEL 6.16-5.4] dm-integrity: limit MAX_TAG_SIZE to 255 Sasha Levin
2025-09-22 17:57 ` Sasha Levin [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=20250922175751.3747114-12-sashal@kernel.org \
--to=sashal@kernel.org \
--cc=broonie@kernel.org \
--cc=jack.yu@realtek.com \
--cc=oder_chiou@realtek.com \
--cc=patches@lists.linux.dev \
--cc=stable@vger.kernel.org \
/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).