mapped_tvalspec.html   [plain text]


<h2>mapped_tvalspec</h2>
<hr>
<p>
<strong>Structure</strong> - Specifies the format the kernel uses to maintain a mapped clock's time.
<h3>SYNOPSIS</h3>
<pre>
<strong>struct mapped_tvalspec</strong>
<strong>{</strong>
       <strong>tvalspec_t</strong>          <var>mtv_time</var><strong>;</strong>
       <strong>unsigned int</strong>        <var>mtv_csec</var><strong>;</strong>
<strong>};</strong>

<strong>typedef struct mapped_tvalspec mapped_tvalspec_t;</strong>
</pre>
<h3>FIELDS</h3>
<dl>
<dt> <var>mtv_time</var>
<dd>
Clock time.
<p>
<dt> <var>mtv_csec</var>
<dd>
A field used to synchronize with the kernel's setting of the time.
</dl>
<h3>DESCRIPTION</h3>
<p>
The <strong>mapped_tvalspec</strong> structure defines the format of the 
current-time structure 
maintained by the kernel and visible through a mapped clock 
(<strong>clock_map_time</strong>).  The data in this structure is updated at the 
clock's current resolution and contains the same <strong>tvalspec</strong> value that 
would be returned by <strong>clock_get_time</strong>.
<h3>NOTES</h3>
<p>
Because of the race between the referencing of the multiple fields
in the clock 
value and the kernel's setting them, they should be referenced as follows:
<p>
<pre>
   <strong>tvalspec_t* ts;</strong>
   <strong>do</strong>
   <strong>{</strong>
              <strong>ts-> tv_sec = mtime -> mtv_time.tv_sec;</strong>
              <strong>ts  -> tv_nsec = mtime -> mtv_time.tv_nsec;</strong>
   <strong>} while (ts  -> tv_sec != mtime -> mtv_csec);</strong>
</pre>
<h3>RELATED INFORMATION</h3>
<p>
Functions:
<a href="clock_map_time.html"><strong>clock_map_time</strong></a>,
<a href="clock_get_time.html"><strong>clock_get_time</strong></a>.
<p>
Data Structures:
<a href="tvalspec.html"><strong>tvalspec</strong></a>.