From: Jonathan Rajotte Date: Fri, 17 Apr 2015 21:26:41 +0000 (-0400) Subject: Save/load: add support for shared memory path X-Git-Url: http://git.efficios.com/?p=lttng-tools.git;a=commitdiff_plain;h=9e7c9f56fd5089269e5af3d7e79f43cf6f87285d Save/load: add support for shared memory path Signed-off-by: Jonathan Rajotte Signed-off-by: Jérémie Galarneau --- diff --git a/src/bin/lttng-sessiond/save.c b/src/bin/lttng-sessiond/save.c index 0c6894b0a..d6316ef97 100644 --- a/src/bin/lttng-sessiond/save.c +++ b/src/bin/lttng-sessiond/save.c @@ -1663,6 +1663,16 @@ int save_session(struct ltt_session *session, goto end; } + if(session->shm_path[0] != '\0') { + ret = config_writer_write_element_string(writer, + config_element_shared_memory_path, + session->shm_path); + if (ret) { + ret = LTTNG_ERR_SAVE_IO_FAIL; + goto end; + } + } + ret = save_domains(writer, session); if (ret) { goto end; diff --git a/src/common/config/config-session-abi.h b/src/common/config/config-session-abi.h index 230b41161..c578af7e9 100644 --- a/src/common/config/config-session-abi.h +++ b/src/common/config/config-session-abi.h @@ -67,6 +67,7 @@ extern const char * const config_element_data_uri; extern const char * const config_element_max_size; extern const char * const config_element_pid; extern const char * const config_element_pids; +extern const char * const config_element_shared_memory_path; extern const char * const config_domain_type_kernel; extern const char * const config_domain_type_ust; diff --git a/src/common/config/config.c b/src/common/config/config.c index d84e38b9f..0366f5a87 100644 --- a/src/common/config/config.c +++ b/src/common/config/config.c @@ -117,6 +117,7 @@ const char * const config_element_data_uri = "data_uri"; const char * const config_element_max_size = "max_size"; const char * const config_element_pid = "pid"; const char * const config_element_pids = "pids"; +const char * const config_element_shared_memory_path = "shared_memory_path"; const char * const config_domain_type_kernel = "KERNEL"; const char * const config_domain_type_ust = "UST"; @@ -2172,6 +2173,7 @@ int process_session_node(xmlNodePtr session_node, const char *session_name, int ret, started = -1, snapshot_mode = -1; uint64_t live_timer_interval = UINT64_MAX; char *name = NULL; + xmlChar *shm_path = NULL; xmlNodePtr domains_node = NULL; xmlNodePtr output_node = NULL; xmlNodePtr node; @@ -2216,6 +2218,16 @@ int process_session_node(xmlNodePtr session_node, const char *session_name, config_element_output)) { /* output */ output_node = node; + } else if (!shm_path && !strcmp((const char *) node->name, + config_element_shared_memory_path)) { + /* shared memory path */ + xmlChar *node_content = xmlNodeGetContent(node); + if (!node_content) { + ret = -LTTNG_ERR_NOMEM; + goto error; + } + + shm_path = node_content; } else { /* attributes, snapshot_mode or live_timer_interval */ xmlNodePtr attributes_child = @@ -2356,6 +2368,14 @@ domain_init_error: goto error; } + if (shm_path) { + ret = lttng_set_session_shm_path((const char *) name, + (const char *) shm_path); + if (ret) { + goto error; + } + } + for (node = xmlFirstElementChild(domains_node); node; node = xmlNextElementSibling(node)) { ret = process_domain_node(node, name); @@ -2384,6 +2404,7 @@ error: free(log4j_domain); free(python_domain); free(name); + xmlFree(shm_path); return ret; } diff --git a/src/common/config/session.xsd b/src/common/config/session.xsd index 6d74e85f7..0a7458d17 100644 --- a/src/common/config/session.xsd +++ b/src/common/config/session.xsd @@ -279,6 +279,7 @@ elementFormDefault="qualified" version="2.5"> +