Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: HDA: Use LPIB Position fix for Intel SCH Poulsbo ALSA: hda: fix mute led polarity for HP laptops with buggy BIOS ALSA: HDA: Set position fix to LPIB for an Atom/Poulsbo based device ASoC: Fix hx4700 error handling to free gpios if snd_soc_register_card fails ASoC: WM8958: correctly show firmware magic on mismatch ASoC: mxs: Add appropriate MODULE_ALIAS() ASoC: mxs: Add missing MODULE_LICENSE("GPL") ASoC: Fix WM8996 24.576MHz clock operation ASoC: Include linux/module.h for smdk2443_wm9710 ASoC: Fix a typo in jive_wm8750 ASoC: Fix build dependency for SND_SOC_JZ4740_CODEC ASoC: Include linux/io.h for jz4740 codec
This commit is contained in:
commit
5885b9b3f0
11 changed files with 23 additions and 6 deletions
|
@ -2507,6 +2507,7 @@ static struct snd_pci_quirk position_fix_list[] __devinitdata = {
|
||||||
SND_PCI_QUIRK(0x1043, 0x813d, "ASUS P5AD2", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x1043, 0x813d, "ASUS P5AD2", POS_FIX_LPIB),
|
||||||
SND_PCI_QUIRK(0x1043, 0x81b3, "ASUS", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x1043, 0x81b3, "ASUS", POS_FIX_LPIB),
|
||||||
SND_PCI_QUIRK(0x1043, 0x81e7, "ASUS M2V", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x1043, 0x81e7, "ASUS M2V", POS_FIX_LPIB),
|
||||||
|
SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS 1101HA", POS_FIX_LPIB),
|
||||||
SND_PCI_QUIRK(0x104d, 0x9069, "Sony VPCS11V9E", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x104d, 0x9069, "Sony VPCS11V9E", POS_FIX_LPIB),
|
||||||
SND_PCI_QUIRK(0x1297, 0x3166, "Shuttle", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x1297, 0x3166, "Shuttle", POS_FIX_LPIB),
|
||||||
SND_PCI_QUIRK(0x1458, 0xa022, "ga-ma770-ud3", POS_FIX_LPIB),
|
SND_PCI_QUIRK(0x1458, 0xa022, "ga-ma770-ud3", POS_FIX_LPIB),
|
||||||
|
@ -2970,7 +2971,8 @@ static DEFINE_PCI_DEVICE_TABLE(azx_ids) = {
|
||||||
/* SCH */
|
/* SCH */
|
||||||
{ PCI_DEVICE(0x8086, 0x811b),
|
{ PCI_DEVICE(0x8086, 0x811b),
|
||||||
.driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |
|
.driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |
|
||||||
AZX_DCAPS_BUFSIZE},
|
AZX_DCAPS_BUFSIZE | AZX_DCAPS_POSFIX_LPIB }, /* Poulsbo */
|
||||||
|
/* ICH */
|
||||||
{ PCI_DEVICE(0x8086, 0x2668),
|
{ PCI_DEVICE(0x8086, 0x2668),
|
||||||
.driver_data = AZX_DRIVER_ICH | AZX_DCAPS_OLD_SSYNC |
|
.driver_data = AZX_DRIVER_ICH | AZX_DCAPS_OLD_SSYNC |
|
||||||
AZX_DCAPS_BUFSIZE }, /* ICH6 */
|
AZX_DCAPS_BUFSIZE }, /* ICH6 */
|
||||||
|
|
|
@ -4929,6 +4929,12 @@ static int find_mute_led_gpio(struct hda_codec *codec, int default_polarity)
|
||||||
set_hp_led_gpio(codec);
|
set_hp_led_gpio(codec);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
/* BIOS bug: unfilled OEM string */
|
||||||
|
if (strstr(dev->name, "HP_Mute_LED_P_G")) {
|
||||||
|
set_hp_led_gpio(codec);
|
||||||
|
spec->gpio_led_polarity = 1;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -33,7 +33,7 @@ config SND_SOC_ALL_CODECS
|
||||||
select SND_SOC_CX20442
|
select SND_SOC_CX20442
|
||||||
select SND_SOC_DA7210 if I2C
|
select SND_SOC_DA7210 if I2C
|
||||||
select SND_SOC_DFBMCS320
|
select SND_SOC_DFBMCS320
|
||||||
select SND_SOC_JZ4740_CODEC if SOC_JZ4740
|
select SND_SOC_JZ4740_CODEC
|
||||||
select SND_SOC_LM4857 if I2C
|
select SND_SOC_LM4857 if I2C
|
||||||
select SND_SOC_MAX98088 if I2C
|
select SND_SOC_MAX98088 if I2C
|
||||||
select SND_SOC_MAX98095 if I2C
|
select SND_SOC_MAX98095 if I2C
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
|
#include <linux/io.h>
|
||||||
|
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
|
||||||
|
|
|
@ -60,6 +60,8 @@ static int wm8958_dsp2_fw(struct snd_soc_codec *codec, const char *name,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (memcmp(fw->data, "WMFW", 4) != 0) {
|
if (memcmp(fw->data, "WMFW", 4) != 0) {
|
||||||
|
memcpy(&data32, fw->data, sizeof(data32));
|
||||||
|
data32 = be32_to_cpu(data32);
|
||||||
dev_err(codec->dev, "%s: firmware has bad file magic %08x\n",
|
dev_err(codec->dev, "%s: firmware has bad file magic %08x\n",
|
||||||
name, data32);
|
name, data32);
|
||||||
goto err;
|
goto err;
|
||||||
|
|
|
@ -1968,6 +1968,7 @@ static int wm8996_set_sysclk(struct snd_soc_dai *dai,
|
||||||
break;
|
break;
|
||||||
case 24576000:
|
case 24576000:
|
||||||
ratediv = WM8996_SYSCLK_DIV;
|
ratediv = WM8996_SYSCLK_DIV;
|
||||||
|
wm8996->sysclk /= 2;
|
||||||
case 12288000:
|
case 12288000:
|
||||||
snd_soc_update_bits(codec, WM8996_AIF_RATE,
|
snd_soc_update_bits(codec, WM8996_AIF_RATE,
|
||||||
WM8996_SYSCLK_RATE, WM8996_SYSCLK_RATE);
|
WM8996_SYSCLK_RATE, WM8996_SYSCLK_RATE);
|
||||||
|
|
|
@ -357,3 +357,6 @@ static void __exit snd_mxs_pcm_exit(void)
|
||||||
platform_driver_unregister(&mxs_pcm_driver);
|
platform_driver_unregister(&mxs_pcm_driver);
|
||||||
}
|
}
|
||||||
module_exit(snd_mxs_pcm_exit);
|
module_exit(snd_mxs_pcm_exit);
|
||||||
|
|
||||||
|
MODULE_LICENSE("GPL");
|
||||||
|
MODULE_ALIAS("platform:mxs-pcm-audio");
|
||||||
|
|
|
@ -171,3 +171,4 @@ module_exit(mxs_sgtl5000_exit);
|
||||||
MODULE_AUTHOR("Freescale Semiconductor, Inc.");
|
MODULE_AUTHOR("Freescale Semiconductor, Inc.");
|
||||||
MODULE_DESCRIPTION("MXS ALSA SoC Machine driver");
|
MODULE_DESCRIPTION("MXS ALSA SoC Machine driver");
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
MODULE_ALIAS("platform:mxs-sgtl5000");
|
||||||
|
|
|
@ -209,9 +209,10 @@ static int __devinit hx4700_audio_probe(struct platform_device *pdev)
|
||||||
snd_soc_card_hx4700.dev = &pdev->dev;
|
snd_soc_card_hx4700.dev = &pdev->dev;
|
||||||
ret = snd_soc_register_card(&snd_soc_card_hx4700);
|
ret = snd_soc_register_card(&snd_soc_card_hx4700);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
gpio_free_array(hx4700_audio_gpios,
|
||||||
|
ARRAY_SIZE(hx4700_audio_gpios));
|
||||||
|
|
||||||
return 0;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __devexit hx4700_audio_remove(struct platform_device *pdev)
|
static int __devexit hx4700_audio_remove(struct platform_device *pdev)
|
||||||
|
|
|
@ -101,7 +101,6 @@ static int jive_wm8750_init(struct snd_soc_pcm_runtime *rtd)
|
||||||
{
|
{
|
||||||
struct snd_soc_codec *codec = rtd->codec;
|
struct snd_soc_codec *codec = rtd->codec;
|
||||||
struct snd_soc_dapm_context *dapm = &codec->dapm;
|
struct snd_soc_dapm_context *dapm = &codec->dapm;
|
||||||
int err;
|
|
||||||
|
|
||||||
/* These endpoints are not being used. */
|
/* These endpoints are not being used. */
|
||||||
snd_soc_dapm_nc_pin(dapm, "LINPUT2");
|
snd_soc_dapm_nc_pin(dapm, "LINPUT2");
|
||||||
|
@ -131,7 +130,7 @@ static struct snd_soc_card snd_soc_machine_jive = {
|
||||||
.dai_link = &jive_dai,
|
.dai_link = &jive_dai,
|
||||||
.num_links = 1,
|
.num_links = 1,
|
||||||
|
|
||||||
.dapm_widgtets = wm8750_dapm_widgets,
|
.dapm_widgets = wm8750_dapm_widgets,
|
||||||
.num_dapm_widgets = ARRAY_SIZE(wm8750_dapm_widgets),
|
.num_dapm_widgets = ARRAY_SIZE(wm8750_dapm_widgets),
|
||||||
.dapm_routes = audio_map,
|
.dapm_routes = audio_map,
|
||||||
.num_dapm_routes = ARRAY_SIZE(audio_map),
|
.num_dapm_routes = ARRAY_SIZE(audio_map),
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <linux/module.h>
|
||||||
#include <sound/soc.h>
|
#include <sound/soc.h>
|
||||||
|
|
||||||
static struct snd_soc_card smdk2443;
|
static struct snd_soc_card smdk2443;
|
||||||
|
|
Loading…
Reference in a new issue