X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Funrelacy.h;h=729d76fdc24b9ae10705dd762fabd01e844a0c93;hb=77847ecd3fa6a643302770491928787ba143cde1;hp=f4d75e8648c88dd6d9b7f5053dbc986ac394b9e0;hpb=6e3ab697e4e1630e3f3815b59ec629288ee7a97c;p=model-checker-benchmarks.git diff --git a/include/unrelacy.h b/include/unrelacy.h index f4d75e8..729d76f 100644 --- a/include/unrelacy.h +++ b/include/unrelacy.h @@ -1,9 +1,22 @@ +#ifndef __UNRELACY_H__ +#define __UNRELACY_H__ + #include +#include +#include +#include +#include + +#include +#include #define $ -/* Should re-define to something meaningful */ -#define 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 #define mo_seqcst memory_order_relaxed #define mo_release memory_order_release @@ -13,6 +26,58 @@ 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() { useless::store(&value, 0); } + var(T v) { useless::store(&value, v); } + var(var const& r) { + value = r.value; + } + ~var() { } + + 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; + }; + class backoff_t { public: @@ -27,3 +92,5 @@ namespace rl { typedef backoff_t exp_backoff; } + +#endif /* __UNRELACY_H__ */