[alsa-devel] [PATCH RFC 5/9] ALSA: core: selection of audio_tstamp type and accuracy reports
Takashi Iwai
tiwai at suse.de
Wed Dec 10 21:08:48 CET 2014
At Wed, 10 Dec 2014 18:39:09 +0100,
Takashi Iwai wrote:
>
> At Wed, 10 Dec 2014 11:27:26 -0600,
> Pierre-Louis Bossart wrote:
> >
> > On 12/10/14, 10:35 AM, Takashi Iwai wrote:
> > > Just a minor issue before going to detailed review:
> > >
> > > At Mon, 8 Dec 2014 16:23:42 -0600,
> > > Pierre-Louis Bossart wrote:
> > >>
> > >> +/* user space provides config to kernel */
> > >> +struct snd_pcm_audio_tstamp_config {
> > >> + __u32 type_requested:4;
> > >> + __u32 report_delay:1; /* add total delay to A/D or D/A */
> > >> +};
> > > ....
> > >> +/* kernel provides report to user-space */
> > >> +struct snd_pcm_audio_tstamp_report {
> > >> + /* actual type if hardware could not support requested timestamp */
> > >> + __u32 actual_type:4;
> > >> +
> > >> + /* accuracy represented in mantissa/exponent form */
> > >> + __u32 accuracy_report:1; /* 0 if accuracy unknown, 1 if rest of structure is valid */
> > >> + __u32 accuracy_m:7; /* 0..127, ~3 significant digit for mantissa */
> > >> + __u32 accuracy_e:4; /* base10 exponent, 0 for ns, 3 for us, 6 for ms, 9 for s */
> > >> +};
> > >
> > > Please avoid the bit fields in these, since these values will be a
> > > part of ABI. There is absolutely no compatibility when you're using
> > > bitfields. Use the explicit bit operations.
> >
> > Those definitions are not used as part of the kernel/user interaction, I
> > did use pack/unpack operations as requested in previous reviews. see
> > snd_pcm_unpack_tstamp_config and snd_pcm_pack_audio_tstamp_report.
> > A similar pack/unpack operation is provided in the alsa-lib patches
> > The data is exchanged using the reclaimed 32-bit word only.
> >
> > Would that work?
>
> Ah OK, then it's fine. Then could you add more comments mentioning
> that the structs are internal only and converted by the dedicated
> functions for kernel ABI?
>
> Also, use simple u32 instead of __u32. Then it's clearer that it's an
> internal usage.
A few more items that came to my mind later:
- It'd be better to align both input and output; namely, the input
struct and output struct must be compatible.
Currently, report_delay flag is overwritten in return. This bit
should be kept upon read back.
This essentially unifies snd_pcm_audio_tstamp_config and
snd_pcm_audio_tstamp_report. We don't have to pass two structs to
callbacks.
- Or, we may avoid packing/unpacking by defining the struct like:
unsigned char type;
unsigned char flags;
unsigned char accuracy_mantessa;
unsigned char accuracy_exponent;
where flags field contains the bit flags for report_delay and
accuracy_report.
That said, I'm worrying a bit about the complexity of the new
callback function.
- The biggest concern I have now is whether it's really feasible to
change the semantics of snd_pcm_status ioctl, i.e. from the
read-only to the write-read. I guess this would work as the padding
field is very likely zero even in the very old alsa-lib version.
- Another concern is the compatibility with the current wallclock
implementation. Judging from your patch, the audio_tstamp won't be
obtained from get_time_info callback in the default tstamp mode,
right? This may result in a regression, as currently the driver
always gives the h/w audio_tstamp when the driver supports the
wallclock.
- Last but not least: we're receiving multiple enhancement requests
regarding tstamp at the very same time. This patchset conflicts
with Tim and Nick's start_at extention.
I believe this can be resolved later, but let's discuss the ground
line at first: the requirement and influence on both changes.
thanks,
Takashi
More information about the Alsa-devel
mailing list