- 172 -
loc_cpu Lock the CPU iloc_cpu Lock the CPU (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = loc_cpu();
ER ercd = iloc_cpu();
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
None
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)
[
[[
[
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
loc_cpu
iloc_cpu
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
None
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
[
[[
[
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 places the system into a CPU locked state, thereby disabling interrupts and task dispatches. The features of
a CPU locked state are outlined below.
(1) No task scheduling is performed during a CPU locked state.
(2) No external interrupts are accepted unless their priority levels are higher than the kernel interrupt
mask level defined in the configurator.
(3) Only the following service calls can be invoked from a CPU locked state. If any other service calls
are invoked, operation of the service call cannot be guaranteed.
* ext_tsk
* loc_cpu, iloc_cpu
* unl_cpu, iunl_cpu
* sns_ctx
* sns_loc
* sns_dsp
* sns_dpn
The system is freed from a CPU locked state by one of the following operations.
(a) Invocation of the unl_cpu or iunl_cpu service call
(b) Invocation of the ext_tsk service call
Transitions between CPU locked and CPU unlocked states occur only when the loc_cpu, iloc_cpu, unl_cpu, iunl_cpu, or
ext_tsk service call is invoked. The system must always be in a CPU unlocked state when the interrupt handler or the time
event handler is terminated. If either handler terminates while the system is in a CPU locked state, handler operation cannot
be guaranteed. Note that the system is always in a CPU unlocked state when these handlers start.
Invoking this service call again while the system is already in a CPU locked state does not cause an error, in which case
task queuing is not performed, however.
If this service call is to be issued from task context, use loc_cpu; if issued from non-task context, use iloc_cpu.