linux/sound
Paul Mackerras 547ac2ae38 [ALSA] aoa i2sbus: Stop Apple i2s DMA gracefully
This fixes the problem of getting extra bytes inserted at the
beginning of a recording when using the Apple i2s interface and DBDMA
controller.  It turns out that we can't just abort the DMA; we have to
let it stop at the end of a command, and then wait for the S7 bit to
be set before turning off the DBDMA controller.  Doing that for
playback doesn't seem to be necessary, but doesn't hurt either.
We use the technique used by the Darwin driver: make each transfer
command branch to a stop command if the S0 status bit is set.  Thus we
can ask the DMA controller to stop at the end of the current command
by setting S0.
The interrupt routine now looks at and clears the status word of the
DBDMA command ring.  This is necessary so it can know when the DBDMA
controller has seen that S0 is set, and so when it should look for the
DBDMA controller being stopped and S7 being set.  This also ended up
simplifying the calculation in i2sbus_pcm_pointer.
Tested on a 15 inch albook.
[Addition by Johannes]
I modified this patch and added the suspend/resume bits to it to get my
powermac into a decent state when playing sound across suspend to disk
that has a different bitrate from what the firmware programs the
hardware to.
I also added the SNDRV_PCM_INFO_JOINT_DUPLEX flag because it seemed the
right thing to do and I was looking at the info stuff.

Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Jaroslav Kysela <perex@suse.cz>
2007-02-09 09:04:02 +01:00
..
aoa [ALSA] aoa i2sbus: Stop Apple i2s DMA gracefully 2007-02-09 09:04:02 +01:00
arm [ALSA] arm header fix 2007-02-09 09:02:22 +01:00
core [ALSA] Fix possible deadlocks in sequencer at removal of ports 2007-02-09 09:03:58 +01:00
drivers [ALSA] Add even more 'const' to everything related to TLV 2007-02-09 09:03:19 +01:00
i2c [ALSA] snd-ak4114: Fix two array overflows 2007-02-09 09:03:55 +01:00
isa [ALSA] Add even more 'const' to everything related to TLV 2007-02-09 09:03:19 +01:00
mips IRQ: Maintain regs pointer globally rather than passing to IRQ handlers 2006-10-05 15:10:12 +01:00
oss [PATCH] more work_struct fixes: tas300x sound drivers 2006-12-17 19:07:21 -08:00
parisc IRQ: Maintain regs pointer globally rather than passing to IRQ handlers 2006-10-05 15:10:12 +01:00
pci [ALSA] hda-codec - Add support for Fujitsu PI1556 Realtek ALC880 2007-02-09 09:04:00 +01:00
pcmcia [ALSA] Add even more 'const' to everything related to TLV 2007-02-09 09:03:19 +01:00
ppc WorkStruct: make allyesconfig 2006-11-22 14:57:56 +00:00
soc [ALSA] soc - Clean up with kmemdup() 2007-02-09 09:03:56 +01:00
sparc [ALSA] sparc dbri comment fix 2007-02-09 09:02:37 +01:00
synth [ALSA] Fix disconnection of proc interface 2006-09-23 10:36:48 +02:00
usb [ALSA] usbaudio - Add support for Edirol UA-101 2007-02-09 09:03:53 +01:00
ac97_bus.c [ALSA] ac97_bus power management 2007-02-09 09:03:54 +01:00
Kconfig [ALSA] ASoC: Build files 2007-02-09 09:00:19 +01:00
last.c
Makefile [ALSA] ASoC: Build files 2007-02-09 09:00:19 +01:00
sound_core.c Driver core: convert sound core to use struct device 2006-12-01 14:52:01 -08:00
sound_firmware.c [PATCH] struct path: convert sound 2006-12-08 08:28:49 -08:00