sound fixes for 5.16-rc7
Quite a few small fixes, hopefully the last batch for 5.16. Most of them are device-specific quirks and/or fixes, and nothing looks scary for the late stage. -----BEGIN PGP SIGNATURE----- iQJCBAABCAAsFiEEIXTw5fNLNI7mMiVaLtJE4w1nLE8FAmHDfDgOHHRpd2FpQHN1 c2UuZGUACgkQLtJE4w1nLE8BEQ//bGg53nT2PnTjqPToe61XNti4SZg4esV0bQUL wU4rl0kg4vrnoQsZWYeGu3+rRzLQd7Cx7dOoWCaZx00/+O4Bpqb0uebbOyttLTEv K/RGLRmvscU3XK+xLJ4TSIh2CPu+8njj2ugl4Za0UclmxdOtB+1oPLVP609FEmIm XgLuAQNnWSMvZg+rrG98L+GdcVt8g/e/ga3EAVbWZHUSo/VtnM2U2gI0NQV6+d0Z cxmRp8X50VgptM1EdpHDyJpO+Mu23RLhoH8XhhoiuJKCj0K6wuMqZRuVewxSOQyR 3gg42MLFCklPArWWEJ223HSFjTxx4KAgUdVyJGN+TTOmwNiqLCzFNaLSSy+XZA8r I7P+/ol4sJ5JRKbBojOE0w3LyZuI9X0ypH+9OnWRKA/nxoKtQemUa4Z9U3l2wIUg csH9gT7VaV7km6heVOuCvH3yDRxe8eP+zCdXgo8j+1krV0lwDSUp0lKTtTWvwuz2 AoCJpBIUZz8Cj26wdpKPHSc2GkutUv6RmibTLqzd7iSvAIYSTshOYAABRPil9YYj sx5NDe/VrI/kyEJF0xWj/3HCFozOhIndsNWe0sAATL3JPqeikLXxukKqACLUbiQu 1nOhEdZ2LqW6wLHZqQnnrsdG85BMJRcE8cKwqcmoTGq6fCis9iQIcX3i/qz/bHRg torPhos= =oW9C -----END PGP SIGNATURE----- Merge tag 'sound-5.16-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound Pull sound fixes from Takashi Iwai: "Quite a few small fixes, hopefully the last batch for 5.16. Most of them are device-specific quirks and/or fixes, and nothing looks scary for the late stage" * tag 'sound-5.16-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: hda/realtek: Fix quirk for Clevo NJ51CU ALSA: rawmidi - fix the uninitalized user_pversion ALSA: hda: intel-sdw-acpi: go through HDAS ACPI at max depth of 2 ALSA: hda: intel-sdw-acpi: harden detection of controller ALSA: hda/hdmi: Disable silent stream on GLK ALSA: hda/realtek: fix mute/micmute LEDs for a HP ProBook ASoC: meson: aiu: Move AIU_I2S_MISC hold setting to aiu-fifo-i2s ASoC: meson: aiu: fifo: Add missing dma_coerce_mask_and_coherent() ASoC: tas2770: Fix setting of high sample rates ASoC: rt5682: fix the wrong jack type detected ALSA: hda/realtek: Add new alc285-hp-amp-init model ALSA: hda/realtek: Amp init fixup for HP ZBook 15 G6 ASoC: tegra: Restore headphones jack name on Nyan Big ASoC: tegra: Add DAPM switches for headphones and mic jack ALSA: jack: Check the return value of kstrdup() ALSA: drivers: opl3: Fix incorrect use of vp->state ASoC: SOF: Intel: pci-tgl: add new ADL-P variant ASoC: SOF: Intel: pci-tgl: add ADL-N support
This commit is contained in:
commit
996a18eb79
|
@ -326,6 +326,8 @@ usi-headset
|
||||||
Headset support on USI machines
|
Headset support on USI machines
|
||||||
dual-codecs
|
dual-codecs
|
||||||
Lenovo laptops with dual codecs
|
Lenovo laptops with dual codecs
|
||||||
|
alc285-hp-amp-init
|
||||||
|
HP laptops which require speaker amplifier initialization (ALC285)
|
||||||
|
|
||||||
ALC680
|
ALC680
|
||||||
======
|
======
|
||||||
|
|
|
@ -509,6 +509,10 @@ int snd_jack_new(struct snd_card *card, const char *id, int type,
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
jack->id = kstrdup(id, GFP_KERNEL);
|
jack->id = kstrdup(id, GFP_KERNEL);
|
||||||
|
if (jack->id == NULL) {
|
||||||
|
kfree(jack);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
/* don't creat input device for phantom jack */
|
/* don't creat input device for phantom jack */
|
||||||
if (!phantom_jack) {
|
if (!phantom_jack) {
|
||||||
|
|
|
@ -447,6 +447,7 @@ static int snd_rawmidi_open(struct inode *inode, struct file *file)
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
goto __error;
|
goto __error;
|
||||||
}
|
}
|
||||||
|
rawmidi_file->user_pversion = 0;
|
||||||
init_waitqueue_entry(&wait, current);
|
init_waitqueue_entry(&wait, current);
|
||||||
add_wait_queue(&rmidi->open_wait, &wait);
|
add_wait_queue(&rmidi->open_wait, &wait);
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
|
@ -397,7 +397,7 @@ void snd_opl3_note_on(void *p, int note, int vel, struct snd_midi_channel *chan)
|
||||||
}
|
}
|
||||||
if (instr_4op) {
|
if (instr_4op) {
|
||||||
vp2 = &opl3->voices[voice + 3];
|
vp2 = &opl3->voices[voice + 3];
|
||||||
if (vp->state > 0) {
|
if (vp2->state > 0) {
|
||||||
opl3_reg = reg_side | (OPL3_REG_KEYON_BLOCK +
|
opl3_reg = reg_side | (OPL3_REG_KEYON_BLOCK +
|
||||||
voice_offset + 3);
|
voice_offset + 3);
|
||||||
reg_val = vp->keyon_reg & ~OPL3_KEYON_BIT;
|
reg_val = vp->keyon_reg & ~OPL3_KEYON_BIT;
|
||||||
|
|
|
@ -132,8 +132,6 @@ static acpi_status sdw_intel_acpi_cb(acpi_handle handle, u32 level,
|
||||||
return AE_NOT_FOUND;
|
return AE_NOT_FOUND;
|
||||||
}
|
}
|
||||||
|
|
||||||
info->handle = handle;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* On some Intel platforms, multiple children of the HDAS
|
* On some Intel platforms, multiple children of the HDAS
|
||||||
* device can be found, but only one of them is the SoundWire
|
* device can be found, but only one of them is the SoundWire
|
||||||
|
@ -144,6 +142,9 @@ static acpi_status sdw_intel_acpi_cb(acpi_handle handle, u32 level,
|
||||||
if (FIELD_GET(GENMASK(31, 28), adr) != SDW_LINK_TYPE)
|
if (FIELD_GET(GENMASK(31, 28), adr) != SDW_LINK_TYPE)
|
||||||
return AE_OK; /* keep going */
|
return AE_OK; /* keep going */
|
||||||
|
|
||||||
|
/* found the correct SoundWire controller */
|
||||||
|
info->handle = handle;
|
||||||
|
|
||||||
/* device found, stop namespace walk */
|
/* device found, stop namespace walk */
|
||||||
return AE_CTRL_TERMINATE;
|
return AE_CTRL_TERMINATE;
|
||||||
}
|
}
|
||||||
|
@ -164,8 +165,14 @@ int sdw_intel_acpi_scan(acpi_handle *parent_handle,
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
|
|
||||||
info->handle = NULL;
|
info->handle = NULL;
|
||||||
|
/*
|
||||||
|
* In the HDAS ACPI scope, 'SNDW' may be either the child of
|
||||||
|
* 'HDAS' or the grandchild of 'HDAS'. So let's go through
|
||||||
|
* the ACPI from 'HDAS' at max depth of 2 to find the 'SNDW'
|
||||||
|
* device.
|
||||||
|
*/
|
||||||
status = acpi_walk_namespace(ACPI_TYPE_DEVICE,
|
status = acpi_walk_namespace(ACPI_TYPE_DEVICE,
|
||||||
parent_handle, 1,
|
parent_handle, 2,
|
||||||
sdw_intel_acpi_cb,
|
sdw_intel_acpi_cb,
|
||||||
NULL, info, NULL);
|
NULL, info, NULL);
|
||||||
if (ACPI_FAILURE(status) || info->handle == NULL)
|
if (ACPI_FAILURE(status) || info->handle == NULL)
|
||||||
|
|
|
@ -2947,7 +2947,8 @@ static int parse_intel_hdmi(struct hda_codec *codec)
|
||||||
|
|
||||||
/* Intel Haswell and onwards; audio component with eld notifier */
|
/* Intel Haswell and onwards; audio component with eld notifier */
|
||||||
static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
||||||
const int *port_map, int port_num, int dev_num)
|
const int *port_map, int port_num, int dev_num,
|
||||||
|
bool send_silent_stream)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
int err;
|
||||||
|
@ -2980,7 +2981,7 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
||||||
* Enable silent stream feature, if it is enabled via
|
* Enable silent stream feature, if it is enabled via
|
||||||
* module param or Kconfig option
|
* module param or Kconfig option
|
||||||
*/
|
*/
|
||||||
if (enable_silent_stream)
|
if (send_silent_stream)
|
||||||
spec->send_silent_stream = true;
|
spec->send_silent_stream = true;
|
||||||
|
|
||||||
return parse_intel_hdmi(codec);
|
return parse_intel_hdmi(codec);
|
||||||
|
@ -2988,12 +2989,18 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
||||||
|
|
||||||
static int patch_i915_hsw_hdmi(struct hda_codec *codec)
|
static int patch_i915_hsw_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
return intel_hsw_common_init(codec, 0x08, NULL, 0, 3);
|
return intel_hsw_common_init(codec, 0x08, NULL, 0, 3,
|
||||||
|
enable_silent_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_glk_hdmi(struct hda_codec *codec)
|
static int patch_i915_glk_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
return intel_hsw_common_init(codec, 0x0b, NULL, 0, 3);
|
/*
|
||||||
|
* Silent stream calls audio component .get_power() from
|
||||||
|
* .pin_eld_notify(). On GLK this will deadlock in i915 due
|
||||||
|
* to the audio vs. CDCLK workaround.
|
||||||
|
*/
|
||||||
|
return intel_hsw_common_init(codec, 0x0b, NULL, 0, 3, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
||||||
|
@ -3004,7 +3011,8 @@ static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
||||||
*/
|
*/
|
||||||
static const int map[] = {0x0, 0x4, 0x6, 0x8, 0xa, 0xb};
|
static const int map[] = {0x0, 0x4, 0x6, 0x8, 0xa, 0xb};
|
||||||
|
|
||||||
return intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 3);
|
return intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 3,
|
||||||
|
enable_silent_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_tgl_hdmi(struct hda_codec *codec)
|
static int patch_i915_tgl_hdmi(struct hda_codec *codec)
|
||||||
|
@ -3016,7 +3024,8 @@ static int patch_i915_tgl_hdmi(struct hda_codec *codec)
|
||||||
static const int map[] = {0x4, 0x6, 0x8, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf};
|
static const int map[] = {0x4, 0x6, 0x8, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf};
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 4);
|
ret = intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 4,
|
||||||
|
enable_silent_stream);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
|
|
||||||
|
|
|
@ -6546,6 +6546,23 @@ static void alc233_fixup_no_audio_jack(struct hda_codec *codec,
|
||||||
alc_process_coef_fw(codec, alc233_fixup_no_audio_jack_coefs);
|
alc_process_coef_fw(codec, alc233_fixup_no_audio_jack_coefs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void alc256_fixup_mic_no_presence_and_resume(struct hda_codec *codec,
|
||||||
|
const struct hda_fixup *fix,
|
||||||
|
int action)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* The Clevo NJ51CU comes either with the ALC293 or the ALC256 codec,
|
||||||
|
* but uses the 0x8686 subproduct id in both cases. The ALC256 codec
|
||||||
|
* needs an additional quirk for sound working after suspend and resume.
|
||||||
|
*/
|
||||||
|
if (codec->core.vendor_id == 0x10ec0256) {
|
||||||
|
alc_update_coef_idx(codec, 0x10, 1<<9, 0);
|
||||||
|
snd_hda_codec_set_pincfg(codec, 0x19, 0x04a11120);
|
||||||
|
} else {
|
||||||
|
snd_hda_codec_set_pincfg(codec, 0x1a, 0x04a1113c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
ALC269_FIXUP_GPIO2,
|
ALC269_FIXUP_GPIO2,
|
||||||
ALC269_FIXUP_SONY_VAIO,
|
ALC269_FIXUP_SONY_VAIO,
|
||||||
|
@ -6766,6 +6783,7 @@ enum {
|
||||||
ALC256_FIXUP_SET_COEF_DEFAULTS,
|
ALC256_FIXUP_SET_COEF_DEFAULTS,
|
||||||
ALC256_FIXUP_SYSTEM76_MIC_NO_PRESENCE,
|
ALC256_FIXUP_SYSTEM76_MIC_NO_PRESENCE,
|
||||||
ALC233_FIXUP_NO_AUDIO_JACK,
|
ALC233_FIXUP_NO_AUDIO_JACK,
|
||||||
|
ALC256_FIXUP_MIC_NO_PRESENCE_AND_RESUME,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct hda_fixup alc269_fixups[] = {
|
static const struct hda_fixup alc269_fixups[] = {
|
||||||
|
@ -8490,6 +8508,12 @@ static const struct hda_fixup alc269_fixups[] = {
|
||||||
.type = HDA_FIXUP_FUNC,
|
.type = HDA_FIXUP_FUNC,
|
||||||
.v.func = alc233_fixup_no_audio_jack,
|
.v.func = alc233_fixup_no_audio_jack,
|
||||||
},
|
},
|
||||||
|
[ALC256_FIXUP_MIC_NO_PRESENCE_AND_RESUME] = {
|
||||||
|
.type = HDA_FIXUP_FUNC,
|
||||||
|
.v.func = alc256_fixup_mic_no_presence_and_resume,
|
||||||
|
.chained = true,
|
||||||
|
.chain_id = ALC269_FIXUP_HEADSET_MODE_NO_HP_MIC
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||||
|
@ -8660,6 +8684,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||||
SND_PCI_QUIRK(0x103c, 0x84da, "HP OMEN dc0019-ur", ALC295_FIXUP_HP_OMEN),
|
SND_PCI_QUIRK(0x103c, 0x84da, "HP OMEN dc0019-ur", ALC295_FIXUP_HP_OMEN),
|
||||||
SND_PCI_QUIRK(0x103c, 0x84e7, "HP Pavilion 15", ALC269_FIXUP_HP_MUTE_LED_MIC3),
|
SND_PCI_QUIRK(0x103c, 0x84e7, "HP Pavilion 15", ALC269_FIXUP_HP_MUTE_LED_MIC3),
|
||||||
SND_PCI_QUIRK(0x103c, 0x8519, "HP Spectre x360 15-df0xxx", ALC285_FIXUP_HP_SPECTRE_X360),
|
SND_PCI_QUIRK(0x103c, 0x8519, "HP Spectre x360 15-df0xxx", ALC285_FIXUP_HP_SPECTRE_X360),
|
||||||
|
SND_PCI_QUIRK(0x103c, 0x860f, "HP ZBook 15 G6", ALC285_FIXUP_HP_GPIO_AMP_INIT),
|
||||||
SND_PCI_QUIRK(0x103c, 0x861f, "HP Elite Dragonfly G1", ALC285_FIXUP_HP_GPIO_AMP_INIT),
|
SND_PCI_QUIRK(0x103c, 0x861f, "HP Elite Dragonfly G1", ALC285_FIXUP_HP_GPIO_AMP_INIT),
|
||||||
SND_PCI_QUIRK(0x103c, 0x869d, "HP", ALC236_FIXUP_HP_MUTE_LED),
|
SND_PCI_QUIRK(0x103c, 0x869d, "HP", ALC236_FIXUP_HP_MUTE_LED),
|
||||||
SND_PCI_QUIRK(0x103c, 0x86c7, "HP Envy AiO 32", ALC274_FIXUP_HP_ENVY_GPIO),
|
SND_PCI_QUIRK(0x103c, 0x86c7, "HP Envy AiO 32", ALC274_FIXUP_HP_ENVY_GPIO),
|
||||||
|
@ -8705,6 +8730,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||||
SND_PCI_QUIRK(0x103c, 0x8896, "HP EliteBook 855 G8 Notebook PC", ALC285_FIXUP_HP_MUTE_LED),
|
SND_PCI_QUIRK(0x103c, 0x8896, "HP EliteBook 855 G8 Notebook PC", ALC285_FIXUP_HP_MUTE_LED),
|
||||||
SND_PCI_QUIRK(0x103c, 0x8898, "HP EliteBook 845 G8 Notebook PC", ALC285_FIXUP_HP_LIMIT_INT_MIC_BOOST),
|
SND_PCI_QUIRK(0x103c, 0x8898, "HP EliteBook 845 G8 Notebook PC", ALC285_FIXUP_HP_LIMIT_INT_MIC_BOOST),
|
||||||
SND_PCI_QUIRK(0x103c, 0x88d0, "HP Pavilion 15-eh1xxx (mainboard 88D0)", ALC287_FIXUP_HP_GPIO_LED),
|
SND_PCI_QUIRK(0x103c, 0x88d0, "HP Pavilion 15-eh1xxx (mainboard 88D0)", ALC287_FIXUP_HP_GPIO_LED),
|
||||||
|
SND_PCI_QUIRK(0x103c, 0x89ca, "HP", ALC236_FIXUP_HP_MUTE_LED_MICMUTE_VREF),
|
||||||
SND_PCI_QUIRK(0x1043, 0x103e, "ASUS X540SA", ALC256_FIXUP_ASUS_MIC),
|
SND_PCI_QUIRK(0x1043, 0x103e, "ASUS X540SA", ALC256_FIXUP_ASUS_MIC),
|
||||||
SND_PCI_QUIRK(0x1043, 0x103f, "ASUS TX300", ALC282_FIXUP_ASUS_TX300),
|
SND_PCI_QUIRK(0x1043, 0x103f, "ASUS TX300", ALC282_FIXUP_ASUS_TX300),
|
||||||
SND_PCI_QUIRK(0x1043, 0x106d, "Asus K53BE", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
|
SND_PCI_QUIRK(0x1043, 0x106d, "Asus K53BE", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
|
||||||
|
@ -8829,7 +8855,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||||
SND_PCI_QUIRK(0x1558, 0x8562, "Clevo NH[57][0-9]RZ[Q]", ALC269_FIXUP_DMIC),
|
SND_PCI_QUIRK(0x1558, 0x8562, "Clevo NH[57][0-9]RZ[Q]", ALC269_FIXUP_DMIC),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8668, "Clevo NP50B[BE]", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8668, "Clevo NP50B[BE]", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8680, "Clevo NJ50LU", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8680, "Clevo NJ50LU", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8686, "Clevo NH50[CZ]U", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8686, "Clevo NH50[CZ]U", ALC256_FIXUP_MIC_NO_PRESENCE_AND_RESUME),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8a20, "Clevo NH55DCQ-Y", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8a20, "Clevo NH55DCQ-Y", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8a51, "Clevo NH70RCQ-Y", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8a51, "Clevo NH70RCQ-Y", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
||||||
SND_PCI_QUIRK(0x1558, 0x8d50, "Clevo NH55RCQ-M", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
SND_PCI_QUIRK(0x1558, 0x8d50, "Clevo NH55RCQ-M", ALC293_FIXUP_SYSTEM76_MIC_NO_PRESENCE),
|
||||||
|
@ -9123,6 +9149,7 @@ static const struct hda_model_fixup alc269_fixup_models[] = {
|
||||||
{.id = ALC287_FIXUP_IDEAPAD_BASS_SPK_AMP, .name = "alc287-ideapad-bass-spk-amp"},
|
{.id = ALC287_FIXUP_IDEAPAD_BASS_SPK_AMP, .name = "alc287-ideapad-bass-spk-amp"},
|
||||||
{.id = ALC623_FIXUP_LENOVO_THINKSTATION_P340, .name = "alc623-lenovo-thinkstation-p340"},
|
{.id = ALC623_FIXUP_LENOVO_THINKSTATION_P340, .name = "alc623-lenovo-thinkstation-p340"},
|
||||||
{.id = ALC255_FIXUP_ACER_HEADPHONE_AND_MIC, .name = "alc255-acer-headphone-and-mic"},
|
{.id = ALC255_FIXUP_ACER_HEADPHONE_AND_MIC, .name = "alc255-acer-headphone-and-mic"},
|
||||||
|
{.id = ALC285_FIXUP_HP_GPIO_AMP_INIT, .name = "alc285-hp-amp-init"},
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
#define ALC225_STANDARD_PINS \
|
#define ALC225_STANDARD_PINS \
|
||||||
|
|
|
@ -929,6 +929,8 @@ int rt5682_headset_detect(struct snd_soc_component *component, int jack_insert)
|
||||||
unsigned int val, count;
|
unsigned int val, count;
|
||||||
|
|
||||||
if (jack_insert) {
|
if (jack_insert) {
|
||||||
|
snd_soc_dapm_mutex_lock(dapm);
|
||||||
|
|
||||||
snd_soc_component_update_bits(component, RT5682_PWR_ANLG_1,
|
snd_soc_component_update_bits(component, RT5682_PWR_ANLG_1,
|
||||||
RT5682_PWR_VREF2 | RT5682_PWR_MB,
|
RT5682_PWR_VREF2 | RT5682_PWR_MB,
|
||||||
RT5682_PWR_VREF2 | RT5682_PWR_MB);
|
RT5682_PWR_VREF2 | RT5682_PWR_MB);
|
||||||
|
@ -979,6 +981,8 @@ int rt5682_headset_detect(struct snd_soc_component *component, int jack_insert)
|
||||||
snd_soc_component_update_bits(component, RT5682_MICBIAS_2,
|
snd_soc_component_update_bits(component, RT5682_MICBIAS_2,
|
||||||
RT5682_PWR_CLK25M_MASK | RT5682_PWR_CLK1M_MASK,
|
RT5682_PWR_CLK25M_MASK | RT5682_PWR_CLK1M_MASK,
|
||||||
RT5682_PWR_CLK25M_PU | RT5682_PWR_CLK1M_PU);
|
RT5682_PWR_CLK25M_PU | RT5682_PWR_CLK1M_PU);
|
||||||
|
|
||||||
|
snd_soc_dapm_mutex_unlock(dapm);
|
||||||
} else {
|
} else {
|
||||||
rt5682_enable_push_button_irq(component, false);
|
rt5682_enable_push_button_irq(component, false);
|
||||||
snd_soc_component_update_bits(component, RT5682_CBJ_CTRL_1,
|
snd_soc_component_update_bits(component, RT5682_CBJ_CTRL_1,
|
||||||
|
|
|
@ -291,11 +291,11 @@ static int tas2770_set_samplerate(struct tas2770_priv *tas2770, int samplerate)
|
||||||
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_44_1KHZ |
|
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_44_1KHZ |
|
||||||
TAS2770_TDM_CFG_REG0_31_88_2_96KHZ;
|
TAS2770_TDM_CFG_REG0_31_88_2_96KHZ;
|
||||||
break;
|
break;
|
||||||
case 19200:
|
case 192000:
|
||||||
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_48KHZ |
|
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_48KHZ |
|
||||||
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
||||||
break;
|
break;
|
||||||
case 17640:
|
case 176400:
|
||||||
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_44_1KHZ |
|
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_44_1KHZ |
|
||||||
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
#define AIU_RST_SOFT_I2S_FAST BIT(0)
|
#define AIU_RST_SOFT_I2S_FAST BIT(0)
|
||||||
|
|
||||||
#define AIU_I2S_DAC_CFG_MSB_FIRST BIT(2)
|
#define AIU_I2S_DAC_CFG_MSB_FIRST BIT(2)
|
||||||
#define AIU_I2S_MISC_HOLD_EN BIT(2)
|
|
||||||
#define AIU_CLK_CTRL_I2S_DIV_EN BIT(0)
|
#define AIU_CLK_CTRL_I2S_DIV_EN BIT(0)
|
||||||
#define AIU_CLK_CTRL_I2S_DIV GENMASK(3, 2)
|
#define AIU_CLK_CTRL_I2S_DIV GENMASK(3, 2)
|
||||||
#define AIU_CLK_CTRL_AOCLK_INVERT BIT(6)
|
#define AIU_CLK_CTRL_AOCLK_INVERT BIT(6)
|
||||||
|
@ -36,37 +35,6 @@ static void aiu_encoder_i2s_divider_enable(struct snd_soc_component *component,
|
||||||
enable ? AIU_CLK_CTRL_I2S_DIV_EN : 0);
|
enable ? AIU_CLK_CTRL_I2S_DIV_EN : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aiu_encoder_i2s_hold(struct snd_soc_component *component,
|
|
||||||
bool enable)
|
|
||||||
{
|
|
||||||
snd_soc_component_update_bits(component, AIU_I2S_MISC,
|
|
||||||
AIU_I2S_MISC_HOLD_EN,
|
|
||||||
enable ? AIU_I2S_MISC_HOLD_EN : 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int aiu_encoder_i2s_trigger(struct snd_pcm_substream *substream, int cmd,
|
|
||||||
struct snd_soc_dai *dai)
|
|
||||||
{
|
|
||||||
struct snd_soc_component *component = dai->component;
|
|
||||||
|
|
||||||
switch (cmd) {
|
|
||||||
case SNDRV_PCM_TRIGGER_START:
|
|
||||||
case SNDRV_PCM_TRIGGER_RESUME:
|
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
|
||||||
aiu_encoder_i2s_hold(component, false);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
case SNDRV_PCM_TRIGGER_STOP:
|
|
||||||
case SNDRV_PCM_TRIGGER_SUSPEND:
|
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
|
||||||
aiu_encoder_i2s_hold(component, true);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int aiu_encoder_i2s_setup_desc(struct snd_soc_component *component,
|
static int aiu_encoder_i2s_setup_desc(struct snd_soc_component *component,
|
||||||
struct snd_pcm_hw_params *params)
|
struct snd_pcm_hw_params *params)
|
||||||
{
|
{
|
||||||
|
@ -353,7 +321,6 @@ static void aiu_encoder_i2s_shutdown(struct snd_pcm_substream *substream,
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct snd_soc_dai_ops aiu_encoder_i2s_dai_ops = {
|
const struct snd_soc_dai_ops aiu_encoder_i2s_dai_ops = {
|
||||||
.trigger = aiu_encoder_i2s_trigger,
|
|
||||||
.hw_params = aiu_encoder_i2s_hw_params,
|
.hw_params = aiu_encoder_i2s_hw_params,
|
||||||
.hw_free = aiu_encoder_i2s_hw_free,
|
.hw_free = aiu_encoder_i2s_hw_free,
|
||||||
.set_fmt = aiu_encoder_i2s_set_fmt,
|
.set_fmt = aiu_encoder_i2s_set_fmt,
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
#define AIU_MEM_I2S_CONTROL_MODE_16BIT BIT(6)
|
#define AIU_MEM_I2S_CONTROL_MODE_16BIT BIT(6)
|
||||||
#define AIU_MEM_I2S_BUF_CNTL_INIT BIT(0)
|
#define AIU_MEM_I2S_BUF_CNTL_INIT BIT(0)
|
||||||
#define AIU_RST_SOFT_I2S_FAST BIT(0)
|
#define AIU_RST_SOFT_I2S_FAST BIT(0)
|
||||||
|
#define AIU_I2S_MISC_HOLD_EN BIT(2)
|
||||||
|
#define AIU_I2S_MISC_FORCE_LEFT_RIGHT BIT(4)
|
||||||
|
|
||||||
#define AIU_FIFO_I2S_BLOCK 256
|
#define AIU_FIFO_I2S_BLOCK 256
|
||||||
|
|
||||||
|
@ -90,6 +92,10 @@ static int aiu_fifo_i2s_hw_params(struct snd_pcm_substream *substream,
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
snd_soc_component_update_bits(component, AIU_I2S_MISC,
|
||||||
|
AIU_I2S_MISC_HOLD_EN,
|
||||||
|
AIU_I2S_MISC_HOLD_EN);
|
||||||
|
|
||||||
ret = aiu_fifo_hw_params(substream, params, dai);
|
ret = aiu_fifo_hw_params(substream, params, dai);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -117,6 +123,19 @@ static int aiu_fifo_i2s_hw_params(struct snd_pcm_substream *substream,
|
||||||
snd_soc_component_update_bits(component, AIU_MEM_I2S_MASKS,
|
snd_soc_component_update_bits(component, AIU_MEM_I2S_MASKS,
|
||||||
AIU_MEM_I2S_MASKS_IRQ_BLOCK, val);
|
AIU_MEM_I2S_MASKS_IRQ_BLOCK, val);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Most (all?) supported SoCs have this bit set by default. The vendor
|
||||||
|
* driver however sets it manually (depending on the version either
|
||||||
|
* while un-setting AIU_I2S_MISC_HOLD_EN or right before that). Follow
|
||||||
|
* the same approach for consistency with the vendor driver.
|
||||||
|
*/
|
||||||
|
snd_soc_component_update_bits(component, AIU_I2S_MISC,
|
||||||
|
AIU_I2S_MISC_FORCE_LEFT_RIGHT,
|
||||||
|
AIU_I2S_MISC_FORCE_LEFT_RIGHT);
|
||||||
|
|
||||||
|
snd_soc_component_update_bits(component, AIU_I2S_MISC,
|
||||||
|
AIU_I2S_MISC_HOLD_EN, 0);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
#include <linux/bitfield.h>
|
#include <linux/bitfield.h>
|
||||||
#include <linux/clk.h>
|
#include <linux/clk.h>
|
||||||
|
#include <linux/dma-mapping.h>
|
||||||
#include <sound/pcm_params.h>
|
#include <sound/pcm_params.h>
|
||||||
#include <sound/soc.h>
|
#include <sound/soc.h>
|
||||||
#include <sound/soc-dai.h>
|
#include <sound/soc-dai.h>
|
||||||
|
@ -179,6 +180,11 @@ int aiu_fifo_pcm_new(struct snd_soc_pcm_runtime *rtd,
|
||||||
struct snd_card *card = rtd->card->snd_card;
|
struct snd_card *card = rtd->card->snd_card;
|
||||||
struct aiu_fifo *fifo = dai->playback_dma_data;
|
struct aiu_fifo *fifo = dai->playback_dma_data;
|
||||||
size_t size = fifo->pcm->buffer_bytes_max;
|
size_t size = fifo->pcm->buffer_bytes_max;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = dma_coerce_mask_and_coherent(card->dev, DMA_BIT_MASK(32));
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
snd_pcm_set_managed_buffer_all(rtd->pcm, SNDRV_DMA_TYPE_DEV,
|
snd_pcm_set_managed_buffer_all(rtd->pcm, SNDRV_DMA_TYPE_DEV,
|
||||||
card->dev, size, size);
|
card->dev, size, size);
|
||||||
|
|
|
@ -112,8 +112,12 @@ static const struct pci_device_id sof_pci_ids[] = {
|
||||||
.driver_data = (unsigned long)&adls_desc},
|
.driver_data = (unsigned long)&adls_desc},
|
||||||
{ PCI_DEVICE(0x8086, 0x51c8), /* ADL-P */
|
{ PCI_DEVICE(0x8086, 0x51c8), /* ADL-P */
|
||||||
.driver_data = (unsigned long)&adl_desc},
|
.driver_data = (unsigned long)&adl_desc},
|
||||||
|
{ PCI_DEVICE(0x8086, 0x51cd), /* ADL-P */
|
||||||
|
.driver_data = (unsigned long)&adl_desc},
|
||||||
{ PCI_DEVICE(0x8086, 0x51cc), /* ADL-M */
|
{ PCI_DEVICE(0x8086, 0x51cc), /* ADL-M */
|
||||||
.driver_data = (unsigned long)&adl_desc},
|
.driver_data = (unsigned long)&adl_desc},
|
||||||
|
{ PCI_DEVICE(0x8086, 0x54c8), /* ADL-N */
|
||||||
|
.driver_data = (unsigned long)&adl_desc},
|
||||||
{ 0, }
|
{ 0, }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(pci, sof_pci_ids);
|
MODULE_DEVICE_TABLE(pci, sof_pci_ids);
|
||||||
|
|
|
@ -116,16 +116,24 @@ static const struct snd_kcontrol_new tegra_machine_controls[] = {
|
||||||
SOC_DAPM_PIN_SWITCH("Headset Mic"),
|
SOC_DAPM_PIN_SWITCH("Headset Mic"),
|
||||||
SOC_DAPM_PIN_SWITCH("Internal Mic 1"),
|
SOC_DAPM_PIN_SWITCH("Internal Mic 1"),
|
||||||
SOC_DAPM_PIN_SWITCH("Internal Mic 2"),
|
SOC_DAPM_PIN_SWITCH("Internal Mic 2"),
|
||||||
|
SOC_DAPM_PIN_SWITCH("Headphones"),
|
||||||
|
SOC_DAPM_PIN_SWITCH("Mic Jack"),
|
||||||
};
|
};
|
||||||
|
|
||||||
int tegra_asoc_machine_init(struct snd_soc_pcm_runtime *rtd)
|
int tegra_asoc_machine_init(struct snd_soc_pcm_runtime *rtd)
|
||||||
{
|
{
|
||||||
struct snd_soc_card *card = rtd->card;
|
struct snd_soc_card *card = rtd->card;
|
||||||
struct tegra_machine *machine = snd_soc_card_get_drvdata(card);
|
struct tegra_machine *machine = snd_soc_card_get_drvdata(card);
|
||||||
|
const char *jack_name;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (machine->gpiod_hp_det && machine->asoc->add_hp_jack) {
|
if (machine->gpiod_hp_det && machine->asoc->add_hp_jack) {
|
||||||
err = snd_soc_card_jack_new(card, "Headphones Jack",
|
if (machine->asoc->hp_jack_name)
|
||||||
|
jack_name = machine->asoc->hp_jack_name;
|
||||||
|
else
|
||||||
|
jack_name = "Headphones Jack";
|
||||||
|
|
||||||
|
err = snd_soc_card_jack_new(card, jack_name,
|
||||||
SND_JACK_HEADPHONE,
|
SND_JACK_HEADPHONE,
|
||||||
&tegra_machine_hp_jack,
|
&tegra_machine_hp_jack,
|
||||||
tegra_machine_hp_jack_pins,
|
tegra_machine_hp_jack_pins,
|
||||||
|
@ -658,6 +666,7 @@ static struct snd_soc_card snd_soc_tegra_max98090 = {
|
||||||
static const struct tegra_asoc_data tegra_max98090_data = {
|
static const struct tegra_asoc_data tegra_max98090_data = {
|
||||||
.mclk_rate = tegra_machine_mclk_rate_12mhz,
|
.mclk_rate = tegra_machine_mclk_rate_12mhz,
|
||||||
.card = &snd_soc_tegra_max98090,
|
.card = &snd_soc_tegra_max98090,
|
||||||
|
.hp_jack_name = "Headphones",
|
||||||
.add_common_dapm_widgets = true,
|
.add_common_dapm_widgets = true,
|
||||||
.add_common_controls = true,
|
.add_common_controls = true,
|
||||||
.add_common_snd_ops = true,
|
.add_common_snd_ops = true,
|
||||||
|
|
|
@ -14,6 +14,7 @@ struct snd_soc_pcm_runtime;
|
||||||
struct tegra_asoc_data {
|
struct tegra_asoc_data {
|
||||||
unsigned int (*mclk_rate)(unsigned int srate);
|
unsigned int (*mclk_rate)(unsigned int srate);
|
||||||
const char *codec_dev_name;
|
const char *codec_dev_name;
|
||||||
|
const char *hp_jack_name;
|
||||||
struct snd_soc_card *card;
|
struct snd_soc_card *card;
|
||||||
unsigned int mclk_id;
|
unsigned int mclk_id;
|
||||||
bool hp_jack_gpio_active_low;
|
bool hp_jack_gpio_active_low;
|
||||||
|
|
Loading…
Reference in New Issue