提交 4972a177 编写于 作者: C Clemens Ladisch 提交者: Takashi Iwai

[ALSA] oxygen: generalize DAC volume TLV handling

Add a pointer for DAC volume TLV data to the model structure so that the
model driver do not need to manually assign it in their control filter.
Signed-off-by: NClemens Ladisch <clemens@ladisch.de>
Signed-off-by: NTakashi Iwai <tiwai@suse.de>
上级 e983532e
...@@ -127,12 +127,8 @@ static const DECLARE_TLV_DB_LINEAR(ak4396_db_scale, TLV_DB_GAIN_MUTE, 0); ...@@ -127,12 +127,8 @@ static const DECLARE_TLV_DB_LINEAR(ak4396_db_scale, TLV_DB_GAIN_MUTE, 0);
static int hifier_control_filter(struct snd_kcontrol_new *template) static int hifier_control_filter(struct snd_kcontrol_new *template)
{ {
if (!strcmp(template->name, "Master Playback Volume")) { if (!strcmp(template->name, "Stereo Upmixing"))
template->access |= SNDRV_CTL_ELEM_ACCESS_TLV_READ;
template->tlv.p = ak4396_db_scale;
} else if (!strcmp(template->name, "Stereo Upmixing")) {
return 1; /* stereo only - we don't need upmixing */ return 1; /* stereo only - we don't need upmixing */
}
return 0; return 0;
} }
...@@ -148,6 +144,7 @@ static const struct oxygen_model model_hifier = { ...@@ -148,6 +144,7 @@ static const struct oxygen_model model_hifier = {
.set_adc_params = set_cs5340_params, .set_adc_params = set_cs5340_params,
.update_dac_volume = update_ak4396_volume, .update_dac_volume = update_ak4396_volume,
.update_dac_mute = update_ak4396_mute, .update_dac_mute = update_ak4396_mute,
.dac_tlv = ak4396_db_scale,
.model_data_size = sizeof(struct hifier_data), .model_data_size = sizeof(struct hifier_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
......
...@@ -249,27 +249,18 @@ static void set_ak5385_params(struct oxygen *chip, ...@@ -249,27 +249,18 @@ static void set_ak5385_params(struct oxygen *chip,
static const DECLARE_TLV_DB_LINEAR(ak4396_db_scale, TLV_DB_GAIN_MUTE, 0); static const DECLARE_TLV_DB_LINEAR(ak4396_db_scale, TLV_DB_GAIN_MUTE, 0);
static int ak4396_control_filter(struct snd_kcontrol_new *template)
{
if (!strcmp(template->name, "Master Playback Volume")) {
template->access |= SNDRV_CTL_ELEM_ACCESS_TLV_READ;
template->tlv.p = ak4396_db_scale;
}
return 0;
}
static const struct oxygen_model model_generic = { static const struct oxygen_model model_generic = {
.shortname = "C-Media CMI8788", .shortname = "C-Media CMI8788",
.longname = "C-Media Oxygen HD Audio", .longname = "C-Media Oxygen HD Audio",
.chip = "CMI8788", .chip = "CMI8788",
.owner = THIS_MODULE, .owner = THIS_MODULE,
.init = generic_init, .init = generic_init,
.control_filter = ak4396_control_filter,
.cleanup = generic_cleanup, .cleanup = generic_cleanup,
.set_dac_params = set_ak4396_params, .set_dac_params = set_ak4396_params,
.set_adc_params = set_wm8785_params, .set_adc_params = set_wm8785_params,
.update_dac_volume = update_ak4396_volume, .update_dac_volume = update_ak4396_volume,
.update_dac_mute = update_ak4396_mute, .update_dac_mute = update_ak4396_mute,
.dac_tlv = ak4396_db_scale,
.model_data_size = sizeof(struct generic_data), .model_data_size = sizeof(struct generic_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
...@@ -291,12 +282,12 @@ static const struct oxygen_model model_meridian = { ...@@ -291,12 +282,12 @@ static const struct oxygen_model model_meridian = {
.chip = "CMI8788", .chip = "CMI8788",
.owner = THIS_MODULE, .owner = THIS_MODULE,
.init = meridian_init, .init = meridian_init,
.control_filter = ak4396_control_filter,
.cleanup = generic_cleanup, .cleanup = generic_cleanup,
.set_dac_params = set_ak4396_params, .set_dac_params = set_ak4396_params,
.set_adc_params = set_ak5385_params, .set_adc_params = set_ak5385_params,
.update_dac_volume = update_ak4396_volume, .update_dac_volume = update_ak4396_volume,
.update_dac_mute = update_ak4396_mute, .update_dac_mute = update_ak4396_mute,
.dac_tlv = ak4396_db_scale,
.model_data_size = sizeof(struct generic_data), .model_data_size = sizeof(struct generic_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
......
...@@ -100,6 +100,7 @@ struct oxygen_model { ...@@ -100,6 +100,7 @@ struct oxygen_model {
void (*gpio_changed)(struct oxygen *chip); void (*gpio_changed)(struct oxygen *chip);
void (*ac97_switch)(struct oxygen *chip, void (*ac97_switch)(struct oxygen *chip,
unsigned int reg, unsigned int mute); unsigned int reg, unsigned int mute);
const unsigned int *dac_tlv;
size_t model_data_size; size_t model_data_size;
unsigned int pcm_dev_cfg; unsigned int pcm_dev_cfg;
u8 dac_channels; u8 dac_channels;
......
...@@ -941,6 +941,11 @@ static int add_controls(struct oxygen *chip, ...@@ -941,6 +941,11 @@ static int add_controls(struct oxygen *chip,
return err; return err;
if (err == 1) if (err == 1)
continue; continue;
if (!strcmp(template.name, "Master Playback Volume") &&
chip->model->dac_tlv) {
template.tlv.p = chip->model->dac_tlv;
template.access |= SNDRV_CTL_ELEM_ACCESS_TLV_READ;
}
ctl = snd_ctl_new1(&template, chip); ctl = snd_ctl_new1(&template, chip);
if (!ctl) if (!ctl)
return -ENOMEM; return -ENOMEM;
......
...@@ -502,24 +502,16 @@ static const DECLARE_TLV_DB_SCALE(cs4362a_db_scale, -12700, 100, 0); ...@@ -502,24 +502,16 @@ static const DECLARE_TLV_DB_SCALE(cs4362a_db_scale, -12700, 100, 0);
static int xonar_d2_control_filter(struct snd_kcontrol_new *template) static int xonar_d2_control_filter(struct snd_kcontrol_new *template)
{ {
if (!strcmp(template->name, "Master Playback Volume")) { if (!strncmp(template->name, "CD Capture ", 11))
template->access |= SNDRV_CTL_ELEM_ACCESS_TLV_READ;
template->tlv.p = pcm1796_db_scale;
} else if (!strncmp(template->name, "CD Capture ", 11)) {
/* CD in is actually connected to the video in pin */ /* CD in is actually connected to the video in pin */
template->private_value ^= AC97_CD ^ AC97_VIDEO; template->private_value ^= AC97_CD ^ AC97_VIDEO;
}
return 0; return 0;
} }
static int xonar_dx_control_filter(struct snd_kcontrol_new *template) static int xonar_dx_control_filter(struct snd_kcontrol_new *template)
{ {
if (!strcmp(template->name, "Master Playback Volume")) { if (!strncmp(template->name, "CD Capture ", 11))
template->access |= SNDRV_CTL_ELEM_ACCESS_TLV_READ;
template->tlv.p = cs4362a_db_scale;
} else if (!strncmp(template->name, "CD Capture ", 11)) {
return 1; /* no CD input */ return 1; /* no CD input */
}
return 0; return 0;
} }
...@@ -547,6 +539,7 @@ static const struct oxygen_model xonar_models[] = { ...@@ -547,6 +539,7 @@ static const struct oxygen_model xonar_models[] = {
.set_adc_params = set_cs53x1_params, .set_adc_params = set_cs53x1_params,
.update_dac_volume = update_pcm1796_volume, .update_dac_volume = update_pcm1796_volume,
.update_dac_mute = update_pcm1796_mute, .update_dac_mute = update_pcm1796_mute,
.dac_tlv = pcm1796_db_scale,
.model_data_size = sizeof(struct xonar_data), .model_data_size = sizeof(struct xonar_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
...@@ -575,6 +568,7 @@ static const struct oxygen_model xonar_models[] = { ...@@ -575,6 +568,7 @@ static const struct oxygen_model xonar_models[] = {
.update_dac_volume = update_pcm1796_volume, .update_dac_volume = update_pcm1796_volume,
.update_dac_mute = update_pcm1796_mute, .update_dac_mute = update_pcm1796_mute,
.gpio_changed = xonar_gpio_changed, .gpio_changed = xonar_gpio_changed,
.dac_tlv = pcm1796_db_scale,
.model_data_size = sizeof(struct xonar_data), .model_data_size = sizeof(struct xonar_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
...@@ -604,6 +598,7 @@ static const struct oxygen_model xonar_models[] = { ...@@ -604,6 +598,7 @@ static const struct oxygen_model xonar_models[] = {
.update_dac_mute = update_cs43xx_mute, .update_dac_mute = update_cs43xx_mute,
.gpio_changed = xonar_gpio_changed, .gpio_changed = xonar_gpio_changed,
.ac97_switch = xonar_dx_ac97_switch, .ac97_switch = xonar_dx_ac97_switch,
.dac_tlv = cs4362a_db_scale,
.model_data_size = sizeof(struct xonar_data), .model_data_size = sizeof(struct xonar_data),
.pcm_dev_cfg = PLAYBACK_0_TO_I2S | .pcm_dev_cfg = PLAYBACK_0_TO_I2S |
PLAYBACK_1_TO_SPDIF | PLAYBACK_1_TO_SPDIF |
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册