From: Mathieu Desnoyers Date: Wed, 28 Sep 2011 00:01:51 +0000 (-0400) Subject: Fix handling of systems without sysconf nr possible cpu support X-Git-Tag: v0.7.0~43^2~115 X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=commitdiff_plain;h=91452a6aeb429d72aafaed0fd176cac5e742251d Fix handling of systems without sysconf nr possible cpu support Signed-off-by: Mathieu Desnoyers --- diff --git a/rculfhash.c b/rculfhash.c index bff26a8..638432a 100644 --- a/rculfhash.c +++ b/rculfhash.c @@ -608,7 +608,7 @@ void ht_count_del(struct cds_lfht *ht, unsigned long size) #else /* #if defined(HAVE_SCHED_GETCPU) && defined(HAVE_SYSCONF) */ -static const long nr_cpus_mask = -1; +static const long nr_cpus_mask = -2; static struct ht_items_count *alloc_per_cpu_items_count(void) @@ -1041,8 +1041,12 @@ void partition_resize_helper(struct cds_lfht *ht, unsigned long i, * We spawn just the number of threads we need to satisfy the minimum * partition size, up to the number of CPUs in the system. */ - nr_threads = min(nr_cpus_mask + 1, - len >> MIN_PARTITION_PER_THREAD_ORDER); + if (nr_cpus_mask > 0) { + nr_threads = min(nr_cpus_mask + 1, + len >> MIN_PARTITION_PER_THREAD_ORDER); + } else { + nr_threads = 1; + } partition_len = len >> get_count_order_ulong(nr_threads); work = calloc(nr_threads, sizeof(*work)); thread_id = calloc(nr_threads, sizeof(*thread_id));