Hi all,
I am trying to understand the precision of htimestamp for samples captured with
a kernel real-time, and I am not sure if I understood well, because I have
found old informations togheter with new informations and I've the doubt that
something changed. I am interested in this because of a project for my degree
thesis.
snd_pcm_hw_params_supports_audio_wallclock_ts returns 0 on capture, so my
hardware doesn't support wallclock timestamps on capture.
I've understood that SND_PCM_TSTAMP_ENABLE is equivalent to
SND_PCM_TSTAMP_MMAP, so it updates timestamp at every position update on DMA
from the driver. I've read elsewhere that this timestamp is updated every
period-size ( equal interrupt), is it correct?
I've digged in the code to understand better inner working of htimestamp, but
I've found that snd_pcm_htimestamp in pcm.c calls:
err = pcm->fast_ops->htimestamp(pcm->fast_op_arg, avail, tstamp);
And I have not found where fast_ops is initialized, maybe in the driver? Anyway
I thougth that maybe in my case the called function is snd_pcm_hw_htimestamp in
pcm_hw.c :
" while (1) {
avail1 = snd_pcm_hw_avail_update(pcm);
if (avail1 < 0)
return avail1;
if (ok && (snd_pcm_uframes_t)avail1 == *avail)
break;
*avail = avail1;
*tstamp = snd_pcm_hw_fast_tstamp(pcm);
ok = 1;
}"
that calls snd_pcm_hw_fast_tstamp, that calls finally:
"#define FAST_PCM_TSTAMP(hw) \
((hw)->mmap_status->tstamp)
"
And finally is this the timestamp that is updated every period-size? Am I
correct that in the case that hardware doesn't support wallclock timestamp is
snd_pcm_hw_htimestamp in pcm_hw.c the called function?
Thanks in advance
------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
Alsa-user mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/alsa-user