diff options
author | Takashi Iwai <tiwai@suse.de> | 2011-05-20 10:29:09 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2011-05-20 10:29:09 -0400 |
commit | 50e3bbf9898840eead86f90a43b3625a2b2f4112 (patch) | |
tree | efc2ade5103aef34f3555b387fe6bffa1cf6eff6 /sound | |
parent | 314c3ff47643c7c1f11317f81a80902af80795e3 (diff) |
ALSA: hda - Use LPIB for ATI/AMD chipsets as default
ATI and AMD chipsets seem not providing the proper position-buffer
information, and it also doesn't provide FIFO register required by
VIACOMBO fix. It's better to use LPIB for these.
Reported-by: David Henningsson <david.henningsson@canonical.com>
Cc: <stable@kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound')
-rw-r--r-- | sound/pci/hda/hda_intel.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c index 0c1996dd137b..43a036716d25 100644 --- a/sound/pci/hda/hda_intel.c +++ b/sound/pci/hda/hda_intel.c | |||
@@ -2367,9 +2367,16 @@ static int __devinit check_position_fix(struct azx *chip, int fix) | |||
2367 | /* Check VIA/ATI HD Audio Controller exist */ | 2367 | /* Check VIA/ATI HD Audio Controller exist */ |
2368 | switch (chip->driver_type) { | 2368 | switch (chip->driver_type) { |
2369 | case AZX_DRIVER_VIA: | 2369 | case AZX_DRIVER_VIA: |
2370 | case AZX_DRIVER_ATI: | ||
2371 | /* Use link position directly, avoid any transfer problem. */ | 2370 | /* Use link position directly, avoid any transfer problem. */ |
2372 | return POS_FIX_VIACOMBO; | 2371 | return POS_FIX_VIACOMBO; |
2372 | case AZX_DRIVER_ATI: | ||
2373 | /* ATI chipsets don't work well with position-buffer */ | ||
2374 | return POS_FIX_LPIB; | ||
2375 | case AZX_DRIVER_GENERIC: | ||
2376 | /* AMD chipsets also don't work with position-buffer */ | ||
2377 | if (chip->pci->vendor == PCI_VENDOR_ID_AMD) | ||
2378 | return POS_FIX_LPIB; | ||
2379 | break; | ||
2373 | } | 2380 | } |
2374 | 2381 | ||
2375 | return POS_FIX_AUTO; | 2382 | return POS_FIX_AUTO; |