Fix trace UST destroy channel
authorDavid Goulet <dgoulet@efficios.com>
Thu, 12 Jan 2012 15:47:13 +0000 (10:47 -0500)
committerDavid Goulet <dgoulet@efficios.com>
Thu, 12 Jan 2012 15:47:13 +0000 (10:47 -0500)
The trace_ust_destroy_channel call was iterating over the internal
events hash table and destroying the complete hash table at each event
which makes no sense at all. This caused a major segfault in the hash
table data structure when destroying a session.

Reported-by: Tan Dung Le Tran<tan.dung.le.tran@ericsson.com>
Signed-off-by: David Goulet <dgoulet@efficios.com>
lttng-sessiond/trace-ust.c

index e4a5218110d78258973868aa11925623415816ce..c85e79ce14fba897c280d1efaefa3d3602664cc0 100644 (file)
@@ -322,7 +322,7 @@ static void destroy_context_rcu(struct rcu_head *head)
 /*
  * Cleanup UST context hash table.
  */
-static void destroy_context(struct lttng_ht *ht)
+static void destroy_contexts(struct lttng_ht *ht)
 {
        int ret;
        struct lttng_ht_node_ulong *node;
@@ -344,7 +344,7 @@ static void destroy_context(struct lttng_ht *ht)
 void trace_ust_destroy_event(struct ltt_ust_event *event)
 {
        DBG2("Trace destroy UST event %s", event->attr.name);
-       destroy_context(event->ctx);
+       destroy_contexts(event->ctx);
 
        free(event);
 }
@@ -365,7 +365,7 @@ static void destroy_event_rcu(struct rcu_head *head)
 /*
  * Cleanup UST events hashtable.
  */
-static void destroy_event(struct lttng_ht *events)
+static void destroy_events(struct lttng_ht *events)
 {
        int ret;
        struct lttng_ht_node_str *node;
@@ -373,9 +373,8 @@ static void destroy_event(struct lttng_ht *events)
 
        cds_lfht_for_each_entry(events->ht, &iter.iter, node, node) {
                ret = lttng_ht_del(events, &iter);
-               if (!ret) {
-                       call_rcu(&node->head, destroy_event_rcu);
-               }
+               assert(!ret);
+               call_rcu(&node->head, destroy_event_rcu);
        }
 
        lttng_ht_destroy(events);
@@ -386,21 +385,15 @@ static void destroy_event(struct lttng_ht *events)
  */
 void trace_ust_destroy_channel(struct ltt_ust_channel *channel)
 {
-       int ret;
-       struct lttng_ht_node_str *node;
-       struct lttng_ht_iter iter;
-
        DBG2("Trace destroy UST channel %s", channel->name);
 
        rcu_read_lock();
 
-       cds_lfht_for_each_entry(channel->events->ht, &iter.iter, node, node) {
-               ret = lttng_ht_del(channel->events, &iter);
-               assert(!ret);
-               destroy_event(channel->events);
-       }
+       /* Destroying all events of the channel */
+       destroy_events(channel->events);
+       /* Destroying all context of the channel */
+       destroy_contexts(channel->ctx);
 
-       destroy_context(channel->ctx);
        free(channel);
 
        rcu_read_unlock();
@@ -442,9 +435,8 @@ static void destroy_channels(struct lttng_ht *channels)
 
        cds_lfht_for_each_entry(channels->ht, &iter.iter, node, node) {
                ret = lttng_ht_del(channels, &iter);
-               if (!ret) {
-                       call_rcu(&node->head, destroy_channel_rcu);
-               }
+               assert(!ret);
+               call_rcu(&node->head, destroy_channel_rcu);
        }
 
        lttng_ht_destroy(channels);
@@ -463,9 +455,8 @@ static void destroy_domain_pid(struct lttng_ht *ht)
 
        cds_lfht_for_each_entry(ht->ht, &iter.iter, dpid, node.node) {
                ret = lttng_ht_del(ht , &iter);
-               if (!ret) {
-                       destroy_channels(dpid->channels);
-               }
+               assert(!ret);
+               destroy_channels(dpid->channels);
        }
 
        lttng_ht_destroy(ht);
@@ -482,9 +473,8 @@ static void destroy_domain_exec(struct lttng_ht *ht)
 
        cds_lfht_for_each_entry(ht->ht, &iter.iter, dexec, node.node) {
                ret = lttng_ht_del(ht , &iter);
-               if (!ret) {
-                       destroy_channels(dexec->channels);
-               }
+               assert(!ret);
+               destroy_channels(dexec->channels);
        }
 
        lttng_ht_destroy(ht);
This page took 0.027533 seconds and 4 git commands to generate.