ALSA: hda: realtek: Re-work CS35L41 fixups to re-use for other amps
Slightly re-work the code around cs35l41_generic_fixup() and the component binding search so that it can be re-used for other amps that use the component binding mechanism. The match string is stored in struct scodec_dev_name instead of hardcoding it in the match function. The tas2781 does not use the amp index as part of the driver name match. But its match format string does not include a field for the index, so snprintf() would safely ignore the p->index argument. Because of this there is no need for a special match function for this case, the CS35L41 code can be re-used. Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com> Tested-by: Gergo Koteles <soyer@irl.hu> Link: https://lore.kernel.org/r/20240124112607.77614-2-rf@opensource.cirrus.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
1ac1b4b79b
commit
cf0d956635
@ -6841,11 +6841,12 @@ static void comp_generic_playback_hook(struct hda_pcm_stream *hinfo, struct hda_
|
||||
struct scodec_dev_name {
|
||||
const char *bus;
|
||||
const char *hid;
|
||||
const char *match_str;
|
||||
int index;
|
||||
};
|
||||
|
||||
/* match the device name in a slightly relaxed manner */
|
||||
static int comp_match_cs35l41_dev_name(struct device *dev, void *data)
|
||||
static int comp_match_dev_name(struct device *dev, void *data)
|
||||
{
|
||||
struct scodec_dev_name *p = data;
|
||||
const char *d = dev_name(dev);
|
||||
@ -6859,32 +6860,12 @@ static int comp_match_cs35l41_dev_name(struct device *dev, void *data)
|
||||
if (isdigit(d[n]))
|
||||
n++;
|
||||
/* the rest must be exact matching */
|
||||
snprintf(tmp, sizeof(tmp), "-%s:00-cs35l41-hda.%d", p->hid, p->index);
|
||||
snprintf(tmp, sizeof(tmp), p->match_str, p->hid, p->index);
|
||||
return !strcmp(d + n, tmp);
|
||||
}
|
||||
|
||||
static int comp_match_tas2781_dev_name(struct device *dev,
|
||||
void *data)
|
||||
{
|
||||
struct scodec_dev_name *p = data;
|
||||
const char *d = dev_name(dev);
|
||||
int n = strlen(p->bus);
|
||||
char tmp[32];
|
||||
|
||||
/* check the bus name */
|
||||
if (strncmp(d, p->bus, n))
|
||||
return 0;
|
||||
/* skip the bus number */
|
||||
if (isdigit(d[n]))
|
||||
n++;
|
||||
/* the rest must be exact matching */
|
||||
snprintf(tmp, sizeof(tmp), "-%s:00", p->hid);
|
||||
|
||||
return !strcmp(d + n, tmp);
|
||||
}
|
||||
|
||||
static void cs35l41_generic_fixup(struct hda_codec *cdc, int action, const char *bus,
|
||||
const char *hid, int count)
|
||||
static void comp_generic_fixup(struct hda_codec *cdc, int action, const char *bus,
|
||||
const char *hid, const char *match_str, int count)
|
||||
{
|
||||
struct device *dev = hda_codec_dev(cdc);
|
||||
struct alc_spec *spec = cdc->spec;
|
||||
@ -6899,10 +6880,11 @@ static void cs35l41_generic_fixup(struct hda_codec *cdc, int action, const char
|
||||
return;
|
||||
rec->bus = bus;
|
||||
rec->hid = hid;
|
||||
rec->match_str = match_str;
|
||||
rec->index = i;
|
||||
spec->comps[i].codec = cdc;
|
||||
component_match_add(dev, &spec->match,
|
||||
comp_match_cs35l41_dev_name, rec);
|
||||
comp_match_dev_name, rec);
|
||||
}
|
||||
ret = component_master_add_with_match(dev, &comp_master_ops, spec->match);
|
||||
if (ret)
|
||||
@ -6916,83 +6898,48 @@ static void cs35l41_generic_fixup(struct hda_codec *cdc, int action, const char
|
||||
}
|
||||
}
|
||||
|
||||
static void tas2781_generic_fixup(struct hda_codec *cdc, int action,
|
||||
const char *bus, const char *hid)
|
||||
{
|
||||
struct device *dev = hda_codec_dev(cdc);
|
||||
struct alc_spec *spec = cdc->spec;
|
||||
struct scodec_dev_name *rec;
|
||||
int ret;
|
||||
|
||||
switch (action) {
|
||||
case HDA_FIXUP_ACT_PRE_PROBE:
|
||||
rec = devm_kmalloc(dev, sizeof(*rec), GFP_KERNEL);
|
||||
if (!rec)
|
||||
return;
|
||||
rec->bus = bus;
|
||||
rec->hid = hid;
|
||||
rec->index = 0;
|
||||
spec->comps[0].codec = cdc;
|
||||
component_match_add(dev, &spec->match,
|
||||
comp_match_tas2781_dev_name, rec);
|
||||
ret = component_master_add_with_match(dev, &comp_master_ops,
|
||||
spec->match);
|
||||
if (ret)
|
||||
codec_err(cdc,
|
||||
"Fail to register component aggregator %d\n",
|
||||
ret);
|
||||
else
|
||||
spec->gen.pcm_playback_hook =
|
||||
comp_generic_playback_hook;
|
||||
break;
|
||||
case HDA_FIXUP_ACT_FREE:
|
||||
component_master_del(dev, &comp_master_ops);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void cs35l41_fixup_i2c_two(struct hda_codec *cdc, const struct hda_fixup *fix, int action)
|
||||
{
|
||||
cs35l41_generic_fixup(cdc, action, "i2c", "CSC3551", 2);
|
||||
comp_generic_fixup(cdc, action, "i2c", "CSC3551", "-%s:00-cs35l41-hda.%d", 2);
|
||||
}
|
||||
|
||||
static void cs35l41_fixup_i2c_four(struct hda_codec *cdc, const struct hda_fixup *fix, int action)
|
||||
{
|
||||
cs35l41_generic_fixup(cdc, action, "i2c", "CSC3551", 4);
|
||||
comp_generic_fixup(cdc, action, "i2c", "CSC3551", "-%s:00-cs35l41-hda.%d", 4);
|
||||
}
|
||||
|
||||
static void cs35l41_fixup_spi_two(struct hda_codec *codec, const struct hda_fixup *fix, int action)
|
||||
{
|
||||
cs35l41_generic_fixup(codec, action, "spi", "CSC3551", 2);
|
||||
comp_generic_fixup(codec, action, "spi", "CSC3551", "-%s:00-cs35l41-hda.%d", 2);
|
||||
}
|
||||
|
||||
static void cs35l41_fixup_spi_four(struct hda_codec *codec, const struct hda_fixup *fix, int action)
|
||||
{
|
||||
cs35l41_generic_fixup(codec, action, "spi", "CSC3551", 4);
|
||||
comp_generic_fixup(codec, action, "spi", "CSC3551", "-%s:00-cs35l41-hda.%d", 4);
|
||||
}
|
||||
|
||||
static void alc287_fixup_legion_16achg6_speakers(struct hda_codec *cdc, const struct hda_fixup *fix,
|
||||
int action)
|
||||
{
|
||||
cs35l41_generic_fixup(cdc, action, "i2c", "CLSA0100", 2);
|
||||
comp_generic_fixup(cdc, action, "i2c", "CLSA0100", "-%s:00-cs35l41-hda.%d", 2);
|
||||
}
|
||||
|
||||
static void alc287_fixup_legion_16ithg6_speakers(struct hda_codec *cdc, const struct hda_fixup *fix,
|
||||
int action)
|
||||
{
|
||||
cs35l41_generic_fixup(cdc, action, "i2c", "CLSA0101", 2);
|
||||
comp_generic_fixup(cdc, action, "i2c", "CLSA0101", "-%s:00-cs35l41-hda.%d", 2);
|
||||
}
|
||||
|
||||
static void tas2781_fixup_i2c(struct hda_codec *cdc,
|
||||
const struct hda_fixup *fix, int action)
|
||||
{
|
||||
tas2781_generic_fixup(cdc, action, "i2c", "TIAS2781");
|
||||
comp_generic_fixup(cdc, action, "i2c", "TIAS2781", "-%s:00", 1);
|
||||
}
|
||||
|
||||
static void yoga7_14arb7_fixup_i2c(struct hda_codec *cdc,
|
||||
const struct hda_fixup *fix, int action)
|
||||
{
|
||||
tas2781_generic_fixup(cdc, action, "i2c", "INT8866");
|
||||
comp_generic_fixup(cdc, action, "i2c", "INT8866", "-%s:00", 1);
|
||||
}
|
||||
|
||||
/* for alc295_fixup_hp_top_speakers */
|
||||
|
Loading…
x
Reference in New Issue
Block a user