2009-10-11 19:43:13 +00:00
|
|
|
/*
|
2010-02-21 07:24:53 +00:00
|
|
|
ChibiOS/RT - Copyright (C) 2006,2007,2008,2009,2010 Giovanni Di Sirio.
|
2009-10-11 19:43:13 +00:00
|
|
|
|
|
|
|
This file is part of ChibiOS/RT.
|
|
|
|
|
|
|
|
ChibiOS/RT is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
ChibiOS/RT is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2010-02-06 10:55:53 +00:00
|
|
|
* @file chmemcore.c
|
|
|
|
* @brief Core memory manager code.
|
|
|
|
*
|
2009-10-16 17:45:19 +00:00
|
|
|
* @addtogroup memcore
|
2010-03-16 19:36:21 +00:00
|
|
|
* @details Core Memory Manager related APIs and services.
|
|
|
|
* <h2>Operation mode</h2>
|
|
|
|
* The core memory manager is a simplified allocator that only allows
|
|
|
|
* to allocate memory blocks without the possibility to free them.<br>
|
|
|
|
* This allocator is meant as a memory blocks provider for the other
|
|
|
|
* allocators such as:
|
|
|
|
* - C-Runtime allocator (through a compiler specific adapter module).
|
|
|
|
* - Heap allocator (see @ref heaps).
|
|
|
|
* - Memory pools allocator (see @ref pools).
|
|
|
|
* .
|
|
|
|
* By having a centralized memory provider the various allocators can
|
|
|
|
* coexist and share the main memory.<br>
|
|
|
|
* This allocator, alone, is also useful for very simple applications
|
|
|
|
* that just require a simple way to get memory blocks.<br>
|
|
|
|
* In order to use the core memory manager APIs the @p CH_USE_MEMCORE
|
|
|
|
* option must be enabled in @p chconf.h.
|
2009-10-11 19:43:13 +00:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2009-12-08 17:37:49 +00:00
|
|
|
#include "ch.h"
|
2009-10-11 19:43:13 +00:00
|
|
|
|
2009-10-16 17:45:19 +00:00
|
|
|
#if CH_USE_MEMCORE
|
2009-10-11 19:43:13 +00:00
|
|
|
|
2009-12-11 15:55:08 +00:00
|
|
|
static uint8_t *nextmem;
|
|
|
|
static uint8_t *endmem;
|
2009-10-11 19:43:13 +00:00
|
|
|
|
2009-10-16 17:45:19 +00:00
|
|
|
/**
|
2010-02-03 18:40:10 +00:00
|
|
|
* @brief Low level memory manager initialization.
|
|
|
|
* @note Internal use only.
|
2009-10-16 17:45:19 +00:00
|
|
|
*/
|
|
|
|
void core_init(void) {
|
|
|
|
#if CH_MEMCORE_SIZE == 0
|
2009-12-11 15:55:08 +00:00
|
|
|
extern uint8_t __heap_base__;
|
|
|
|
extern uint8_t __heap_end__;
|
2009-10-11 19:43:13 +00:00
|
|
|
nextmem = &__heap_base__;
|
|
|
|
endmem = &__heap_end__;
|
|
|
|
#else
|
2010-02-16 19:21:42 +00:00
|
|
|
static stkalign_t buffer[MEM_ALIGN_SIZE(CH_MEMCORE_SIZE) /
|
|
|
|
sizeof(stkalign_t)];
|
2009-12-11 15:55:08 +00:00
|
|
|
nextmem = (uint8_t *)&buffer[0];
|
2010-02-16 19:21:42 +00:00
|
|
|
endmem = (uint8_t *)&buffer[MEM_ALIGN_SIZE(CH_MEMCORE_SIZE) /
|
|
|
|
sizeof(stkalign_t)];
|
2009-10-11 19:43:13 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-02-03 18:40:10 +00:00
|
|
|
* @brief Allocates a memory block.
|
2009-10-11 19:43:13 +00:00
|
|
|
* @details The size of the returned block is aligned to the alignment
|
2010-02-16 19:21:42 +00:00
|
|
|
* type @p stkalign_t so it is not possible to allocate less
|
|
|
|
* than <code>sizeof(stkalign_t)</code>.
|
2009-10-11 19:43:13 +00:00
|
|
|
*
|
|
|
|
*
|
2010-02-06 10:55:53 +00:00
|
|
|
* @param[in] size the size of the block to be allocated
|
|
|
|
* @return A pointer to the allocated memory block.
|
2010-02-21 07:24:53 +00:00
|
|
|
* @retval NULL allocation failed, core memory exhausted.
|
2009-10-11 19:43:13 +00:00
|
|
|
*/
|
|
|
|
void *chCoreAlloc(size_t size) {
|
|
|
|
void *p;
|
|
|
|
|
|
|
|
chSysLock();
|
|
|
|
p = chCoreAllocI(size);
|
|
|
|
chSysUnlock();
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-02-03 18:40:10 +00:00
|
|
|
* @brief Allocates a memory block.
|
2009-10-11 19:43:13 +00:00
|
|
|
* @details The size of the returned block is aligned to the alignment
|
|
|
|
* type @p align_t so it is not possible to allocate less than
|
|
|
|
* <code>sizeof(align_t)</code>.
|
|
|
|
*
|
2010-02-06 10:55:53 +00:00
|
|
|
* @param[in] size the size of the block to be allocated.
|
|
|
|
* @return A pointer to the allocated memory block.
|
|
|
|
* @retval NULL allocation failed, core memory exhausted.
|
2009-10-11 19:43:13 +00:00
|
|
|
*/
|
|
|
|
void *chCoreAllocI(size_t size) {
|
|
|
|
void *p;
|
|
|
|
|
2009-10-16 17:45:19 +00:00
|
|
|
size = MEM_ALIGN_SIZE(size);
|
2009-12-11 15:55:08 +00:00
|
|
|
if ((size_t)(endmem - nextmem) < size)
|
2009-10-11 19:43:13 +00:00
|
|
|
return NULL;
|
|
|
|
p = nextmem;
|
|
|
|
nextmem += size;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2010-02-03 18:40:10 +00:00
|
|
|
/**
|
2010-05-04 12:31:05 +00:00
|
|
|
* @brief Core memory status.
|
2010-02-03 18:40:10 +00:00
|
|
|
*
|
2010-02-21 07:24:53 +00:00
|
|
|
* @return The size, in bytes, of the free core memory.
|
2010-02-03 18:40:10 +00:00
|
|
|
*/
|
2010-05-04 12:31:05 +00:00
|
|
|
size_t chCoreStatus(void) {
|
2010-02-03 18:40:10 +00:00
|
|
|
|
|
|
|
return (size_t)(endmem - nextmem);
|
|
|
|
}
|
2009-10-16 17:45:19 +00:00
|
|
|
#endif /* CH_USE_MEMCORE */
|
2009-10-11 19:43:13 +00:00
|
|
|
|
|
|
|
/** @} */
|