Merge branch 'linus' of master.kernel.org:/pub/scm/linux/kernel/git/perex/alsa
* 'linus' of master.kernel.org:/pub/scm/linux/kernel/git/perex/alsa: [ALSA] version 1.0.14rc3 [ALSA] cmipci - Allow to disable integrated FM port [ALSA] hda-codec - Fix logic error in headphone mute for Conexant codecs [ALSA] hda-codec - Add missing Mic Boost for AD1986A codec [ALSA] ac97 - Add Thinkpad X31 and R40 to AD1981x blacklist [ALSA] Add missing sysfs device assignment for ALSA PCI drivers [ALSA] hda-codec - Define pin configs for MacBooks [ALSA] hda-codec - Add missing Mic Boost controls for ALC262 [ALSA] soc - WM9712 PCM volume [ALSA] soc - Fix WM9712 register cache entry [ALSA] hda-codec - Add method for configuring Mac Pro without PCI SSID [ALSA] hda-codec - Add LFE support on Dell M90
This commit is contained in:
commit
cba5a641ca
@ -370,7 +370,9 @@ Prior to version 0.9.0rc4 options had a 'snd_' prefix. This was removed.
|
|||||||
mpu_port - 0x300,0x310,0x320,0x330 = legacy port,
|
mpu_port - 0x300,0x310,0x320,0x330 = legacy port,
|
||||||
1 = integrated PCI port,
|
1 = integrated PCI port,
|
||||||
0 = disable (default)
|
0 = disable (default)
|
||||||
fm_port - 0x388 (default), 0 = disable (default)
|
fm_port - 0x388 = legacy port,
|
||||||
|
1 = integrated PCI port (default),
|
||||||
|
0 = disable
|
||||||
soft_ac3 - Software-conversion of raw SPDIF packets (model 033 only)
|
soft_ac3 - Software-conversion of raw SPDIF packets (model 033 only)
|
||||||
(default = 1)
|
(default = 1)
|
||||||
joystick_port - Joystick port address (0 = disable, 1 = auto-detect)
|
joystick_port - Joystick port address (0 = disable, 1 = auto-detect)
|
||||||
@ -895,10 +897,16 @@ Prior to version 0.9.0rc4 options had a 'snd_' prefix. This was removed.
|
|||||||
can be adjusted. Appearing only when compiled with
|
can be adjusted. Appearing only when compiled with
|
||||||
$CONFIG_SND_DEBUG=y
|
$CONFIG_SND_DEBUG=y
|
||||||
|
|
||||||
STAC9200/9205/9220/9221/9254
|
STAC9200/9205/9254
|
||||||
|
ref Reference board
|
||||||
|
|
||||||
|
STAC9220/9221
|
||||||
ref Reference board
|
ref Reference board
|
||||||
3stack D945 3stack
|
3stack D945 3stack
|
||||||
5stack D945 5stack + SPDIF
|
5stack D945 5stack + SPDIF
|
||||||
|
macmini Intel Mac Mini
|
||||||
|
macbook Intel Mac Book
|
||||||
|
macbook-pro Intel Mac Book Pro
|
||||||
|
|
||||||
STAC9202/9250/9251
|
STAC9202/9250/9251
|
||||||
ref Reference board, base config
|
ref Reference board, base config
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
/* include/version.h. Generated by alsa/ksync script. */
|
/* include/version.h. Generated by alsa/ksync script. */
|
||||||
#define CONFIG_SND_VERSION "1.0.14rc2"
|
#define CONFIG_SND_VERSION "1.0.14rc3"
|
||||||
#define CONFIG_SND_DATE " (Wed Feb 14 07:42:13 2007 UTC)"
|
#define CONFIG_SND_DATE " (Tue Mar 06 13:10:00 2007 UTC)"
|
||||||
|
@ -1790,6 +1790,8 @@ static const struct snd_kcontrol_new snd_ac97_ad1981x_jack_sense[] = {
|
|||||||
* (SS vendor << 16 | device)
|
* (SS vendor << 16 | device)
|
||||||
*/
|
*/
|
||||||
static unsigned int ad1981_jacks_blacklist[] = {
|
static unsigned int ad1981_jacks_blacklist[] = {
|
||||||
|
0x10140523, /* Thinkpad R40 */
|
||||||
|
0x10140534, /* Thinkpad X31 */
|
||||||
0x10140537, /* Thinkpad T41p */
|
0x10140537, /* Thinkpad T41p */
|
||||||
0x10140554, /* Thinkpad T42p/R50p */
|
0x10140554, /* Thinkpad T42p/R50p */
|
||||||
0 /* end */
|
0 /* end */
|
||||||
|
@ -2312,6 +2312,8 @@ static int __devinit snd_ali_create(struct snd_card *card,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
snd_card_set_dev(card, &pci->dev);
|
||||||
|
|
||||||
/* initialise synth voices*/
|
/* initialise synth voices*/
|
||||||
for (i = 0; i < ALI_CHANNELS; i++ ) {
|
for (i = 0; i < ALI_CHANNELS; i++ ) {
|
||||||
codec->synth.voices[i].number = i;
|
codec->synth.voices[i].number = i;
|
||||||
|
@ -57,7 +57,7 @@ static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; /* Index 0-MAX */
|
|||||||
static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */
|
static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */
|
||||||
static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP; /* Enable switches */
|
static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP; /* Enable switches */
|
||||||
static long mpu_port[SNDRV_CARDS];
|
static long mpu_port[SNDRV_CARDS];
|
||||||
static long fm_port[SNDRV_CARDS];
|
static long fm_port[SNDRV_CARDS] = {[0 ... (SNDRV_CARDS-1)]=1};
|
||||||
static int soft_ac3[SNDRV_CARDS] = {[0 ... (SNDRV_CARDS-1)]=1};
|
static int soft_ac3[SNDRV_CARDS] = {[0 ... (SNDRV_CARDS-1)]=1};
|
||||||
#ifdef SUPPORT_JOYSTICK
|
#ifdef SUPPORT_JOYSTICK
|
||||||
static int joystick_port[SNDRV_CARDS];
|
static int joystick_port[SNDRV_CARDS];
|
||||||
@ -2779,6 +2779,9 @@ static int __devinit snd_cmipci_create_fm(struct cmipci *cm, long fm_port)
|
|||||||
struct snd_opl3 *opl3;
|
struct snd_opl3 *opl3;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
if (!fm_port)
|
||||||
|
goto disable_fm;
|
||||||
|
|
||||||
/* first try FM regs in PCI port range */
|
/* first try FM regs in PCI port range */
|
||||||
iosynth = cm->iobase + CM_REG_FM_PCI;
|
iosynth = cm->iobase + CM_REG_FM_PCI;
|
||||||
err = snd_opl3_create(cm->card, iosynth, iosynth + 2,
|
err = snd_opl3_create(cm->card, iosynth, iosynth + 2,
|
||||||
@ -2793,7 +2796,7 @@ static int __devinit snd_cmipci_create_fm(struct cmipci *cm, long fm_port)
|
|||||||
case 0x3C8: val |= CM_FMSEL_3C8; break;
|
case 0x3C8: val |= CM_FMSEL_3C8; break;
|
||||||
case 0x388: val |= CM_FMSEL_388; break;
|
case 0x388: val |= CM_FMSEL_388; break;
|
||||||
default:
|
default:
|
||||||
return 0;
|
goto disable_fm;
|
||||||
}
|
}
|
||||||
snd_cmipci_write(cm, CM_REG_LEGACY_CTRL, val);
|
snd_cmipci_write(cm, CM_REG_LEGACY_CTRL, val);
|
||||||
/* enable FM */
|
/* enable FM */
|
||||||
@ -2803,11 +2806,7 @@ static int __devinit snd_cmipci_create_fm(struct cmipci *cm, long fm_port)
|
|||||||
OPL3_HW_OPL3, 0, &opl3) < 0) {
|
OPL3_HW_OPL3, 0, &opl3) < 0) {
|
||||||
printk(KERN_ERR "cmipci: no OPL device at %#lx, "
|
printk(KERN_ERR "cmipci: no OPL device at %#lx, "
|
||||||
"skipping...\n", iosynth);
|
"skipping...\n", iosynth);
|
||||||
/* disable FM */
|
goto disable_fm;
|
||||||
snd_cmipci_write(cm, CM_REG_LEGACY_CTRL,
|
|
||||||
val & ~CM_FMSEL_MASK);
|
|
||||||
snd_cmipci_clear_bit(cm, CM_REG_MISC_CTRL, CM_FM_EN);
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ((err = snd_opl3_hwdep_new(opl3, 0, 1, NULL)) < 0) {
|
if ((err = snd_opl3_hwdep_new(opl3, 0, 1, NULL)) < 0) {
|
||||||
@ -2815,6 +2814,11 @@ static int __devinit snd_cmipci_create_fm(struct cmipci *cm, long fm_port)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
disable_fm:
|
||||||
|
snd_cmipci_clear_bit(cm, CM_REG_LEGACY_CTRL, CM_FMSEL_MASK);
|
||||||
|
snd_cmipci_clear_bit(cm, CM_REG_MISC_CTRL, CM_FM_EN);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __devinit snd_cmipci_create(struct snd_card *card, struct pci_dev *pci,
|
static int __devinit snd_cmipci_create(struct snd_card *card, struct pci_dev *pci,
|
||||||
|
@ -2033,6 +2033,8 @@ static int __devinit snd_echo_probe(struct pci_dev *pci,
|
|||||||
if (card == NULL)
|
if (card == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
|
snd_card_set_dev(card, &pci->dev);
|
||||||
|
|
||||||
if ((err = snd_echo_create(card, pci, &chip)) < 0) {
|
if ((err = snd_echo_create(card, pci, &chip)) < 0) {
|
||||||
snd_card_free(card);
|
snd_card_free(card);
|
||||||
return err;
|
return err;
|
||||||
|
@ -523,6 +523,7 @@ static struct snd_kcontrol_new ad1986a_mixers[] = {
|
|||||||
HDA_CODEC_MUTE("Aux Playback Switch", 0x16, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Aux Playback Switch", 0x16, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x0f, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("PC Speaker Playback Volume", 0x18, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("PC Speaker Playback Volume", 0x18, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("PC Speaker Playback Switch", 0x18, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("PC Speaker Playback Switch", 0x18, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Mono Playback Volume", 0x1e, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Mono Playback Volume", 0x1e, 0x0, HDA_OUTPUT),
|
||||||
@ -570,6 +571,7 @@ static struct snd_kcontrol_new ad1986a_laptop_mixers[] = {
|
|||||||
HDA_CODEC_MUTE("Aux Playback Switch", 0x16, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Aux Playback Switch", 0x16, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x0f, 0x0, HDA_OUTPUT),
|
||||||
/* HDA_CODEC_VOLUME("PC Speaker Playback Volume", 0x18, 0x0, HDA_OUTPUT),
|
/* HDA_CODEC_VOLUME("PC Speaker Playback Volume", 0x18, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("PC Speaker Playback Switch", 0x18, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("PC Speaker Playback Switch", 0x18, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Mono Playback Volume", 0x1e, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Mono Playback Volume", 0x1e, 0x0, HDA_OUTPUT),
|
||||||
@ -658,6 +660,7 @@ static struct snd_kcontrol_new ad1986a_laptop_eapd_mixers[] = {
|
|||||||
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x17, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x17, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x13, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x13, 0x0, HDA_OUTPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x0f, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Capture Volume", 0x12, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Capture Volume", 0x12, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_MUTE("Capture Switch", 0x12, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE("Capture Switch", 0x12, 0x0, HDA_OUTPUT),
|
||||||
{
|
{
|
||||||
|
@ -629,10 +629,12 @@ static int cxt5045_hp_master_vol_put(struct snd_kcontrol *kcontrol,
|
|||||||
static void cxt5045_hp_automute(struct hda_codec *codec)
|
static void cxt5045_hp_automute(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct conexant_spec *spec = codec->spec;
|
struct conexant_spec *spec = codec->spec;
|
||||||
unsigned int bits = (spec->hp_present || !spec->cur_eapd) ? 0x80 : 0;
|
unsigned int bits;
|
||||||
|
|
||||||
spec->hp_present = snd_hda_codec_read(codec, 0x11, 0,
|
spec->hp_present = snd_hda_codec_read(codec, 0x11, 0,
|
||||||
AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
||||||
|
|
||||||
|
bits = (spec->hp_present || !spec->cur_eapd) ? 0x80 : 0;
|
||||||
snd_hda_codec_amp_update(codec, 0x10, 0, HDA_OUTPUT, 0, 0x80, bits);
|
snd_hda_codec_amp_update(codec, 0x10, 0, HDA_OUTPUT, 0, 0x80, bits);
|
||||||
snd_hda_codec_amp_update(codec, 0x10, 1, HDA_OUTPUT, 0, 0x80, bits);
|
snd_hda_codec_amp_update(codec, 0x10, 1, HDA_OUTPUT, 0, 0x80, bits);
|
||||||
}
|
}
|
||||||
@ -979,10 +981,12 @@ static int cxt5047_hp_master_vol_put(struct snd_kcontrol *kcontrol,
|
|||||||
static void cxt5047_hp_automute(struct hda_codec *codec)
|
static void cxt5047_hp_automute(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct conexant_spec *spec = codec->spec;
|
struct conexant_spec *spec = codec->spec;
|
||||||
unsigned int bits = spec->hp_present || !spec->cur_eapd ? 0x80 : 0;
|
unsigned int bits;
|
||||||
|
|
||||||
spec->hp_present = snd_hda_codec_read(codec, 0x13, 0,
|
spec->hp_present = snd_hda_codec_read(codec, 0x13, 0,
|
||||||
AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
||||||
|
|
||||||
|
bits = (spec->hp_present || !spec->cur_eapd) ? 0x80 : 0;
|
||||||
snd_hda_codec_amp_update(codec, 0x1d, 0, HDA_OUTPUT, 0, 0x80, bits);
|
snd_hda_codec_amp_update(codec, 0x1d, 0, HDA_OUTPUT, 0, 0x80, bits);
|
||||||
snd_hda_codec_amp_update(codec, 0x1d, 1, HDA_OUTPUT, 0, 0x80, bits);
|
snd_hda_codec_amp_update(codec, 0x1d, 1, HDA_OUTPUT, 0, 0x80, bits);
|
||||||
/* Mute/Unmute PCM 2 for good measure - some systems need this */
|
/* Mute/Unmute PCM 2 for good measure - some systems need this */
|
||||||
|
@ -4942,9 +4942,16 @@ static int patch_alc882(struct hda_codec *codec)
|
|||||||
alc882_cfg_tbl);
|
alc882_cfg_tbl);
|
||||||
|
|
||||||
if (board_config < 0 || board_config >= ALC882_MODEL_LAST) {
|
if (board_config < 0 || board_config >= ALC882_MODEL_LAST) {
|
||||||
printk(KERN_INFO "hda_codec: Unknown model for ALC882, "
|
/* Pick up systems that don't supply PCI SSID */
|
||||||
"trying auto-probe from BIOS...\n");
|
switch (codec->subsystem_id) {
|
||||||
board_config = ALC882_AUTO;
|
case 0x106b0c00: /* Mac Pro */
|
||||||
|
board_config = ALC885_MACPRO;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printk(KERN_INFO "hda_codec: Unknown model for ALC882, "
|
||||||
|
"trying auto-probe from BIOS...\n");
|
||||||
|
board_config = ALC882_AUTO;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (board_config == ALC882_AUTO) {
|
if (board_config == ALC882_AUTO) {
|
||||||
@ -5917,8 +5924,10 @@ static struct snd_kcontrol_new alc262_base_mixer[] = {
|
|||||||
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
|
||||||
/* HDA_CODEC_VOLUME("PC Beep Playback Volume", 0x0b, 0x05, HDA_INPUT),
|
/* HDA_CODEC_VOLUME("PC Beep Playback Volume", 0x0b, 0x05, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("PC Beelp Playback Switch", 0x0b, 0x05, HDA_INPUT), */
|
HDA_CODEC_MUTE("PC Beelp Playback Switch", 0x0b, 0x05, HDA_INPUT), */
|
||||||
HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),
|
HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),
|
||||||
@ -5937,8 +5946,10 @@ static struct snd_kcontrol_new alc262_hippo1_mixer[] = {
|
|||||||
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
|
||||||
/* HDA_CODEC_VOLUME("PC Beep Playback Volume", 0x0b, 0x05, HDA_INPUT),
|
/* HDA_CODEC_VOLUME("PC Beep Playback Volume", 0x0b, 0x05, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("PC Beelp Playback Switch", 0x0b, 0x05, HDA_INPUT), */
|
HDA_CODEC_MUTE("PC Beelp Playback Switch", 0x0b, 0x05, HDA_INPUT), */
|
||||||
/*HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),*/
|
/*HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),*/
|
||||||
@ -5955,8 +5966,10 @@ static struct snd_kcontrol_new alc262_HP_BPC_mixer[] = {
|
|||||||
|
|
||||||
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
||||||
@ -5977,6 +5990,7 @@ static struct snd_kcontrol_new alc262_HP_BPC_WildWest_mixer[] = {
|
|||||||
HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
|
HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
|
||||||
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Front Mic Boost", 0x1a, 0, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x01, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x01, HDA_INPUT),
|
||||||
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
||||||
@ -5989,6 +6003,7 @@ static struct snd_kcontrol_new alc262_HP_BPC_WildWest_mixer[] = {
|
|||||||
static struct snd_kcontrol_new alc262_HP_BPC_WildWest_option_mixer[] = {
|
static struct snd_kcontrol_new alc262_HP_BPC_WildWest_option_mixer[] = {
|
||||||
HDA_CODEC_VOLUME("Rear Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_VOLUME("Rear Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
||||||
HDA_CODEC_MUTE("Rear Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
HDA_CODEC_MUTE("Rear Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
||||||
|
HDA_CODEC_VOLUME("Rear Mic Boost", 0x18, 0, HDA_INPUT),
|
||||||
{ } /* end */
|
{ } /* end */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -59,6 +59,8 @@ enum {
|
|||||||
STAC_D945GTP3,
|
STAC_D945GTP3,
|
||||||
STAC_D945GTP5,
|
STAC_D945GTP5,
|
||||||
STAC_MACMINI,
|
STAC_MACMINI,
|
||||||
|
STAC_MACBOOK,
|
||||||
|
STAC_MACBOOK_PRO,
|
||||||
STAC_922X_MODELS
|
STAC_922X_MODELS
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -461,6 +463,8 @@ static struct snd_pci_quirk stac9200_cfg_tbl[] = {
|
|||||||
"Dell Inspiron E1705/9400", STAC_REF),
|
"Dell Inspiron E1705/9400", STAC_REF),
|
||||||
SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ce,
|
SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ce,
|
||||||
"Dell XPS M1710", STAC_REF),
|
"Dell XPS M1710", STAC_REF),
|
||||||
|
SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cf,
|
||||||
|
"Dell Precision M90", STAC_REF),
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -519,11 +523,25 @@ static unsigned int d945gtp5_pin_configs[10] = {
|
|||||||
0x02a19320, 0x40000100,
|
0x02a19320, 0x40000100,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static unsigned int macbook_pin_configs[10] = {
|
||||||
|
0x0321e230, 0x03a1e020, 0x400000fd, 0x9017e110,
|
||||||
|
0x400000fe, 0x0381e021, 0x1345e240, 0x13c5e22e,
|
||||||
|
0x400000fc, 0x400000fb,
|
||||||
|
};
|
||||||
|
|
||||||
|
static unsigned int macbook_pro_pin_configs[10] = {
|
||||||
|
0x0221401f, 0x90a70120, 0x01813024, 0x01014010,
|
||||||
|
0x400000fd, 0x01016011, 0x1345e240, 0x13c5e22e,
|
||||||
|
0x400000fc, 0x400000fb,
|
||||||
|
};
|
||||||
|
|
||||||
static unsigned int *stac922x_brd_tbl[STAC_922X_MODELS] = {
|
static unsigned int *stac922x_brd_tbl[STAC_922X_MODELS] = {
|
||||||
[STAC_D945_REF] = ref922x_pin_configs,
|
[STAC_D945_REF] = ref922x_pin_configs,
|
||||||
[STAC_D945GTP3] = d945gtp3_pin_configs,
|
[STAC_D945GTP3] = d945gtp3_pin_configs,
|
||||||
[STAC_D945GTP5] = d945gtp5_pin_configs,
|
[STAC_D945GTP5] = d945gtp5_pin_configs,
|
||||||
[STAC_MACMINI] = d945gtp5_pin_configs,
|
[STAC_MACMINI] = d945gtp5_pin_configs,
|
||||||
|
[STAC_MACBOOK] = macbook_pin_configs,
|
||||||
|
[STAC_MACBOOK_PRO] = macbook_pro_pin_configs,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *stac922x_models[STAC_922X_MODELS] = {
|
static const char *stac922x_models[STAC_922X_MODELS] = {
|
||||||
@ -531,6 +549,8 @@ static const char *stac922x_models[STAC_922X_MODELS] = {
|
|||||||
[STAC_D945GTP5] = "5stack",
|
[STAC_D945GTP5] = "5stack",
|
||||||
[STAC_D945GTP3] = "3stack",
|
[STAC_D945GTP3] = "3stack",
|
||||||
[STAC_MACMINI] = "macmini",
|
[STAC_MACMINI] = "macmini",
|
||||||
|
[STAC_MACBOOK] = "macbook",
|
||||||
|
[STAC_MACBOOK_PRO] = "macbook-pro",
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct snd_pci_quirk stac922x_cfg_tbl[] = {
|
static struct snd_pci_quirk stac922x_cfg_tbl[] = {
|
||||||
@ -1864,6 +1884,18 @@ static int patch_stac922x(struct hda_codec *codec)
|
|||||||
spec->board_config = snd_hda_check_board_config(codec, STAC_922X_MODELS,
|
spec->board_config = snd_hda_check_board_config(codec, STAC_922X_MODELS,
|
||||||
stac922x_models,
|
stac922x_models,
|
||||||
stac922x_cfg_tbl);
|
stac922x_cfg_tbl);
|
||||||
|
if (spec->board_config == STAC_MACMINI) {
|
||||||
|
spec->gpio_mute = 1;
|
||||||
|
/* Intel Macs have all same PCI SSID, so we need to check
|
||||||
|
* codec SSID to distinguish the exact models
|
||||||
|
*/
|
||||||
|
switch (codec->subsystem_id) {
|
||||||
|
case 0x106b1e00:
|
||||||
|
spec->board_config = STAC_MACBOOK_PRO;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
again:
|
again:
|
||||||
if (spec->board_config < 0) {
|
if (spec->board_config < 0) {
|
||||||
snd_printdd(KERN_INFO "hda_codec: Unknown model for STAC922x, "
|
snd_printdd(KERN_INFO "hda_codec: Unknown model for STAC922x, "
|
||||||
@ -1904,9 +1936,6 @@ static int patch_stac922x(struct hda_codec *codec)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (spec->board_config == STAC_MACMINI)
|
|
||||||
spec->gpio_mute = 1;
|
|
||||||
|
|
||||||
codec->patch_ops = stac92xx_patch_ops;
|
codec->patch_ops = stac92xx_patch_ops;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1919,6 +1919,8 @@ snd_riptide_create(struct snd_card *card, struct pci_dev *pci,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
snd_card_set_dev(card, &pci->dev);
|
||||||
|
|
||||||
*rchip = chip;
|
*rchip = chip;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -4468,6 +4468,8 @@ static int __devinit snd_hdspm_probe(struct pci_dev *pci,
|
|||||||
hdspm->dev = dev;
|
hdspm->dev = dev;
|
||||||
hdspm->pci = pci;
|
hdspm->pci = pci;
|
||||||
|
|
||||||
|
snd_card_set_dev(card, &pci->dev);
|
||||||
|
|
||||||
if ((err =
|
if ((err =
|
||||||
snd_hdspm_create(card, hdspm, precise_ptr[dev],
|
snd_hdspm_create(card, hdspm, precise_ptr[dev],
|
||||||
enable_monitor[dev])) < 0) {
|
enable_monitor[dev])) < 0) {
|
||||||
|
@ -39,7 +39,7 @@ static int ac97_write(struct snd_soc_codec *codec,
|
|||||||
*/
|
*/
|
||||||
static const u16 wm9712_reg[] = {
|
static const u16 wm9712_reg[] = {
|
||||||
0x6174, 0x8000, 0x8000, 0x8000, // 6
|
0x6174, 0x8000, 0x8000, 0x8000, // 6
|
||||||
0xf0f0, 0xaaa0, 0xc008, 0x6808, // e
|
0x0f0f, 0xaaa0, 0xc008, 0x6808, // e
|
||||||
0xe808, 0xaaa0, 0xad00, 0x8000, // 16
|
0xe808, 0xaaa0, 0xad00, 0x8000, // 16
|
||||||
0xe808, 0x3000, 0x8000, 0x0000, // 1e
|
0xe808, 0x3000, 0x8000, 0x0000, // 1e
|
||||||
0x0000, 0x0000, 0x0000, 0x000f, // 26
|
0x0000, 0x0000, 0x0000, 0x000f, // 26
|
||||||
@ -96,6 +96,7 @@ SOC_DOUBLE("Speaker Playback Volume", AC97_MASTER, 8, 0, 31, 1),
|
|||||||
SOC_SINGLE("Speaker Playback Switch", AC97_MASTER, 15, 1, 1),
|
SOC_SINGLE("Speaker Playback Switch", AC97_MASTER, 15, 1, 1),
|
||||||
SOC_DOUBLE("Headphone Playback Volume", AC97_HEADPHONE, 8, 0, 31, 1),
|
SOC_DOUBLE("Headphone Playback Volume", AC97_HEADPHONE, 8, 0, 31, 1),
|
||||||
SOC_SINGLE("Headphone Playback Switch", AC97_HEADPHONE,15, 1, 1),
|
SOC_SINGLE("Headphone Playback Switch", AC97_HEADPHONE,15, 1, 1),
|
||||||
|
SOC_DOUBLE("PCM Playback Volume", AC97_PCM, 8, 0, 31, 1),
|
||||||
|
|
||||||
SOC_SINGLE("Speaker Playback ZC Switch", AC97_MASTER, 7, 1, 0),
|
SOC_SINGLE("Speaker Playback ZC Switch", AC97_MASTER, 7, 1, 0),
|
||||||
SOC_SINGLE("Speaker Playback Invert Switch", AC97_MASTER, 6, 1, 0),
|
SOC_SINGLE("Speaker Playback Invert Switch", AC97_MASTER, 6, 1, 0),
|
||||||
|
Loading…
Reference in New Issue
Block a user