]> git.sur5r.net Git - openldap/commitdiff
Key alignment tweaks for Sparc
authorHoward Chu <hyc@openldap.org>
Wed, 9 Nov 2011 09:03:14 +0000 (01:03 -0800)
committerQuanah Gibson-Mount <quanah@openldap.org>
Thu, 10 Nov 2011 01:06:55 +0000 (17:06 -0800)
servers/slapd/back-mdb/back-mdb.h
servers/slapd/back-mdb/idl.c
servers/slapd/back-mdb/index.c
servers/slapd/back-mdb/key.c

index 603812830b86031abcd9312d0929bfc572330f73..d0377a3e05aba9900b867e7ccaf2c1eec2e527b9 100644 (file)
@@ -168,6 +168,10 @@ typedef struct AttrList {
 #define CACHELINE      64
 #endif
 
+#if defined(__i386) || defined(__x86_64)
+#define MISALIGNED_OK  1
+#endif
+
 typedef struct IndexRbody {
        AttrInfo *ai;
        AttrList *attrs;
index f4cb11f9602db27a5bebf1b882967b64ad48efd2..1bc048a3b6842d845b0545599b1dc2e81eb727fe 100644 (file)
@@ -400,6 +400,9 @@ mdb_idl_insert_keys(
        char *err;
        int     rc, k;
        unsigned int flag = MDB_NODUPDATA;
+#ifndef        MISALIGNED_OK
+       int kbuf[2];
+#endif
 
        {
                char buf[16];
@@ -413,12 +416,25 @@ mdb_idl_insert_keys(
        if ( slapMode & SLAP_TOOL_QUICK )
                flag |= MDB_APPEND;
 
+#ifndef MISALIGNED_OK
+       if (keys[0].bv_len & 0x03)
+               kbuf[1] = 0;
+#endif
        for ( k=0; keys[k].bv_val; k++ ) {
        /* Fetch the first data item for this key, to see if it
         * exists and if it's a range.
         */
-       key.mv_size = keys[k].bv_len;
-       key.mv_data = keys[k].bv_val;
+#ifndef MISALIGNED_OK
+       if (keys[k].bv_len & 0x03) {
+               key.mv_size = sizeof(kbuf);
+               key.mv_data = kbuf;
+               memcpy(key.mv_data, keys[k].bv_val, keys[k].bv_len);
+       } else
+#endif
+       {
+               key.mv_size = keys[k].bv_len;
+               key.mv_data = keys[k].bv_val;
+       }
        rc = mdb_cursor_get( cursor, &key, &data, MDB_SET );
        err = "c_get";
        if ( rc == 0 ) {
@@ -534,6 +550,9 @@ mdb_idl_delete_keys(
        MDB_val key, data;
        ID lo, hi, tmp, *i;
        char *err;
+#ifndef        MISALIGNED_OK
+       int kbuf[2];
+#endif
 
        {
                char buf[16];
@@ -543,12 +562,25 @@ mdb_idl_delete_keys(
        }
        assert( id != NOID );
 
+#ifndef MISALIGNED_OK
+       if (keys[0].bv_len & 0x03)
+               kbuf[1] = 0;
+#endif
        for ( k=0; keys[k].bv_val; k++) {
        /* Fetch the first data item for this key, to see if it
         * exists and if it's a range.
         */
-       key.mv_size = keys[k].bv_len;
-       key.mv_data = keys[k].bv_val;
+#ifndef MISALIGNED_OK
+       if (keys[k].bv_len & 0x03) {
+               key.mv_size = sizeof(kbuf);
+               key.mv_data = kbuf;
+               memcpy(key.mv_data, keys[k].bv_val, keys[k].bv_len);
+       } else
+#endif
+       {
+               key.mv_size = keys[k].bv_len;
+               key.mv_data = keys[k].bv_val;
+       }
        rc = mdb_cursor_get( cursor, &key, &data, MDB_SET );
        err = "c_get";
        if ( rc == 0 ) {
index 2b71bc1a2a4218099bf936415b160bb599af6e43..4d2dc01457f07ab7b378ac311cbc350ca47a0a3f 100644 (file)
@@ -25,7 +25,7 @@
 #include "back-mdb.h"
 #include "lutil_hash.h"
 
-static char presence_keyval[] = {0,0};
+static char presence_keyval[] = {0,0,0,0,0};
 static struct berval presence_key[2] = {BER_BVC(presence_keyval), BER_BVNULL};
 
 AttrInfo *mdb_index_mask(
index 45af1cd1f497e9eecb6fac644c8a378bdca00065..a147cfa5c5191bb6b4ee27af2ee68235323982ff 100644 (file)
@@ -39,11 +39,24 @@ mdb_key_read(
 {
        int rc;
        MDB_val key;
+#ifndef MSIALIGNED_OK
+       int kbuf[2];
+#endif
 
        Debug( LDAP_DEBUG_TRACE, "=> key_read\n", 0, 0, 0 );
 
-       key.mv_size = k->bv_len;
-       key.mv_data = k->bv_val;
+#ifndef MISALIGNED_OK
+       if (k->bv_len & 0x03) {
+               key.mv_size = sizeof(kbuf);
+               key.mv_data = kbuf;
+               kbuf[1] = 0;
+               memcpy(kbuf, k->bv_val, k->bv_len);
+       } else
+#endif
+       {
+               key.mv_size = k->bv_len;
+               key.mv_data = k->bv_val;
+       }
 
        rc = mdb_idl_fetch_key( be, txn, dbi, &key, ids, saved_cursor, get_flag );