-
get_mpl
-
Acquire variable-sized memory block (waiting forever).
ER get_mpl (ID mplid, UINT blksz, VP *p_blk);
|
|
|
|
ID mplid;
|
ID number of the variable-sized memory pool from which a memory block is acquired.
|
|
UINT blksz;
|
Memory block size to be acquired (in bytes).
|
|
VP *p_blk;
|
Start address of the acquired memory block.
|
This service call acquires a variable-size memory block of the size specified by parameter blksz from the variable-size memory pool specified by parameter
mplid, and stores its start address into the area specified by parameter
p_blk.
If no variable-size memory blocks could be acquired from the target variable-size memory pool (no successive areas equivalent to the requested size were available) when this service call is issued, this service call does not acquire variable-size memory blocks but queues the invoking task to the target variable-size memory pool wait queue and moves it from the RUNNING state to the WAITING state (variable-size memory block acquisition wait state).
The WAITING state for a variable-sized memory block is cancelled in the following cases, and then moved to the READY state
WAITING State for a Variable-sized Memory Block Cancel Operation
|
|
The variable-size memory block that satisfies the requested size was returned to the target variable-size memory pool as a result of issuing rel_mpl.
|
|
The variable-size memory block that satisfies the requested size was returned to the target variable-size memory pool as a result of issuing irel_mpl.
|
|
Forced release from waiting (accept rel_wai while waiting).
|
|
Forced release from waiting (accept irel_wai while waiting).
|
|
Note 1 The RI850V4 acquires variable-size memory blocks in the unit of "integral multiple of 4". If a value other than an integral multiple of 4 is specified for parameter
blksz, it is rounded up to be an integral multiple of 4.
Note 2 Invoking tasks are queued to the target variable-size memory pool wait queue in the order defined during configuration (FIFO order or priority order).
Note 3 If the variable-size memory block acquisition wait state is cancelled because
rel_wai or
irel_wai was issued, the contents in the area specified by parameter
p_blk become undefined.
|
|
|
|
|
|
|
|
|
|
|
- mplid > Maximum ID number
|
|
|
- This service call was issued from a non-task.
- This service call was issued in the CPU locked state.
- This service call was issued in the dispatching disabled state.
|
|
|
- Specified variable-sized memory pool is not registered.
|
|
|
Forced release from the WAITING state.
|