From 7631f459f737f114182dfab72bac066bfd2c7232 Mon Sep 17 00:00:00 2001 From: Jukka Laitinen Date: Thu, 12 Dec 2024 12:22:39 +0200 Subject: [PATCH] fs/shm/shmfs_alloc.c: Allocate zero-initialized memory in flat build POSIX requires that the shm objects are zero-initialized. This has been broken in some earlier commits (starting from 9af5fc5d09724a5d300bc07ce85b9ba5c01ffadd) Also fix the flat build memory allocation to allocate both object data and payload in the same chunk (as the comment also suggests). This saves allocations and memory in a system with lots of shm objects. Signed-off-by: Jukka Laitinen --- fs/shm/shmfs_alloc.c | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/fs/shm/shmfs_alloc.c b/fs/shm/shmfs_alloc.c index 4764c901e6849..9b1083b20f7c9 100644 --- a/fs/shm/shmfs_alloc.c +++ b/fs/shm/shmfs_alloc.c @@ -51,24 +51,26 @@ FAR struct shmfs_object_s *shmfs_alloc_object(size_t length) * chunk in kernel heap */ - object = fs_heap_zalloc(sizeof(struct shmfs_object_s)); - if (object) + size_t hdr_size = sizeof(struct shmfs_object_s); + size_t alloc_size = length; + size_t cachesize = up_get_dcache_linesize(); + + if (cachesize > 0) { - size_t cachesize = up_get_dcache_linesize(); - if (cachesize > 0) - { - object->paddr = fs_heap_memalign(cachesize, - ALIGN_UP(length, cachesize)); - } - else - { - object->paddr = fs_heap_malloc(length); - } + hdr_size = ALIGN_UP(hdr_size, cachesize); + alloc_size = ALIGN_UP(alloc_size, cachesize); + object = fs_heap_memalign(cachesize, hdr_size + alloc_size); + } + else + { + object = fs_heap_malloc(hdr_size + alloc_size); + } - if (object->paddr) - { - allocated = true; - } + if (object) + { + memset(object, 0, hdr_size + alloc_size); + object->paddr = (void *)((uintptr_t)object + hdr_size); + allocated = true; } #elif defined(CONFIG_BUILD_PROTECTED) @@ -152,9 +154,7 @@ void shmfs_free_object(FAR struct shmfs_object_s *object) { if (object) { -#if defined(CONFIG_BUILD_FLAT) - fs_heap_free(object->paddr); -#elif defined(CONFIG_BUILD_PROTECTED) +#if defined(CONFIG_BUILD_PROTECTED) kumm_free(object->paddr); #elif defined(CONFIG_BUILD_KERNEL) size_t i;