X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Funrelacy.h;h=729d76fdc24b9ae10705dd762fabd01e844a0c93;hb=8d33d370dc330e62ba3086d7a98c362e231a4307;hp=c16a373b7945bf1caf142956f5545848d28ce2d6;hpb=6254750fb7b01a21dad05459d3d9f9519ef2f1ee;p=model-checker-benchmarks.git diff --git a/include/unrelacy.h b/include/unrelacy.h index c16a373..729d76f 100644 --- a/include/unrelacy.h +++ b/include/unrelacy.h @@ -8,6 +8,7 @@ #include #include +#include #define $ @@ -25,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; };