nuttx/fs/fs_heap.c
buxiasen 946ed96926 fs: add fs_heap, support shm/tmpfs/pseudofile with indepent heap
For some case, need large files from tmpfs or shmfs, will lead to high
pressure on memory fragments, add an optional fs_heap with independent
heap will benifit for memory fragments issue.

Signed-off-by: buxiasen <buxiasen@xiaomi.com>
2024-08-25 22:12:37 +08:00

67 lines
2.1 KiB
C

/****************************************************************************
* fs/fs_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 "fs_heap.h"
#if defined(CONFIG_FS_HEAPSIZE) && CONFIG_FS_HEAPSIZE > 0
/****************************************************************************
* Private Data
****************************************************************************/
static FAR struct mm_heap_s *g_fs_heap;
/****************************************************************************
* Public Functions
****************************************************************************/
void fs_heap_initialize(void)
{
FAR void *buf = kmm_malloc(CONFIG_FS_HEAPSIZE);
DEBUGASSERT(buf != NULL);
g_fs_heap = mm_initialize("heapfs", buf, CONFIG_FS_HEAPSIZE);
}
FAR void *fs_heap_zalloc(size_t size)
{
return mm_zalloc(g_fs_heap, size);
}
size_t fs_heap_malloc_size(FAR void *mem)
{
return mm_malloc_size(g_fs_heap, mem);
}
FAR void *fs_heap_realloc(FAR void *oldmem, size_t size)
{
return mm_realloc(g_fs_heap, oldmem, size);
}
void fs_heap_free(FAR void *mem)
{
mm_free(g_fs_heap, mem);
}
#endif