X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Funrelacy.h;h=729d76fdc24b9ae10705dd762fabd01e844a0c93;hb=ff4cd01eb602228cbd4091539c3f9754cb946dda;hp=d65ffc3d1b2f7168313aac05563cf19be8a5aae1;hpb=204232f143970fcc7001063af8096da4aec0f3d1;p=model-checker-benchmarks.git diff --git a/include/unrelacy.h b/include/unrelacy.h index d65ffc3..729d76f 100644 --- a/include/unrelacy.h +++ b/include/unrelacy.h @@ -4,16 +4,16 @@ #include #include #include +#include +#include + +#include +#include #define $ -#define _TEST_ASSERT(expr) \ - if (!(expr)) { \ - printf("Error: assertion failed at %s:%d\n", __FILE__, __LINE__); \ - exit(EXIT_FAILURE); \ - } -#define ASSERT(expr) _TEST_ASSERT(expr) -#define RL_ASSERT(expr) _TEST_ASSERT(expr) +#define ASSERT(expr) MODEL_ASSERT(expr) +#define RL_ASSERT(expr) MODEL_ASSERT(expr) #define RL_NEW new #define RL_DELETE(expr) delete expr @@ -26,17 +26,54 @@ namespace rl { + /* This 'useless' struct is declared just so we can use partial template + * specialization in our store and load functions. */ + template + struct useless { + static void store(void *addr, T val); + static T load(const void *addr); + }; + + template + struct useless { + static void store(void *addr, T val) { store_8(addr, (uint8_t)val); } + static T load(const void *addr) { return (T)load_8(addr); } + }; + + template + struct useless { + static void store(void *addr, T val) { store_16(addr, (uint16_t)val); } + static T load(const void *addr) { return (T)load_16(addr); } + }; + + template + struct useless { + static void store(void *addr, T val) { store_32(addr, (uint32_t)val); } + static T load(const void *addr) { return (T)load_32(addr); } + }; + + template + struct useless { + static void store(void *addr, T val) { store_64(addr, (uint64_t)val); } + static T load(const void *addr) { return (T)load_64(addr); } + }; + template struct var { - var() { value = 0; } - var(T v) { value = v; } - var(var const& r) { value = r.value; } + var() { useless::store(&value, 0); } + var(T v) { useless::store(&value, v); } + var(var const& r) { + value = r.value; + } ~var() { } - void operator = (T v) { value = v; } - T operator () () { return value; } - void operator += (T v) { value += v; } - bool operator == (const struct var v) const { return value == v.value; } + void operator = (T v) { useless::store(&value, v); } + T operator () () { return useless::load(&value); } + void operator += (T v) { + useless::store(&value, + useless::load(&value) + v); + } + bool operator == (const struct var v) const { return useless::load(&value) == useless::load(&v.value); } T value; };