mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
110754f57c
Current tests fail (not regressions, they fail as of 13461) * {{{x1.tdbrun}}} * {{{test_log(2,3,4,5,6,7,8,9,10).recover}}} * {{{test-recover(1,2,3).tdbrun}}} * {{{test1324.tdbrun}}} ULE_DEBUG disabled (defined to 0) Can be re-enabled for test purposes (set to 1). refs [t:1125] Merging into the temp branch (tokudb.main_13461+1125) {{{svn merge --accept=postpone -r 12527:13461 ../tokudb.1125 ./}}} Merging into main {{{svn merge --accept=postpone -r13462:13463 ../tokudb.main_13461+1125/ ./}}} git-svn-id: file:///svn/toku/tokudb@13464 c7de825b-a66e-492c-adef-691d508d4ae1
74 lines
2.2 KiB
C
74 lines
2.2 KiB
C
/* -*- mode: C; c-basic-offset: 4 -*- */
|
|
#ident "Copyright (c) 2007 Tokutek Inc. All rights reserved."
|
|
|
|
|
|
/* Purpose of this file is to provide definitions of
|
|
* Host to Disk byte transposition functions, an abstraction of
|
|
* htod32()/dtoh32() and htod16()/dtoh16() functions.
|
|
*
|
|
* These htod/dtoh functions will only perform the transposition
|
|
* if the disk and host are defined to be in opposite endian-ness.
|
|
* If we define the disk to be in host order, then no byte
|
|
* transposition is performed. (We might do this to save the
|
|
* the time used for byte transposition.)
|
|
*
|
|
* This abstraction layer allows us to define the disk to be in
|
|
* any byte order with a single compile-time switch (in htod.c).
|
|
*
|
|
* NOTE: THIS FILE DOES NOT CURRENTLY SUPPORT A BIG-ENDIAN
|
|
* HOST AND A LITTLE-ENDIAN DISK.
|
|
*/
|
|
|
|
#ifndef HTOD_H
|
|
#define HTOD_H
|
|
|
|
static const int64_t toku_byte_order_host = 0x0102030405060708LL;
|
|
|
|
#include <endian.h>
|
|
#if !defined(__BYTE_ORDER) || \
|
|
!defined(__LITTLE_ENDIAN) || \
|
|
!defined(__BIG_ENDIAN)
|
|
#error Standard endianness things not all defined
|
|
#endif
|
|
|
|
#define NETWORK_BYTE_ORDER (__BIG_ENDIAN)
|
|
#define INTEL_BYTE_ORDER (__LITTLE_ENDIAN)
|
|
#define HOST_BYTE_ORDER (__BYTE_ORDER)
|
|
|
|
//DISK_BYTE_ORDER is the byte ordering for integers written to disk.
|
|
//If DISK_BYTE_ORDER is the same as HOST_BYTE_ORDER no conversions are necessary.
|
|
//Otherwise some structures require conversion to HOST_BYTE_ORDER on loading from disk (HOST_BYTE_ORDER in memory), and
|
|
//others require conversion to HOST_BYTE_ORDER on every access/mutate (DISK_BYTE_ORDER in memory).
|
|
#define DISK_BYTE_ORDER (INTEL_BYTE_ORDER)
|
|
|
|
#if HOST_BYTE_ORDER!=INTEL_BYTE_ORDER
|
|
//Even though the functions are noops if DISK==HOST, we do not have the logic to test whether the file was moved from another BYTE_ORDER machine.
|
|
#error Only intel byte order supported so far.
|
|
#endif
|
|
|
|
#if DISK_BYTE_ORDER == HOST_BYTE_ORDER
|
|
static inline uint64_t
|
|
toku_dtoh64(uint64_t i) {
|
|
return i;
|
|
}
|
|
|
|
static inline uint64_t
|
|
toku_htod64(uint64_t i) {
|
|
return i;
|
|
}
|
|
|
|
static inline uint32_t
|
|
toku_dtoh32(uint32_t i) {
|
|
return i;
|
|
}
|
|
|
|
static inline uint32_t
|
|
toku_htod32(uint32_t i) {
|
|
return i;
|
|
}
|
|
#else
|
|
#error Not supported
|
|
#endif
|
|
|
|
#endif
|
|
|