2 * Written by Josh Dybnis and released to the public domain, as explained at
3 * http://creativecommons.org/licenses/publicdomain
12 #include <sys/types.h>
14 #define MAX_NUM_THREADS 4 // make this whatever you want, but make it a power of 2
16 #define CACHE_LINE_SIZE 64 // 64 byte cache line on x86 and x86-64
17 #define CACHE_LINE_SCALE 6 // log base 2 of the cache line size
19 #define EXPECT_TRUE(x) __builtin_expect(!!(x), 1)
20 #define EXPECT_FALSE(x) __builtin_expect(!!(x), 0)
22 #define SYNC_SWAP __sync_lock_test_and_set
23 #define SYNC_CAS __sync_val_compare_and_swap
24 #define SYNC_ADD __sync_add_and_fetch
25 #define SYNC_FETCH_AND_OR __sync_fetch_and_or
27 #define MASK(n) ((1ULL << (n)) - 1)
33 #define TAG1 (1U << 31)
34 #define TAG2 (1U << 30)
36 #define TAG1 (1ULL << 63)
37 #define TAG2 (1ULL << 62)
39 #define TAG_VALUE(v, tag) ((v) | tag)
40 #define IS_TAGGED(v, tag) ((v) & tag)
41 #define STRIP_TAG(v, tag) ((v) & ~tag)
43 #define DOES_NOT_EXIST 0
44 #define ERROR_INVALID_OPTION (-1)
45 #define ERROR_INVALID_ARGUMENT (-2)
46 #define ERROR_UNSUPPORTED_FEATURE (-3)
47 #define ERROR_TXN_NOT_RUNNING (-4)
49 #define VOLATILE_DEREF(x) (*((volatile typeof(x))(x)))
51 typedef unsigned long long uint64_t;
52 typedef unsigned int uint32_t;
53 typedef unsigned char uint8_t;
55 typedef size_t markable_t;
57 static inline uint64_t rdtsc (void) {
59 __asm__ __volatile__("rdtsc" : "=a" (l), "=d" (u));
60 return ((uint64_t)u << 32) | l;