URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [doc/] [html/] [ref/] [compat-uitron-sync-and-comm-functions.html] - Rev 174
Compare with Previous | Blame | View Log
<!-- Copyright (C) 2003 Red Hat, Inc. -->
<!-- This material may be distributed only subject to the terms -->
<!-- and conditions set forth in the Open Publication License, v1.0 -->
<!-- or later (the latest version is presently available at -->
<!-- http://www.opencontent.org/openpub/). -->
<!-- Distribution of the work or derivative of the work in any -->
<!-- standard (paper) book form is prohibited unless prior -->
<!-- permission is obtained from the copyright holder. -->
<HTML
><HEAD
><TITLE
> Synchronization and Communication Functions</TITLE
><meta name="MSSmartTagsPreventParsing" content="TRUE">
<META
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.76b+
"><LINK
REL="HOME"
TITLE="eCos Reference Manual"
HREF="ecos-ref.html"><LINK
REL="UP"
TITLE="µITRON API"
HREF="compat-uitron-microitron-api.html"><LINK
REL="PREVIOUS"
TITLE="Task-Dependent Synchronization Functions"
HREF="compat-uitron-task-dependent-synch-functions.html"><LINK
REL="NEXT"
TITLE="Extended Synchronization and Communication Functions"
HREF="compat-uitron-extended-sync-comm-functions.html"></HEAD
><BODY
CLASS="SECT1"
BGCOLOR="#FFFFFF"
TEXT="#000000"
LINK="#0000FF"
VLINK="#840084"
ALINK="#0000FF"
><DIV
CLASS="NAVHEADER"
><TABLE
SUMMARY="Header navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TH
COLSPAN="3"
ALIGN="center"
>eCos Reference Manual</TH
></TR
><TR
><TD
WIDTH="10%"
ALIGN="left"
VALIGN="bottom"
><A
HREF="compat-uitron-task-dependent-synch-functions.html"
ACCESSKEY="P"
>Prev</A
></TD
><TD
WIDTH="80%"
ALIGN="center"
VALIGN="bottom"
>Chapter 32. µITRON API</TD
><TD
WIDTH="10%"
ALIGN="right"
VALIGN="bottom"
><A
HREF="compat-uitron-extended-sync-comm-functions.html"
ACCESSKEY="N"
>Next</A
></TD
></TR
></TABLE
><HR
ALIGN="LEFT"
WIDTH="100%"></DIV
><DIV
CLASS="SECT1"
><H1
CLASS="SECT1"
><A
NAME="COMPAT-UITRON-SYNC-AND-COMM-FUNCTIONS">Synchronization and Communication Functions</H1
><P
>These functions are fully supported in this release: </P
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>sig_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>wai_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>preq_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>twai_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid,</I
></SPAN
> TMO <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>tmout</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>ref_sem</TT
>(
T_RSEM *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_rsem ,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>set_flg</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid,</I
></SPAN
> UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>setptn</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>clr_flg</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid,</I
></SPAN
> UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>clrptn</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>wai_flg</TT
>(
UINT *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>p_flgptn,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid ,</I
></SPAN
>
UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>waiptn ,</I
></SPAN
> UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>wfmode</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>pol_flg</TT
>(
UINT *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>p_flgptn,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid ,</I
></SPAN
>
UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>waiptn ,</I
></SPAN
> UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>wfmode</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>twai_flg</TT
>(
UINT *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>p_flgptn</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid ,</I
></SPAN
>
UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>waiptn ,</I
></SPAN
> UINT <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>wfmode,</I
></SPAN
> TMO <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>tmout</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>ref_flg</TT
>(
T_RFLG *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_rflg,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>snd_msg</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid,</I
></SPAN
> T_MSG <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>*pk_msg</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>rcv_msg</TT
>(
T_MSG **<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>ppk_msg,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>prcv_msg</TT
>(
T_MSG **<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>ppk_msg,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>trcv_msg</TT
>(
T_MSG **<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>ppk_msg,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid ,</I
></SPAN
> TMO <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>tmout</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>ref_mbx</TT
>(
T_RMBX *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_rmbx,</I
></SPAN
> ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><P
>The following functions are supported in this release (with
some restrictions) if enabled with the appropriate configuration
option for the object type (for example
<TT
CLASS="LITERAL"
>CYGPKG_UITRON_SEMAS_CREATE_DELETE</TT
>):</P
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>cre_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid,</I
></SPAN
> T_CSEM *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_csem</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>del_sem</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>semid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>cre_flg</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid,</I
></SPAN
> T_CFLG *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_cflg</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>del_flg</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>flgid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>cre_mbx</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid,</I
></SPAN
> T_CMBX *<SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>pk_cmbx</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><TABLE
BORDER="5"
BGCOLOR="#E0E0F0"
WIDTH="70%"
><TR
><TD
><PRE
CLASS="PROGRAMLISTING"
>ER <TT
CLASS="FUNCTION"
>del_mbx</TT
>(
ID <SPAN
CLASS="emphasis"
><I
CLASS="EMPHASIS"
>mbxid</I
></SPAN
> )</PRE
></TD
></TR
></TABLE
><P
>In general the queueing order when waiting on a synchronization
object depends on the underlying kernel configuration. The multi-level
queue scheduler is required for strict µITRON
conformance and it queues tasks in FIFO order, so requests to create
an object with priority queueing of tasks (<TT
CLASS="LITERAL"
>pk_cxxx->xxxatr = TA_TPRI</TT
>)
are rejected with E_RSATR. Additional undefined bits in
the attributes fields must be zero. </P
><P
>In general, extended information (pk_cxxx->exinf)
is ignored. </P
><P
>For semaphores, the initial semaphore count (pk_csem->isemcnt)
is supported; the new semaphore's count is set. The maximum
count is not supported, and is not in fact defined in type pk_csem. </P
><P
>For flags, multiple tasks are allowed to wait. Because single
task waiting is a subset of this, the W bit (TA_WMUL) of
the flag attributes is ignored; all other bits must be zero. The
initial flag value is supported. </P
><P
>For mailboxes, the buffer count is defined statically by kernel
configuration option
<TT
CLASS="LITERAL"
>CYGNUM_KERNEL_SYNCH_MBOX_QUEUE_SIZE</TT
>;
therefore the buffer count field is not supported and is not in
fact defined in type pk_cmbx. Queueing of messages is FIFO
ordered only, so TA_MPRI (in pk_cmbx->mbxatr)
is not supported. </P
><DIV
CLASS="SECT2"
><H2
CLASS="SECT2"
><A
NAME="AEN13716">Error checking</H2
><P
>The following conditions are only checked for, and only return
errors if
<TT
CLASS="LITERAL"
>CYGSEM_UITRON_BAD_PARAMS_RETURN_ERRORS</TT
>
is enabled:</P
><P
></P
><UL
><LI
><P
>invalid object id; less than 1 or greater than
<TT
CLASS="LITERAL"
>CYGNUM_UITRON_TASKS/SEMAS/MBOXES</TT
>
as appropriate returns E_ID</P
></LI
><LI
><P
>dispatching is enabled in any call which can sleep, or
E_CTX</P
></LI
><LI
><P
>tmout must be positive, otherwise E_PAR</P
></LI
><LI
><P
>pk_cxxx pointers in
<TT
CLASS="FUNCTION"
>cre_xxx()</TT
>
must be valid pointers, or E_PAR</P
></LI
><LI
><P
>return value pointer in
<TT
CLASS="FUNCTION"
>ref_xxx()</TT
>
is valid pointer, or E_PAR</P
></LI
><LI
><P
>flag wait pattern must be non-zero, and mode must be valid,
or E_PAR</P
></LI
><LI
><P
>return value pointer in flag wait calls is a valid pointer,
or E_PAR</P
></LI
></UL
><P
>The following conditions are checked for, and can return error
codes, regardless of the setting of
<TT
CLASS="LITERAL"
>CYGSEM_UITRON_BAD_PARAMS_RETURN_ERRORS</TT
>
:</P
><P
></P
><UL
><LI
><P
>When create and delete functions
<TT
CLASS="FUNCTION"
>cre_xxx()</TT
>
and
<TT
CLASS="FUNCTION"
>del_xxx()</TT
>
are supported, all calls which use a valid object ID number check
that the object exists. If not, E_NOEXS is returned.</P
></LI
><LI
><P
>In create functions
<TT
CLASS="FUNCTION"
>cre_xxx()</TT
>
, when supported, if the object already exists, then E_OBJ</P
></LI
><LI
><P
>In any call which can sleep, such as
<TT
CLASS="FUNCTION"
>twai_sem()</TT
>
: return codes E_TMOUT, E_RLWAI, E_DLT
or of course E_OK are returned depending on the reason
for terminating the sleep</P
></LI
><LI
><P
>In polling functions such as
<TT
CLASS="FUNCTION"
>preq_sem()</TT
>
return codes E_TMOUT or E_OK are returned depending
on the state of the synchronization object</P
></LI
><LI
><P
>In creation functions, the attributes must be compatible
with the selected underlying kernel configuration: in
<TT
CLASS="FUNCTION"
>cre_sem()</TT
>
<TT
CLASS="LITERAL"
>pk_csem->sematr</TT
>
must be equal to
<TT
CLASS="LITERAL"
>TA_TFIFO</TT
>
else E_RSATR.</P
></LI
><LI
><P
>In
<TT
CLASS="FUNCTION"
>cre_flg()</TT
>
<TT
CLASS="LITERAL"
>pk_cflg->flgatr</TT
>
must be either
<TT
CLASS="VARNAME"
>TA_WMUL</TT
>
or
<TT
CLASS="VARNAME"
>TA_WSGL</TT
>
else <TT
CLASS="VARNAME"
>E_RSATR</TT
>.</P
></LI
><LI
><P
>In
<TT
CLASS="FUNCTION"
>cre_mbx()</TT
>
<TT
CLASS="LITERAL"
>pk_cmbx->mbxatr</TT
>
must be
<TT
CLASS="LITERAL"
>TA_TFIFO + TA_MFIFO</TT
>
else E_RSATR.</P
></LI
></UL
></DIV
></DIV
><DIV
CLASS="NAVFOOTER"
><HR
ALIGN="LEFT"
WIDTH="100%"><TABLE
SUMMARY="Footer navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
><A
HREF="compat-uitron-task-dependent-synch-functions.html"
ACCESSKEY="P"
>Prev</A
></TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="ecos-ref.html"
ACCESSKEY="H"
>Home</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
><A
HREF="compat-uitron-extended-sync-comm-functions.html"
ACCESSKEY="N"
>Next</A
></TD
></TR
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
>Task-Dependent Synchronization Functions</TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="compat-uitron-microitron-api.html"
ACCESSKEY="U"
>Up</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
>Extended Synchronization and Communication Functions</TD
></TR
></TABLE
></DIV
></BODY
></HTML
> 