- 106 -
ref_sem Reference semaphore status iref_sem Reference semaphore status (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = ref_sem( ID semid, T_RSEM *pk_rsem );
ER ercd = iref_sem( ID semid, T_RSEM *pk_rsem );
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
ID semid ID number of the target semaphore
T_RSEM *pk_rsem Pointer to the packet to which semaphore status is returned
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)
T_RSEM *pk_rsem Pointer to the packet to which semaphore status is returned
Contents of pk_rsem
typedef struct t_rsem{
ID wtskid +0 2 ID number of the task at the head of the semaphore’s wait queue
UINT semcnt +2 4 Current semaphore resource count
} T_RSEM;
[
[[
[
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
ref_sem SEMID, PK_RSEM
iref_sem SEMID, PK_RSEM
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
SEMID ID number of the target semaphore
PK_RSEM Pointer to the packet to which semaphore status is returned
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 target semaphore
A1 Pointer to the packet to which semaphore status is returned
[
[[
[
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 returns various statuses of the semaphore indicated by semid.
wtskid
Returned to wtskid is the ID number of the task at the head of the semaphore’s wait queue (the next task to be
dequeued). If no tasks are kept waiting, TSK_NONE is returned.
semcnt
Returned to semcnt is the current semaphore resource count.
If this service call is to be issued from task context, use ref_sem; if issued from non-task context, use iref_sem.