- 101 -
sig_sem Release semaphore resource isig_sem Release semaphore resource (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = sig_sem( ID semid );
ER ercd = isig_sem( ID semid );
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
ID semid Semaphore ID number to which 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) or error code
[
[[
[
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
sig_sem SEMID
isig_sem SEMID
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
SEMID Semaphore ID number to which 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 Semaphore ID number to which returned
[
[[
[
E
Er
rr
ro
or
r
c
co
od
de
e
]
]]
]
E_QOVR Queuing overflow
[
[[
[
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 releases one resource to the semaphore indicated by semid.
If tasks are enqueued in a waiting queue for the target semaphore, the task at the top of the queue is placed into READY
state. Conversely, if no tasks are enqueued in that waiting queue, the semaphore resource count is incremented by 1. If an
attempt is made to return resources (sig_sem or isig_sem service call) causing the semaphore resource count value to ex-
ceed the maximum value specified in a configuration file (maxsem), the error code E_QOVR is returned to the service call
issuing task, with the semaphore count value left intact.
If this service call is to be issued from task context, use sig_sem; if issued from non-task context, use isig_sem.