<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>