X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FADT%2FStatistic.h;h=1a4833cc4a07b538fa5072ce6e284583b75c89a4;hb=d6a2aab53e3c4fcd53399cfa6f66d62913e53663;hp=4bf47640eeed73bbab5f4ef55ebbee9ef0bdd442;hpb=ecb27687587d04475097596c53349b631f7ef42d;p=oota-llvm.git diff --git a/include/llvm/ADT/Statistic.h b/include/llvm/ADT/Statistic.h index 4bf47640eee..1a4833cc4a0 100644 --- a/include/llvm/ADT/Statistic.h +++ b/include/llvm/ADT/Statistic.h @@ -2,8 +2,8 @@ // // The LLVM Compiler Infrastructure // -// This file was developed by the LLVM research group and is distributed under -// the University of Illinois Open Source License. See LICENSE.TXT for details. +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // @@ -26,50 +26,92 @@ #ifndef LLVM_ADT_STATISTIC_H #define LLVM_ADT_STATISTIC_H +#include "llvm/System/Atomic.h" + namespace llvm { -class StatisticBase { +class Statistic { public: const char *Name; const char *Desc; - unsigned Value : 31; - bool Initialized : 1; + volatile llvm::sys::cas_flag Value; + bool Initialized; - unsigned getValue() const { return Value; } + llvm::sys::cas_flag getValue() const { return Value; } const char *getName() const { return Name; } const char *getDesc() const { return Desc; } - + + /// construct - This should only be called for non-global statistics. + void construct(const char *name, const char *desc) { + Name = name; Desc = desc; + Value = 0; Initialized = 0; + } + // Allow use of this class as the value itself. operator unsigned() const { return Value; } - const StatisticBase &operator=(unsigned Val) { Value = Val; return init(); } - const StatisticBase &operator++() { ++Value; return init(); } - unsigned operator++(int) { init(); return Value++; } - const StatisticBase &operator--() { --Value; return init(); } - unsigned operator--(int) { init(); return Value--; } - const StatisticBase &operator+=(const unsigned &V) {Value += V;return init();} - const StatisticBase &operator-=(const unsigned &V) {Value -= V;return init();} - const StatisticBase &operator*=(const unsigned &V) {Value *= V;return init();} - const StatisticBase &operator/=(const unsigned &V) {Value /= V;return init();} + const Statistic &operator=(unsigned Val) { + Value = Val; + return init(); + } -private: - StatisticBase &init() { - if (!Initialized) RegisterStatistic(); - return *this; + const Statistic &operator++() { + sys::AtomicIncrement(&Value); + return init(); + } + + unsigned operator++(int) { + init(); + unsigned OldValue = Value; + sys::AtomicIncrement(&Value); + return OldValue; + } + + const Statistic &operator--() { + sys::AtomicDecrement(&Value); + return init(); } - void RegisterStatistic(); -}; -struct Statistic : public StatisticBase { - Statistic(const char *name, const char *desc) { - Name = name; Desc = desc; Value = 0; Initialized = 0; + unsigned operator--(int) { + init(); + unsigned OldValue = Value; + sys::AtomicDecrement(&Value); + return OldValue; } + + const Statistic &operator+=(const unsigned &V) { + sys::AtomicAdd(&Value, V); + return init(); + } + + const Statistic &operator-=(const unsigned &V) { + sys::AtomicAdd(&Value, -V); + return init(); + } + + const Statistic &operator*=(const unsigned &V) { + sys::AtomicMul(&Value, V); + return init(); + } + + const Statistic &operator/=(const unsigned &V) { + sys::AtomicDiv(&Value, V); + return init(); + } + +protected: + Statistic &init() { + bool tmp = Initialized; + sys::MemoryFence(); + if (!tmp) RegisterStatistic(); + return *this; + } + void RegisterStatistic(); }; - // STATISTIC - A macro to make definition of statistics really simple. This // automatically passes the DEBUG_TYPE of the file into the statistic. #define STATISTIC(VARNAME, DESC) \ - static StatisticBase VARNAME = { DEBUG_TYPE, DESC, 0, 0 } + static llvm::Statistic VARNAME = { DEBUG_TYPE, DESC, 0, 0 } } // End llvm namespace