Skip to content

Commit f28ad47

Browse files
committed
Merge tag 'sound-6.17-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound
Pull sound fixes from Takashi Iwai: "Only small fixes. - ASoC Cirrus codec fixes - A regression fix for the recent TAS2781 codec refactoring - A fix for user-timer error handling - Fixes for USB-audio descriptor validators - Usual HD-audio and ASoC device-specific quirks" * tag 'sound-6.17-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: usb-audio: Use correct sub-type for UAC3 feature unit validation ALSA: timer: fix ida_free call while not allocated ASoC: cs35l56: Remove SoundWire Clock Divider workaround for CS35L63 ASoC: cs35l56: Handle new algorithms IDs for CS35L63 ASoC: cs35l56: Update Firmware Addresses for CS35L63 for production silicon ALSA: hda: tas2781: Fix wrong reference of tasdevice_priv ALSA: hda/realtek: Audio disappears on HP 15-fc000 after warm boot again ALSA: hda/realtek: Fix headset mic on ASUS Zenbook 14 ASoC: codecs: ES9389: Modify the standby configuration ALSA: usb-audio: Fix size validation in convert_chmap_v3() ALSA: hda/tas2781: Add name prefix tas2781 for tas2781's dvc_tlv and amp_vol_tlv ALSA: hda/realtek: Add support for HP EliteBook x360 830 G6 and EliteBook 830 G6
2 parents 3cfcd57 + 8410fe8 commit f28ad47

14 files changed

Lines changed: 68 additions & 101 deletions

File tree

include/sound/cs35l56.h

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -107,8 +107,8 @@
107107
#define CS35L56_DSP1_PMEM_5114 0x3804FE8
108108

109109
#define CS35L63_DSP1_FW_VER CS35L56_DSP1_FW_VER
110-
#define CS35L63_DSP1_HALO_STATE 0x280396C
111-
#define CS35L63_DSP1_PM_CUR_STATE 0x28042C8
110+
#define CS35L63_DSP1_HALO_STATE 0x2803C04
111+
#define CS35L63_DSP1_PM_CUR_STATE 0x2804518
112112
#define CS35L63_PROTECTION_STATUS 0x340009C
113113
#define CS35L63_TRANSDUCER_ACTUAL_PS 0x34000F4
114114
#define CS35L63_MAIN_RENDER_USER_MUTE 0x3400020
@@ -306,6 +306,7 @@ struct cs35l56_base {
306306
struct gpio_desc *reset_gpio;
307307
struct cs35l56_spi_payload *spi_payload_buf;
308308
const struct cs35l56_fw_reg *fw_reg;
309+
const struct cirrus_amp_cal_controls *calibration_controls;
309310
};
310311

311312
static inline bool cs35l56_is_otp_register(unsigned int reg)

include/sound/tas2781-tlv.h

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
//
33
// ALSA SoC Texas Instruments TAS2781 Audio Smart Amplifier
44
//
5-
// Copyright (C) 2022 - 2024 Texas Instruments Incorporated
5+
// Copyright (C) 2022 - 2025 Texas Instruments Incorporated
66
// https://www.ti.com
77
//
88
// The TAS2781 driver implements a flexible and configurable
@@ -15,7 +15,7 @@
1515
#ifndef __TAS2781_TLV_H__
1616
#define __TAS2781_TLV_H__
1717

18-
static const __maybe_unused DECLARE_TLV_DB_SCALE(dvc_tlv, -10000, 50, 0);
19-
static const __maybe_unused DECLARE_TLV_DB_SCALE(amp_vol_tlv, 1100, 50, 0);
18+
static const __maybe_unused DECLARE_TLV_DB_SCALE(tas2781_dvc_tlv, -10000, 50, 0);
19+
static const __maybe_unused DECLARE_TLV_DB_SCALE(tas2781_amp_tlv, 1100, 50, 0);
2020

2121
#endif

sound/core/timer.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2139,14 +2139,14 @@ static int snd_utimer_create(struct snd_timer_uinfo *utimer_info,
21392139
goto err_take_id;
21402140
}
21412141

2142+
utimer->id = utimer_id;
2143+
21422144
utimer->name = kasprintf(GFP_KERNEL, "snd-utimer%d", utimer_id);
21432145
if (!utimer->name) {
21442146
err = -ENOMEM;
21452147
goto err_get_name;
21462148
}
21472149

