Commit 806d9405 authored by vasil's avatar vasil

branches/zip:

Change mach_read_int_type() to return an integer type (ullint) instead
of array of bytes that later needs to be converted to an appropriate
integer type.

Approved by:	Sunny
parent 51f09f64
...@@ -368,10 +368,10 @@ mach_write_to_2_little_endian( ...@@ -368,10 +368,10 @@ mach_write_to_2_little_endian(
Convert integral type from storage byte order (big endian) to Convert integral type from storage byte order (big endian) to
host byte order. */ host byte order. */
UNIV_INLINE UNIV_INLINE
void ullint
mach_read_int_type( mach_read_int_type(
/*===============*/ /*===============*/
byte* dest, /* out: where to write */ /* out: integer value */
const byte* src, /* in: where to read from */ const byte* src, /* in: where to read from */
ulint len, /* in: length of src */ ulint len, /* in: length of src */
ibool unsigned_type); /* in: signed or unsigned flag */ ibool unsigned_type); /* in: signed or unsigned flag */
......
...@@ -730,33 +730,39 @@ mach_write_to_2_little_endian( ...@@ -730,33 +730,39 @@ mach_write_to_2_little_endian(
Convert integral type from storage byte order (big endian) to Convert integral type from storage byte order (big endian) to
host byte order. */ host byte order. */
UNIV_INLINE UNIV_INLINE
void ullint
mach_read_int_type( mach_read_int_type(
/*===============*/ /*===============*/
byte* dest, /* out: where to write */ /* out: integer value */
const byte* src, /* in: where to read from */ const byte* src, /* in: where to read from */
ulint len, /* in: length of src */ ulint len, /* in: length of src */
ibool unsigned_type) /* in: signed or unsigned flag */ ibool unsigned_type) /* in: signed or unsigned flag */
{ {
#ifdef WORDS_BIGENDIAN /* XXX this can be optimized on big-endian machines */
memcpy(dest, src, len);
ullint ret;
uint i;
if (unsigned_type || (src[0] & 0x80)) {
if (!unsigned_type) { ret = 0x0000000000000000ULL;
dest[0] ^= 128; } else {
ret = 0xFFFFFFFFFFFFFF00ULL;
} }
#else
byte* ptr;
/* Convert integer data from Innobase to a little-endian format, if (unsigned_type) {
sign bit restored to normal. */
ret |= src[0];
} else {
for (ptr = dest + len; ptr != dest; ++src) { ret |= src[0] ^ 0x80;
--ptr;
*ptr = *src;
} }
if (!unsigned_type) { for (i = 1; i < len; i++) {
dest[len - 1] ^= 128; ret <<= 8;
ret |= src[i];
} }
#endif
return(ret);
} }
...@@ -4616,8 +4616,6 @@ row_search_autoinc_read_column( ...@@ -4616,8 +4616,6 @@ row_search_autoinc_read_column(
const byte* data; const byte* data;
ib_longlong value; ib_longlong value;
mem_heap_t* heap = NULL; mem_heap_t* heap = NULL;
/* Our requirement is that dest should be word aligned. */
byte dest[sizeof(value)];
ulint offsets_[REC_OFFS_NORMAL_SIZE]; ulint offsets_[REC_OFFS_NORMAL_SIZE];
ulint* offsets = offsets_; ulint* offsets = offsets_;
...@@ -4635,35 +4633,8 @@ row_search_autoinc_read_column( ...@@ -4635,35 +4633,8 @@ row_search_autoinc_read_column(
ut_a(len != UNIV_SQL_NULL); ut_a(len != UNIV_SQL_NULL);
ut_a(len <= sizeof value); ut_a(len <= sizeof value);
mach_read_int_type(dest, data, len, unsigned_type); /* we assume AUTOINC value cannot be negative */
value = (ib_longlong) mach_read_int_type(data, len, unsigned_type);
/* The assumption here is that the AUTOINC value can't be negative
and that dest is word aligned. */
switch (len) {
case 8:
value = *(ib_longlong*) dest;
break;
case 4:
value = *(ib_uint32_t*) dest;
break;
case 3:
value = *(ib_uint32_t*) dest;
value &= 0xFFFFFF;
break;
case 2:
value = *(uint16 *) dest;
break;
case 1:
value = *dest;
break;
default:
ut_error;
}
if (UNIV_LIKELY_NULL(heap)) { if (UNIV_LIKELY_NULL(heap)) {
mem_heap_free(heap); mem_heap_free(heap);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment