Merge branch 'sparc' of ssh://209.141.57.197:12222//export/home/antirez/redis into sparc

This commit is contained in:
antirez 2017-02-23 15:35:01 +01:00
commit ed7e331051
3 changed files with 25 additions and 9 deletions

View File

@ -104,6 +104,7 @@ long redisBitpos(void *s, unsigned long count, int bit) {
unsigned long skipval, word = 0, one; unsigned long skipval, word = 0, one;
long pos = 0; /* Position of bit, to return to the caller. */ long pos = 0; /* Position of bit, to return to the caller. */
unsigned long j; unsigned long j;
int found;
/* Process whole words first, seeking for first word that is not /* Process whole words first, seeking for first word that is not
* all ones or all zeros respectively if we are lookig for zeros * all ones or all zeros respectively if we are lookig for zeros
@ -117,21 +118,27 @@ long redisBitpos(void *s, unsigned long count, int bit) {
/* Skip initial bits not aligned to sizeof(unsigned long) byte by byte. */ /* Skip initial bits not aligned to sizeof(unsigned long) byte by byte. */
skipval = bit ? 0 : UCHAR_MAX; skipval = bit ? 0 : UCHAR_MAX;
c = (unsigned char*) s; c = (unsigned char*) s;
found = 0;
while((unsigned long)c & (sizeof(*l)-1) && count) { while((unsigned long)c & (sizeof(*l)-1) && count) {
if (*c != skipval) break; if (*c != skipval) {
found = 1;
break;
}
c++; c++;
count--; count--;
pos += 8; pos += 8;
} }
/* Skip bits with full word step. */ /* Skip bits with full word step. */
skipval = bit ? 0 : ULONG_MAX;
l = (unsigned long*) c; l = (unsigned long*) c;
while (count >= sizeof(*l)) { if (!found) {
if (*l != skipval) break; skipval = bit ? 0 : ULONG_MAX;
l++; while (count >= sizeof(*l)) {
count -= sizeof(*l); if (*l != skipval) break;
pos += sizeof(*l)*8; l++;
count -= sizeof(*l);
pos += sizeof(*l)*8;
}
} }
/* Load bytes into "word" considering the first byte as the most significant /* Load bytes into "word" considering the first byte as the most significant
@ -658,7 +665,7 @@ void bitopCommand(client *c) {
* result in GCC compiling the code using multiple-words load/store * result in GCC compiling the code using multiple-words load/store
* operations that are not supported even in ARM >= v6. */ * operations that are not supported even in ARM >= v6. */
j = 0; j = 0;
#ifndef __arm__ #ifndef USE_ALIGNED_ACCESS
if (minlen >= sizeof(unsigned long)*4 && numkeys <= 16) { if (minlen >= sizeof(unsigned long)*4 && numkeys <= 16) {
unsigned long *lp[16]; unsigned long *lp[16];
unsigned long *lres = (unsigned long*) res; unsigned long *lres = (unsigned long*) res;

View File

@ -215,4 +215,13 @@ void setproctitle(const char *fmt, ...);
#define __arm64__ #define __arm64__
#endif #endif
/* Make sure we can test for SPARC just checking for __sparc__. */
#if defined(__sparc) && !defined(__sparc__)
#define __sparc__
#endif
#if defined(__sparc__) || defined(__arm__)
#define USE_ALIGNED_ACCESS
#endif
#endif #endif

View File

@ -401,7 +401,7 @@ uint64_t MurmurHash64A (const void * key, int len, unsigned int seed) {
uint64_t k; uint64_t k;
#if (BYTE_ORDER == LITTLE_ENDIAN) #if (BYTE_ORDER == LITTLE_ENDIAN)
#if defined(__arm__) && !defined(__arm64__) #ifdef USE_ALIGNED_ACCESS
memcpy(&k,data,sizeof(uint64_t)); memcpy(&k,data,sizeof(uint64_t));
#else #else
k = *((uint64_t*)data); k = *((uint64_t*)data);