<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW - protocol-native: I get endless underruns when I playback when alsa buffer size is small"
href="https://bugs.freedesktop.org/show_bug.cgi?id=84878#c16">Comment # 16</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW - protocol-native: I get endless underruns when I playback when alsa buffer size is small"
href="https://bugs.freedesktop.org/show_bug.cgi?id=84878">bug 84878</a>
from <span class="vcard"><a class="email" href="mailto:prahal@yahoo.com" title="Alban Browaeys <prahal@yahoo.com>"> <span class="fn">Alban Browaeys</span></a>
</span></b>
<pre>(In reply to Raymond from <a href="show_bug.cgi?id=84878#c14">comment #14</a>)
<span class="quote">> (In reply to Alban Browaeys from <a href="show_bug.cgi?id=84878#c12">comment #12</a>)
> > Created <span class=""><a href="attachment.cgi?id=112915" name="attach_112915" title="pcm_avail.c results : results from BURST">attachment 112915</a> <a href="attachment.cgi?id=112915&action=edit" title="pcm_avail.c results : results from BURST">[details]</a></span>
> > pcm_avail.c results : results from BURST
> >
> > DESCRIPTOR results are same for setup output, only diff is in Playing silence
>
> how do the hardware support both modes ?</span >
The hardware is burst in that it has register to get the progress (destination
and source address registers).
Only that current kernel code does not get their values thus behaves the
descriptor way.
<span class="quote">> it is strange that the avail increment by one in brust mode and not by
> period size in descriptor mode</span >
Sorry an artefact : I switched only mode from BURST to DESCRIPTOR mode. When I
revert the whole changeset avail increment by 1024.
Playing silence
now_us-last_us=1987690780 now_us-start_us=32 time_us-start_us=20
time_us-last_time=1987690768 time_us-start_time=9 Available: 0 loop
iteration: 0
now_us-last_us=27 now_us-start_us=20064 time_us-start_us=20040
time_us-last_time=8 time_us-start_time=20029 Available: 1024
loop iteration: 2117
now_us-last_us=26 now_us-start_us=41395 time_us-start_us=41372
time_us-last_time=8 time_us-start_time=41361 Available: 2048
loop iteration: 4844
now_us-last_us=26 now_us-start_us=62725 time_us-start_us=62702
time_us-last_time=8 time_us-start_time=62691 Available: 3072
loop iteration: 7575
still a bit dubious as to why there is a different behaviour then (after all
the only diff is that I compute the residue which should not matter in
descriptor mode as not used).
But mind that be it with the full revert or the partial revert both exhibit the
same issue this report is about :
"the client always request a prebuf equal or greater than minreq. Only when
heuristics in fix__playback_buffer_attr increase minreq they do not change
prebuf)."</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the QA Contact for the bug.</li>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>