<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_ASSIGNED "
   title="ASSIGNED --- - High latency in HTTP streaming"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=65703#c60">Comment # 60</a>
              on <a class="bz_bug_link 
          bz_status_ASSIGNED "
   title="ASSIGNED --- - High latency in HTTP streaming"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=65703">bug 65703</a>
              from <span class="vcard"><a class="email" href="mailto:tanuk@iki.fi" title="Tanu Kaskinen <tanuk@iki.fi>"> <span class="fn">Tanu Kaskinen</span></a>
</span></b>
        <pre>I think I have now a bit better idea of how source rewinding works. I still
don't think that setting a rewind callback for the source output implementation
is a good idea. It does reduce the latency, because data doesn't get buffered
in pa_source_output.thread_info.delay_memblock if the callback is set. However,
the delay_memblockq exists for a reason: clients can't handle the stream time
going backwards, which is what happens on rewinds, so there must be a buffer
somewhere that hides the rewind events from clients. If you disable the buffer
in pa_source_output, you should implement a similar buffer in protocol-http,
but your patch doesn't implement that. The result is that your patch most
likely causes non-continuities in the audio, when rewinds occur.

If the latency caused by the delay memblockq is too large, the solution is to
request lower latency from the source output. This should reduce the maximum
rewind size, and therefore also the size of the delay memblockq.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the QA Contact for the bug.</li>
      </ul>
    </body>
</html>