From c32cf0fea4a8666768bc65c319b062636d60d21a Mon Sep 17 00:00:00 2001 From: Leo Yuriev Date: Wed, 5 Aug 2015 00:43:20 +0300 Subject: [PATCH] lmdb, back-mdb: use 'long' as result to speedup comparison. Change-Id: I3ade0c7525f4a461a7edf5873af196e6b33c0727 --- lmdb.h | 2 +- mdb.c | 35 +++++++++++++++-------------------- 2 files changed, 16 insertions(+), 21 deletions(-) diff --git a/lmdb.h b/lmdb.h index 1d3ba60a..11b343a2 100644 --- a/lmdb.h +++ b/lmdb.h @@ -240,7 +240,7 @@ typedef struct MDB_val { } MDB_val; /** @brief A callback function used to compare two keys in a database */ -typedef int (MDB_cmp_func)(const MDB_val *a, const MDB_val *b); +typedef long (MDB_cmp_func)(const MDB_val *a, const MDB_val *b); /** @brief A callback function used to relocate a position-dependent data item * in a fixed-address database. diff --git a/mdb.c b/mdb.c index bdaa7fda..d8c0badb 100644 --- a/mdb.c +++ b/mdb.c @@ -4819,24 +4819,22 @@ mdb_env_close_ex(MDB_env *env, int dont_sync) } /** Compare two items pointing at aligned unsigned int's. */ -static int +static long mdb_cmp_int_ai(const MDB_val *a, const MDB_val *b) { mdb_assert(NULL, a->mv_size == b->mv_size); mdb_assert(NULL, 0 == (uintptr_t) a->mv_data % sizeof(int) && 0 == (uintptr_t) b->mv_data % sizeof(int)); - if (sizeof(int) != sizeof(size_t) && likely(a->mv_size == sizeof(size_t))) { - return (*(size_t *)a->mv_data < *(size_t *)b->mv_data) ? -1 : - *(size_t *)a->mv_data > *(size_t *)b->mv_data; - } + if (sizeof(int) != sizeof(long) && likely(a->mv_size == sizeof(long))) + return *(long *)a->mv_data - *(long *)b->mv_data; mdb_assert(NULL, a->mv_size == sizeof(int) ); return *(int *)a->mv_data - *(int *)b->mv_data; } /** Compare two items pointing at 2-byte aligned unsigned int's. */ -static int +static long mdb_cmp_int_a2(const MDB_val *a, const MDB_val *b) { mdb_assert(NULL, a->mv_size == b->mv_size); @@ -4844,16 +4842,14 @@ mdb_cmp_int_a2(const MDB_val *a, const MDB_val *b) mdb_assert(NULL, 0 == (uintptr_t) a->mv_data % sizeof(short) && 0 == (uintptr_t) b->mv_data % sizeof(short)); #ifdef MISALIGNED_OK - if (sizeof(int) != sizeof(size_t) && likely(a->mv_size == sizeof(size_t))) { - return (*(size_t *)a->mv_data < *(size_t *)b->mv_data) ? -1 : - *(size_t *)a->mv_data > *(size_t *)b->mv_data; - } + if (sizeof(int) != sizeof(long) && likely(a->mv_size == sizeof(long))) + return *(long *)a->mv_data - *(long *)b->mv_data; mdb_assert(NULL, a->mv_size == sizeof(int) ); return *(int *)a->mv_data - *(int *)b->mv_data; #else { - int x; + long x; unsigned short *u, *c; #if BYTE_ORDER == LITTLE_ENDIAN @@ -4881,14 +4877,13 @@ mdb_cmp_int_a2(const MDB_val *a, const MDB_val *b) * * This is also set as #MDB_INTEGERDUP|#MDB_DUPFIXED's #MDB_dbx.%md_dcmp. */ -static int +static long mdb_cmp_int_ua(const MDB_val *a, const MDB_val *b) { mdb_assert(NULL, a->mv_size == b->mv_size); #if MISALIGNED_OK - if (sizeof(int) != sizeof(size_t) && likely(a->mv_size == sizeof(size_t))) - return (*(size_t *)a->mv_data < *(size_t *)b->mv_data) ? -1 : - *(size_t *)a->mv_data > *(size_t *)b->mv_data; + if (sizeof(int) != sizeof(long) && likely(a->mv_size == sizeof(long))) + return *(long *)a->mv_data - *(long *)b->mv_data; mdb_assert(NULL, a->mv_size == sizeof(int) ); return *(int *)a->mv_data - *(int *)b->mv_data; @@ -4897,7 +4892,7 @@ mdb_cmp_int_ua(const MDB_val *a, const MDB_val *b) { #if BYTE_ORDER == LITTLE_ENDIAN const unsigned char *p1, *p2; - int diff; + long diff; p1 = (const unsigned char *)a->mv_data + a->mv_size; p2 = (const unsigned char *)b->mv_data + a->mv_size; @@ -4916,10 +4911,10 @@ mdb_cmp_int_ua(const MDB_val *a, const MDB_val *b) } /** Compare two items lexically */ -static int +static long mdb_cmp_memn(const MDB_val *a, const MDB_val *b) { - int diff; + long diff; ssize_t len_diff; unsigned len; @@ -4935,12 +4930,12 @@ mdb_cmp_memn(const MDB_val *a, const MDB_val *b) } /** Compare two items in reverse byte order */ -static int +static long mdb_cmp_memnr(const MDB_val *a, const MDB_val *b) { const unsigned char *p1, *p2, *p1_lim; ssize_t len_diff; - int diff; + long diff; p1_lim = (const unsigned char *)a->mv_data; p1 = (const unsigned char *)a->mv_data + a->mv_size;