- 139 -
rel_mpf Release fixed-size memory block irel_mpf Release fixed-size memory block (handler only)
[
[[
[
C
C
L
La
an
ng
gu
ua
ag
ge
e
A
AP
PI
I
]
]]
]
ER ercd = rel_mpf( ID mpfid, VP blk );
ER ercd = irel_mpf( ID mpfid, VP blk);
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
ID mpfid ID number of the fixed-size memory pool to be released
VP blk Start address of the memory block to be 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)
[
[[
[
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_mpf MPFID,BLK
irel_mpf MPFID,BLK
z
z
P
Pa
ar
ra
am
me
et
te
er
rs
s
MPFID ID number of the fixed-size memory pool to be released
BLK Start address of the memory block to be 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
R3R1 Start address of the memory block to be returned
R2 ID number of the fixed-size memory pool to be released
[
[[
[
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 releases a memory block whose start address is indicated by blk. The start address of the memory block to
be released that is specified here should always be that of the memory block acquired by get_mpf, tget_mpf, pget_mpf, or
ipget_mpf.
If tasks are enqueued in a waiting queue for the target memory pool, the task at the top of the waiting queue is dequeued
and linked to a ready queue, and is assigned a memory block. At this time, the task changes state from a memory block wait
state to RUNNING or READY state. This service call does not check the content of blk, so that if the address stored in blk
is incorrect, the service call may not operate correctly.
If this service call is to be issued from task context, use rel_mpf; if issued from non-task context, use irel_mpf.