Commit 81c3795c authored by Jaroslav Kysela's avatar Jaroslav Kysela

ALSA CVS update - Takashi Iwai <tiwai@suse.de>

Documentation,VIA82xx driver
- added dxs_support=4 option.  no VRA is used for DXS channels in this case.
- fixed the quirk for ASUS A7V8-X.
- added the quirk for Gigabyte mobo.
- removed the error message in codec_valid().
parent 4c742bc3
...@@ -994,7 +994,7 @@ Module parameters ...@@ -994,7 +994,7 @@ Module parameters
ac97_clock - AC'97 codec clock base (default 48000Hz) ac97_clock - AC'97 codec clock base (default 48000Hz)
dxs_support - support DXS channels, dxs_support - support DXS channels,
0 = auto (defalut), 1 = enable, 2 = disable, 0 = auto (defalut), 1 = enable, 2 = disable,
3 = 48k only 3 = 48k only, 4 = no VRA
[VIA8233/C,8235 only] [VIA8233/C,8235 only]
Module supports autoprobe and multiple bus-master chips (max 8). Module supports autoprobe and multiple bus-master chips (max 8).
...@@ -1008,13 +1008,20 @@ Module parameters ...@@ -1008,13 +1008,20 @@ Module parameters
Note: VIA8233/5 (not VIA8233A) can support DXS (direct sound) Note: VIA8233/5 (not VIA8233A) can support DXS (direct sound)
channels as the first PCM. On these channels, up to 4 channels as the first PCM. On these channels, up to 4
streams can be played at the same time. streams can be played at the same time.
As default (dxs_support = 0), 48k fixed rate is chosen since As default (dxs_support = 0), 48k fixed rate is chosen
the output is often noisy except for 48k on some mother except for the known devices since the output is often
boards due to the bug of BIOS. noisy except for 48k on some mother boards due to the
bug of BIOS.
Please try once dxs_support=1 and if it works on other Please try once dxs_support=1 and if it works on other
sample rates, please let us know the PCI subsystem sample rates (e.g. 44.1kHz of mp3 playback), please let us
vendor/device id's (output of "lspci -nv"). know the PCI subsystem vendor/device id's (output of
If it doesn't work, use dxs_support=3 or dxs_support=2. "lspci -nv").
If it doesn't work, try dxs_support=4. If it still doesn't
work and the default setting is ok, dxs_support=3 is the
right choice. If the default setting doesn't work at all,
try dxs_support=2 to disable the DXS channels.
In any cases, please let us know the result and the
subsystem vendor/device ids.
Note: for the MPU401 on VIA823x, use snd-mpu401 driver Note: for the MPU401 on VIA823x, use snd-mpu401 driver
additonally. The mpu_port option is for VIA686 chips only. additonally. The mpu_port option is for VIA686 chips only.
......
...@@ -92,7 +92,7 @@ MODULE_PARM(ac97_clock, "1-" __MODULE_STRING(SNDRV_CARDS) "i"); ...@@ -92,7 +92,7 @@ MODULE_PARM(ac97_clock, "1-" __MODULE_STRING(SNDRV_CARDS) "i");
MODULE_PARM_DESC(ac97_clock, "AC'97 codec clock (default 48000Hz)."); MODULE_PARM_DESC(ac97_clock, "AC'97 codec clock (default 48000Hz).");
MODULE_PARM_SYNTAX(ac97_clock, SNDRV_ENABLED ",default:48000"); MODULE_PARM_SYNTAX(ac97_clock, SNDRV_ENABLED ",default:48000");
MODULE_PARM(dxs_support, "1-" __MODULE_STRING(SNDRV_CARDS) "i"); MODULE_PARM(dxs_support, "1-" __MODULE_STRING(SNDRV_CARDS) "i");
MODULE_PARM_DESC(dxs_support, "Support for DXS channels (0 = auto, 1 = enable, 2 = disable, 3 = 48k only)"); MODULE_PARM_DESC(dxs_support, "Support for DXS channels (0 = auto, 1 = enable, 2 = disable, 3 = 48k only, 4 = no VRA)");
MODULE_PARM_SYNTAX(dxs_support, SNDRV_ENABLED ",allows:{{0,3}},dialog:list"); MODULE_PARM_SYNTAX(dxs_support, SNDRV_ENABLED ",allows:{{0,3}},dialog:list");
...@@ -290,6 +290,7 @@ DEFINE_VIA_REGSET(CAPTURE_8233, 0x60); ...@@ -290,6 +290,7 @@ DEFINE_VIA_REGSET(CAPTURE_8233, 0x60);
#define VIA_DXS_ENABLE 1 #define VIA_DXS_ENABLE 1
#define VIA_DXS_DISABLE 2 #define VIA_DXS_DISABLE 2
#define VIA_DXS_48K 3 #define VIA_DXS_48K 3
#define VIA_DXS_NO_VRA 4
/* /*
...@@ -449,6 +450,7 @@ struct _snd_via82xx { ...@@ -449,6 +450,7 @@ struct _snd_via82xx {
viadev_t devs[VIA_MAX_DEVS]; viadev_t devs[VIA_MAX_DEVS];
struct via_rate_lock rates[2]; /* playback and capture */ struct via_rate_lock rates[2]; /* playback and capture */
unsigned int dxs_fixed: 1; /* DXS channel accepts only 48kHz */ unsigned int dxs_fixed: 1; /* DXS channel accepts only 48kHz */
unsigned int no_vra: 1; /* no need to set VRA on DXS channels */
snd_rawmidi_t *rmidi; snd_rawmidi_t *rmidi;
...@@ -509,7 +511,6 @@ static int snd_via82xx_codec_valid(via82xx_t *chip, int secondary) ...@@ -509,7 +511,6 @@ static int snd_via82xx_codec_valid(via82xx_t *chip, int secondary)
if ((val = snd_via82xx_codec_xread(chip)) & stat) if ((val = snd_via82xx_codec_xread(chip)) & stat)
return val & 0xffff; return val & 0xffff;
} }
snd_printk(KERN_ERR "codec_valid: codec %i is not valid [0x%x]\n", secondary, snd_via82xx_codec_xread(chip));
return -EIO; return -EIO;
} }
...@@ -554,6 +555,7 @@ static unsigned short snd_via82xx_codec_read(ac97_t *ac97, unsigned short reg) ...@@ -554,6 +555,7 @@ static unsigned short snd_via82xx_codec_read(ac97_t *ac97, unsigned short reg)
while (1) { while (1) {
if (again++ > 3) { if (again++ > 3) {
spin_unlock(&chip->ac97_lock); spin_unlock(&chip->ac97_lock);
snd_printk(KERN_ERR "codec_read: codec %i is not valid [0x%x]\n", ac97->num, snd_via82xx_codec_xread(chip));
return 0xffff; return 0xffff;
} }
snd_via82xx_codec_xwrite(chip, xval); snd_via82xx_codec_xwrite(chip, xval);
...@@ -889,11 +891,11 @@ static int snd_via8233_playback_prepare(snd_pcm_substream_t *substream) ...@@ -889,11 +891,11 @@ static int snd_via8233_playback_prepare(snd_pcm_substream_t *substream)
if ((rate_changed = via_lock_rate(&chip->rates[0], runtime->rate)) < 0) if ((rate_changed = via_lock_rate(&chip->rates[0], runtime->rate)) < 0)
return rate_changed; return rate_changed;
if (rate_changed) { if (rate_changed || chip->no_vra) {
snd_ac97_set_rate(chip->ac97, AC97_PCM_FRONT_DAC_RATE, runtime->rate); snd_ac97_set_rate(chip->ac97, AC97_PCM_FRONT_DAC_RATE,
snd_ac97_set_rate(chip->ac97, AC97_PCM_SURR_DAC_RATE, runtime->rate); chip->no_vra ? 48000 : runtime->rate);
snd_ac97_set_rate(chip->ac97, AC97_PCM_LFE_DAC_RATE, runtime->rate); if (rate_changed)
snd_ac97_set_rate(chip->ac97, AC97_SPDIF, runtime->rate); snd_ac97_set_rate(chip->ac97, AC97_SPDIF, runtime->rate);
} }
#if 0 #if 0
if (chip->revision == VIA_REV_8233A) if (chip->revision == VIA_REV_8233A)
...@@ -1974,8 +1976,9 @@ static int __devinit check_dxs_list(struct pci_dev *pci) ...@@ -1974,8 +1976,9 @@ static int __devinit check_dxs_list(struct pci_dev *pci)
{ {
static struct dxs_whitelist whitelist[] = { static struct dxs_whitelist whitelist[] = {
{ .vendor = 0x1019, .device = 0x0996, .action = VIA_DXS_48K }, { .vendor = 0x1019, .device = 0x0996, .action = VIA_DXS_48K },
{ .vendor = 0x1043, .device = 0x80a1, .action = VIA_DXS_NO_VRA }, /* ASUS A7V8-X */
{ .vendor = 0x1297, .device = 0xc160, .action = VIA_DXS_ENABLE }, /* Shuttle SK41G */ { .vendor = 0x1297, .device = 0xc160, .action = VIA_DXS_ENABLE }, /* Shuttle SK41G */
{ .vendor = 0x1043, .device = 0x80a1, .action = VIA_DXS_ENABLE }, /* ASUS A7V8-X */ { .vendor = 0x1458, .device = 0xa002, .action = VIA_DXS_ENABLE }, /* Gigabyte GA-7VAXP */
{ .vendor = 0x1462, .device = 0x7120, .action = VIA_DXS_ENABLE }, /* MSI KT4V */ { .vendor = 0x1462, .device = 0x7120, .action = VIA_DXS_ENABLE }, /* MSI KT4V */
{ } /* terminator */ { } /* terminator */
}; };
...@@ -2002,7 +2005,8 @@ static int __devinit check_dxs_list(struct pci_dev *pci) ...@@ -2002,7 +2005,8 @@ static int __devinit check_dxs_list(struct pci_dev *pci)
* not detected, try 48k rate only to be sure. * not detected, try 48k rate only to be sure.
*/ */
printk(KERN_INFO "via82xx: Assuming DXS channels with 48k fixed sample rate.\n"); printk(KERN_INFO "via82xx: Assuming DXS channels with 48k fixed sample rate.\n");
printk(KERN_INFO " Please try dxs_support=1 option and report if it works on your machine.\n"); printk(KERN_INFO " Please try dxs_support=1 or dxs_support=4 option\n");
printk(KERN_INFO " and report if it works on your machine.\n");
return VIA_DXS_48K; return VIA_DXS_48K;
}; };
...@@ -2087,6 +2091,8 @@ static int __devinit snd_via82xx_probe(struct pci_dev *pci, ...@@ -2087,6 +2091,8 @@ static int __devinit snd_via82xx_probe(struct pci_dev *pci,
goto __error; goto __error;
if (dxs_support[dev] == VIA_DXS_48K) if (dxs_support[dev] == VIA_DXS_48K)
chip->dxs_fixed = 1; chip->dxs_fixed = 1;
else if (dxs_support[dev] == VIA_DXS_NO_VRA)
chip->no_vra = 1;
} }
if ((err = snd_via8233_init_misc(chip, dev)) < 0) if ((err = snd_via8233_init_misc(chip, dev)) < 0)
goto __error; goto __error;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment