changeset 05405c5b8c16 in /z/repo/m5
details: http://repo.m5sim.org/m5?cmd=changeset;node=05405c5b8c16
description:
        stats: Shuffle around info stuff so it can be accessed separately

diffstat:

4 files changed, 233 insertions(+), 190 deletions(-)
src/base/statistics.hh  |  190 ----------------------------------------
src/base/stats/info.hh  |  220 +++++++++++++++++++++++++++++++++++++++++++++++
src/base/stats/mysql.cc |    2 
src/base/stats/text.cc  |   11 ++

diffs (truncated from 528 to 300 lines):

diff -r fdfbd4c6e449 -r 05405c5b8c16 src/base/statistics.hh
--- a/src/base/statistics.hh    Wed Apr 22 13:38:00 2009 -0700
+++ b/src/base/statistics.hh    Wed Apr 22 13:38:00 2009 -0700
@@ -65,8 +65,9 @@
 #include "base/refcnt.hh"
 #include "base/str.hh"
 #include "base/stats/flags.hh"
+#include "base/stats/info.hh"
+#include "base/stats/types.hh"
 #include "base/stats/visit.hh"
-#include "base/stats/types.hh"
 #include "sim/host.hh"
 
 class Callback;
@@ -77,92 +78,6 @@
 /* A namespace for all of the Statistics */
 namespace Stats {
 
-struct StorageParams
-{
-    virtual ~StorageParams();
-};
-
-//////////////////////////////////////////////////////////////////////
-//
-// Statistics Framework Base classes
-//
-//////////////////////////////////////////////////////////////////////
-class Info
-{
-  public:
-    /** The name of the stat. */
-    std::string name;
-    /** The description of the stat. */
-    std::string desc;
-    /** The formatting flags. */
-    StatFlags flags;
-    /** The display precision. */
-    int precision;
-    /** A pointer to a prerequisite Stat. */
-    const Info *prereq;
-    /**
-     * A unique stat ID for each stat in the simulator.
-     * Can be used externally for lookups as well as for debugging.
-     */
-    static int id_count;
-    int id;
-
-  public:
-    const StorageParams *storageParams;
-
-  public:
-    Info();
-    virtual ~Info();
-
-    /** Set the name of this statistic */
-    void setName(const std::string &name);
-
-    /**
-     * Check that this stat has been set up properly and is ready for
-     * use
-     * @return true for success
-     */
-    virtual bool check() const = 0;
-    bool baseCheck() const;
-
-    /**
-     * Enable the stat for use
-     */
-    virtual void enable();
-
-    /**
-     * Prepare the stat for dumping.
-     */
-    virtual void prepare() = 0;
-
-    /**
-     * Reset the stat to the default state.
-     */
-    virtual void reset() = 0;
-
-    /**
-     * @return true if this stat has a value and satisfies its
-     * requirement as a prereq
-     */
-    virtual bool zero() const = 0;
-
-    /**
-     * Visitor entry for outputing statistics data
-     */
-    virtual void visit(Visit &visitor) = 0;
-
-    /**
-     * Checks if the first stat's name is alphabetically less than the second.
-     * This function breaks names up at periods and considers each subname
-     * separately.
-     * @param stat1 The first stat.
-     * @param stat2 The second stat.
-     * @return stat1's name is alphabetically before stat2's
-     */
-    static bool less(Info *stat1, Info *stat2);
-};
-struct StorageParams;
-
 template <class Stat, class Base>
 class InfoProxy : public Base
 {
@@ -183,14 +98,6 @@
     bool zero() const { return s.zero(); }
 };
 
-class ScalarInfo : public Info
-{
-  public:
-    virtual Counter value() const = 0;
-    virtual Result result() const = 0;
-    virtual Result total() const = 0;
-};
-
 template <class Stat>
 class ScalarInfoProxy : public InfoProxy<Stat, ScalarInfo>
 {
@@ -202,23 +109,6 @@
     Result total() const { return this->s.total(); }
 };
 
-class VectorInfo : public Info
-{
-  public:
-    /** Names and descriptions of subfields. */
-    std::vector<std::string> subnames;
-    std::vector<std::string> subdescs;
-
-  public:
-    void enable();
-
-  public:
-    virtual size_type size() const = 0;
-    virtual const VCounter &value() const = 0;
-    virtual const VResult &result() const = 0;
-    virtual Result total() const = 0;
-};
-
 template <class Stat>
 class VectorInfoProxy : public InfoProxy<Stat, VectorInfo>
 {
@@ -248,25 +138,6 @@
     Result total() const { return this->s.total(); }
 };
 
-struct DistData
-{
-    Counter min_val;
-    Counter max_val;
-    Counter underflow;
-    Counter overflow;
-    VCounter cvec;
-    Counter sum;
-    Counter squares;
-    Counter samples;
-};
-
-class DistInfo : public Info
-{
-  public:
-    /** Local storage for the entry values, used for printing. */
-    DistData data;
-};
-
 template <class Stat>
 class DistInfoProxy : public InfoProxy<Stat, DistInfo>
 {
@@ -274,24 +145,6 @@
     DistInfoProxy(Stat &stat) : InfoProxy<Stat, DistInfo>(stat) {}
 };
 
-class VectorDistInfo : public Info
-{
-  public:
-    std::vector<DistData> data;
-
-    /** Names and descriptions of subfields. */
-    std::vector<std::string> subnames;
-    std::vector<std::string> subdescs;
-    void enable();
-
-  protected:
-    /** Local storage for the entry values, used for printing. */
-    mutable VResult rvec;
-
-  public:
-    virtual size_type size() const = 0;
-};
-
 template <class Stat>
 class VectorDistInfoProxy : public InfoProxy<Stat, VectorDistInfo>
 {
@@ -301,23 +154,6 @@
     size_type size() const { return this->s.size(); }
 };
 
-class Vector2dInfo : public Info
-{
-  public:
-    /** Names and descriptions of subfields. */
-    std::vector<std::string> subnames;
-    std::vector<std::string> subdescs;
-    std::vector<std::string> y_subnames;
-
-    size_type x;
-    size_type y;
-
-    /** Local storage for the entry values, used for printing. */
-    mutable VCounter cvec;
-
-    void enable();
-};
-
 template <class Stat>
 class Vector2dInfoProxy : public InfoProxy<Stat, Vector2dInfo>
 {
@@ -1427,22 +1263,6 @@
 //
 //////////////////////////////////////////////////////////////////////
 
-struct DistParams : public StorageParams
-{
-    const bool fancy;
-
-    /** The minimum value to track. */
-    Counter min;
-    /** The maximum value to track. */
-    Counter max;
-    /** The number of entries in each bucket. */
-    Counter bucket_size;
-    /** The number of buckets. Equal to (max-min)/bucket_size. */
-    size_type buckets;
-
-    explicit DistParams(bool f) : fancy(f) {}
-};
-
 /**
  * Templatized storage and interface for a distrbution stat.
  */
@@ -2555,12 +2375,6 @@
     }
 };
 
-class FormulaInfo : public VectorInfo
-{
-  public:
-    virtual std::string str() const = 0;
-};
-
 template <class Stat>
 class FormulaInfoProxy : public InfoProxy<Stat, FormulaInfo>
 {
diff -r fdfbd4c6e449 -r 05405c5b8c16 src/base/stats/info.hh
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/src/base/stats/info.hh    Wed Apr 22 13:38:00 2009 -0700
@@ -0,0 +1,220 @@
+/*
+ * Copyright (c) 2003-2005 The Regents of The University of Michigan
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met: redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer;
+ * redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution;
+ * neither the name of the copyright holders nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * Authors: Nathan Binkert
+ */
+
+#include "base/stats/flags.hh"
+#include "base/stats/types.hh"
+
+namespace Stats {
+
+struct StorageParams
+{
+    virtual ~StorageParams();
+};
_______________________________________________
m5-dev mailing list
[email protected]
http://m5sim.org/mailman/listinfo/m5-dev

Reply via email to