summaryrefslogtreecommitdiff
path: root/cmake/config
diff options
context:
space:
mode:
authorDimitri Staessens <dimitri@ouroboros.rocks>2026-02-19 22:03:16 +0100
committerSander Vrijders <sander@ouroboros.rocks>2026-02-22 16:02:16 +0100
commitc3636005831064e71b03a5f8796a21e89b2a714f (patch)
treeca57f7d09e9de015107edb1bda6f30654bf7699b /cmake/config
parent1bf1d33db3e7622c8b97c5518f0f0ff984b989a8 (diff)
downloadouroboros-c3636005831064e71b03a5f8796a21e89b2a714f.tar.gz
ouroboros-c3636005831064e71b03a5f8796a21e89b2a714f.zip
irmd: Allow direct rbuff between local processes
This allows bypassing the IPCP for local processes that share the same packet pool, lowering latency between processes to comparable levels as Unix sockets (RTT in the order of a microsecond). For local processes, no IPCPs are needed: $ irm b prog oping n oping $ oping -l Ouroboros ping server started. New flow 64. Received 64 bytes on fd 64. The direct IPC can be disabled with the DISABLE_DIRECT_IPC build flag. Note that this is needed for rumba 'local' experiments to emulate network topologies. Without this flag all processes will just communicate directly. Signed-off-by: Dimitri Staessens <dimitri@ouroboros.rocks> Signed-off-by: Sander Vrijders <sander@ouroboros.rocks>
Diffstat (limited to 'cmake/config')
-rw-r--r--cmake/config/irmd.cmake4
1 files changed, 4 insertions, 0 deletions
diff --git a/cmake/config/irmd.cmake b/cmake/config/irmd.cmake
index 9795e4a4..b86a40c5 100644
--- a/cmake/config/irmd.cmake
+++ b/cmake/config/irmd.cmake
@@ -29,6 +29,10 @@ set(IRMD_MIN_THREADS 8 CACHE STRING
set(IRMD_ADD_THREADS 8 CACHE STRING
"Number of extra threads to start when the IRMD faces thread starvation")
+# Direct IPC
+set(DISABLE_DIRECT_IPC FALSE CACHE BOOL
+ "Disable direct inter-process communication between local applications")
+
# Process management
set(IRMD_PKILL_TIMEOUT 30 CACHE STRING
"Number of seconds to wait before sending SIGKILL to subprocesses on exit")