Sophie

Sophie

distrib > Mandriva > 2009.1 > x86_64 > media > main-testing > by-pkgid > 187676b5433787923dfa2cdd6900c6cd > files > 174

lib64pulseaudio-devel-0.9.15-2.0.7mdv2009.1.x86_64.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>PulseAudio: pa_timing_info Struct Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css">
<link href="doxygen.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.5.8 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="main.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
      <li class="current"><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li><a href="examples.html"><span>Examples</span></a></li>
    </ul>
  </div>
  <div class="tabs">
    <ul>
      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
      <li><a href="classes.html"><span>Data&nbsp;Structure&nbsp;Index</span></a></li>
      <li><a href="functions.html"><span>Data&nbsp;Fields</span></a></li>
    </ul>
  </div>
</div>
<div class="contents">
<h1>pa_timing_info Struct Reference</h1><!-- doxytag: class="pa_timing_info" -->A structure for all kinds of timing information of a stream.  
<a href="#_details">More...</a>
<p>
<table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Data Fields</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">struct timeval&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#1d7bfa57c2980cb34fd535ba700057ff">timestamp</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The time when this timing info structure was current.  <a href="#1d7bfa57c2980cb34fd535ba700057ff"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#b1b6c3d12cca0172e5d10374cb2f322c">synchronized_clocks</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Non-zero if the local and the remote machine have synchronized clocks.  <a href="#b1b6c3d12cca0172e5d10374cb2f322c"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#1fa047dbabfc097c05ebc74f66a234c8">sink_usec</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Time in usecs a sample takes to be played on the sink.  <a href="#1fa047dbabfc097c05ebc74f66a234c8"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#d34351f6a2480aa73a1afa9f9596768c">source_usec</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Time in usecs a sample takes from being recorded to being delivered to the application.  <a href="#d34351f6a2480aa73a1afa9f9596768c"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#c77f5e79645fd59640138d86e610d773">transport_usec</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Estimated time in usecs a sample takes to be transferred to/from the daemon.  <a href="#c77f5e79645fd59640138d86e610d773"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#a2b512f984e3d24e20159f542e80549a">playing</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Non-zero when the stream is currently not underrun and data is being passed on to the device.  <a href="#a2b512f984e3d24e20159f542e80549a"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#28e63adc8b284fb2d2e90e302ba1e6e4">write_index_corrupt</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Non-zero if write_index is not up-to-date because a local write command that corrupted it has been issued in the time since this latency info was current .  <a href="#28e63adc8b284fb2d2e90e302ba1e6e4"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int64_t&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#378893046ab19c58fdb50633c66c5d4a">write_index</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Current write index into the playback buffer in bytes.  <a href="#378893046ab19c58fdb50633c66c5d4a"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#b675235e605a24a7be4486beaf0c65d9">read_index_corrupt</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Non-zero if read_index is not up-to-date because a local pause or flush request that corrupted it has been issued in the time since this latency info was current.  <a href="#b675235e605a24a7be4486beaf0c65d9"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int64_t&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#5e04baf968cc1d53a7795a58b2e4f788">read_index</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Current read index into the playback buffer in bytes.  <a href="#5e04baf968cc1d53a7795a58b2e4f788"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#b0289d7d18950165d8b81825cd03b9c8">configured_sink_usec</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The configured latency for the sink.  <a href="#b0289d7d18950165d8b81825cd03b9c8"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#fa23d72067027b54b525ae547520a2df">configured_source_usec</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The configured latency for the source.  <a href="#fa23d72067027b54b525ae547520a2df"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">int64_t&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structpa__timing__info.html#d2f26c8efa733d738dade0ed1b8123d3">since_underrun</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Bytes that were handed to the sink since the last underrun happened, or since playback started again after the last underrun.  <a href="#d2f26c8efa733d738dade0ed1b8123d3"></a><br></td></tr>
</table>
<hr><a name="_details"></a><h2>Detailed Description</h2>
A structure for all kinds of timing information of a stream. 
<p>
See <a class="el" href="stream_8h.html#c8300aa5136a223b14a5384f44564284" title="Request a timing info structure update for a stream.">pa_stream_update_timing_info()</a> and <a class="el" href="stream_8h.html#090147751441a97e04a4acef1d6514cb" title="Return the latest raw timing data structure.">pa_stream_get_timing_info()</a>. The total output latency a sample that is written with <a class="el" href="stream_8h.html#4fc69dec0cc202fcc174125dc88dada7" title="Write some data to the server (for playback sinks), if free_cb is non-NULL this routine...">pa_stream_write()</a> takes to be played may be estimated by sink_usec+buffer_usec+transport_usec. (where buffer_usec is defined as pa_bytes_to_usec(write_index-read_index)) The output buffer which buffer_usec relates to may be manipulated freely (with <a class="el" href="stream_8h.html#4fc69dec0cc202fcc174125dc88dada7" title="Write some data to the server (for playback sinks), if free_cb is non-NULL this routine...">pa_stream_write()</a>'s seek argument, <a class="el" href="stream_8h.html#c9c524eb275d258b00c553409682409c" title="Flush the playback buffer of this stream.">pa_stream_flush()</a> and friends), the buffers sink_usec and source_usec relate to are first-in first-out (FIFO) buffers which cannot be flushed or manipulated in any way. The total input latency a sample that is recorded takes to be delivered to the application is: source_usec+buffer_usec+transport_usec-sink_usec. (Take care of sign issues!) When connected to a monitor source sink_usec contains the latency of the owning sink. The two latency estimations described here are implemented in <a class="el" href="stream_8h.html#a521efcc16fe2abf0f8461462432ac16" title="Return the total stream latency.">pa_stream_get_latency()</a>. Please note that this structure can be extended as part of evolutionary API updates at any time in any new release. <hr><h2>Field Documentation</h2>
<a class="anchor" name="b0289d7d18950165d8b81825cd03b9c8"></a><!-- doxytag: member="pa_timing_info::configured_sink_usec" ref="b0289d7d18950165d8b81825cd03b9c8" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a> <a class="el" href="structpa__timing__info.html#b0289d7d18950165d8b81825cd03b9c8">pa_timing_info::configured_sink_usec</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The configured latency for the sink. 
<p>
<dl class="since" compact><dt><b>Since:</b></dt><dd>0.9.11 </dd></dl>

</div>
</div><p>
<a class="anchor" name="fa23d72067027b54b525ae547520a2df"></a><!-- doxytag: member="pa_timing_info::configured_source_usec" ref="fa23d72067027b54b525ae547520a2df" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a> <a class="el" href="structpa__timing__info.html#fa23d72067027b54b525ae547520a2df">pa_timing_info::configured_source_usec</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The configured latency for the source. 
<p>
<dl class="since" compact><dt><b>Since:</b></dt><dd>0.9.11 </dd></dl>

</div>
</div><p>
<a class="anchor" name="a2b512f984e3d24e20159f542e80549a"></a><!-- doxytag: member="pa_timing_info::playing" ref="a2b512f984e3d24e20159f542e80549a" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int <a class="el" href="structpa__timing__info.html#a2b512f984e3d24e20159f542e80549a">pa_timing_info::playing</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Non-zero when the stream is currently not underrun and data is being passed on to the device. 
<p>
Only for playback streams. This field does not say whether the data is actually already being played. To determine this check whether since_underrun (converted to usec) is larger than sink_usec. 
</div>
</div><p>
<a class="anchor" name="5e04baf968cc1d53a7795a58b2e4f788"></a><!-- doxytag: member="pa_timing_info::read_index" ref="5e04baf968cc1d53a7795a58b2e4f788" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int64_t <a class="el" href="structpa__timing__info.html#5e04baf968cc1d53a7795a58b2e4f788">pa_timing_info::read_index</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Current read index into the playback buffer in bytes. 
<p>
Think twice before using this for seeking purposes: it might be out of date a the time you want to use it. Consider using PA_SEEK_RELATIVE_ON_READ instead. 
</div>
</div><p>
<a class="anchor" name="b675235e605a24a7be4486beaf0c65d9"></a><!-- doxytag: member="pa_timing_info::read_index_corrupt" ref="b675235e605a24a7be4486beaf0c65d9" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int <a class="el" href="structpa__timing__info.html#b675235e605a24a7be4486beaf0c65d9">pa_timing_info::read_index_corrupt</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Non-zero if read_index is not up-to-date because a local pause or flush request that corrupted it has been issued in the time since this latency info was current. 
<p>

</div>
</div><p>
<a class="anchor" name="d2f26c8efa733d738dade0ed1b8123d3"></a><!-- doxytag: member="pa_timing_info::since_underrun" ref="d2f26c8efa733d738dade0ed1b8123d3" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int64_t <a class="el" href="structpa__timing__info.html#d2f26c8efa733d738dade0ed1b8123d3">pa_timing_info::since_underrun</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Bytes that were handed to the sink since the last underrun happened, or since playback started again after the last underrun. 
<p>
playing will tell you which case it is. <dl class="since" compact><dt><b>Since:</b></dt><dd>0.9.11 </dd></dl>

</div>
</div><p>
<a class="anchor" name="1fa047dbabfc097c05ebc74f66a234c8"></a><!-- doxytag: member="pa_timing_info::sink_usec" ref="1fa047dbabfc097c05ebc74f66a234c8" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a> <a class="el" href="structpa__timing__info.html#1fa047dbabfc097c05ebc74f66a234c8">pa_timing_info::sink_usec</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Time in usecs a sample takes to be played on the sink. 
<p>
For playback streams and record streams connected to a monitor source. 
</div>
</div><p>
<a class="anchor" name="d34351f6a2480aa73a1afa9f9596768c"></a><!-- doxytag: member="pa_timing_info::source_usec" ref="d34351f6a2480aa73a1afa9f9596768c" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a> <a class="el" href="structpa__timing__info.html#d34351f6a2480aa73a1afa9f9596768c">pa_timing_info::source_usec</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Time in usecs a sample takes from being recorded to being delivered to the application. 
<p>
Only for record streams. 
</div>
</div><p>
<a class="anchor" name="b1b6c3d12cca0172e5d10374cb2f322c"></a><!-- doxytag: member="pa_timing_info::synchronized_clocks" ref="b1b6c3d12cca0172e5d10374cb2f322c" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int <a class="el" href="structpa__timing__info.html#b1b6c3d12cca0172e5d10374cb2f322c">pa_timing_info::synchronized_clocks</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Non-zero if the local and the remote machine have synchronized clocks. 
<p>
If synchronized clocks are detected transport_usec becomes much more reliable. However, the code that detects synchronized clocks is very limited and unreliable itself. 
</div>
</div><p>
<a class="anchor" name="1d7bfa57c2980cb34fd535ba700057ff"></a><!-- doxytag: member="pa_timing_info::timestamp" ref="1d7bfa57c2980cb34fd535ba700057ff" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">struct timeval <a class="el" href="structpa__timing__info.html#1d7bfa57c2980cb34fd535ba700057ff">pa_timing_info::timestamp</a><code> [read]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The time when this timing info structure was current. 
<p>

</div>
</div><p>
<a class="anchor" name="c77f5e79645fd59640138d86e610d773"></a><!-- doxytag: member="pa_timing_info::transport_usec" ref="c77f5e79645fd59640138d86e610d773" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="sample_8h.html#885df3b973773f0dccbbec6bc6777f89">pa_usec_t</a> <a class="el" href="structpa__timing__info.html#c77f5e79645fd59640138d86e610d773">pa_timing_info::transport_usec</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Estimated time in usecs a sample takes to be transferred to/from the daemon. 
<p>
For both playback and record streams. 
</div>
</div><p>
<a class="anchor" name="378893046ab19c58fdb50633c66c5d4a"></a><!-- doxytag: member="pa_timing_info::write_index" ref="378893046ab19c58fdb50633c66c5d4a" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int64_t <a class="el" href="structpa__timing__info.html#378893046ab19c58fdb50633c66c5d4a">pa_timing_info::write_index</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Current write index into the playback buffer in bytes. 
<p>
Think twice before using this for seeking purposes: it might be out of date a the time you want to use it. Consider using PA_SEEK_RELATIVE instead. 
</div>
</div><p>
<a class="anchor" name="28e63adc8b284fb2d2e90e302ba1e6e4"></a><!-- doxytag: member="pa_timing_info::write_index_corrupt" ref="28e63adc8b284fb2d2e90e302ba1e6e4" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int <a class="el" href="structpa__timing__info.html#28e63adc8b284fb2d2e90e302ba1e6e4">pa_timing_info::write_index_corrupt</a>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Non-zero if write_index is not up-to-date because a local write command that corrupted it has been issued in the time since this latency info was current . 
<p>
Only write commands with SEEK_RELATIVE_ON_READ and SEEK_RELATIVE_END can corrupt write_index. 
</div>
</div><p>
<hr>The documentation for this struct was generated from the following file:<ul>
<li><a class="el" href="def_8h-source.html">def.h</a></ul>
</div>
<hr size="1"><address style="text-align: right;"><small>Generated on Wed Sep 2 04:18:20 2009 for PulseAudio by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address>
</body>
</html>