[lttng-dev] [PATCH lttng-tools] Save/load: add support for shared memory path
Jérémie Galarneau
jeremie.galarneau at efficios.com
Thu Jun 25 13:09:55 EDT 2015
Merged with a memory leak fix, read on.
Thanks!
Jérémie
On Fri, Apr 17, 2015 at 5:26 PM, Jonathan Rajotte <
jonathan.rajotte-julien at efficios.com> wrote:
> Signed-off-by: Jonathan Rajotte <jonathan.rajotte-julien at efficios.com>
> ---
> src/bin/lttng-sessiond/save.c | 10 ++++++++++
> src/common/config/config-session-abi.h | 1 +
> src/common/config/config.c | 19 +++++++++++++++++++
> src/common/config/session.xsd | 1 +
> 4 files changed, 31 insertions(+)
>
> diff --git a/src/bin/lttng-sessiond/save.c b/src/bin/lttng-sessiond/save.c
> index 0c6894b..d6316ef 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 8cbff25..8ac5cb0 100644
> --- a/src/common/config/config-session-abi.h
> +++ b/src/common/config/config-session-abi.h
> @@ -67,6 +67,7 @@ const char * const config_element_data_uri;
> const char * const config_element_max_size;
> const char * const config_element_pid;
> const char * const config_element_pids;
> +const char * const config_element_shared_memory_path;
>
> const char * const config_domain_type_kernel;
> const char * const config_domain_type_ust;
> diff --git a/src/common/config/config.c b/src/common/config/config.c
> index d84e38b..bc4f0c0 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;
> + char *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);
>
As per the libxml docs[1]:
xmlNodeGetContent():
Returns: a new #xmlChar * or NULL if no content is available. It's up to
the caller to free the memory with xmlFree().
I have added an xmlFree() call to the teardown.
[1] http://xmlsoft.org/html/libxml-tree.html#xmlNodeGetContent
+ if (!node_content) {
> + ret = -LTTNG_ERR_NOMEM;
> + goto error;
> + }
> +
> + shm_path = (char *) node_content;
> } else {
> /* attributes, snapshot_mode or
> live_timer_interval */
> xmlNodePtr attributes_child =
> @@ -2356,6 +2368,13 @@ domain_init_error:
> goto error;
> }
>
> + if (shm_path) {
> + ret = lttng_set_session_shm_path(name, shm_path);
> + if (ret) {
> + goto error;
> + }
> + }
> +
> for (node = xmlFirstElementChild(domains_node); node;
> node = xmlNextElementSibling(node)) {
> ret = process_domain_node(node, name);
> diff --git a/src/common/config/session.xsd b/src/common/config/session.xsd
> index 6d74e85..0a7458d 100644
> --- a/src/common/config/session.xsd
> +++ b/src/common/config/session.xsd
> @@ -279,6 +279,7 @@ elementFormDefault="qualified" version="2.5">
> <xs:complexType name="session_type">
> <xs:all>
> <xs:element name="name" type="name_type"/>
> + <xs:element name="shared_memory_path" type="xs:string"
> minOccurs="0"/>
> <xs:element name="domains" type="domain_list_type"
> minOccurs="0"/>
> <xs:element name="started" type="xs:boolean" default="0"
> minOccurs="0"/>
> <xs:element name="attributes"
> type="session_attributes_type" minOccurs="0"/>
> --
> 2.1.4
>
>
--
Jérémie Galarneau
EfficiOS Inc.
http://www.efficios.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.lttng.org/pipermail/lttng-dev/attachments/20150625/d9f057eb/attachment.html>
More information about the lttng-dev
mailing list