- 128 -
snd_mbx Send to mailbox isnd_mbx Send to mailbox (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = snd_mbx( ID mbxid, T_MSG *pk_msg );
ER ercd = isnd_mbx( ID mbxid, T_MSG *pk_msg );
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
ID mbxid ID number of the mailbox to which transmitted
T_MSG *pk_msg Message to be transmitted
z
z
R
Re
et
tu
ur
rn
n
P
Pa
ar
ra
am
me
et
te
er
rs
s
ER ercd Terminated normally (E_OK)
[
[[
[
A
As
ss
se
em
mb
bl
ly
y
l
la
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
.include mr100.inc
snd_mbx MBXID,PK_MBX
isnd_mbx MBXID,PK_MBX
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
MBXID ID number of the mailbox to which transmitted
PK_MBX Message to be transmitted (address)
z
z
R
Re
eg
gi
is
st
te
er
r
c
co
on
nt
te
en
nt
ts
s
a
af
ft
te
er
r
s
se
er
rv
vi
ic
ce
e
c
ca
al
ll
l
i
is
s
i
is
ss
su
ue
ed
d
Register name Content after service call is issued
R0 Error code
R2 ID number of the mailbox to which transmitted
A1 Message to be transmitted (add ress)
[
[[
[
S
St
tr
ru
uc
ct
tu
ur
re
e
o
of
f
t
th
he
e
m
me
es
ss
sa
ag
ge
e
p
pa
ac
ck
ke
et
t
]
]]
]
<<Mailbox message header>>
typedef struct t_msg{
VP msghead +0 4 Kernel managed area
} T_MSG;
<<Mailbox message header with priority included>>
typedef struct t_msg{
T_MSG msgque +0 4 Message header
PRI msgpri +2 2 Message priority
} T_MSG;
[
[[
[
E
Er
rr
ro
or
r
c
co
od
de
e
]
]]
]
None
[
[[
[
F
Fu
un
nc
ct
ti
io
on
na
al
l
d
de
es
sc
cr
ri
ip
pt
ti
io
on
n
]
]]
]
This service call sends the message indicated by pk_msg to the mailbox indicated by mbxid. T_MSG* should be specified
with a 32-bit address. If there is any task waiting to receive a message in the target mailbox, the transmitted message is
passed to the task at the top of the waiting queue, and the task is released from WAITING state.
To send a message to a mailbox whose attribute is TA_MFIFO, add a T_MSG structure at the beginning of the message
when creating it, as shown in the example below.
To send a message to a mailbox whose attribute is TA_MPRI, add a T_MSG_PRI structure at the beginning of the message
when creating it, as shown in the example below.
Messages should always be created in a RAM area regardless of whether its attribute is TA_MFIFO or TA_MPRI.
The T_MSG area is used by the kernel, so that it cannot be rewritten after a message has been sent. If this area is rewritten
before the message is received after it was sent, operation of the service call cannot be guaranteed.
If this service call is to be issued from task context, use snd_mbx; if issued from non-task context, use isnd_mbx.