mm: add heap policy and anta logic to support mm debug on sim platform
since atan tool will enhance memory debug operation. Change-Id: Ic953755faff156832e84b6a764452751dc14f0e3
This commit is contained in:
parent
e14c458747
commit
6ff11d8c76
@ -58,6 +58,14 @@ config SIM_CYGWIN_DECORATED
|
|||||||
run: It will crash early, probably in some function due to the failure to
|
run: It will crash early, probably in some function due to the failure to
|
||||||
allocate memory.
|
allocate memory.
|
||||||
|
|
||||||
|
config SIM_SANITIZE
|
||||||
|
bool "Address Sanitizer"
|
||||||
|
default n
|
||||||
|
depends on MM_CUSTOMIZE_MANAGER
|
||||||
|
---help---
|
||||||
|
AddressSanitizer (ASan) is a fast compiler-based tool for detecting memory
|
||||||
|
bugs in native code.
|
||||||
|
|
||||||
choice
|
choice
|
||||||
prompt "X64_64 ABI"
|
prompt "X64_64 ABI"
|
||||||
default SIM_X8664_SYSTEMV if HOST_LINUX
|
default SIM_X8664_SYSTEMV if HOST_LINUX
|
||||||
|
@ -61,7 +61,7 @@ CSRCS = up_initialize.c up_idle.c up_interruptcontext.c up_initialstate.c
|
|||||||
CSRCS += up_createstack.c up_usestack.c up_releasestack.c up_stackframe.c
|
CSRCS += up_createstack.c up_usestack.c up_releasestack.c up_stackframe.c
|
||||||
CSRCS += up_unblocktask.c up_blocktask.c up_releasepending.c
|
CSRCS += up_unblocktask.c up_blocktask.c up_releasepending.c
|
||||||
CSRCS += up_reprioritizertr.c up_exit.c up_schedulesigaction.c
|
CSRCS += up_reprioritizertr.c up_exit.c up_schedulesigaction.c
|
||||||
CSRCS += up_allocateheap.c up_uart.c
|
CSRCS += up_heap.c up_uart.c
|
||||||
CSRCS += up_copyfullstate.c
|
CSRCS += up_copyfullstate.c
|
||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_HAVE_VFORK),y)
|
ifeq ($(CONFIG_ARCH_HAVE_VFORK),y)
|
||||||
|
@ -48,6 +48,8 @@ NXSYMBOLS(if_nametoindex)
|
|||||||
NXSYMBOLS(ioctl)
|
NXSYMBOLS(ioctl)
|
||||||
NXSYMBOLS(lseek)
|
NXSYMBOLS(lseek)
|
||||||
NXSYMBOLS(malloc)
|
NXSYMBOLS(malloc)
|
||||||
|
NXSYMBOLS(mallinfo)
|
||||||
|
NXSYMBOLS(memalign)
|
||||||
NXSYMBOLS(memcpy)
|
NXSYMBOLS(memcpy)
|
||||||
NXSYMBOLS(mkdir)
|
NXSYMBOLS(mkdir)
|
||||||
NXSYMBOLS(mmap)
|
NXSYMBOLS(mmap)
|
||||||
@ -73,6 +75,7 @@ NXSYMBOLS(pthread_sigmask)
|
|||||||
NXSYMBOLS(read)
|
NXSYMBOLS(read)
|
||||||
NXSYMBOLS(readdir)
|
NXSYMBOLS(readdir)
|
||||||
NXSYMBOLS(readv)
|
NXSYMBOLS(readv)
|
||||||
|
NXSYMBOLS(realloc)
|
||||||
NXSYMBOLS(rename)
|
NXSYMBOLS(rename)
|
||||||
NXSYMBOLS(rewinddir)
|
NXSYMBOLS(rewinddir)
|
||||||
NXSYMBOLS(rmdir)
|
NXSYMBOLS(rmdir)
|
||||||
|
@ -1,81 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
* arch/sim/src/sim/up_allocateheap.c
|
|
||||||
*
|
|
||||||
* Copyright (C) 2007-2009, 2013 Gregory Nutt. All rights reserved.
|
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
|
||||||
* used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Included Files
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <sched.h>
|
|
||||||
#include <debug.h>
|
|
||||||
|
|
||||||
#include <nuttx/arch.h>
|
|
||||||
|
|
||||||
#include "up_internal.h"
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Public Functions
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Name: up_allocate_heap
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* This function will be called to dynamically set aside the heap region.
|
|
||||||
*
|
|
||||||
* If a protected kernel-space heap is provided, the kernel heap must be
|
|
||||||
* allocated (and protected) by an analogous up_allocate_kheap().
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
void up_allocate_heap(void **heap_start, size_t *heap_size)
|
|
||||||
{
|
|
||||||
/* Note: Some subsystems like modlib and binfmt need to allocate
|
|
||||||
* executable memory.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* We make the entire heap executable here to keep
|
|
||||||
* the sim simpler. If it turns out to be a problem, the
|
|
||||||
* ARCH_HAVE_MODULE_TEXT mechanism can be an alternative.
|
|
||||||
*/
|
|
||||||
|
|
||||||
uint8_t *sim_heap = host_alloc_heap(SIM_HEAP_SIZE);
|
|
||||||
|
|
||||||
*heap_start = sim_heap;
|
|
||||||
*heap_size = SIM_HEAP_SIZE;
|
|
||||||
}
|
|
466
arch/sim/src/sim/up_heap.c
Normal file
466
arch/sim/src/sim/up_heap.c
Normal file
@ -0,0 +1,466 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/sim/src/sim/up_heap.c
|
||||||
|
*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership. The
|
||||||
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance with the
|
||||||
|
* License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <malloc.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#include <nuttx/arch.h>
|
||||||
|
#include <nuttx/mm/mm.h>
|
||||||
|
|
||||||
|
#include "up_internal.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_MM_CUSTOMIZE_MANAGER
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Private Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* This describes one heap (possibly with multiple regions) */
|
||||||
|
|
||||||
|
struct mm_delaynode_s
|
||||||
|
{
|
||||||
|
FAR struct mm_delaynode_s *flink;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct mm_heap_impl_s
|
||||||
|
{
|
||||||
|
struct mm_delaynode_s *mm_delaylist;
|
||||||
|
};
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Private Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_BUILD_FLAT) || defined(__KERNEL__)
|
||||||
|
static void mm_add_delaylist(FAR struct mm_heap_s *heap, FAR void *mem)
|
||||||
|
{
|
||||||
|
FAR struct mm_delaynode_s *tmp = mem;
|
||||||
|
irqstate_t flags;
|
||||||
|
|
||||||
|
/* Delay the deallocation until a more appropriate time. */
|
||||||
|
|
||||||
|
flags = enter_critical_section();
|
||||||
|
|
||||||
|
tmp->flink = heap->mm_impl->mm_delaylist;
|
||||||
|
heap->mm_impl->mm_delaylist = tmp;
|
||||||
|
|
||||||
|
leave_critical_section(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void mm_free_delaylist(FAR struct mm_heap_s *heap)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_BUILD_FLAT) || defined(__KERNEL__)
|
||||||
|
FAR struct mm_delaynode_s *tmp;
|
||||||
|
irqstate_t flags;
|
||||||
|
|
||||||
|
/* Move the delay list to local */
|
||||||
|
|
||||||
|
flags = enter_critical_section();
|
||||||
|
|
||||||
|
tmp = heap->mm_impl->mm_delaylist;
|
||||||
|
heap->mm_impl->mm_delaylist = NULL;
|
||||||
|
|
||||||
|
leave_critical_section(flags);
|
||||||
|
|
||||||
|
/* Test if the delayed is empty */
|
||||||
|
|
||||||
|
while (tmp)
|
||||||
|
{
|
||||||
|
FAR void *address;
|
||||||
|
|
||||||
|
/* Get the first delayed deallocation */
|
||||||
|
|
||||||
|
address = tmp;
|
||||||
|
tmp = tmp->flink;
|
||||||
|
|
||||||
|
/* The address should always be non-NULL since that was checked in the
|
||||||
|
* 'while' condition above.
|
||||||
|
*/
|
||||||
|
|
||||||
|
mm_free(heap, address);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_initialize
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Initialize the selected heap data structures, providing the initial
|
||||||
|
* heap region.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* heap - The selected heap
|
||||||
|
* heapstart - Start of the initial heap region
|
||||||
|
* heapsize - Size of the initial heap region
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void mm_initialize(FAR struct mm_heap_s *heap, FAR void *heap_start,
|
||||||
|
size_t heap_size)
|
||||||
|
{
|
||||||
|
FAR struct mm_heap_impl_s *impl;
|
||||||
|
impl = host_malloc(sizeof(struct mm_heap_impl_s));
|
||||||
|
impl->mm_delaylist = NULL;
|
||||||
|
heap->mm_impl = impl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_addregion
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function adds a region of contiguous memory to the selected heap.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* heap - The selected heap
|
||||||
|
* heapstart - Start of the heap region
|
||||||
|
* heapsize - Size of the heap region
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void mm_addregion(FAR struct mm_heap_s *heap, FAR void *heapstart,
|
||||||
|
size_t heapsize)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_malloc
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Find the smallest chunk that satisfies the request. Take the memory from
|
||||||
|
* that chunk, save the remaining, smaller chunk (if any).
|
||||||
|
*
|
||||||
|
* 8-byte alignment of the allocated data is assured.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_malloc(FAR struct mm_heap_s *heap, size_t size)
|
||||||
|
{
|
||||||
|
/* Firstly, free mm_delaylist */
|
||||||
|
|
||||||
|
mm_free_delaylist(heap);
|
||||||
|
return host_malloc(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_free
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Returns a chunk of memory to the list of free nodes, merging with
|
||||||
|
* adjacent free chunks if possible.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void mm_free(FAR struct mm_heap_s *heap, FAR void *mem)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_BUILD_FLAT) || defined(__KERNEL__)
|
||||||
|
int ret = (int)getpid();
|
||||||
|
|
||||||
|
/* Check current environment */
|
||||||
|
|
||||||
|
if (up_interrupt_context())
|
||||||
|
{
|
||||||
|
/* We are in ISR, add to mm_delaylist */
|
||||||
|
|
||||||
|
mm_add_delaylist(heap, mem);
|
||||||
|
}
|
||||||
|
else if (ret == -ESRCH || sched_idletask())
|
||||||
|
{
|
||||||
|
/* We are in IDLE task & can't get sem, or meet -ESRCH return,
|
||||||
|
* which means we are in situations during context switching(See
|
||||||
|
* mm_trysemaphore() & getpid()). Then add to mm_delaylist.
|
||||||
|
*/
|
||||||
|
|
||||||
|
mm_add_delaylist(heap, mem);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
host_free(mem);
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_realloc
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* If the reallocation is for less space, then:
|
||||||
|
*
|
||||||
|
* (1) the current allocation is reduced in size
|
||||||
|
* (2) the remainder at the end of the allocation is returned to the
|
||||||
|
* free list.
|
||||||
|
*
|
||||||
|
* If the request is for more space and the current allocation can be
|
||||||
|
* extended, it will be extended by:
|
||||||
|
*
|
||||||
|
* (1) Taking the additional space from the following free chunk, or
|
||||||
|
* (2) Taking the additional space from the preceding free chunk.
|
||||||
|
* (3) Or both
|
||||||
|
*
|
||||||
|
* If the request is for more space but the current chunk cannot be
|
||||||
|
* extended, then malloc a new buffer, copy the data into the new buffer,
|
||||||
|
* and free the old buffer.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_realloc(FAR struct mm_heap_s *heap, FAR void *oldmem,
|
||||||
|
size_t size)
|
||||||
|
{
|
||||||
|
mm_free_delaylist(heap);
|
||||||
|
return host_realloc(oldmem, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_calloc
|
||||||
|
*
|
||||||
|
* Descriptor:
|
||||||
|
* mm_calloc() calculates the size of the allocation and calls mm_zalloc()
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_calloc(FAR struct mm_heap_s *heap, size_t n, size_t elem_size)
|
||||||
|
{
|
||||||
|
mm_free_delaylist(heap);
|
||||||
|
return host_calloc(n, elem_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_zalloc
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* mm_zalloc calls mm_malloc, then zeroes out the allocated chunk.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_zalloc(FAR struct mm_heap_s *heap, size_t size)
|
||||||
|
{
|
||||||
|
FAR void *ptr;
|
||||||
|
|
||||||
|
ptr = mm_malloc(heap, size);
|
||||||
|
if (ptr != NULL)
|
||||||
|
{
|
||||||
|
memset(ptr, 0, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_memalign
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* memalign requests more than enough space from malloc, finds a region
|
||||||
|
* within that chunk that meets the alignment request and then frees any
|
||||||
|
* leading or trailing space.
|
||||||
|
*
|
||||||
|
* The alignment argument must be a power of two (not checked). 8-byte
|
||||||
|
* alignment is guaranteed by normal malloc calls.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_memalign(FAR struct mm_heap_s *heap, size_t alignment,
|
||||||
|
size_t size)
|
||||||
|
{
|
||||||
|
mm_free_delaylist(heap);
|
||||||
|
return host_memalign(alignment, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_heapmember
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Check if an address lies in the heap.
|
||||||
|
*
|
||||||
|
* Parameters:
|
||||||
|
* heap - The heap to check
|
||||||
|
* mem - The address to check
|
||||||
|
*
|
||||||
|
* Return Value:
|
||||||
|
* true if the address is a member of the heap. false if not
|
||||||
|
* not. If the address is not a member of the heap, then it
|
||||||
|
* must be a member of the user-space heap (unchecked)
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
bool mm_heapmember(FAR struct mm_heap_s *heap, FAR void *mem)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_brkaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Return the break address of a heap region. Zero is returned if the
|
||||||
|
* memory region is not initialized.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_brkaddr(FAR struct mm_heap_s *heap, int region)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_sbrk
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* The sbrk() function is used to change the amount of space allocated
|
||||||
|
* for the calling process. The change is made by resetting the process's
|
||||||
|
* break value and allocating the appropriate amount of space. The amount
|
||||||
|
* of allocated space increases as the break value increases.
|
||||||
|
*
|
||||||
|
* The sbrk() function adds 'incr' bytes to the break value and changes
|
||||||
|
* the allocated space accordingly. If incr is negative, the amount of
|
||||||
|
* allocated space is decreased by incr bytes. The current value of the
|
||||||
|
* program break is returned by sbrk(0).
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* heap - A reference to the data structure that defines this heap.
|
||||||
|
* incr - Specifies the number of bytes to add or to remove from the
|
||||||
|
* space allocated for the process.
|
||||||
|
* maxbreak - The maximum permissible break address.
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* Upon successful completion, sbrk() returns the prior break value.
|
||||||
|
* Otherwise, it returns (void *)-1 and sets errno to indicate the
|
||||||
|
* error:
|
||||||
|
*
|
||||||
|
* ENOMEM - The requested change would allocate more space than
|
||||||
|
* allowed under system limits.
|
||||||
|
* EAGAIN - The total amount of system memory available for allocation
|
||||||
|
* to this process is temporarily insufficient. This may occur even
|
||||||
|
* though the space requested was less than the maximum data segment
|
||||||
|
* size.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
FAR void *mm_sbrk(FAR struct mm_heap_s *heap, intptr_t incr,
|
||||||
|
uintptr_t maxbreak)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_extend
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Extend a heap region by add a block of (virtually) contiguous memory
|
||||||
|
* to the end of the heap.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void mm_extend(FAR struct mm_heap_s *heap, FAR void *mem, size_t size,
|
||||||
|
int region)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_mallinfo
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* mallinfo returns a copy of updated current heap information.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int mm_mallinfo(FAR struct mm_heap_s *heap, FAR struct mallinfo *info)
|
||||||
|
{
|
||||||
|
memset(info, 0, sizeof(struct mallinfo));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_DEBUG_MM
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: mm_checkcorruption
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* mm_checkcorruption is used to check whether memory heap is normal.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void mm_checkcorruption(FAR struct mm_heap_s *heap)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CONFIG_DEBUG_MM */
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: up_allocate_heap
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function will be called to dynamically set aside the heap region.
|
||||||
|
*
|
||||||
|
* If a protected kernel-space heap is provided, the kernel heap must be
|
||||||
|
* allocated (and protected) by an analogous up_allocate_kheap().
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void up_allocate_heap(void **heap_start, size_t *heap_size)
|
||||||
|
{
|
||||||
|
*heap_start = NULL;
|
||||||
|
*heap_size = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* CONFIG_MM_CUSTOMIZE_MANAGER */
|
||||||
|
|
||||||
|
void up_allocate_heap(void **heap_start, size_t *heap_size)
|
||||||
|
{
|
||||||
|
/* Note: Some subsystems like modlib and binfmt need to allocate
|
||||||
|
* executable memory.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* We make the entire heap executable here to keep
|
||||||
|
* the sim simpler. If it turns out to be a problem, the
|
||||||
|
* ARCH_HAVE_MODULE_TEXT mechanism can be an alternative.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint8_t *sim_heap = host_alloc_heap(SIM_HEAP_SIZE);
|
||||||
|
|
||||||
|
*heap_start = sim_heap;
|
||||||
|
*heap_size = SIM_HEAP_SIZE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CONFIG_MM_CUSTOMIZE_MANAGER */
|
@ -25,10 +25,14 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
#include "up_internal.h"
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -113,3 +117,28 @@ void host_free_shmem(void *mem)
|
|||||||
{
|
{
|
||||||
munmap(mem, 0);
|
munmap(mem, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void *host_malloc(size_t size)
|
||||||
|
{
|
||||||
|
return malloc(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void host_free(void *mem)
|
||||||
|
{
|
||||||
|
free(mem);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *host_realloc(void *oldmem, size_t size)
|
||||||
|
{
|
||||||
|
return realloc(oldmem, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *host_calloc(size_t n, size_t elem_size)
|
||||||
|
{
|
||||||
|
return calloc(n , elem_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *host_memalign(size_t alignment, size_t size)
|
||||||
|
{
|
||||||
|
return aligned_alloc(alignment, size);
|
||||||
|
}
|
||||||
|
@ -224,6 +224,11 @@ void up_longjmp(void *jb, int val);
|
|||||||
void *host_alloc_heap(size_t sz);
|
void *host_alloc_heap(size_t sz);
|
||||||
void *host_alloc_shmem(const char *name, size_t size, int master);
|
void *host_alloc_shmem(const char *name, size_t size, int master);
|
||||||
void host_free_shmem(void *mem);
|
void host_free_shmem(void *mem);
|
||||||
|
void *host_malloc(size_t size);
|
||||||
|
void host_free(void *mem);
|
||||||
|
void *host_realloc(void *oldmem, size_t size);
|
||||||
|
void *host_calloc(size_t n, size_t elem_size);
|
||||||
|
void *host_memalign(size_t alignment, size_t size);
|
||||||
|
|
||||||
/* up_hosttime.c ************************************************************/
|
/* up_hosttime.c ************************************************************/
|
||||||
|
|
||||||
|
@ -53,6 +53,10 @@ ifeq ($(CONFIG_STACK_CANARIES),y)
|
|||||||
ARCHOPTIMIZATION += -fstack-protector-all
|
ARCHOPTIMIZATION += -fstack-protector-all
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_SIM_SANITIZE),y)
|
||||||
|
ARCHOPTIMIZATION += -fsanitize=address -fsanitize=undefined -fno-omit-frame-pointer
|
||||||
|
endif
|
||||||
|
|
||||||
ARCHCPUFLAGS = -fno-builtin
|
ARCHCPUFLAGS = -fno-builtin
|
||||||
ARCHCPUFLAGSXX = -fno-builtin -nostdinc++
|
ARCHCPUFLAGSXX = -fno-builtin -nostdinc++
|
||||||
ifeq ($(CONFIG_CXX_EXCEPTION),)
|
ifeq ($(CONFIG_CXX_EXCEPTION),)
|
||||||
@ -189,5 +193,9 @@ ifeq ($(CONFIG_SIM_M32),y)
|
|||||||
HOSTLDFLAGS += -m32
|
HOSTLDFLAGS += -m32
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_SIM_SANITIZE),y)
|
||||||
|
CCLINKFLAGS += -fsanitize=address -fsanitize=undefined -fno-omit-frame-pointer
|
||||||
|
endif
|
||||||
|
|
||||||
HOSTCFLAGS = $(ARCHWARNINGS) $(ARCHOPTIMIZATION) \
|
HOSTCFLAGS = $(ARCHWARNINGS) $(ARCHOPTIMIZATION) \
|
||||||
$(ARCHCPUFLAGS) $(HOSTINCLUDES) $(EXTRAFLAGS) -pipe
|
$(ARCHCPUFLAGS) $(HOSTINCLUDES) $(EXTRAFLAGS) -pipe
|
||||||
|
Loading…
Reference in New Issue
Block a user