diff options
Diffstat (limited to 'cmake')
| -rw-r--r-- | cmake/lib.cmake | 4 | ||||
| -rw-r--r-- | cmake/lib/common.cmake | 6 | ||||
| -rw-r--r-- | cmake/lib/lib.cmake | 19 | ||||
| -rw-r--r-- | cmake/lib/ssm.cmake | 89 | ||||
| -rw-r--r-- | cmake/tests.cmake | 1 | ||||
| -rw-r--r-- | cmake/utils/HumanReadable.cmake | 17 |
6 files changed, 115 insertions, 21 deletions
diff --git a/cmake/lib.cmake b/cmake/lib.cmake index 6d9333a3..284c19ee 100644 --- a/cmake/lib.cmake +++ b/cmake/lib.cmake @@ -2,6 +2,10 @@ include(lib/lib) include(lib/common) include(lib/dev) include(lib/irm) +include(lib/ssm) configure_file("${LIB_SOURCE_DIR}/config.h.in" "${LIB_BINARY_DIR}/config.h" @ONLY) + +configure_file("${LIB_SOURCE_DIR}/ssm/ssm.h.in" + "${LIB_BINARY_DIR}/ssm.h" @ONLY) diff --git a/cmake/lib/common.cmake b/cmake/lib/common.cmake index 1e834f10..b0898950 100644 --- a/cmake/lib/common.cmake +++ b/cmake/lib/common.cmake @@ -47,9 +47,9 @@ set(SOURCE_FILES_COMMON serdes-irm.c serdes-oep.c sha3.c - shm_flow_set.c - shm_rbuff.c - shm_rdrbuff.c + ssm/flow_set.c + ssm/rbuff.c + ssm/pool.c sockets.c tpm.c utils.c diff --git a/cmake/lib/lib.cmake b/cmake/lib/lib.cmake index bb24d1b9..86b4418c 100644 --- a/cmake/lib/lib.cmake +++ b/cmake/lib/lib.cmake @@ -2,10 +2,6 @@ set(LIB_SOURCE_DIR "${CMAKE_SOURCE_DIR}/src/lib") set(LIB_BINARY_DIR "${CMAKE_BINARY_DIR}/src/lib") # Library configuration variables -set(SHM_BUFFER_SIZE 16384 CACHE STRING - "Number of blocks in packet buffer, must be a power of 2") -set(SHM_RBUFF_SIZE 1024 CACHE STRING - "Number of blocks in rbuff buffer, must be a power of 2") set(SYS_MAX_FLOWS 10240 CACHE STRING "Maximum number of total flows for this system") set(PROG_MAX_FLOWS 4096 CACHE STRING @@ -14,10 +10,6 @@ set(PROG_RES_FDS 64 CACHE STRING "Number of reserved flow descriptors per application") set(PROG_MAX_FQUEUES 32 CACHE STRING "Maximum number of flow sets per application") -set(DU_BUFF_HEADSPACE 256 CACHE STRING - "Bytes of headspace to reserve for future headers") -set(DU_BUFF_TAILSPACE 32 CACHE STRING - "Bytes of tailspace to reserve for future tails") if (NOT APPLE) set(PTHREAD_COND_CLOCK "CLOCK_MONOTONIC" CACHE STRING @@ -31,18 +23,9 @@ set(SOCKET_TIMEOUT 500 CACHE STRING "Default timeout for responses from IPCPs (ms)") set(SHM_PREFIX "ouroboros" CACHE STRING "String to prepend to POSIX shared memory filenames") -set(SHM_RBUFF_PREFIX "/${SHM_PREFIX}.rbuff." CACHE INTERNAL - "Prefix for rbuff POSIX shared memory filenames") set(SHM_LOCKFILE_NAME "/${SHM_PREFIX}.lockfile" CACHE INTERNAL "Filename for the POSIX shared memory lockfile") -set(SHM_FLOW_SET_PREFIX "/${SHM_PREFIX}.set." CACHE INTERNAL - "Prefix for the POSIX shared memory flow set") -set(SHM_RDRB_NAME "/${SHM_PREFIX}.rdrb" CACHE INTERNAL - "Name for the main POSIX shared memory buffer") -set(SHM_RDRB_BLOCK_SIZE "sysconf(_SC_PAGESIZE)" CACHE STRING - "Packet buffer block size, multiple of pagesize for performance") -set(SHM_RDRB_MULTI_BLOCK TRUE CACHE BOOL - "Packet buffer multiblock packet support") + set(QOS_DISABLE_CRC TRUE CACHE BOOL "Ignores ber setting on all QoS cubes") set(DELTA_T_MPL 60 CACHE STRING diff --git a/cmake/lib/ssm.cmake b/cmake/lib/ssm.cmake new file mode 100644 index 00000000..71790a4a --- /dev/null +++ b/cmake/lib/ssm.cmake @@ -0,0 +1,89 @@ +# Pool size configuration for Ouroboros secure shared memory +# This file defines the allocation parameters for the +# secure shared memory pool allocator + +# Shared memory pool naming configuration +set(SSM_PREFIX "o7s.ssm" CACHE STRING + "Prefix for secure shared memory pools") +set(SSM_GSMP_SUFFIX ".gsmp" CACHE STRING + "Suffix for Group Shared Memory Pool") +set(SSM_PPP_SUFFIX ".ppp" CACHE STRING + "Suffix for Process Private Pool") + +set(SSM_POOL_NAME "/${SHM_PREFIX}.pool" CACHE INTERNAL + "Name for the main POSIX shared memory pool") +set(SSM_POOL_BLOCKS 16384 CACHE STRING + "Number of blocks in SSM packet pool, must be a power of 2") +set(SSM_PK_BUFF_HEADSPACE 256 CACHE STRING + "Bytes of headspace to reserve for future headers") +set(SSM_PK_BUFF_TAILSPACE 32 CACHE STRING + "Bytes of tailspace to reserve for future tails") +set(SSM_RBUFF_SIZE 1024 CACHE STRING + "Number of blocks in rbuff buffer, must be a power of 2") +set(SSM_RBUFF_PREFIX "/${SHM_PREFIX}.rbuff." CACHE INTERNAL + "Prefix for rbuff POSIX shared memory filenames") +set(SSM_FLOW_SET_PREFIX "/${SHM_PREFIX}.set." CACHE INTERNAL + "Prefix for the POSIX shared memory flow set") + +# Pool blocks per size class +# This determines how many blocks of each size are preallocated in the pool +# Higher values reduce allocation failures but increase memory usage +set(SSM_POOL_256_BLOCKS 1024 CACHE STRING + "Number of 256B blocks in pool") +set(SSM_POOL_512_BLOCKS 768 CACHE STRING + "Number of 512B blocks in pool") +set(SSM_POOL_1K_BLOCKS 512 CACHE STRING + "Number of 1KB blocks in pool") +set(SSM_POOL_2K_BLOCKS 384 CACHE STRING + "Number of 2KB blocks in pool") +set(SSM_POOL_4K_BLOCKS 256 CACHE STRING + "Number of 4KB blocks in pool") +set(SSM_POOL_16K_BLOCKS 128 CACHE STRING + "Number of 16KB blocks in pool") +set(SSM_POOL_64K_BLOCKS 64 CACHE STRING + "Number of 64KB blocks in pool") +set(SSM_POOL_256K_BLOCKS 32 CACHE STRING + "Number of 256KB blocks in pool") +set(SSM_POOL_1M_BLOCKS 16 CACHE STRING + "Number of 1MB blocks in pool") + +# Number of shards per size class for reducing contention +set(SSM_POOL_SHARDS 4 CACHE STRING + "Number of allocator shards per size class") + +# SSM packet buffer overhead - computed at compile time via sizeof() +# Defined in config.h.in as sizeof(_ssm_memory_block) + sizeof(_ssm_pk_buff) +# This makes it portable across platforms with different pid_t sizes and padding + +# Total shared memory pool size calculation +math(EXPR SSM_POOL_TOTAL_SIZE + "(1 << 8) * ${SSM_POOL_256_BLOCKS} + \ + (1 << 9) * ${SSM_POOL_512_BLOCKS} + \ + (1 << 10) * ${SSM_POOL_1K_BLOCKS} + \ + (1 << 11) * ${SSM_POOL_2K_BLOCKS} + \ + (1 << 12) * ${SSM_POOL_4K_BLOCKS} + \ + (1 << 14) * ${SSM_POOL_16K_BLOCKS} + \ + (1 << 16) * ${SSM_POOL_64K_BLOCKS} + \ + (1 << 18) * ${SSM_POOL_256K_BLOCKS} + \ + (1 << 20) * ${SSM_POOL_1M_BLOCKS}") + +set(SSM_POOL_TOTAL_SIZE ${SSM_POOL_TOTAL_SIZE} CACHE INTERNAL + "Total shared memory pool size in bytes") + +include(utils/HumanReadable) +format_bytes_human_readable(${SSM_POOL_TOTAL_SIZE} SSM_POOL_SIZE_DISPLAY) + +# Display configuration summary +message(STATUS "Secure Shared Memory Pool Configuration:") +message(STATUS " Pool prefix: ${SSM_PREFIX}") +message(STATUS " Size classes: " + "256B, 512B, 1KiB, 2KiB, 4KiB, 16KiB, 64KiB, 256KiB, 1MiB") +message(STATUS " Max allocation: 1 MB") +message(STATUS " Total pool size: ${SSM_POOL_SIZE_DISPLAY} " + "(${SSM_POOL_TOTAL_SIZE} bytes)") +message(STATUS " Shards per class: ${SSM_POOL_SHARDS}") +message(STATUS " Blocks per class: ${SSM_POOL_256_BLOCKS}, " + "${SSM_POOL_512_BLOCKS}, ${SSM_POOL_1K_BLOCKS}, " + "${SSM_POOL_2K_BLOCKS}, ${SSM_POOL_4K_BLOCKS}, " + "${SSM_POOL_16K_BLOCKS}, ${SSM_POOL_64K_BLOCKS}, " + "${SSM_POOL_256K_BLOCKS}, ${SSM_POOL_1M_BLOCKS}") diff --git a/cmake/tests.cmake b/cmake/tests.cmake index 456ad120..e3857cab 100644 --- a/cmake/tests.cmake +++ b/cmake/tests.cmake @@ -17,6 +17,7 @@ if (BUILD_TESTS) # Add test subdirectories add_subdirectory(src/lib/tests) + add_subdirectory(src/lib/ssm/tests) add_subdirectory(src/irmd/oap/tests) add_subdirectory(src/ipcpd/unicast/pff/tests) add_subdirectory(src/ipcpd/unicast/routing/tests) diff --git a/cmake/utils/HumanReadable.cmake b/cmake/utils/HumanReadable.cmake new file mode 100644 index 00000000..8bc1722f --- /dev/null +++ b/cmake/utils/HumanReadable.cmake @@ -0,0 +1,17 @@ +# Human-readable size conversion utilities + +# Convert bytes to human-readable format (GB, MB, KB) +# Usage: format_bytes_human_readable(<bytes> <output_var>) +function(format_bytes_human_readable bytes output_var) + math(EXPR size_gb "${bytes} / 1073741824") + math(EXPR size_mb "${bytes} / 1048576") + math(EXPR size_kb "${bytes} / 1024") + + if(size_gb GREATER 0) + set(${output_var} "${size_gb} GB" PARENT_SCOPE) + elseif(size_mb GREATER 0) + set(${output_var} "${size_mb} MB" PARENT_SCOPE) + else() + set(${output_var} "${size_kb} KB" PARENT_SCOPE) + endif() +endfunction() |
