- 88 -
wup_tsk Wakeup task iwup_tsk Wakeup task (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = wup_tsk( ID tskid );
ER ercd = iwup_tsk( 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
wup_tsk TSKID
iwup_tsk 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 an inactive state)
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
]
]]
]
If the task specified by tskid has been placed into WAITING state by slp_tsk or tslp_tsk, this service call wakes up the task
from WAITING state to place it into READY or RUNNING state. Or if the task specified by tskid is in WAIT-
ING-SUSPENDED state, this service call awakes the task from only the sleeping state so that the task goes to SUS-
PENDED state.
If a wakeup request is issued while the target task remains in DORMANT state, the error code E_OBJ is returned to the
service call issuing task. If TSK_SELF is specified for tskid, it means specifying the issuing task itself. If TSK_SELF is
specified for tskid in non-task context, operation of the service call cannot be guaranteed.
If this service call is issued to a task that has not been placed in WAITING state or in WAITING-SUSPENDED state by
execution of slp_tsk or tslp_tsk, the wakeup request is accumulated. More specifically, the wakeup request count for the
target task to be awakened is incremented by 1, in which way wakeup requests are accumulated.
The maximum value of the wakeup request count is 255. If while the wakeup request count = 255 a new wakeup request is
generated exceeding this limit, the error code E_QOVR is returned to the task that issued the service call, with the wakeup
request count left intact.
If this service call is to be issued from task context, use wup_tsk; if issued from non-task context, use iwup_tsk.