[PATCH] mux: suppress lookup errors for mux controls
From: Johan Hovold
Date: Mon Apr 14 2025 - 08:43:15 EST
Since commit eec611d26f84 ("ASoC: codecs: wcd938x: add mux control
support for hp audio mux") we have drivers looking up mux controls that
are optional. This results in errors incorrectly being logged on
machines like the Lenovo ThinkPad X13s where the mux is missing:
wcd938x_codec audio-codec: /audio-codec: failed to get mux-control (0)
Suppress the error message when lookup of mux controls fails and make
sure to return -ENOENT consistently also when looking up controls by
name so that consumer drivers can easily determine how to proceed.
Note that most current consumers already log mux lookup failures
themselves.
Fixes: eec611d26f84 ("ASoC: codecs: wcd938x: add mux control support for hp audio mux")
Link: https://lore.kernel.org/lkml/Z-z_ZAyVBK5ui50k@xxxxxxxxxxxxxxxxxxxx/
Signed-off-by: Johan Hovold <johan+linaro@xxxxxxxxxx>
---
drivers/mux/core.c | 16 ++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)
diff --git a/drivers/mux/core.c b/drivers/mux/core.c
index 02be4ba37257..b95bc03e3d6b 100644
--- a/drivers/mux/core.c
+++ b/drivers/mux/core.c
@@ -544,8 +544,13 @@ static struct mux_control *mux_get(struct device *dev, const char *mux_name,
index = of_property_match_string(np, "mux-control-names",
mux_name);
if (index < 0) {
- dev_err(dev, "mux controller '%s' not found\n",
- mux_name);
+ if (!state && index == -EINVAL)
+ index = -ENOENT;
+
+ if (index != -ENOENT) {
+ dev_err(dev, "mux controller '%s' not found\n",
+ mux_name);
+ }
return ERR_PTR(index);
}
}
@@ -559,8 +564,11 @@ static struct mux_control *mux_get(struct device *dev, const char *mux_name,
"mux-controls", "#mux-control-cells",
index, &args);
if (ret) {
- dev_err(dev, "%pOF: failed to get mux-%s %s(%i)\n",
- np, state ? "state" : "control", mux_name ?: "", index);
+ if (state || ret != -ENOENT) {
+ dev_err(dev, "%pOF: failed to get mux-%s %s(%i)\n",
+ np, state ? "state" : "control",
+ mux_name ?: "", index);
+ }
return ERR_PTR(ret);
}
--
2.49.0