]> git.alsa-project.org Git - alsa-lib.git/commit
pcm: initialize pcm_dmix monotonic field
authorOlivier Langlois <olivier@trillion01.com>
Thu, 23 Jan 2014 00:04:45 +0000 (19:04 -0500)
committerTakashi Iwai <tiwai@suse.de>
Thu, 23 Jan 2014 08:42:01 +0000 (09:42 +0100)
commite51cd448971c472d75dd700b0000988f6197b4da
treeee551bd65c7e4e2715863062de16456137b44b83
parent336dc58beba0ca7cf5650dc12ed3eb72d61ac6d3
pcm: initialize pcm_dmix monotonic field

not doing so, leaves the pcm object in an inconsistent state since
'info' field is copied from the slave which is then used when
snd_pcm_hw_params_is_monotonic() is called.

For instance, when using dmix with aplay and an underrun is occuring, the following
info is returned:

underrun!!! (at least 1248687948.256 ms long)
Status:
  state       : XRUN
  trigger_time: 1390347762.628483000
  tstamp      : 1390347766.184350000
  delay       : -635
  avail       : 15687
  avail_max   : 15675

now is computed from CLOCK_MONOTONIC while pcm status tstamps are from gettimeofday().

After the fix, underruns are still occuring on my setup but at least the displayed info
is correct:

underrun!!! (at least 7630.409 ms long)
Status:
  state       : XRUN
  trigger_time: 7652.739201431
  tstamp      : 7660.369600636
  delay       : -624
  avail       : 15676
  avail_max   : 15664

Signed-off-by: Olivier Langlois <olivier@trillion01.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
src/pcm/pcm_direct.c
src/pcm/pcm_dmix.c