- 98 -
dly_tsk Delay task
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = dly_tsk(RELTIM dlytim);
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
RELTIM dlytim Delay time
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
dly_tsk RELTIM
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
RELTIM Delay time
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
R6R4 Delay time
[
[[
[
E
Er
rr
ro
or
r
c
co
od
de
e
]
]]
]
E_RLWAI Forced release from waiting
[
[[
[
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 temporarily stops execution of the issuing task itself for a duration of time specified by dlytim to place the
task from RUNNING state into WAITING state. In this case, the task is released from the WAITING state at the first time
tick after the time specified by dlytim has elapsed. Therefore, if specified dlytim = 0, the task is placed into WAITING state
briefly and then released from the WAITING state at the first time tick.
The task placed into WAITING state by invocation of this service call is released from the WAITING state in the following
cases. Note that when released from WAITING state, the task that issued the service call is removed from the timeout
waiting queue and linked to a ready queue.
When the first time tick occurred after dlytim elapsed
The error code returned in this case is E_OK.
When the rel_wai or irel_wai service call is issued before dlytim elapses
The error code returned in this case is E_RLWAI.
Note that even when the wup_tsk or iwup_tsk service call is issued during the delay time, the task is not released from
WAITING state.
The delay time dlytim is expressed in ms units. Therefore, if specified as dly_tsk(50);, the issuing task is placed from
RUNNING state into a delayed wait state for a period of 50 ms.
The values specified for dlytim must be within (0x7FFFFFFF- time tick value). If any value exceeding this limit is speci-
fied, the service call may not operate correctly.
This service call can be issued only from task context. It cannot be issued from non-task context.