[alsa-devel] [PATCH] ASoC: Intel: Bsw: Read sst DSP DMA pointer after period elapse occurs

Fang, Yang A yang.a.fang at intel.com
Thu Aug 20 03:30:21 CEST 2015



> -----Original Message-----
> From: Fang, Yang A
> Sent: Wednesday, August 19, 2015 6:25 PM
> To: 'Mark Brown'
> Cc: lgirdwood at gmail.com; alsa-devel at alsa-project.org;
> dgreid at chromium.org; Nujella, Sathyanarayana;
> kevin.strasser at linux.intel.com; Sripathi, Srinivas; Iriawan, Denny; Jain,
> Praveen K; Koul, Vinod; Mirche, Dinesh
> Subject: RE: [PATCH] ASoC: Intel: Bsw: Read sst DSP DMA pointer after
> period elapse occurs
> 
> 
> 
> > -----Original Message-----
> > From: Mark Brown [mailto:broonie at kernel.org]
> > Sent: Tuesday, August 18, 2015 5:35 PM
> > To: Fang, Yang A
> > Cc: lgirdwood at gmail.com; alsa-devel at alsa-project.org;
> > dgreid at chromium.org; Nujella, Sathyanarayana;
> > kevin.strasser at linux.intel.com; Sripathi, Srinivas; Iriawan, Denny;
> > Jain, Praveen K; Koul, Vinod; Mirche, Dinesh
> > Subject: Re: [PATCH] ASoC: Intel: Bsw: Read sst DSP DMA pointer after
> > period elapse occurs
> >
> > On Tue, Aug 18, 2015 at 05:33:33PM +0000, Fang, Yang A wrote:
> >
> > > > > We should not read sst hw_ptr and pcm_delay in
> > > > > sst_platform_pcm_pointer Since it will be ricky if
> > > > > sst_platform_pcm_pointer is called while dsp is updating the
> > > > > timestamp.Now read sst hw_ptr after period elapse interrupt occurs.
> >
> > > > So I guess there's still some risk that we could run into problems
> > > > here if we take too long to service the interrupt and/or the
> > > > period is very short?  Is there anything we can do to improve that?
> >
> > >  I think before and after the patch. There is no difference in term
> > > of handling the period elapse interrupt . because before the patch
> > > sst_period_elapsed calls the snd_pcm_period_elapsed which in turn
> > > calling the sst_platform_pcm_pointer which calls the
> stream_read_tstamp.
> >
> > I'm not sure I understand what the patch fixes then?  My concern is
> > that we're just moving the timing around which changes but doesn't
> > address the race condition.
> 
> We are seeing the issue during the long time playback.
> The ring_buffer_counter (part of snd_sst_tstamp  struct )supposes only
> increasing by the firmware  once firmware fetches  one period size of data.
>  It will update the ring_buffer_counter in the mailbox and trigger a period
> elapse interrupt.  We have found the ring_buffer_counter got decreased
> during long time playback if we  call stream_read_tstamp to read mailbox  in
> sst_platform_pcm_pointer function.
> 
> There are two cases sst_platform_pcm_pointer will be getting called. One is
> called by sst_period_elapsed function.
>  The second case is triggered by the userspace ioctl . The second case
> supposes reading the same case  ring_buffer_counter  value as last  read
> when period elapse interrupt  occurs . However we saw it somehow
> decreases.This causes audio stutter.

So I moved  stream_read_tstamp  to read the mailbox sst_period_elapsed to make sure read after receving the interrupt
and return a cached value if other place tried to read. you are right this is indeed a workaround patch for the time being


More information about the Alsa-devel mailing list