[ltt-dev] [PATCH 2/7] rculfhash: Move "struct rcu_head head" out of "struct cds_lfht_node"
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Wed Nov 2 13:18:14 EDT 2011
* Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
> It is user's responsibility to free it by call_rcu(),
> synchronize_rcu() or defer_rcu().
merged, thanks!
Mathieu
>
> Signed-off-by: Lai Jiangshan <laijs at cn.fujitsu.com>
> ---
> tests/test_urcu_hash.c | 12 +++++++-----
> urcu/rculfhash.h | 2 --
> 2 files changed, 7 insertions(+), 7 deletions(-)
>
> diff --git a/tests/test_urcu_hash.c b/tests/test_urcu_hash.c
> index dbacf73..e28c14a 100644
> --- a/tests/test_urcu_hash.c
> +++ b/tests/test_urcu_hash.c
> @@ -107,6 +107,8 @@ struct test_data {
>
> struct lfht_test_node {
> struct cds_lfht_node node;
> + /* cache-cold for iteration */
> + struct rcu_head head;
> };
>
> static inline struct lfht_test_node *
> @@ -516,7 +518,7 @@ static
> void free_node_cb(struct rcu_head *head)
> {
> struct lfht_test_node *node =
> - caa_container_of(head, struct lfht_test_node, node.head);
> + caa_container_of(head, struct lfht_test_node, head);
> free(node);
> }
>
> @@ -562,7 +564,7 @@ void *thr_writer(void *_count)
> nr_addexist++;
> } else {
> if (add_replace && ret_node) {
> - call_rcu(&to_test_node(ret_node)->node.head,
> + call_rcu(&to_test_node(ret_node)->head,
> free_node_cb);
> nr_addexist++;
> } else {
> @@ -579,7 +581,7 @@ void *thr_writer(void *_count)
> rcu_read_unlock();
> if (ret == 0) {
> node = cds_lfht_iter_get_test_node(&iter);
> - call_rcu(&node->node.head, free_node_cb);
> + call_rcu(&node->head, free_node_cb);
> nr_del++;
> } else
> nr_delnoent++;
> @@ -653,7 +655,7 @@ static int populate_hash(void)
> nr_addexist++;
> } else {
> if (add_replace && ret_node) {
> - call_rcu(&to_test_node(ret_node)->node.head, free_node_cb);
> + call_rcu(&to_test_node(ret_node)->head, free_node_cb);
> nr_addexist++;
> } else {
> nr_add++;
> @@ -677,7 +679,7 @@ void test_delete_all_nodes(struct cds_lfht *ht)
>
> ret = cds_lfht_del(test_ht, &iter);
> assert(!ret);
> - call_rcu(&node->node.head, free_node_cb);
> + call_rcu(&node->head, free_node_cb);
> cds_lfht_next(ht, &iter);
> count++;
> }
> diff --git a/urcu/rculfhash.h b/urcu/rculfhash.h
> index 008b1d4..f4f3373 100644
> --- a/urcu/rculfhash.h
> +++ b/urcu/rculfhash.h
> @@ -62,8 +62,6 @@ struct cds_lfht_node {
> struct _cds_lfht_node p; /* needs to be first field */
> void *key;
> unsigned int key_len;
> - /* cache-cold for iteration */
> - struct rcu_head head;
> };
>
> /* cds_lfht_iter: Used to track state while traversing a hash chain. */
> --
> 1.7.4.4
>
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list