mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
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
|
||||
dual-codecs
|
||||
Lenovo laptops with dual codecs
|
||||
alc285-hp-amp-init
|
||||
HP laptops which require speaker amplifier initialization (ALC285)
|
||||
|
||||
ALC680
|
||||
======
|
||||
|
@ -509,6 +509,10 @@ int snd_jack_new(struct snd_card *card, const char *id, int type,
|
||||
return -ENOMEM;
|
||||
|
||||
jack->id = kstrdup(id, GFP_KERNEL);
|
||||
if (jack->id == NULL) {
|
||||
kfree(jack);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
/* don't creat input device for phantom jack */
|
||||
if (!phantom_jack) {
|
||||
|
@ -447,6 +447,7 @@ static int snd_rawmidi_open(struct inode *inode, struct file *file)
|
||||
err = -ENOMEM;
|
||||
goto __error;
|
||||
}
|
||||
rawmidi_file->user_pversion = 0;
|
||||
init_waitqueue_entry(&wait, current);
|
||||
add_wait_queue(&rmidi->open_wait, &wait);
|
||||
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) {
|
||||
vp2 = &opl3->voices[voice + 3];
|
||||
if (vp->state > 0) {
|
||||
if (vp2->state > 0) {
|
||||
opl3_reg = reg_side | (OPL3_REG_KEYON_BLOCK +
|
||||
voice_offset + 3);
|
||||
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;
|
||||
}
|
||||
|
||||
info->handle = handle;
|
||||
|
||||
/*
|
||||
* On some Intel platforms, multiple children of the HDAS
|
||||
* 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)
|
||||
return AE_OK; /* keep going */
|
||||
|
||||
/* found the correct SoundWire controller */
|
||||
info->handle = handle;
|
||||
|
||||
/* device found, stop namespace walk */
|
||||
return AE_CTRL_TERMINATE;
|
||||
}
|
||||
@ -164,8 +165,14 @@ int sdw_intel_acpi_scan(acpi_handle *parent_handle,
|
||||
acpi_status status;
|
||||
|
||||
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,
|
||||
parent_handle, 1,
|
||||
parent_handle, 2,
|
||||
sdw_intel_acpi_cb,
|
||||
NULL, info, 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 */
|
||||
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;
|
||||
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
|
||||
* module param or Kconfig option
|
||||
*/
|
||||
if (enable_silent_stream)
|
||||
if (send_silent_stream)
|
||||
spec->send_silent_stream = true;
|
||||
|
||||
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)
|
||||
{
|
||||
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)
|
||||
{
|
||||
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)
|
||||
@ -3004,7 +3011,8 @@ static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
||||
*/
|
||||
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)
|
||||
@ -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};
|
||||
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) {
|
||||
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);
|
||||
}
|
||||
|
||||
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 {
|
||||
ALC269_FIXUP_GPIO2,
|
||||
ALC269_FIXUP_SONY_VAIO,
|
||||
@ -6766,6 +6783,7 @@ enum {
|
||||
ALC256_FIXUP_SET_COEF_DEFAULTS,
|
||||
ALC256_FIXUP_SYSTEM76_MIC_NO_PRESENCE,
|
||||
ALC233_FIXUP_NO_AUDIO_JACK,
|
||||
ALC256_FIXUP_MIC_NO_PRESENCE_AND_RESUME,
|
||||
};
|
||||
|
||||
static const struct hda_fixup alc269_fixups[] = {
|
||||
@ -8490,6 +8508,12 @@ static const struct hda_fixup alc269_fixups[] = {
|
||||
.type = HDA_FIXUP_FUNC,
|
||||
.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[] = {
|
||||
@ -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, 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, 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, 0x869d, "HP", ALC236_FIXUP_HP_MUTE_LED),
|
||||
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, 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, 0x89ca, "HP", ALC236_FIXUP_HP_MUTE_LED_MICMUTE_VREF),
|
||||
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, 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, 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, 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, 0x8a51, "Clevo NH70RCQ-Y", 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 = ALC623_FIXUP_LENOVO_THINKSTATION_P340, .name = "alc623-lenovo-thinkstation-p340"},
|
||||
{.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 \
|
||||
|
@ -929,6 +929,8 @@ int rt5682_headset_detect(struct snd_soc_component *component, int jack_insert)
|
||||
unsigned int val, count;
|
||||
|
||||
if (jack_insert) {
|
||||
snd_soc_dapm_mutex_lock(dapm);
|
||||
|
||||
snd_soc_component_update_bits(component, RT5682_PWR_ANLG_1,
|
||||
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,
|
||||
RT5682_PWR_CLK25M_MASK | RT5682_PWR_CLK1M_MASK,
|
||||
RT5682_PWR_CLK25M_PU | RT5682_PWR_CLK1M_PU);
|
||||
|
||||
snd_soc_dapm_mutex_unlock(dapm);
|
||||
} else {
|
||||
rt5682_enable_push_button_irq(component, false);
|
||||
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 |
|
||||
TAS2770_TDM_CFG_REG0_31_88_2_96KHZ;
|
||||
break;
|
||||
case 19200:
|
||||
case 192000:
|
||||
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_48KHZ |
|
||||
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
||||
break;
|
||||
case 17640:
|
||||
case 176400:
|
||||
ramp_rate_val = TAS2770_TDM_CFG_REG0_SMP_44_1KHZ |
|
||||
TAS2770_TDM_CFG_REG0_31_176_4_192KHZ;
|
||||
break;
|
||||
|
@ -18,7 +18,6 @@
|
||||
#define AIU_RST_SOFT_I2S_FAST BIT(0)
|
||||
|
||||
#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 GENMASK(3, 2)
|
||||
#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);
|
||||
}
|
||||
|
||||
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,
|
||||
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 = {
|
||||
.trigger = aiu_encoder_i2s_trigger,
|
||||
.hw_params = aiu_encoder_i2s_hw_params,
|
||||
.hw_free = aiu_encoder_i2s_hw_free,
|
||||
.set_fmt = aiu_encoder_i2s_set_fmt,
|
||||
|
@ -20,6 +20,8 @@
|
||||
#define AIU_MEM_I2S_CONTROL_MODE_16BIT BIT(6)
|
||||
#define AIU_MEM_I2S_BUF_CNTL_INIT 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
|
||||
|
||||
@ -90,6 +92,10 @@ static int aiu_fifo_i2s_hw_params(struct snd_pcm_substream *substream,
|
||||
unsigned int val;
|
||||
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);
|
||||
if (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,
|
||||
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;
|
||||
}
|
||||
|
||||
|
@ -5,6 +5,7 @@
|
||||
|
||||
#include <linux/bitfield.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/dma-mapping.h>
|
||||
#include <sound/pcm_params.h>
|
||||
#include <sound/soc.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 aiu_fifo *fifo = dai->playback_dma_data;
|
||||
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,
|
||||
card->dev, size, size);
|
||||
|
@ -112,8 +112,12 @@ static const struct pci_device_id sof_pci_ids[] = {
|
||||
.driver_data = (unsigned long)&adls_desc},
|
||||
{ PCI_DEVICE(0x8086, 0x51c8), /* ADL-P */
|
||||
.driver_data = (unsigned long)&adl_desc},
|
||||
{ PCI_DEVICE(0x8086, 0x51cd), /* ADL-P */
|
||||
.driver_data = (unsigned long)&adl_desc},
|
||||
{ PCI_DEVICE(0x8086, 0x51cc), /* ADL-M */
|
||||
.driver_data = (unsigned long)&adl_desc},
|
||||
{ PCI_DEVICE(0x8086, 0x54c8), /* ADL-N */
|
||||
.driver_data = (unsigned long)&adl_desc},
|
||||
{ 0, }
|
||||
};
|
||||
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("Internal Mic 1"),
|
||||
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)
|
||||
{
|
||||
struct snd_soc_card *card = rtd->card;
|
||||
struct tegra_machine *machine = snd_soc_card_get_drvdata(card);
|
||||
const char *jack_name;
|
||||
int err;
|
||||
|
||||
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,
|
||||
&tegra_machine_hp_jack,
|
||||
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 = {
|
||||
.mclk_rate = tegra_machine_mclk_rate_12mhz,
|
||||
.card = &snd_soc_tegra_max98090,
|
||||
.hp_jack_name = "Headphones",
|
||||
.add_common_dapm_widgets = true,
|
||||
.add_common_controls = true,
|
||||
.add_common_snd_ops = true,
|
||||
|
@ -14,6 +14,7 @@ struct snd_soc_pcm_runtime;
|
||||
struct tegra_asoc_data {
|
||||
unsigned int (*mclk_rate)(unsigned int srate);
|
||||
const char *codec_dev_name;
|
||||
const char *hp_jack_name;
|
||||
struct snd_soc_card *card;
|
||||
unsigned int mclk_id;
|
||||
bool hp_jack_gpio_active_low;
|
||||
|
Loading…
Reference in New Issue
Block a user