X-Git-Url: http://plrg.eecs.uci.edu/git/?p=model-checker-benchmarks.git;a=blobdiff_plain;f=include%2Funrelacy.h;h=729d76fdc24b9ae10705dd762fabd01e844a0c93;hp=3f2e5ebdf429b918b0624a81be88c4100ac47de7;hb=36c9d1f76e69a018f72a8aa85d70c58dd8f0d5cc;hpb=fcf905f172a2b1f019e2b4e730b2628e487d2b56 diff --git a/include/unrelacy.h b/include/unrelacy.h index 3f2e5eb..729d76f 100644 --- a/include/unrelacy.h +++ b/include/unrelacy.h @@ -2,12 +2,18 @@ #define __UNRELACY_H__ #include +#include +#include +#include +#include + +#include +#include #define $ -/* Should re-define to something meaningful */ -#define ASSERT(expr) -#define RL_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 @@ -20,16 +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; } + 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; } + 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; };