- 92 -
rel_wai Release task from waiting irel_wai Release task from waiting (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = rel_wai( ID tskid );
ER ercd = irel_wai( ID tskid );
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
ID tskid ID number of the target task
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
rel_wai TSKID
irel_wai TSKID
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
TSKID ID number of the target task
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 task
[
[[
[
E
Er
rr
ro
or
r
c
co
od
de
e
]
]]
]
E_OBJ Object status invalid(task indicated by tskid is not an wait state)
[
[[
[
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 forcibly release the task indicated by tskid from waiting (except SUSPENDED state) to place it into
READY or RUNNING state. The forcibly released task returns the error code E_RLWA I. If the target task has been en-
queued in some waiting queue, the task is dequeued from it by execution of this service call.
If this service call is issued to a task in WAITING-SUSPENDED state, the target task is released from WAITING state and
goes to SUSPENDED state.34
If the target task is not in WAITING state, the error code E_OBJ is returned. This service call forbids specifying the issuing
task itself for tskid.
If this service call is to be issued from task context, use rel_wai; if issued from non-task context, use irel_wai.
34 This means that tasks cannot be resumed from SUSPENDED state by this service call. Only the rsm_tsk, irsm_tsk, frsm_tsk, and
ifrsm_tsk service calls can release them from SUSPENDED state.