2148-
utimer->id = utimer_id;
2149-
21502150
tid.dev_sclass = SNDRV_TIMER_SCLASS_APPLICATION;
21512151
tid.dev_class = SNDRV_TIMER_CLASS_GLOBAL;
21522152
tid.card = -1;

sound/hda/codecs/realtek/alc269.c

Lines changed: 22 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -510,6 +510,15 @@ static void alc256_shutup(struct hda_codec *codec)
510510
hp_pin = 0x21;
511511

512512
alc_update_coefex_idx(codec, 0x57, 0x04, 0x0007, 0x1); /* Low power */
513+
514+
/* 3k pull low control for Headset jack. */
515+
/* NOTE: call this before clearing the pin, otherwise codec stalls */
516+
/* If disable 3k pulldown control for alc257, the Mic detection will not work correctly
517+
* when booting with headset plugged. So skip setting it for the codec alc257
518+
*/
519+
if (spec->en_3kpull_low)
520+
alc_update_coef_idx(codec, 0x46, 0, 3 << 12);
521+
513522
hp_pin_sense = snd_hda_jack_detect(codec, hp_pin);
514523

515524
if (hp_pin_sense) {
@@ -520,14 +529,6 @@ static void alc256_shutup(struct hda_codec *codec)
520529

521530
msleep(75);
522531

523-
/* 3k pull low control for Headset jack. */
524-
/* NOTE: call this before clearing the pin, otherwise codec stalls */
525-
/* If disable 3k pulldown control for alc257, the Mic detection will not work correctly
526-
* when booting with headset plugged. So skip setting it for the codec alc257
527-
*/
528-
if (spec->en_3kpull_low)
529-
alc_update_coef_idx(codec, 0x46, 0, 3 << 12);
530-
531532
if (!spec->no_shutup_pins)
532533
snd_hda_codec_write(codec, hp_pin, 0,
533534
AC_VERB_SET_PIN_WIDGET_CONTROL, 0x0);
@@ -3579,6 +3580,7 @@ enum {
35793580
ALC286_FIXUP_ACER_AIO_MIC_NO_PRESENCE,
35803581
ALC294_FIXUP_ASUS_MIC,
35813582
ALC294_FIXUP_ASUS_HEADSET_MIC,
3583+
ALC294_FIXUP_ASUS_I2C_HEADSET_MIC,
35823584
ALC294_FIXUP_ASUS_SPK,
35833585
ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE,
35843586
ALC285_FIXUP_LENOVO_PC_BEEP_IN_NOISE,
@@ -4889,6 +4891,15 @@ static const struct hda_fixup alc269_fixups[] = {
48894891
.chained = true,
48904892
.chain_id = ALC269_FIXUP_HEADSET_MIC
48914893
},
4894+
[ALC294_FIXUP_ASUS_I2C_HEADSET_MIC] = {
4895+
.type = HDA_FIXUP_PINS,
4896+
.v.pins = (const struct hda_pintbl[]) {
4897+
{ 0x19, 0x03a19020 }, /* use as headset mic */
4898+
{ }
4899+
},
4900+
.chained = true,
4901+
.chain_id = ALC287_FIXUP_CS35L41_I2C_2
4902+
},
48924903
[ALC294_FIXUP_ASUS_SPK] = {
48934904
.type = HDA_FIXUP_VERBS,
48944905
.v.verbs = (const struct hda_verb[]) {
@@ -6368,6 +6379,8 @@ static const struct hda_quirk alc269_fixup_tbl[] = {
63686379
SND_PCI_QUIRK(0x103c, 0x84e7, "HP Pavilion 15", ALC269_FIXUP_HP_MUTE_LED_MIC3),
63696380
SND_PCI_QUIRK(0x103c, 0x8519, "HP Spectre x360 15-df0xxx", ALC285_FIXUP_HP_SPECTRE_X360),
63706381
SND_PCI_QUIRK(0x103c, 0x8537, "HP ProBook 440 G6", ALC236_FIXUP_HP_MUTE_LED_MICMUTE_VREF),
6382+
SND_PCI_QUIRK(0x103c, 0x8548, "HP EliteBook x360 830 G6", ALC285_FIXUP_HP_GPIO_LED),
6383+
SND_PCI_QUIRK(0x103c, 0x854a, "HP EliteBook 830 G6", ALC285_FIXUP_HP_GPIO_LED),
63716384
SND_PCI_QUIRK(0x103c, 0x85c6, "HP Pavilion x360 Convertible 14-dy1xxx", ALC295_FIXUP_HP_MUTE_LED_COEFBIT11),
63726385
SND_PCI_QUIRK(0x103c, 0x85de, "HP Envy x360 13-ar0xxx", ALC285_FIXUP_HP_ENVY_X360),
63736386
SND_PCI_QUIRK(0x103c, 0x860f, "HP ZBook 15 G6", ALC285_FIXUP_HP_GPIO_AMP_INIT),
@@ -6728,7 +6741,7 @@ static const struct hda_quirk alc269_fixup_tbl[] = {
67286741
SND_PCI_QUIRK(0x1043, 0x1b13, "ASUS U41SV/GA403U", ALC285_FIXUP_ASUS_GA403U_HEADSET_MIC),
67296742
SND_PCI_QUIRK(0x1043, 0x1b93, "ASUS G614JVR/JIR", ALC245_FIXUP_CS35L41_SPI_2),
67306743
SND_PCI_QUIRK(0x1043, 0x1bbd, "ASUS Z550MA", ALC255_FIXUP_ASUS_MIC_NO_PRESENCE),
6731-
SND_PCI_QUIRK(0x1043, 0x1c03, "ASUS UM3406HA", ALC287_FIXUP_CS35L41_I2C_2),
6744+
SND_PCI_QUIRK(0x1043, 0x1c03, "ASUS UM3406HA", ALC294_FIXUP_ASUS_I2C_HEADSET_MIC),
67326745
SND_PCI_QUIRK(0x1043, 0x1c23, "Asus X55U", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
67336746
SND_PCI_QUIRK(0x1043, 0x1c33, "ASUS UX5304MA", ALC245_FIXUP_CS35L41_SPI_2),
67346747
SND_PCI_QUIRK(0x1043, 0x1c43, "ASUS UX8406MA", ALC245_FIXUP_CS35L41_SPI_2),

sound/hda/codecs/side-codecs/tas2781_hda_i2c.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -267,7 +267,7 @@ static const struct snd_kcontrol_new tas2770_snd_controls[] = {
267267
static const struct snd_kcontrol_new tas2781_snd_controls[] = {
268268
ACARD_SINGLE_RANGE_EXT_TLV("Speaker Analog Volume", TAS2781_AMP_LEVEL,
269269
1, 0, 20, 0, tas2781_amp_getvol,
270-
tas2781_amp_putvol, amp_vol_tlv),
270+
tas2781_amp_putvol, tas2781_amp_tlv),
271271
ACARD_SINGLE_BOOL_EXT("Speaker Force Firmware Load", 0,
272272
tas2781_force_fwload_get, tas2781_force_fwload_put),
273273
};
@@ -305,7 +305,7 @@ static int tas2563_save_calibration(struct tas2781_hda *h)
305305
efi_char16_t efi_name[TAS2563_CAL_VAR_NAME_MAX];
306306
unsigned long max_size = TAS2563_CAL_DATA_SIZE;
307307
unsigned char var8[TAS2563_CAL_VAR_NAME_MAX];
308-
struct tasdevice_priv *p = h->hda_priv;
308+
struct tasdevice_priv *p = h->priv;
309309
struct calidata *cd = &p->cali_data;
310310
struct cali_reg *r = &cd->cali_reg_array;
311311
unsigned int offset = 0;

sound/hda/codecs/side-codecs/tas2781_hda_spi.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -494,9 +494,11 @@ static int tas2781_force_fwload_put(struct snd_kcontrol *kcontrol,
494494

495495
static struct snd_kcontrol_new tas2781_snd_ctls[] = {
496496
ACARD_SINGLE_RANGE_EXT_TLV(NULL, TAS2781_AMP_LEVEL, 1, 0, 20, 0,
497-
tas2781_amp_getvol, tas2781_amp_putvol, amp_vol_tlv),
497+
tas2781_amp_getvol, tas2781_amp_putvol,
498+
tas2781_amp_tlv),
498499
ACARD_SINGLE_RANGE_EXT_TLV(NULL, TAS2781_DVC_LVL, 0, 0, 200, 1,
499-
tas2781_digital_getvol, tas2781_digital_putvol, dvc_tlv),
500+
tas2781_digital_getvol, tas2781_digital_putvol,
501+
tas2781_dvc_tlv),
500502
ACARD_SINGLE_BOOL_EXT(NULL, 0, tas2781_force_fwload_get,
501503
tas2781_force_fwload_put),
502504
};

sound/soc/codecs/cs35l56-sdw.c

Lines changed: 0 additions & 69 deletions
Original file line numberDiff line numberDiff line change
@@ -393,74 +393,6 @@ static int cs35l56_sdw_update_status(struct sdw_slave *peripheral,
393393
return 0;
394394
}
395395

396-
static int cs35l63_sdw_kick_divider(struct cs35l56_private *cs35l56,
397-
struct sdw_slave *peripheral)
398-
{
399-
unsigned int curr_scale_reg, next_scale_reg;
400-
int curr_scale, next_scale, ret;
401-
402-
if (!cs35l56->base.init_done)
403-
return 0;
404-
405-
if (peripheral->bus->params.curr_bank) {
406-
curr_scale_reg = SDW_SCP_BUSCLOCK_SCALE_B1;
407-
next_scale_reg = SDW_SCP_BUSCLOCK_SCALE_B0;
408-
} else {
409-
curr_scale_reg = SDW_SCP_BUSCLOCK_SCALE_B0;
410-
next_scale_reg = SDW_SCP_BUSCLOCK_SCALE_B1;
411-
}
412-
413-
/*
414-
* Current clock scale value must be different to new value.
415-
* Modify current to guarantee this. If next still has the dummy
416-
* value we wrote when it was current, the core code has not set
417-
* a new scale so restore its original good value
418-
*/
419-
curr_scale = sdw_read_no_pm(peripheral, curr_scale_reg);
420-
if (curr_scale < 0) {
421-
dev_err(cs35l56->base.dev, "Failed to read current clock scale: %d\n", curr_scale);
422-
return curr_scale;
423-
}
424-
425-
next_scale = sdw_read_no_pm(peripheral, next_scale_reg);
426-
if (next_scale < 0) {
427-
dev_err(cs35l56->base.dev, "Failed to read next clock scale: %d\n", next_scale);
428-
return next_scale;
429-
}
430-
431-
if (next_scale == CS35L56_SDW_INVALID_BUS_SCALE) {
432-
next_scale = cs35l56->old_sdw_clock_scale;
433-
ret = sdw_write_no_pm(peripheral, next_scale_reg, next_scale);
434-
if (ret < 0) {
435-
dev_err(cs35l56->base.dev, "Failed to modify current clock scale: %d\n",
436-
ret);
437-
return ret;
438-
}
439-
}
440-
441-
cs35l56->old_sdw_clock_scale = curr_scale;
442-
ret = sdw_write_no_pm(peripheral, curr_scale_reg, CS35L56_SDW_INVALID_BUS_SCALE);
443-
if (ret < 0) {
444-
dev_err(cs35l56->base.dev, "Failed to modify current clock scale: %d\n", ret);
445-
return ret;
446-
}
447-
448-
dev_dbg(cs35l56->base.dev, "Next bus scale: %#x\n", next_scale);
449-
450-
return 0;
451-
}
452-
453-
static int cs35l56_sdw_bus_config(struct sdw_slave *peripheral,
454-
struct sdw_bus_params *params)
455-
{
456-
struct cs35l56_private *cs35l56 = dev_get_drvdata(&peripheral->dev);
457-
458-
if ((cs35l56->base.type == 0x63) && (cs35l56->base.rev < 0xa1))
459-
return cs35l63_sdw_kick_divider(cs35l56, peripheral);
460-
461-
return 0;
462-
}
463-
464396
static int __maybe_unused cs35l56_sdw_clk_stop(struct sdw_slave *peripheral,
465397
enum sdw_clk_stop_mode mode,
466398
enum sdw_clk_stop_type type)
@@ -476,7 +408,6 @@ static const struct sdw_slave_ops cs35l56_sdw_ops = {
476408
.read_prop = cs35l56_sdw_read_prop,
477409
.interrupt_callback = cs35l56_sdw_interrupt,
478410
.update_status = cs35l56_sdw_update_status,
479-
.bus_config = cs35l56_sdw_bus_config,
480411
#ifdef DEBUG
481412
.clk_stop = cs35l56_sdw_clk_stop,
482413
#endif

sound/soc/codecs/cs35l56-shared.c

Lines changed: 26 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -838,6 +838,15 @@ const struct cirrus_amp_cal_controls cs35l56_calibration_controls = {
838838
};
839839
EXPORT_SYMBOL_NS_GPL(cs35l56_calibration_controls, "SND_SOC_CS35L56_SHARED");
840840

841+
static const struct cirrus_amp_cal_controls cs35l63_calibration_controls = {
842+
.alg_id = 0xbf210,
843+
.mem_region = WMFW_ADSP2_YM,
844+
.ambient = "CAL_AMBIENT",
845+
.calr = "CAL_R",
846+
.status = "CAL_STATUS",
847+
.checksum = "CAL_CHECKSUM",
848+
};
849+
841850
int cs35l56_get_calibration(struct cs35l56_base *cs35l56_base)
842851
{
843852
u64 silicon_uid = 0;
@@ -912,19 +921,31 @@ EXPORT_SYMBOL_NS_GPL(cs35l56_read_prot_status, "SND_SOC_CS35L56_SHARED");
912921
void cs35l56_log_tuning(struct cs35l56_base *cs35l56_base, struct cs_dsp *cs_dsp)
913922
{
914923
__be32 pid, sid, tid;
924+
unsigned int alg_id;
915925
int ret;
916926

927+
switch (cs35l56_base->type) {
928+
case 0x54:
929+
case 0x56:
930+
case 0x57:
931+
alg_id = 0x9f212;
932+
break;
933+
default:
934+
alg_id = 0xbf212;
935+
break;
936+
}
937+
917938
scoped_guard(mutex, &cs_dsp->pwr_lock) {
918939
ret = cs_dsp_coeff_read_ctrl(cs_dsp_get_ctl(cs_dsp, "AS_PRJCT_ID",
919-
WMFW_ADSP2_XM, 0x9f212),
940+
WMFW_ADSP2_XM, alg_id),
920941
0, &pid, sizeof(pid));
921942
if (!ret)
922943
ret = cs_dsp_coeff_read_ctrl(cs_dsp_get_ctl(cs_dsp, "AS_CHNNL_ID",
923-
WMFW_ADSP2_XM, 0x9f212),
944+
WMFW_ADSP2_XM, alg_id),
924945
0, &sid, sizeof(sid));
925946
if (!ret)
926947
ret = cs_dsp_coeff_read_ctrl(cs_dsp_get_ctl(cs_dsp, "AS_SNPSHT_ID",
927-
WMFW_ADSP2_XM, 0x9f212),
948+
WMFW_ADSP2_XM, alg_id),
928949
0, &tid, sizeof(tid));
929950
}
930951

@@ -974,8 +995,10 @@ int cs35l56_hw_init(struct cs35l56_base *cs35l56_base)
974995
case 0x35A54:
975996
case 0x35A56:
976997
case 0x35A57:
998+
cs35l56_base->calibration_controls = &cs35l56_calibration_controls;
977999
break;
9781000
case 0x35A630:
1001+
cs35l56_base->calibration_controls = &cs35l63_calibration_controls;
9791002
devid = devid >> 4;
9801003
break;
9811004
default:

sound/soc/codecs/cs35l56.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -695,7 +695,7 @@ static int cs35l56_write_cal(struct cs35l56_private *cs35l56)
695695
return ret;
696696

697697
ret = cs_amp_write_cal_coeffs(&cs35l56->dsp.cs_dsp,
698-
&cs35l56_calibration_controls,
698+
cs35l56->base.calibration_controls,
699699
&cs35l56->base.cal_data);
700700

701701
wm_adsp_stop(&cs35l56->dsp);

sound/soc/codecs/cs35l56.h

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -20,8 +20,6 @@
2020
#define CS35L56_SDW_GEN_INT_MASK_1 0xc1
2121
#define CS35L56_SDW_INT_MASK_CODEC_IRQ BIT(0)
2222

23-
#define CS35L56_SDW_INVALID_BUS_SCALE 0xf
24-
2523
#define CS35L56_RX_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S24_LE)
2624
#define CS35L56_TX_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S24_LE \
2725
| SNDRV_PCM_FMTBIT_S32_LE)
@@ -52,7 +50,6 @@ struct cs35l56_private {
5250
u8 asp_slot_count;
5351
bool tdm_mode;
5452
bool sysclk_set;
55-
u8 old_sdw_clock_scale;
5653
u8 sdw_link_num;
5754
u8 sdw_unique_id;
5855
};

0 commit comments

Comments
 (0)