RTEMS ITRON 3.0 API User's Guide
ER ref_mbf( T_RMBF *pk_rmbf, ID mbfid );
E_OK
- Normal Completion
E_ID
- Invalid ID number (mbfid was invalid or could not be used)
E_NOEXS
- Object does not exist (the message buffer specified by
mbfid does not exist)
E_OACV
- Object access violation (A mbfid less than -4 was
specified from a user task. This is implementation dependent.)
E_PAR
- Parameter error (the packet address for the return
parameters could not be used)
EN_OBJNO
- An object number which could not be accessed on the
target node is specified.
EN_CTXID
- Specified an object on another node when the system
call was issued from a task in dispatch disabled state or from a
task-independent portion
EN_RPAR
- A value outside the range supported by the issuing node
and/or transmission packet format was returned as a return parameter (a
value outside supported range for exinf, wtsk, stsk, msgsz and/or
frbufsz on a requesting node)
This system call refers to the state of the message buffer specified by
mbfid
, and returns information of a task waiting to send a
message (stsk
), the size of the next message to be received
(msgsz
), the free buffer size (frbufsz
), information of a
task waiting to receive a message (wtsk
), and its extended
information (exinf
).
Wtsk
and stsk
indicate whether or not there is a task
waiting for the message buffer in question. If there is no waiting
task, wtsk
and stsk
are returned as FALSE
= 0. If
there is a waiting task, wtsk
and stsk
are returned as
values other than 0.
An E_NOEXS
error will result if the message buffer specified to
ref_mbf
does not exist.
The size of the message at the head of the message buffer (the next
message to be received) is returned to msgsz
. If there are no
messages on the message buffer, msgsz
will be returned as
FALSE
= 0. A message whose size is zero cannot be sent.
At least one of msgsz
= FALSE
and wtsk
=
FALSE
is always true in this system call.
Frbufsz
indicates the amount of free memory in the message
buffer. This value can be used to know the total approximate size of
the messages which can be sent to the message buffer.
Multiprocessing is not supported. Thus none of the "EN_" status codes will be returned.
RTEMS ITRON 3.0 API User's Guide
Copyright © 1988-2007OAR Corporation