]> git.ipfire.org Git - people/ms/linux.git/commitdiff
ALSA: ca0106: Disable IZD on SB0570 DAC to fix audio pops
authorAlex Stanoev <alex@astanoev.com>
Sun, 28 Oct 2018 16:55:12 +0000 (16:55 +0000)
committerTakashi Iwai <tiwai@suse.de>
Mon, 29 Oct 2018 15:59:06 +0000 (16:59 +0100)
The Creative Audigy SE (SB0570) card currently exhibits an audible pop
whenever playback is stopped or resumed, or during silent periods of an
audio stream. Initialise the IZD bit to the 0 to eliminate these pops.

The Infinite Zero Detection (IZD) feature on the DAC causes the output
to be shunted to Vcap after 2048 samples of silence. This discharges the
AC coupling capacitor through the output and causes the aforementioned
pop/click noise.

The behaviour of the IZD bit is described on page 15 of the WM8768GEDS
datasheet: "With IZD=1, applying MUTE for 1024 consecutive input samples
will cause all outputs to be connected directly to VCAP. This also
happens if 2048 consecutive zero input samples are applied to all 6
channels, and IZD=0. It will be removed as soon as any channel receives
a non-zero input". I believe the second sentence might be referring to
IZD=1 instead of IZD=0 given the observed behaviour of the card.

This change should make the DAC initialisation consistent with
Creative's Windows driver, as this popping persists when initialising
the card in Linux and soft rebooting into Windows, but is not present on
a cold boot to Windows.

Signed-off-by: Alex Stanoev <alex@astanoev.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/ca0106/ca0106.h

index 04402c14cb2392276bb23308244c626b6539fc4e..9847b669cf3cf0fbc698e89fd78774ace013d619 100644 (file)
 #define SPI_PL_BIT_R_R         (2<<7)  /* right channel = right */
 #define SPI_PL_BIT_R_C         (3<<7)  /* right channel = (L+R)/2 */
 #define SPI_IZD_REG            2
-#define SPI_IZD_BIT            (1<<4)  /* infinite zero detect */
+#define SPI_IZD_BIT            (0<<4)  /* infinite zero detect */
 
 #define SPI_FMT_REG            3
 #define SPI_FMT_BIT_RJ         (0<<0)  /* right justified mode */