summaryrefslogtreecommitdiff
path: root/mysys/ptr_cmp.c
diff options
context:
space:
mode:
authorMikael Ronstrom <mikael@mysql.com>2009-09-23 15:15:35 +0200
committerMikael Ronstrom <mikael@mysql.com>2009-09-23 15:15:35 +0200
commitcd0477e8e397f0f4b14140a81e21778f660e8efc (patch)
tree05b7e0c7d9e4d32e43bc8fa5c6c029487ba21731 /mysys/ptr_cmp.c
parent8e59a23d7d39fd78fbd677672ec1d33b75317ee5 (diff)
downloadmariadb-git-cd0477e8e397f0f4b14140a81e21778f660e8efc.tar.gz
WL#5105, ptr_cmp optimised on Solaris, more efficient to use memcmp on Solaris than native impl.
Diffstat (limited to 'mysys/ptr_cmp.c')
-rw-r--r--mysys/ptr_cmp.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/mysys/ptr_cmp.c b/mysys/ptr_cmp.c
index 24ab6a1ea9c..9f053f0b3b4 100644
--- a/mysys/ptr_cmp.c
+++ b/mysys/ptr_cmp.c
@@ -22,16 +22,39 @@
#include "mysys_priv.h"
#include <myisampack.h>
+#ifdef UNIV_SOLARIS
+/*
+ * On Solaris, memcmp() is normally faster than the unrolled ptr_compare_N
+ * functions, as memcmp() is usually a platform-specific implementation
+ * written in assembler, provided in /usr/lib/libc/libc_hwcap*.so.1.
+ * This implementation is also usually faster than the built-in memcmp
+ * supplied by GCC, so it is recommended to build with "-fno-builtin-memcmp"
+ * in CFLAGS if building with GCC on Solaris.
+ */
+
+#include <string.h>
+
+static int native_compare(size_t *length, unsigned char **a, unsigned char **b)
+{
+ return memcmp(*a, *b, *length);
+}
+
+#else /* UNIV_SOLARIS */
+
static int ptr_compare(size_t *compare_length, uchar **a, uchar **b);
static int ptr_compare_0(size_t *compare_length, uchar **a, uchar **b);
static int ptr_compare_1(size_t *compare_length, uchar **a, uchar **b);
static int ptr_compare_2(size_t *compare_length, uchar **a, uchar **b);
static int ptr_compare_3(size_t *compare_length, uchar **a, uchar **b);
+#endif /* UNIV_SOLARIS */
/* Get a pointer to a optimal byte-compare function for a given size */
qsort2_cmp get_ptr_compare (size_t size)
{
+#ifdef UNIV_SOLARIS
+ return (qsort2_cmp) native_compare;
+#else
if (size < 4)
return (qsort2_cmp) ptr_compare;
switch (size & 3) {
@@ -41,6 +64,7 @@ qsort2_cmp get_ptr_compare (size_t size)
case 3: return (qsort2_cmp) ptr_compare_3;
}
return 0; /* Impossible */
+#endif /* UNIV_SOLARIS */
}