[ltt-dev] [PATCH 9/9] change strategy for AR_RANDOM
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Tue Nov 15 06:35:51 EST 2011
* Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
> Signed-off-by: Lai Jiangshan <laijs at cn.fujitsu.com>
> ---
> tests/test_urcu_hash.c | 34 ++++++++++++++++++++++++++++++++--
> 1 files changed, 32 insertions(+), 2 deletions(-)
>
> diff --git a/tests/test_urcu_hash.c b/tests/test_urcu_hash.c
> index 964a4e1..f07f0d4 100644
> --- a/tests/test_urcu_hash.c
> +++ b/tests/test_urcu_hash.c
> @@ -540,6 +540,37 @@ void free_node_cb(struct rcu_head *head)
> free(node);
> }
>
> +static inline
> +int thr_writer_add(void)
> +{
> + static __thread int addremove_thread;
> + unsigned addremove_random;
> +
> + if (add_only)
> + return 1;
> +
> + if (addremove == AR_ADD)
> + return 1;
> +
> + if (addremove == AR_REMOVE)
> + return 0;
> +
> + addremove_random = test_rand_get_bits(2);
> + if (addremove_random < 2)
> + return addremove_random;
> +
> + while (caa_unlikely(!addremove_thread))
> + addremove_thread = test_rand_get_bits(16) - (1UL << 15);
> +
> + if (addremove_thread > 0) {
> + addremove_thread--;
> + return 1;
> + } else {
> + addremove_thread++;
> + return 0;
> + }
Can you explain what this part of the change does ? I am slightly
uncomfortable about a while () loop in there too that depends on random
results.
Thanks,
Mathieu
> +}
> +
> void *thr_writer(void *_count)
> {
> struct lfht_test_node *node;
> @@ -562,8 +593,7 @@ void *thr_writer(void *_count)
> cmm_smp_mb();
>
> for (;;) {
> - if ((addremove == AR_ADD || add_only)
> - || (addremove == AR_RANDOM && test_rand_get_bits(1))) {
> + if (thr_writer_add()) {
> node = malloc(sizeof(struct lfht_test_node));
> lfht_test_node_init(node);
> rcu_read_lock();
> --
> 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