From 9cde95c5ac203c7d8deabed43d76477b4a900fd6 Mon Sep 17 00:00:00 2001 From: Luca Cominardi Date: Mon, 20 Nov 2023 11:07:16 +0100 Subject: [PATCH] Enable shared-memory in shared-memory examples --- examples/z_pub_shm.c | 5 +++++ examples/z_sub.c | 7 +++++++ 2 files changed, 12 insertions(+) diff --git a/examples/z_pub_shm.c b/examples/z_pub_shm.c index 22ac4f54e..f26c65c08 100644 --- a/examples/z_pub_shm.c +++ b/examples/z_pub_shm.c @@ -34,6 +34,11 @@ int main(int argc, char **argv) { if (argc > 2) value = argv[2]; z_owned_config_t config = z_config_default(); + // Enable shared memory + if (zc_config_insert_json(z_loan(config), "transport/shared_memory/enabled", "true") < 0) { + printf("Error enabling Shared Memory"); + exit(-1); + } if (argc > 3) { if (zc_config_insert_json(z_loan(config), Z_CONFIG_CONNECT_KEY, argv[3]) < 0) { printf( diff --git a/examples/z_sub.c b/examples/z_sub.c index 61ae2246e..ccfb32825 100644 --- a/examples/z_sub.c +++ b/examples/z_sub.c @@ -45,6 +45,13 @@ int main(int argc, char **argv) { exit(-1); } } + // A probing procedure for shared memory is performed upon session opening. To enable `z_pub_shm` to operate + // over shared memory (and to not fallback on network mode), shared memory needs to be enabled also on the + // subscriber side. By doing so, the probing procedure will succeed and shared memory will operate as expected. + if (zc_config_insert_json(z_loan(config), "transport/shared_memory/enabled", "true") < 0) { + printf("Error enabling Shared Memory"); + exit(-1); + } printf("Opening session...\n"); z_owned_session_t s = z_open(z_move(config));