]> www.infradead.org Git - users/hch/misc.git/commitdiff
ASoC: Intel: bytcr_rt5651: Fix invalid quirk input mapping
authorTakashi Iwai <tiwai@suse.de>
Tue, 2 Sep 2025 17:18:21 +0000 (19:18 +0200)
committerMark Brown <broonie@kernel.org>
Mon, 8 Sep 2025 17:39:12 +0000 (18:39 +0100)
When an invalid value is passed via quirk option, currently
bytcr_rt5640 driver just ignores and leaves as is, which may lead to
unepxected results like OOB access.

This patch adds the sanity check and corrects the input mapping to the
certain default value if an invalid value is passed.

Fixes: 64484ccee7af ("ASoC: Intel: bytcr_rt5651: Set card long_name based on quirks")
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Message-ID: <20250902171826.27329-4-tiwai@suse.de>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/intel/boards/bytcr_rt5651.c

index 67c62844ca2a91500a87aaf74be39ef529be4246..604a35d380e9ab63190620faba7477a1d8d45461 100644 (file)
@@ -58,7 +58,8 @@ enum {
        BYT_RT5651_OVCD_SF_1P5  = (RT5651_OVCD_SF_1P5 << 13),
 };
 
-#define BYT_RT5651_MAP(quirk)          ((quirk) & GENMASK(3, 0))
+#define BYT_RT5651_MAP_MASK            GENMASK(3, 0)
+#define BYT_RT5651_MAP(quirk)          ((quirk) & BYT_RT5651_MAP_MASK)
 #define BYT_RT5651_JDSRC(quirk)                (((quirk) & GENMASK(7, 4)) >> 4)
 #define BYT_RT5651_OVCD_TH(quirk)      (((quirk) & GENMASK(12, 8)) >> 8)
 #define BYT_RT5651_OVCD_SF(quirk)      (((quirk) & GENMASK(14, 13)) >> 13)
@@ -100,14 +101,29 @@ MODULE_PARM_DESC(quirk, "Board-specific quirk override");
 
 static void log_quirks(struct device *dev)
 {
-       if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_DMIC_MAP)
+       int map;
+
+       map = BYT_RT5651_MAP(byt_rt5651_quirk);
+       switch (map) {
+       case BYT_RT5651_DMIC_MAP:
                dev_info(dev, "quirk DMIC_MAP enabled");
-       if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_IN1_MAP)
+               break;
+       case BYT_RT5651_IN1_MAP:
                dev_info(dev, "quirk IN1_MAP enabled");
-       if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_IN2_MAP)
+               break;
+       case BYT_RT5651_IN2_MAP:
                dev_info(dev, "quirk IN2_MAP enabled");
-       if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_IN1_IN2_MAP)
+               break;
+       case BYT_RT5651_IN1_IN2_MAP:
                dev_info(dev, "quirk IN1_IN2_MAP enabled");
+               break;
+       default:
+               dev_warn_once(dev, "quirk sets invalid input map: 0x%x, default to DMIC_MAP\n", map);
+               byt_rt5651_quirk &= ~BYT_RT5651_MAP_MASK;
+               byt_rt5651_quirk |= BYT_RT5651_DMIC_MAP;
+               break;
+       }
+
        if (BYT_RT5651_JDSRC(byt_rt5651_quirk)) {
                dev_info(dev, "quirk realtek,jack-detect-source %ld\n",
                         BYT_RT5651_JDSRC(byt_rt5651_quirk));