[PATCH] aoa i2sbus: Stop Apple i2s DMA gracefully
Takashi Iwai
tiwai at suse.de
Fri Feb 9 01:07:44 EST 2007
At Thu, 08 Feb 2007 14:12:37 +0100,
Johannes Berg wrote:
>
> From: Paul Mackerras <paulus at samba.org>
>
> 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.
>
> Signed-off-by: Paul Mackerras <paulus at samba.org>
>
> 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: Johannes Berg <johannes at sipsolutions.net>
Thanks, applied to ALSA tree now. Should be merged to 2.6.21.
Takashi
More information about the Linuxppc-dev
mailing list