forked from Imagelibrary/rtems
@@ -852,6 +852,7 @@ librtemscpu_a_SOURCES += score/src/heapresizeblock.c
|
|||||||
librtemscpu_a_SOURCES += score/src/heapiterate.c
|
librtemscpu_a_SOURCES += score/src/heapiterate.c
|
||||||
librtemscpu_a_SOURCES += score/src/heapgreedy.c
|
librtemscpu_a_SOURCES += score/src/heapgreedy.c
|
||||||
librtemscpu_a_SOURCES += score/src/heapnoextend.c
|
librtemscpu_a_SOURCES += score/src/heapnoextend.c
|
||||||
|
librtemscpu_a_SOURCES += score/src/memoryallocate.c
|
||||||
librtemscpu_a_SOURCES += score/src/objectallocate.c
|
librtemscpu_a_SOURCES += score/src/objectallocate.c
|
||||||
librtemscpu_a_SOURCES += score/src/objectclose.c
|
librtemscpu_a_SOURCES += score/src/objectclose.c
|
||||||
librtemscpu_a_SOURCES += score/src/objectextendinformation.c
|
librtemscpu_a_SOURCES += score/src/objectextendinformation.c
|
||||||
|
|||||||
@@ -331,6 +331,7 @@ include_rtems_score_HEADERS += include/rtems/score/io.h
|
|||||||
include_rtems_score_HEADERS += include/rtems/score/isr.h
|
include_rtems_score_HEADERS += include/rtems/score/isr.h
|
||||||
include_rtems_score_HEADERS += include/rtems/score/isrlevel.h
|
include_rtems_score_HEADERS += include/rtems/score/isrlevel.h
|
||||||
include_rtems_score_HEADERS += include/rtems/score/isrlock.h
|
include_rtems_score_HEADERS += include/rtems/score/isrlock.h
|
||||||
|
include_rtems_score_HEADERS += include/rtems/score/memory.h
|
||||||
include_rtems_score_HEADERS += include/rtems/score/mpci.h
|
include_rtems_score_HEADERS += include/rtems/score/mpci.h
|
||||||
include_rtems_score_HEADERS += include/rtems/score/mpciimpl.h
|
include_rtems_score_HEADERS += include/rtems/score/mpciimpl.h
|
||||||
include_rtems_score_HEADERS += include/rtems/score/mppkt.h
|
include_rtems_score_HEADERS += include/rtems/score/mppkt.h
|
||||||
|
|||||||
331
cpukit/include/rtems/score/memory.h
Normal file
331
cpukit/include/rtems/score/memory.h
Normal file
@@ -0,0 +1,331 @@
|
|||||||
|
/**
|
||||||
|
* @file
|
||||||
|
*
|
||||||
|
* @ingroup RTEMSScoreMemory
|
||||||
|
*
|
||||||
|
* @brief Memory Handler API
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019 embedded brains GmbH
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _RTEMS_SCORE_MEMORY_H
|
||||||
|
#define _RTEMS_SCORE_MEMORY_H
|
||||||
|
|
||||||
|
#include <rtems/score/basedefs.h>
|
||||||
|
#include <rtems/score/assert.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup RTEMSScoreMemory Memory Handler
|
||||||
|
*
|
||||||
|
* @ingroup RTEMSScore
|
||||||
|
*
|
||||||
|
* @brief Low level handler to provide memory areas for higher level memory
|
||||||
|
* handlers such as the Workspace Handler.
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The memory area description.
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
/**
|
||||||
|
* @brief A pointer to the begin of the memory area.
|
||||||
|
*/
|
||||||
|
const void *begin;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief A pointer to the begin of the free area of the memory area.
|
||||||
|
*/
|
||||||
|
void *free;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief A pointer to the end of the memory area.
|
||||||
|
*/
|
||||||
|
const void *end;
|
||||||
|
} Memory_Area;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The memory information.
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
/**
|
||||||
|
* @brief The count of memory areas.
|
||||||
|
*/
|
||||||
|
size_t count;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The memory area table.
|
||||||
|
*/
|
||||||
|
Memory_Area *areas;
|
||||||
|
} Memory_Information;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Statically initialize a memory information.
|
||||||
|
*
|
||||||
|
* @param areas The designator of an array of the memory areas.
|
||||||
|
*/
|
||||||
|
#define MEMORY_INFORMATION_INITIALIZER( areas ) \
|
||||||
|
{ RTEMS_ARRAY_SIZE( areas ), ( areas ) }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Statically initialize a memory area.
|
||||||
|
*
|
||||||
|
* @param begin The begin of the memory area.
|
||||||
|
* @param end The end of the memory area.
|
||||||
|
*/
|
||||||
|
#define MEMORY_INITIALIZER( begin, end ) { ( begin ), ( begin ), ( end ) }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the memory area count.
|
||||||
|
*
|
||||||
|
* @param information The memory information.
|
||||||
|
*
|
||||||
|
* @return The memory area count.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE size_t _Memory_Get_count(
|
||||||
|
const Memory_Information *information
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return information->count;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get a memory area by index.
|
||||||
|
*
|
||||||
|
* @param information The memory information.
|
||||||
|
* @param index The index of the memory area to return.
|
||||||
|
*
|
||||||
|
* @return The memory area of the specified index.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE Memory_Area *_Memory_Get_area(
|
||||||
|
const Memory_Information *information,
|
||||||
|
size_t index
|
||||||
|
)
|
||||||
|
{
|
||||||
|
_Assert( index < _Memory_Get_count( information ) );
|
||||||
|
return &information->areas[ index ];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Initialize the memory area.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param begin The begin of the memory area.
|
||||||
|
* @param end The end of the memory area.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Initialize(
|
||||||
|
Memory_Area *area,
|
||||||
|
void *begin,
|
||||||
|
void *end
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->begin = begin;
|
||||||
|
area->free = begin;
|
||||||
|
area->end = end;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Initialize the memory area by size.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param begin The begin of the memory area.
|
||||||
|
* @param size The size of the memory area in bytes.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Initialize_by_size(
|
||||||
|
Memory_Area *area,
|
||||||
|
void *begin,
|
||||||
|
uintptr_t size
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->begin = begin;
|
||||||
|
area->free = begin;
|
||||||
|
area->end = (char *) begin + size;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the memory area begin.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
*
|
||||||
|
* @return The memory area begin.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE const void *_Memory_Get_begin( const Memory_Area *area )
|
||||||
|
{
|
||||||
|
return area->begin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the memory area begin.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param begin The memory area begin.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Set_begin(
|
||||||
|
Memory_Area *area,
|
||||||
|
const void *begin
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->begin = begin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the memory area end.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
*
|
||||||
|
* @return The memory area end.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE const void *_Memory_Get_end( const Memory_Area *area )
|
||||||
|
{
|
||||||
|
return area->end;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the memory area end.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param end The memory area end.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Set_end(
|
||||||
|
Memory_Area *area,
|
||||||
|
const void *end
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->end = end;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the memory area size.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
*
|
||||||
|
* @return The memory area size in bytes.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE uintptr_t _Memory_Get_size( const Memory_Area *area )
|
||||||
|
{
|
||||||
|
return (uintptr_t) area->end - (uintptr_t) area->begin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the begin of the free area of the memory area.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
*
|
||||||
|
* @return The free memory area begin the memory area.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void *_Memory_Get_free_begin( const Memory_Area *area )
|
||||||
|
{
|
||||||
|
return area->free;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the begin of the free area of the memory area.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param begin The free memory area begin the memory area.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Set_free_begin(
|
||||||
|
Memory_Area *area,
|
||||||
|
void *begin
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->free = begin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the size of the free memory area of the memory area.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
*
|
||||||
|
* @return The free memory area size in bytes of the memory area.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE uintptr_t _Memory_Get_free_size( const Memory_Area *area )
|
||||||
|
{
|
||||||
|
return (uintptr_t) area->end - (uintptr_t) area->free;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Consume the specified size from the free memory area of the memory
|
||||||
|
* area.
|
||||||
|
*
|
||||||
|
* @param area The memory area.
|
||||||
|
* @param consume The bytes to consume from the free memory area of the memory
|
||||||
|
* area.
|
||||||
|
*/
|
||||||
|
RTEMS_INLINE_ROUTINE void _Memory_Consume(
|
||||||
|
Memory_Area *area,
|
||||||
|
uintptr_t consume
|
||||||
|
)
|
||||||
|
{
|
||||||
|
area->free = (char *) area->free + consume;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Return the memory information of this platform.
|
||||||
|
*
|
||||||
|
* This function is provided by the Board Support Package (BSP). Using a
|
||||||
|
* function gives the BSPs a bit more freedom with respect to the
|
||||||
|
* implementation. Calling this function shall not have side-effects.
|
||||||
|
* Initialization steps to set up the memory information shall be done in a
|
||||||
|
* system initialization handler (RTEMS_SYSINIT_MEMORY).
|
||||||
|
*
|
||||||
|
* @return The memory information.
|
||||||
|
*/
|
||||||
|
const Memory_Information *_Memory_Get( void );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Allocate a memory area from the memory information.
|
||||||
|
*
|
||||||
|
* It is not possible to free the memory allocated by this function.
|
||||||
|
*
|
||||||
|
* @param information The memory information.
|
||||||
|
* @param size The size in bytes of the memory area to allocate.
|
||||||
|
* @param alignment The alignment in bytes of the memory area to allocate. It
|
||||||
|
* must be a power of two.
|
||||||
|
*
|
||||||
|
* @retval NULL No such memory area available.
|
||||||
|
* @retval begin The begin of the allocated memory area.
|
||||||
|
*/
|
||||||
|
void *_Memory_Allocate(
|
||||||
|
const Memory_Information *information,
|
||||||
|
uintptr_t size,
|
||||||
|
uintptr_t alignment
|
||||||
|
);
|
||||||
|
|
||||||
|
/** @} */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#endif /* _RTEMS_SCORE_MEMORY_H */
|
||||||
67
cpukit/score/src/memoryallocate.c
Normal file
67
cpukit/score/src/memoryallocate.c
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018, 2019 embedded brains GmbH
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <rtems/score/memory.h>
|
||||||
|
|
||||||
|
void *_Memory_Allocate(
|
||||||
|
const Memory_Information *information,
|
||||||
|
uintptr_t size,
|
||||||
|
uintptr_t alignment
|
||||||
|
)
|
||||||
|
{
|
||||||
|
Memory_Area *area;
|
||||||
|
const Memory_Area *end;
|
||||||
|
uintptr_t alignment_mask;
|
||||||
|
|
||||||
|
area = &information->areas[ 0 ];
|
||||||
|
end = &information->areas[ information->count ];
|
||||||
|
alignment_mask = alignment - 1;
|
||||||
|
|
||||||
|
while ( area != end ) {
|
||||||
|
uintptr_t alloc_begin;
|
||||||
|
uintptr_t alloc_end;
|
||||||
|
|
||||||
|
alloc_begin = (uintptr_t) area->free;
|
||||||
|
alloc_begin += alignment_mask;
|
||||||
|
alloc_begin &= ~alignment_mask;
|
||||||
|
alloc_end = alloc_begin + size;
|
||||||
|
|
||||||
|
if ( alloc_begin <= alloc_end && alloc_end <= (uintptr_t) area->end ) {
|
||||||
|
area->free = (void *) alloc_end;
|
||||||
|
|
||||||
|
return (void *) alloc_begin;
|
||||||
|
}
|
||||||
|
|
||||||
|
++area;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user