Keil™, An ARM® Company

RL-ARM User's Guide

Technical Support

On-Line Manuals

RL-ARM User's Guide

RL-RTX
RL-FlashFS
RL-TCPnet
RL-CAN
Example Programs
Library Reference
Data Types
BIT
BOOL
CAN_ERROR
CAN_msg
FILE
S8
S16
S32
S64
U8
U16
U32
U64
Include Files
can_cfg.h
can_error.h
file_config.h
net_config.h
rtl.h
rtx_can.h
rtx_config.h
stdio.h
Reference
_alloc_box
_calloc_box
_declare_box
_declare_box8
_free_box
_init_box
_init_box8
arp_cache_ip
CAN_init
CAN_receive
CAN_request
CAN_rx_object
CAN_send
CAN_set
CAN_start
CAN_tx_object
cgi_func
cgi_process_data
cgi_process_var
com_getchar
com_putchar
com_tx_active
dhcp_disable
fanalyse
fcheck
fclose
fdefrag
fdelete
feof
ferror
ffind
fflush
fformat
ffree
fgetc
fgets
finit
fopen
fprintf
fputc
fputs
fread
frename
fs_EraseSector
fs_get_date
fs_get_time
fs_Init
fs_ProgramPage
fs_spi_EraseSector
fs_spi_Init
fs_spi_ProgramPage
fs_spi_ReadData
fscanf
fseek
ftell
fwrite
get_host_by_name
http_get_info
http_get_lang
http_get_session
http_get_var
igmp_join
igmp_leave
init_ethernet
init_modem
init_serial
init_TcpNet
int_disable_eth
int_enable_eth
interrupt_ethernet
isr_evt_set
isr_mbx_check
isr_mbx_receive
isr_mbx_send
isr_sem_send
main_TcpNet
mci_init
mci_read_config
mci_read_sect
mci_write_sect
modem_dial
modem_hangup
modem_listen
modem_online
modem_process
modem_run
os_dly_wait
os_evt_clr
os_evt_get
os_evt_set
os_evt_wait_and
os_evt_wait_or
os_itv_set
os_itv_wait
os_mbx_check
os_mbx_declare
os_mbx_init
os_mbx_send
os_mbx_wait
os_mut_init
os_mut_release
os_mut_wait
os_sem_init
os_sem_send
os_sem_wait
os_sys_init
os_sys_init_prio
os_sys_init_user
os_tmr_call
os_tmr_create
os_tmr_kill
os_tsk_create
os_tsk_create_ex
os_tsk_create_user
os_tsk_create_user_ex
os_tsk_delete
os_tsk_delete_self
os_tsk_pass
os_tsk_prio
os_tsk_prio_self
os_tsk_self
poll_ethernet
ppp_close
ppp_connect
ppp_is_up
ppp_listen
rewind
send_frame
slip_close
slip_connect
slip_is_up
slip_listen
smtp_cbfunc
smtp_connect
spi_hi_speed
spi_init
spi_send
spi_ss
tcp_abort
tcp_check_send
tcp_close
tcp_connect
tcp_get_buf
tcp_get_socket
tcp_get_state
tcp_listen
tcp_max_dsize
tcp_release_socket
tcp_reset_window
tcp_send
tftp_fclose
tftp_fopen
tftp_fread
tftp_fwrite
timer_tick
tnet_cbfunc
tnet_ccmp
tnet_get_info
tnet_msg_poll
tnet_process_cmd
tnet_set_delay
tsk_lock
tsk_unlock
udp_close
udp_get_buf
udp_get_socket
udp_mcast_ttl
udp_open
udp_release_socket
udp_send
ungetc
Library Files
Appendix

_init_box8

Summary 
#include <rtl.h>

int _init_box8 (
    void* box_mem,       /* Start address of the memory pool */
    U32   box_size,      /* Number of bytes in the memory pool */
    U32   blk_size );    /* Number of bytes in each block of the pool */
Description 

The _init_box8 function initializes a fixed block size memory pool with 8-byte alignment. When the memory pool is initialized, the RTX kernel handles memory requests by allocating a block of memory from the memory pool.

The box_mem specifies the start address of the memory pool, and this address must be 8-byte aligned.

The box_size argument specifies the size of the memory pool, in bytes.

The blk_size argument specifies the size, in bytes, of the blocks in the memory pool. You can set the block size to any value from 1 to box_size-16. However, the blk_size is rounded up to the next multiple of 8, to maintain 8-byte alignment of the blocks. For example if you initialize a memory pool for 10-byte blocks, the _init_box8 function actually initializes the memory pool for 16-byte blocks.

The _init_box8 function is implemented as a macro and is part of RL-RTX. The definition is in rtl.h.

Note

  • The first 16 bytes from the memory pool are reserved for storing pointers and size information that can be used by the functions that handle the memory pool. The box_size must therefore be more than 16 bytes long.
  • If the start address is not 8-byte aligned, the memory pool handling functions might fail.
Return Value The _init_box8 function returns 0 if the memory pool was initialized without any problem. If there was an initialization error, it returns 1.
See Also _alloc_box, _calloc_box, _declare_box8, _free_box
Example 
#include <rtl.h>

/* Reserve a memory for 25 blocks of 30-bytes. */
_declare_box8(mpool,30,25);

void membox_test (void) {
   U8 *box;
   U8 *cbox;

   _init_box8 (mpool, sizeof (mpool), 30);
   box  = _alloc_box (mpool);
   /* This block is initialized to 0. */
   cbox = _calloc_box (mpool);
   /* 'box' and 'cbox' are always 8-byte aligned. */
    .
    .
   _free_box (mpool, box);
   _free_box (mpool, cbox);
}