Commit 0fc1e447 authored by Hui Wang's avatar Hui Wang Committed by Takashi Iwai

ALSA: hda - Expand pin_match function to match upcoming new tbls

With the existing pintbl, we already have many entries in it. it is
better to figure out a new way to reduce the size of the pintbl.

We plan to define a new tbl which will match more machines with a
single tbl, To do that, this function doesn't need to match all valid
pins between machine and tbl, it just needs to match all pins defined
in the tbl with the machine.

And the plan is to move some tbls from pin_fixup_tbl to
fallback_pin_fixup_tbl gradually.
Signed-off-by: default avatarHui Wang <hui.wang@canonical.com>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 246bb4aa
...@@ -884,7 +884,8 @@ EXPORT_SYMBOL_GPL(snd_hda_apply_fixup); ...@@ -884,7 +884,8 @@ EXPORT_SYMBOL_GPL(snd_hda_apply_fixup);
#define IGNORE_SEQ_ASSOC (~(AC_DEFCFG_SEQUENCE | AC_DEFCFG_DEF_ASSOC)) #define IGNORE_SEQ_ASSOC (~(AC_DEFCFG_SEQUENCE | AC_DEFCFG_DEF_ASSOC))
static bool pin_config_match(struct hda_codec *codec, static bool pin_config_match(struct hda_codec *codec,
const struct hda_pintbl *pins) const struct hda_pintbl *pins,
bool match_all_pins)
{ {
const struct hda_pincfg *pin; const struct hda_pincfg *pin;
int i; int i;
...@@ -908,7 +909,8 @@ static bool pin_config_match(struct hda_codec *codec, ...@@ -908,7 +909,8 @@ static bool pin_config_match(struct hda_codec *codec,
return false; return false;
} }
} }
if (!found && (cfg & 0xf0000000) != 0x40000000) if (match_all_pins &&
!found && (cfg & 0xf0000000) != 0x40000000)
return false; return false;
} }
...@@ -920,10 +922,12 @@ static bool pin_config_match(struct hda_codec *codec, ...@@ -920,10 +922,12 @@ static bool pin_config_match(struct hda_codec *codec,
* @codec: the HDA codec * @codec: the HDA codec
* @pin_quirk: zero-terminated pin quirk list * @pin_quirk: zero-terminated pin quirk list
* @fixlist: the fixup list * @fixlist: the fixup list
* @match_all_pins: all valid pins must match with the table entries
*/ */
void snd_hda_pick_pin_fixup(struct hda_codec *codec, void snd_hda_pick_pin_fixup(struct hda_codec *codec,
const struct snd_hda_pin_quirk *pin_quirk, const struct snd_hda_pin_quirk *pin_quirk,
const struct hda_fixup *fixlist) const struct hda_fixup *fixlist,
bool match_all_pins)
{ {
const struct snd_hda_pin_quirk *pq; const struct snd_hda_pin_quirk *pq;
...@@ -935,7 +939,7 @@ void snd_hda_pick_pin_fixup(struct hda_codec *codec, ...@@ -935,7 +939,7 @@ void snd_hda_pick_pin_fixup(struct hda_codec *codec,
continue; continue;
if (codec->core.vendor_id != pq->codec) if (codec->core.vendor_id != pq->codec)
continue; continue;
if (pin_config_match(codec, pq->pins)) { if (pin_config_match(codec, pq->pins, match_all_pins)) {
codec->fixup_id = pq->value; codec->fixup_id = pq->value;
#ifdef CONFIG_SND_DEBUG_VERBOSE #ifdef CONFIG_SND_DEBUG_VERBOSE
codec->fixup_name = pq->name; codec->fixup_name = pq->name;
......
...@@ -361,7 +361,8 @@ void snd_hda_pick_fixup(struct hda_codec *codec, ...@@ -361,7 +361,8 @@ void snd_hda_pick_fixup(struct hda_codec *codec,
const struct hda_fixup *fixlist); const struct hda_fixup *fixlist);
void snd_hda_pick_pin_fixup(struct hda_codec *codec, void snd_hda_pick_pin_fixup(struct hda_codec *codec,
const struct snd_hda_pin_quirk *pin_quirk, const struct snd_hda_pin_quirk *pin_quirk,
const struct hda_fixup *fixlist); const struct hda_fixup *fixlist,
bool match_all_pins);
/* helper macros to retrieve pin default-config values */ /* helper macros to retrieve pin default-config values */
#define get_defcfg_connect(cfg) \ #define get_defcfg_connect(cfg) \
......
...@@ -7958,7 +7958,7 @@ static int patch_alc269(struct hda_codec *codec) ...@@ -7958,7 +7958,7 @@ static int patch_alc269(struct hda_codec *codec)
snd_hda_pick_fixup(codec, alc269_fixup_models, snd_hda_pick_fixup(codec, alc269_fixup_models,
alc269_fixup_tbl, alc269_fixups); alc269_fixup_tbl, alc269_fixups);
snd_hda_pick_pin_fixup(codec, alc269_pin_fixup_tbl, alc269_fixups); snd_hda_pick_pin_fixup(codec, alc269_pin_fixup_tbl, alc269_fixups, true);
snd_hda_pick_fixup(codec, NULL, alc269_fixup_vendor_tbl, snd_hda_pick_fixup(codec, NULL, alc269_fixup_vendor_tbl,
alc269_fixups); alc269_fixups);
snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
...@@ -8943,7 +8943,7 @@ static int patch_alc662(struct hda_codec *codec) ...@@ -8943,7 +8943,7 @@ static int patch_alc662(struct hda_codec *codec)
snd_hda_pick_fixup(codec, alc662_fixup_models, snd_hda_pick_fixup(codec, alc662_fixup_models,
alc662_fixup_tbl, alc662_fixups); alc662_fixup_tbl, alc662_fixups);
snd_hda_pick_pin_fixup(codec, alc662_pin_fixup_tbl, alc662_fixups); snd_hda_pick_pin_fixup(codec, alc662_pin_fixup_tbl, alc662_fixups, true);
snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE); snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
alc_auto_parse_customize_define(codec); alc_auto_parse_customize_define(codec);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment