sound fixes for 6.7-rc4
No surprise here, including only a collection of HD-audio device-specific small fixes. -----BEGIN PGP SIGNATURE----- iQJCBAABCAAsFiEEIXTw5fNLNI7mMiVaLtJE4w1nLE8FAmVpvSIOHHRpd2FpQHN1 c2UuZGUACgkQLtJE4w1nLE8PRA/+PQFZaI5L5tcEB9+mjH3TUVSYtbBweOBToEbg QFt3KNS550Q6Mcvnhrp1AH7amFkWt354e8iZz5tVAITrFkwkYWImlneZweCWQXeB /TvIViuUr8KMfl2eyAMVRUkuqQ7EoVrkL1uIjNWCernNUQqlc+oUTn6D42lxiwkG mQpzJL/MknSPV+31lv0wZyj7TDSCDPRhmX6Lu6FH+QbbhdZUGpl8etmUUYNa8D1G hh2tPjVGuUxZDcIYtVD3NIjOTFvTyVF3S+cxqW2WT1qs2ZmWH+nBBqZbkGva7gfB /s0TNTTOLq6VD58B5vf25D1AUVEMub5295PKrCnKfo2VO+/PMPQWXBS2pYuCey6y MZpqCKRStgBCCfCZg6byWiVKwqsSJJTvKlXAginYXuK/jFJhnJxqVRQ9Mc6Op81z +c1p0Zy9IEhTAdF2RLGw99zho1B5cx/zBGRvVwq0c9NV+LQwMoRsFKbPr6QAM65K bAb+3wVQ3cG1y8FVz3Amq5JfcbymJ15CLwI5nW3Op47MrUSsYXflbPfgExI7dRTH Xegm8jPbw8V9r66BYAATRQztENxQSGINL/0ngGAS4jEpKN2XTgjSJgBizBdvRis5 RbJERBICEUhFGlogREsareSkkoV20lgIxJ5Nc/uve4RtLaV8ovheTA48NspXZ8ld 6HlRRIg= =57FL -----END PGP SIGNATURE----- Merge tag 'sound-6.7-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound Pull sound fixes from Takashi Iwai: "No surprise here, including only a collection of HD-audio device-specific small fixes" * tag 'sound-6.7-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: hda: Disable power-save on KONTRON SinglePC ALSA: hda/realtek: Add supported ALC257 for ChromeOS ALSA: hda/realtek: Headset Mic VREF to 100% ALSA: hda: intel-nhlt: Ignore vbps when looking for DMIC 32 bps format ALSA: hda: cs35l56: Enable low-power hibernation mode on SPI ALSA: cs35l41: Fix for old systems which do not support command ALSA: hda: cs35l41: Remove unnecessary boolean state variable firmware_running ALSA: hda - Fix speaker and headset mic pin config for CHUWI CoreBook XPro
This commit is contained in:
commit
06a3c59f9c
@ -906,6 +906,6 @@ int cs35l41_init_boost(struct device *dev, struct regmap *regmap,
|
|||||||
bool cs35l41_safe_reset(struct regmap *regmap, enum cs35l41_boost_type b_type);
|
bool cs35l41_safe_reset(struct regmap *regmap, enum cs35l41_boost_type b_type);
|
||||||
int cs35l41_mdsync_up(struct regmap *regmap);
|
int cs35l41_mdsync_up(struct regmap *regmap);
|
||||||
int cs35l41_global_enable(struct device *dev, struct regmap *regmap, enum cs35l41_boost_type b_type,
|
int cs35l41_global_enable(struct device *dev, struct regmap *regmap, enum cs35l41_boost_type b_type,
|
||||||
int enable, bool firmware_running);
|
int enable, struct cs_dsp *dsp);
|
||||||
|
|
||||||
#endif /* __CS35L41_H */
|
#endif /* __CS35L41_H */
|
||||||
|
@ -238,7 +238,7 @@ EXPORT_SYMBOL(intel_nhlt_ssp_mclk_mask);
|
|||||||
|
|
||||||
static struct nhlt_specific_cfg *
|
static struct nhlt_specific_cfg *
|
||||||
nhlt_get_specific_cfg(struct device *dev, struct nhlt_fmt *fmt, u8 num_ch,
|
nhlt_get_specific_cfg(struct device *dev, struct nhlt_fmt *fmt, u8 num_ch,
|
||||||
u32 rate, u8 vbps, u8 bps)
|
u32 rate, u8 vbps, u8 bps, bool ignore_vbps)
|
||||||
{
|
{
|
||||||
struct nhlt_fmt_cfg *cfg = fmt->fmt_config;
|
struct nhlt_fmt_cfg *cfg = fmt->fmt_config;
|
||||||
struct wav_fmt *wfmt;
|
struct wav_fmt *wfmt;
|
||||||
@ -255,8 +255,12 @@ nhlt_get_specific_cfg(struct device *dev, struct nhlt_fmt *fmt, u8 num_ch,
|
|||||||
dev_dbg(dev, "Endpoint format: ch=%d fmt=%d/%d rate=%d\n",
|
dev_dbg(dev, "Endpoint format: ch=%d fmt=%d/%d rate=%d\n",
|
||||||
wfmt->channels, _vbps, _bps, wfmt->samples_per_sec);
|
wfmt->channels, _vbps, _bps, wfmt->samples_per_sec);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* When looking for exact match of configuration ignore the vbps
|
||||||
|
* from NHLT table when ignore_vbps is true
|
||||||
|
*/
|
||||||
if (wfmt->channels == num_ch && wfmt->samples_per_sec == rate &&
|
if (wfmt->channels == num_ch && wfmt->samples_per_sec == rate &&
|
||||||
vbps == _vbps && bps == _bps)
|
(ignore_vbps || vbps == _vbps) && bps == _bps)
|
||||||
return &cfg->config;
|
return &cfg->config;
|
||||||
|
|
||||||
cfg = (struct nhlt_fmt_cfg *)(cfg->config.caps + cfg->config.size);
|
cfg = (struct nhlt_fmt_cfg *)(cfg->config.caps + cfg->config.size);
|
||||||
@ -289,6 +293,7 @@ intel_nhlt_get_endpoint_blob(struct device *dev, struct nhlt_acpi_table *nhlt,
|
|||||||
{
|
{
|
||||||
struct nhlt_specific_cfg *cfg;
|
struct nhlt_specific_cfg *cfg;
|
||||||
struct nhlt_endpoint *epnt;
|
struct nhlt_endpoint *epnt;
|
||||||
|
bool ignore_vbps = false;
|
||||||
struct nhlt_fmt *fmt;
|
struct nhlt_fmt *fmt;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -298,7 +303,26 @@ intel_nhlt_get_endpoint_blob(struct device *dev, struct nhlt_acpi_table *nhlt,
|
|||||||
dev_dbg(dev, "Looking for configuration:\n");
|
dev_dbg(dev, "Looking for configuration:\n");
|
||||||
dev_dbg(dev, " vbus_id=%d link_type=%d dir=%d, dev_type=%d\n",
|
dev_dbg(dev, " vbus_id=%d link_type=%d dir=%d, dev_type=%d\n",
|
||||||
bus_id, link_type, dir, dev_type);
|
bus_id, link_type, dir, dev_type);
|
||||||
dev_dbg(dev, " ch=%d fmt=%d/%d rate=%d\n", num_ch, vbps, bps, rate);
|
if (link_type == NHLT_LINK_DMIC && bps == 32 && (vbps == 24 || vbps == 32)) {
|
||||||
|
/*
|
||||||
|
* The DMIC hardware supports only one type of 32 bits sample
|
||||||
|
* size, which is 24 bit sampling on the MSB side and bits[1:0]
|
||||||
|
* are used for indicating the channel number.
|
||||||
|
* It has been observed that some NHLT tables have the vbps
|
||||||
|
* specified as 32 while some uses 24.
|
||||||
|
* The format these variations describe are identical, the
|
||||||
|
* hardware is configured and behaves the same way.
|
||||||
|
* Note: when the samples assumed to be vbps=32 then the 'noise'
|
||||||
|
* introduced by the lower two bits (channel number) have no
|
||||||
|
* real life implication on audio quality.
|
||||||
|
*/
|
||||||
|
dev_dbg(dev,
|
||||||
|
" ch=%d fmt=%d rate=%d (vbps is ignored for DMIC 32bit format)\n",
|
||||||
|
num_ch, bps, rate);
|
||||||
|
ignore_vbps = true;
|
||||||
|
} else {
|
||||||
|
dev_dbg(dev, " ch=%d fmt=%d/%d rate=%d\n", num_ch, vbps, bps, rate);
|
||||||
|
}
|
||||||
dev_dbg(dev, "Endpoint count=%d\n", nhlt->endpoint_count);
|
dev_dbg(dev, "Endpoint count=%d\n", nhlt->endpoint_count);
|
||||||
|
|
||||||
epnt = (struct nhlt_endpoint *)nhlt->desc;
|
epnt = (struct nhlt_endpoint *)nhlt->desc;
|
||||||
@ -307,7 +331,8 @@ intel_nhlt_get_endpoint_blob(struct device *dev, struct nhlt_acpi_table *nhlt,
|
|||||||
if (nhlt_check_ep_match(dev, epnt, bus_id, link_type, dir, dev_type)) {
|
if (nhlt_check_ep_match(dev, epnt, bus_id, link_type, dir, dev_type)) {
|
||||||
fmt = (struct nhlt_fmt *)(epnt->config.caps + epnt->config.size);
|
fmt = (struct nhlt_fmt *)(epnt->config.caps + epnt->config.size);
|
||||||
|
|
||||||
cfg = nhlt_get_specific_cfg(dev, fmt, num_ch, rate, vbps, bps);
|
cfg = nhlt_get_specific_cfg(dev, fmt, num_ch, rate,
|
||||||
|
vbps, bps, ignore_vbps);
|
||||||
if (cfg)
|
if (cfg)
|
||||||
return cfg;
|
return cfg;
|
||||||
}
|
}
|
||||||
|
@ -504,7 +504,6 @@ static void cs35l41_shutdown_dsp(struct cs35l41_hda *cs35l41)
|
|||||||
|
|
||||||
cs_dsp_stop(dsp);
|
cs_dsp_stop(dsp);
|
||||||
cs_dsp_power_down(dsp);
|
cs_dsp_power_down(dsp);
|
||||||
cs35l41->firmware_running = false;
|
|
||||||
dev_dbg(cs35l41->dev, "Unloaded Firmware\n");
|
dev_dbg(cs35l41->dev, "Unloaded Firmware\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,7 +549,7 @@ static void cs35l41_hda_play_start(struct device *dev)
|
|||||||
|
|
||||||
cs35l41->playback_started = true;
|
cs35l41->playback_started = true;
|
||||||
|
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
regmap_multi_reg_write(reg, cs35l41_hda_config_dsp,
|
regmap_multi_reg_write(reg, cs35l41_hda_config_dsp,
|
||||||
ARRAY_SIZE(cs35l41_hda_config_dsp));
|
ARRAY_SIZE(cs35l41_hda_config_dsp));
|
||||||
regmap_update_bits(reg, CS35L41_PWR_CTRL2,
|
regmap_update_bits(reg, CS35L41_PWR_CTRL2,
|
||||||
@ -580,7 +579,7 @@ static void cs35l41_mute(struct device *dev, bool mute)
|
|||||||
regmap_multi_reg_write(reg, cs35l41_hda_mute, ARRAY_SIZE(cs35l41_hda_mute));
|
regmap_multi_reg_write(reg, cs35l41_hda_mute, ARRAY_SIZE(cs35l41_hda_mute));
|
||||||
} else {
|
} else {
|
||||||
dev_dbg(dev, "Unmuting\n");
|
dev_dbg(dev, "Unmuting\n");
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
regmap_multi_reg_write(reg, cs35l41_hda_unmute_dsp,
|
regmap_multi_reg_write(reg, cs35l41_hda_unmute_dsp,
|
||||||
ARRAY_SIZE(cs35l41_hda_unmute_dsp));
|
ARRAY_SIZE(cs35l41_hda_unmute_dsp));
|
||||||
} else {
|
} else {
|
||||||
@ -599,7 +598,7 @@ static void cs35l41_hda_play_done(struct device *dev)
|
|||||||
dev_dbg(dev, "Play (Complete)\n");
|
dev_dbg(dev, "Play (Complete)\n");
|
||||||
|
|
||||||
cs35l41_global_enable(dev, reg, cs35l41->hw_cfg.bst_type, 1,
|
cs35l41_global_enable(dev, reg, cs35l41->hw_cfg.bst_type, 1,
|
||||||
cs35l41->firmware_running);
|
&cs35l41->cs_dsp);
|
||||||
cs35l41_mute(dev, false);
|
cs35l41_mute(dev, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,7 +611,7 @@ static void cs35l41_hda_pause_start(struct device *dev)
|
|||||||
|
|
||||||
cs35l41_mute(dev, true);
|
cs35l41_mute(dev, true);
|
||||||
cs35l41_global_enable(dev, reg, cs35l41->hw_cfg.bst_type, 0,
|
cs35l41_global_enable(dev, reg, cs35l41->hw_cfg.bst_type, 0,
|
||||||
cs35l41->firmware_running);
|
&cs35l41->cs_dsp);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cs35l41_hda_pause_done(struct device *dev)
|
static void cs35l41_hda_pause_done(struct device *dev)
|
||||||
@ -625,7 +624,7 @@ static void cs35l41_hda_pause_done(struct device *dev)
|
|||||||
regmap_update_bits(reg, CS35L41_PWR_CTRL2, CS35L41_AMP_EN_MASK, 0 << CS35L41_AMP_EN_SHIFT);
|
regmap_update_bits(reg, CS35L41_PWR_CTRL2, CS35L41_AMP_EN_MASK, 0 << CS35L41_AMP_EN_SHIFT);
|
||||||
if (cs35l41->hw_cfg.bst_type == CS35L41_EXT_BOOST)
|
if (cs35l41->hw_cfg.bst_type == CS35L41_EXT_BOOST)
|
||||||
regmap_write(reg, CS35L41_GPIO1_CTRL1, 0x00000001);
|
regmap_write(reg, CS35L41_GPIO1_CTRL1, 0x00000001);
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
cs35l41_set_cspl_mbox_cmd(dev, reg, CSPL_MBOX_CMD_PAUSE);
|
cs35l41_set_cspl_mbox_cmd(dev, reg, CSPL_MBOX_CMD_PAUSE);
|
||||||
regmap_update_bits(reg, CS35L41_PWR_CTRL2,
|
regmap_update_bits(reg, CS35L41_PWR_CTRL2,
|
||||||
CS35L41_VMON_EN_MASK | CS35L41_IMON_EN_MASK,
|
CS35L41_VMON_EN_MASK | CS35L41_IMON_EN_MASK,
|
||||||
@ -675,7 +674,7 @@ static void cs35l41_hda_playback_hook(struct device *dev, int action)
|
|||||||
break;
|
break;
|
||||||
case HDA_GEN_PCM_ACT_CLOSE:
|
case HDA_GEN_PCM_ACT_CLOSE:
|
||||||
mutex_lock(&cs35l41->fw_mutex);
|
mutex_lock(&cs35l41->fw_mutex);
|
||||||
if (!cs35l41->firmware_running && cs35l41->request_fw_load &&
|
if (!cs35l41->cs_dsp.running && cs35l41->request_fw_load &&
|
||||||
!cs35l41->fw_request_ongoing) {
|
!cs35l41->fw_request_ongoing) {
|
||||||
dev_info(dev, "Requesting Firmware Load after HDA_GEN_PCM_ACT_CLOSE\n");
|
dev_info(dev, "Requesting Firmware Load after HDA_GEN_PCM_ACT_CLOSE\n");
|
||||||
cs35l41->fw_request_ongoing = true;
|
cs35l41->fw_request_ongoing = true;
|
||||||
@ -761,10 +760,9 @@ static int cs35l41_verify_id(struct cs35l41_hda *cs35l41, unsigned int *regid, u
|
|||||||
static int cs35l41_ready_for_reset(struct cs35l41_hda *cs35l41)
|
static int cs35l41_ready_for_reset(struct cs35l41_hda *cs35l41)
|
||||||
{
|
{
|
||||||
mutex_lock(&cs35l41->fw_mutex);
|
mutex_lock(&cs35l41->fw_mutex);
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
cs35l41->cs_dsp.running = false;
|
cs35l41->cs_dsp.running = false;
|
||||||
cs35l41->cs_dsp.booted = false;
|
cs35l41->cs_dsp.booted = false;
|
||||||
cs35l41->firmware_running = false;
|
|
||||||
}
|
}
|
||||||
regcache_mark_dirty(cs35l41->regmap);
|
regcache_mark_dirty(cs35l41->regmap);
|
||||||
mutex_unlock(&cs35l41->fw_mutex);
|
mutex_unlock(&cs35l41->fw_mutex);
|
||||||
@ -925,7 +923,7 @@ static int cs35l41_runtime_suspend(struct device *dev)
|
|||||||
|
|
||||||
mutex_lock(&cs35l41->fw_mutex);
|
mutex_lock(&cs35l41->fw_mutex);
|
||||||
|
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
ret = cs35l41_enter_hibernate(cs35l41->dev, cs35l41->regmap,
|
ret = cs35l41_enter_hibernate(cs35l41->dev, cs35l41->regmap,
|
||||||
cs35l41->hw_cfg.bst_type);
|
cs35l41->hw_cfg.bst_type);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -960,7 +958,7 @@ static int cs35l41_runtime_resume(struct device *dev)
|
|||||||
|
|
||||||
regcache_cache_only(cs35l41->regmap, false);
|
regcache_cache_only(cs35l41->regmap, false);
|
||||||
|
|
||||||
if (cs35l41->firmware_running) {
|
if (cs35l41->cs_dsp.running) {
|
||||||
ret = cs35l41_exit_hibernate(cs35l41->dev, cs35l41->regmap);
|
ret = cs35l41_exit_hibernate(cs35l41->dev, cs35l41->regmap);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_warn(cs35l41->dev, "Unable to exit Hibernate.");
|
dev_warn(cs35l41->dev, "Unable to exit Hibernate.");
|
||||||
@ -1052,8 +1050,6 @@ static int cs35l41_smart_amp(struct cs35l41_hda *cs35l41)
|
|||||||
goto clean_dsp;
|
goto clean_dsp;
|
||||||
}
|
}
|
||||||
|
|
||||||
cs35l41->firmware_running = true;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
clean_dsp:
|
clean_dsp:
|
||||||
@ -1063,10 +1059,10 @@ clean_dsp:
|
|||||||
|
|
||||||
static void cs35l41_load_firmware(struct cs35l41_hda *cs35l41, bool load)
|
static void cs35l41_load_firmware(struct cs35l41_hda *cs35l41, bool load)
|
||||||
{
|
{
|
||||||
if (cs35l41->firmware_running && !load) {
|
if (cs35l41->cs_dsp.running && !load) {
|
||||||
dev_dbg(cs35l41->dev, "Unloading Firmware\n");
|
dev_dbg(cs35l41->dev, "Unloading Firmware\n");
|
||||||
cs35l41_shutdown_dsp(cs35l41);
|
cs35l41_shutdown_dsp(cs35l41);
|
||||||
} else if (!cs35l41->firmware_running && load) {
|
} else if (!cs35l41->cs_dsp.running && load) {
|
||||||
dev_dbg(cs35l41->dev, "Loading Firmware\n");
|
dev_dbg(cs35l41->dev, "Loading Firmware\n");
|
||||||
cs35l41_smart_amp(cs35l41);
|
cs35l41_smart_amp(cs35l41);
|
||||||
} else {
|
} else {
|
||||||
@ -1346,7 +1342,7 @@ static int cs35l41_hda_bind(struct device *dev, struct device *master, void *mas
|
|||||||
cs35l41->acpi_subsystem_id, cs35l41->hw_cfg.bst_type,
|
cs35l41->acpi_subsystem_id, cs35l41->hw_cfg.bst_type,
|
||||||
cs35l41->hw_cfg.gpio1.func == CS35l41_VSPK_SWITCH,
|
cs35l41->hw_cfg.gpio1.func == CS35l41_VSPK_SWITCH,
|
||||||
cs35l41->hw_cfg.spk_pos ? 'R' : 'L',
|
cs35l41->hw_cfg.spk_pos ? 'R' : 'L',
|
||||||
cs35l41->firmware_running, cs35l41->speaker_id);
|
cs35l41->cs_dsp.running, cs35l41->speaker_id);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,10 @@ static int cs35l56_hda_spi_probe(struct spi_device *spi)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
cs35l56->base.dev = &spi->dev;
|
cs35l56->base.dev = &spi->dev;
|
||||||
|
|
||||||
|
#ifdef CS35L56_WAKE_HOLD_TIME_US
|
||||||
|
cs35l56->base.can_hibernate = true;
|
||||||
|
#endif
|
||||||
cs35l56->base.regmap = devm_regmap_init_spi(spi, &cs35l56_regmap_spi);
|
cs35l56->base.regmap = devm_regmap_init_spi(spi, &cs35l56_regmap_spi);
|
||||||
if (IS_ERR(cs35l56->base.regmap)) {
|
if (IS_ERR(cs35l56->base.regmap)) {
|
||||||
ret = PTR_ERR(cs35l56->base.regmap);
|
ret = PTR_ERR(cs35l56->base.regmap);
|
||||||
|
@ -2242,6 +2242,8 @@ static const struct snd_pci_quirk power_save_denylist[] = {
|
|||||||
SND_PCI_QUIRK(0x17aa, 0x36a7, "Lenovo C50 All in one", 0),
|
SND_PCI_QUIRK(0x17aa, 0x36a7, "Lenovo C50 All in one", 0),
|
||||||
/* https://bugs.launchpad.net/bugs/1821663 */
|
/* https://bugs.launchpad.net/bugs/1821663 */
|
||||||
SND_PCI_QUIRK(0x1631, 0xe017, "Packard Bell NEC IMEDIA 5204", 0),
|
SND_PCI_QUIRK(0x1631, 0xe017, "Packard Bell NEC IMEDIA 5204", 0),
|
||||||
|
/* KONTRON SinglePC may cause a stall at runtime resume */
|
||||||
|
SND_PCI_QUIRK(0x1734, 0x1232, "KONTRON SinglePC", 0),
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
#endif /* CONFIG_PM */
|
#endif /* CONFIG_PM */
|
||||||
|
@ -1987,6 +1987,7 @@ enum {
|
|||||||
ALC887_FIXUP_ASUS_AUDIO,
|
ALC887_FIXUP_ASUS_AUDIO,
|
||||||
ALC887_FIXUP_ASUS_HMIC,
|
ALC887_FIXUP_ASUS_HMIC,
|
||||||
ALCS1200A_FIXUP_MIC_VREF,
|
ALCS1200A_FIXUP_MIC_VREF,
|
||||||
|
ALC888VD_FIXUP_MIC_100VREF,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void alc889_fixup_coef(struct hda_codec *codec,
|
static void alc889_fixup_coef(struct hda_codec *codec,
|
||||||
@ -2540,6 +2541,13 @@ static const struct hda_fixup alc882_fixups[] = {
|
|||||||
{}
|
{}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
[ALC888VD_FIXUP_MIC_100VREF] = {
|
||||||
|
.type = HDA_FIXUP_PINCTLS,
|
||||||
|
.v.pins = (const struct hda_pintbl[]) {
|
||||||
|
{ 0x18, PIN_VREF100 }, /* headset mic */
|
||||||
|
{}
|
||||||
|
}
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
||||||
@ -2609,6 +2617,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
|||||||
SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC889_FIXUP_MBA11_VREF),
|
SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC889_FIXUP_MBA11_VREF),
|
||||||
|
|
||||||
SND_PCI_QUIRK(0x1071, 0x8258, "Evesham Voyaeger", ALC882_FIXUP_EAPD),
|
SND_PCI_QUIRK(0x1071, 0x8258, "Evesham Voyaeger", ALC882_FIXUP_EAPD),
|
||||||
|
SND_PCI_QUIRK(0x10ec, 0x12d8, "iBase Elo Touch", ALC888VD_FIXUP_MIC_100VREF),
|
||||||
SND_PCI_QUIRK(0x13fe, 0x1009, "Advantech MIT-W101", ALC886_FIXUP_EAPD),
|
SND_PCI_QUIRK(0x13fe, 0x1009, "Advantech MIT-W101", ALC886_FIXUP_EAPD),
|
||||||
SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte EP45-DS3/Z87X-UD3H", ALC889_FIXUP_FRONT_HP_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte EP45-DS3/Z87X-UD3H", ALC889_FIXUP_FRONT_HP_NO_PRESENCE),
|
||||||
SND_PCI_QUIRK(0x1458, 0xa0b8, "Gigabyte AZ370-Gaming", ALC1220_FIXUP_GB_DUAL_CODECS),
|
SND_PCI_QUIRK(0x1458, 0xa0b8, "Gigabyte AZ370-Gaming", ALC1220_FIXUP_GB_DUAL_CODECS),
|
||||||
@ -3256,6 +3265,7 @@ static void alc_disable_headset_jack_key(struct hda_codec *codec)
|
|||||||
case 0x10ec0230:
|
case 0x10ec0230:
|
||||||
case 0x10ec0236:
|
case 0x10ec0236:
|
||||||
case 0x10ec0256:
|
case 0x10ec0256:
|
||||||
|
case 0x10ec0257:
|
||||||
case 0x19e58326:
|
case 0x19e58326:
|
||||||
alc_write_coef_idx(codec, 0x48, 0x0);
|
alc_write_coef_idx(codec, 0x48, 0x0);
|
||||||
alc_update_coef_idx(codec, 0x49, 0x0045, 0x0);
|
alc_update_coef_idx(codec, 0x49, 0x0045, 0x0);
|
||||||
@ -3285,6 +3295,7 @@ static void alc_enable_headset_jack_key(struct hda_codec *codec)
|
|||||||
case 0x10ec0230:
|
case 0x10ec0230:
|
||||||
case 0x10ec0236:
|
case 0x10ec0236:
|
||||||
case 0x10ec0256:
|
case 0x10ec0256:
|
||||||
|
case 0x10ec0257:
|
||||||
case 0x19e58326:
|
case 0x19e58326:
|
||||||
alc_write_coef_idx(codec, 0x48, 0xd011);
|
alc_write_coef_idx(codec, 0x48, 0xd011);
|
||||||
alc_update_coef_idx(codec, 0x49, 0x007f, 0x0045);
|
alc_update_coef_idx(codec, 0x49, 0x007f, 0x0045);
|
||||||
@ -6496,6 +6507,7 @@ static void alc_combo_jack_hp_jd_restart(struct hda_codec *codec)
|
|||||||
case 0x10ec0236:
|
case 0x10ec0236:
|
||||||
case 0x10ec0255:
|
case 0x10ec0255:
|
||||||
case 0x10ec0256:
|
case 0x10ec0256:
|
||||||
|
case 0x10ec0257:
|
||||||
case 0x19e58326:
|
case 0x19e58326:
|
||||||
alc_update_coef_idx(codec, 0x1b, 0x8000, 1 << 15); /* Reset HP JD */
|
alc_update_coef_idx(codec, 0x1b, 0x8000, 1 << 15); /* Reset HP JD */
|
||||||
alc_update_coef_idx(codec, 0x1b, 0x8000, 0 << 15);
|
alc_update_coef_idx(codec, 0x1b, 0x8000, 0 << 15);
|
||||||
@ -7249,6 +7261,7 @@ enum {
|
|||||||
ALC290_FIXUP_SUBWOOFER_HSJACK,
|
ALC290_FIXUP_SUBWOOFER_HSJACK,
|
||||||
ALC269_FIXUP_THINKPAD_ACPI,
|
ALC269_FIXUP_THINKPAD_ACPI,
|
||||||
ALC269_FIXUP_DMIC_THINKPAD_ACPI,
|
ALC269_FIXUP_DMIC_THINKPAD_ACPI,
|
||||||
|
ALC269VB_FIXUP_CHUWI_COREBOOK_XPRO,
|
||||||
ALC255_FIXUP_ACER_MIC_NO_PRESENCE,
|
ALC255_FIXUP_ACER_MIC_NO_PRESENCE,
|
||||||
ALC255_FIXUP_ASUS_MIC_NO_PRESENCE,
|
ALC255_FIXUP_ASUS_MIC_NO_PRESENCE,
|
||||||
ALC255_FIXUP_DELL1_MIC_NO_PRESENCE,
|
ALC255_FIXUP_DELL1_MIC_NO_PRESENCE,
|
||||||
@ -7601,6 +7614,14 @@ static const struct hda_fixup alc269_fixups[] = {
|
|||||||
.type = HDA_FIXUP_FUNC,
|
.type = HDA_FIXUP_FUNC,
|
||||||
.v.func = alc269_fixup_pincfg_U7x7_headset_mic,
|
.v.func = alc269_fixup_pincfg_U7x7_headset_mic,
|
||||||
},
|
},
|
||||||
|
[ALC269VB_FIXUP_CHUWI_COREBOOK_XPRO] = {
|
||||||
|
.type = HDA_FIXUP_PINS,
|
||||||
|
.v.pins = (const struct hda_pintbl[]) {
|
||||||
|
{ 0x18, 0x03a19020 }, /* headset mic */
|
||||||
|
{ 0x1b, 0x90170150 }, /* speaker */
|
||||||
|
{ }
|
||||||
|
},
|
||||||
|
},
|
||||||
[ALC269_FIXUP_AMIC] = {
|
[ALC269_FIXUP_AMIC] = {
|
||||||
.type = HDA_FIXUP_PINS,
|
.type = HDA_FIXUP_PINS,
|
||||||
.v.pins = (const struct hda_pintbl[]) {
|
.v.pins = (const struct hda_pintbl[]) {
|
||||||
@ -10244,6 +10265,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
|||||||
SND_PCI_QUIRK(0x1d72, 0x1901, "RedmiBook 14", ALC256_FIXUP_ASUS_HEADSET_MIC),
|
SND_PCI_QUIRK(0x1d72, 0x1901, "RedmiBook 14", ALC256_FIXUP_ASUS_HEADSET_MIC),
|
||||||
SND_PCI_QUIRK(0x1d72, 0x1945, "Redmi G", ALC256_FIXUP_ASUS_HEADSET_MIC),
|
SND_PCI_QUIRK(0x1d72, 0x1945, "Redmi G", ALC256_FIXUP_ASUS_HEADSET_MIC),
|
||||||
SND_PCI_QUIRK(0x1d72, 0x1947, "RedmiBook Air", ALC255_FIXUP_XIAOMI_HEADSET_MIC),
|
SND_PCI_QUIRK(0x1d72, 0x1947, "RedmiBook Air", ALC255_FIXUP_XIAOMI_HEADSET_MIC),
|
||||||
|
SND_PCI_QUIRK(0x2782, 0x0232, "CHUWI CoreBook XPro", ALC269VB_FIXUP_CHUWI_COREBOOK_XPRO),
|
||||||
SND_PCI_QUIRK(0x8086, 0x2074, "Intel NUC 8", ALC233_FIXUP_INTEL_NUC8_DMIC),
|
SND_PCI_QUIRK(0x8086, 0x2074, "Intel NUC 8", ALC233_FIXUP_INTEL_NUC8_DMIC),
|
||||||
SND_PCI_QUIRK(0x8086, 0x2080, "Intel NUC 8 Rugged", ALC256_FIXUP_INTEL_NUC8_RUGGED),
|
SND_PCI_QUIRK(0x8086, 0x2080, "Intel NUC 8 Rugged", ALC256_FIXUP_INTEL_NUC8_RUGGED),
|
||||||
SND_PCI_QUIRK(0x8086, 0x2081, "Intel NUC 10", ALC256_FIXUP_INTEL_NUC10),
|
SND_PCI_QUIRK(0x8086, 0x2081, "Intel NUC 10", ALC256_FIXUP_INTEL_NUC10),
|
||||||
|
@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
#include <sound/cs35l41.h>
|
#include <sound/cs35l41.h>
|
||||||
|
|
||||||
|
#define CS35L41_FIRMWARE_OLD_VERSION 0x001C00 /* v0.28.0 */
|
||||||
|
|
||||||
static const struct reg_default cs35l41_reg[] = {
|
static const struct reg_default cs35l41_reg[] = {
|
||||||
{ CS35L41_PWR_CTRL1, 0x00000000 },
|
{ CS35L41_PWR_CTRL1, 0x00000000 },
|
||||||
{ CS35L41_PWR_CTRL2, 0x00000000 },
|
{ CS35L41_PWR_CTRL2, 0x00000000 },
|
||||||
@ -1214,7 +1216,7 @@ EXPORT_SYMBOL_GPL(cs35l41_safe_reset);
|
|||||||
* the PLL Lock interrupt, in the IRQ handler.
|
* the PLL Lock interrupt, in the IRQ handler.
|
||||||
*/
|
*/
|
||||||
int cs35l41_global_enable(struct device *dev, struct regmap *regmap, enum cs35l41_boost_type b_type,
|
int cs35l41_global_enable(struct device *dev, struct regmap *regmap, enum cs35l41_boost_type b_type,
|
||||||
int enable, bool firmware_running)
|
int enable, struct cs_dsp *dsp)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
unsigned int gpio1_func, pad_control, pwr_ctrl1, pwr_ctrl3, int_status, pup_pdn_mask;
|
unsigned int gpio1_func, pad_control, pwr_ctrl1, pwr_ctrl3, int_status, pup_pdn_mask;
|
||||||
@ -1309,7 +1311,7 @@ int cs35l41_global_enable(struct device *dev, struct regmap *regmap, enum cs35l4
|
|||||||
}
|
}
|
||||||
regmap_write(regmap, CS35L41_IRQ1_STATUS1, CS35L41_PUP_DONE_MASK);
|
regmap_write(regmap, CS35L41_IRQ1_STATUS1, CS35L41_PUP_DONE_MASK);
|
||||||
|
|
||||||
if (firmware_running)
|
if (dsp->running && dsp->fw_id_version > CS35L41_FIRMWARE_OLD_VERSION)
|
||||||
ret = cs35l41_set_cspl_mbox_cmd(dev, regmap,
|
ret = cs35l41_set_cspl_mbox_cmd(dev, regmap,
|
||||||
CSPL_MBOX_CMD_SPK_OUT_ENABLE);
|
CSPL_MBOX_CMD_SPK_OUT_ENABLE);
|
||||||
else
|
else
|
||||||
|
@ -519,11 +519,11 @@ static int cs35l41_main_amp_event(struct snd_soc_dapm_widget *w,
|
|||||||
ARRAY_SIZE(cs35l41_pup_patch));
|
ARRAY_SIZE(cs35l41_pup_patch));
|
||||||
|
|
||||||
ret = cs35l41_global_enable(cs35l41->dev, cs35l41->regmap, cs35l41->hw_cfg.bst_type,
|
ret = cs35l41_global_enable(cs35l41->dev, cs35l41->regmap, cs35l41->hw_cfg.bst_type,
|
||||||
1, cs35l41->dsp.cs_dsp.running);
|
1, &cs35l41->dsp.cs_dsp);
|
||||||
break;
|
break;
|
||||||
case SND_SOC_DAPM_POST_PMD:
|
case SND_SOC_DAPM_POST_PMD:
|
||||||
ret = cs35l41_global_enable(cs35l41->dev, cs35l41->regmap, cs35l41->hw_cfg.bst_type,
|
ret = cs35l41_global_enable(cs35l41->dev, cs35l41->regmap, cs35l41->hw_cfg.bst_type,
|
||||||
0, cs35l41->dsp.cs_dsp.running);
|
0, &cs35l41->dsp.cs_dsp);
|
||||||
|
|
||||||
regmap_multi_reg_write_bypassed(cs35l41->regmap,
|
regmap_multi_reg_write_bypassed(cs35l41->regmap,
|
||||||
cs35l41_pdn_patch,
|
cs35l41_pdn_patch,
|
||||||
|
Loading…
Reference in New Issue
Block a user