From: David Goulet Date: Wed, 3 Oct 2012 15:19:45 +0000 (-0400) Subject: Add hash table argument to helper functions X-Git-Tag: v2.1.0-rc5~28 X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=commitdiff_plain;h=8389e4f892205f3fa7d4777ea64da88e07021f7c Add hash table argument to helper functions This allows these helper functions to be used more broadly across the code base and not for a specific hash table. Acked-by: Mathieu Desnoyers Signed-off-by: David Goulet --- diff --git a/src/common/consumer.c b/src/common/consumer.c index b55fd153d..161bf7e32 100644 --- a/src/common/consumer.c +++ b/src/common/consumer.c @@ -62,12 +62,15 @@ volatile int consumer_quit = 0; * Find a stream. The consumer_data.lock must be locked during this * call. */ -static struct lttng_consumer_stream *consumer_find_stream(int key) +static struct lttng_consumer_stream *consumer_find_stream(int key, + struct lttng_ht *ht) { struct lttng_ht_iter iter; struct lttng_ht_node_ulong *node; struct lttng_consumer_stream *stream = NULL; + assert(ht); + /* Negative keys are lookup failures */ if (key < 0) { return NULL; @@ -75,8 +78,7 @@ static struct lttng_consumer_stream *consumer_find_stream(int key) rcu_read_lock(); - lttng_ht_lookup(consumer_data.stream_ht, (void *)((unsigned long) key), - &iter); + lttng_ht_lookup(ht, (void *)((unsigned long) key), &iter); node = lttng_ht_iter_get_node_ulong(&iter); if (node != NULL) { stream = caa_container_of(node, struct lttng_consumer_stream, node); @@ -87,12 +89,12 @@ static struct lttng_consumer_stream *consumer_find_stream(int key) return stream; } -static void consumer_steal_stream_key(int key) +static void consumer_steal_stream_key(int key, struct lttng_ht *ht) { struct lttng_consumer_stream *stream; rcu_read_lock(); - stream = consumer_find_stream(key); + stream = consumer_find_stream(key, ht); if (stream) { stream->key = -1; /* @@ -443,7 +445,7 @@ int consumer_add_stream(struct lttng_consumer_stream *stream) pthread_mutex_lock(&consumer_data.lock); /* Steal stream identifier, for UST */ - consumer_steal_stream_key(stream->key); + consumer_steal_stream_key(stream->key, consumer_data.stream_ht); rcu_read_lock(); lttng_ht_lookup(consumer_data.stream_ht, @@ -620,7 +622,7 @@ void consumer_change_stream_state(int stream_key, struct lttng_consumer_stream *stream; pthread_mutex_lock(&consumer_data.lock); - stream = consumer_find_stream(stream_key); + stream = consumer_find_stream(stream_key, consumer_data.stream_ht); if (stream) { stream->state = state; }