[alsa-devel] [PATCH v2] ALSA: hda - Apply codec delay to wallclock.
Takashi Iwai
tiwai at suse.de
Sat Apr 13 10:55:19 CEST 2013
At Fri, 12 Apr 2013 10:55:27 +0200,
Takashi Iwai wrote:
>
> At Thu, 11 Apr 2013 19:17:10 -0600,
> Pierre-Louis Bossart wrote:
> >
> >
> > >> For playback audio_timestamp = wallclk - codec_delay_in_nsec
> > >> for capture audio_timestamp = wallclk + codec_delay_in_nsec
> > >
> > > Hmm... I'm confused, too. From a pretty generic view,
> > >
> > > - hwptr = the samples (frames) transferred on the (memory) buffer
> > > - hwptr + PCM delay = the point being currently captured
> > >
> > > Which position does the wall clock correspond?
> >
> > you now have 3 positions:
> >
> > For capture:
> > hwptr = sample in memory
> > hwptr+ delay = sample recorded on link (tracked by LPIB and wallclock)
> > hwptr+ delay + codec_delay = sample recorded by A/D
> >
> > For playback
> > hwptr = next sample in memory to be DMA'ed
> > hwptr - delay = sample pushed on link (tracked by LPIB and wallclock)
> > hwptr - delay - codec_delay = sample played in A/D
> >
> > the wallclock is only at the soc/chipset level, it doesn't know anything
> > about the peripheral.
> > Makes sense?
>
> Thanks, now it's clearer.
Dylan, could you care to submit the fix patch?
thanks,
Takashi
More information about the Alsa-devel
mailing list