Clean up time handling code

base/str.hh:
    this should really be inline
base/time.cc:
base/time.hh:
    clean up how the time class works.  Export only one, and let
    people calculate their own elapsed times, etc.
sim/main.cc:
    sim/sim_time.X -> base/time.X

--HG--
rename : sim/sim_time.cc => base/time.cc
rename : sim/sim_time.hh => base/time.hh
extra : convert_revision : f3888fe3a1fdd1022084c282b58407c631a6d9a0
This commit is contained in:
Nathan Binkert 2003-12-15 18:23:48 -05:00
parent 3c6fc7c269
commit ef659565ff
5 changed files with 153 additions and 212 deletions

View file

@ -98,7 +98,7 @@ template <class T> bool
to_number(const std::string &value, T &retval); to_number(const std::string &value, T &retval);
template <class T> template <class T>
std::string inline std::string
to_string(const T& value) to_string(const T& value)
{ {
std::stringstream str; std::stringstream str;

130
base/time.cc Normal file
View file

@ -0,0 +1,130 @@
/*
* Copyright (c) 2003 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.
*/
#include <sys/types.h>
#include <sys/time.h>
#include <time.h>
#include <iostream>
#include <string>
#include "base/time.hh"
using namespace std;
struct _timeval
{
timeval tv;
};
double
convert(const timeval &tv)
{
return (double)tv.tv_sec + (double)tv.tv_usec / 1000000.0;
}
Time::Time()
{
time = new _timeval;
::gettimeofday(&time->tv, NULL);
}
Time::Time(const timeval &val)
{
time = new _timeval;
set(val);
}
Time::Time(const Time &val)
{
time = new _timeval;
set(val.get());
}
Time::~Time()
{
delete time;
}
const timeval &
Time::get() const
{
return time->tv;
}
void
Time::set(const timeval &tv)
{
memcpy(&time->tv, &tv, sizeof(timeval));
}
void
Time::reset()
{
::gettimeofday(&time->tv, NULL);
}
double
Time::operator()() const
{
return convert(get());
}
string
Time::date(string format) const
{
const timeval &tv = get();
time_t sec = tv.tv_sec;
char buf[256];
if (format.empty()) {
ctime_r(&sec, buf);
buf[24] = '\0';
return buf;
}
struct tm *tm = localtime(&sec);
strftime(buf, sizeof(buf), format.c_str(), tm);
return buf;
}
ostream &
operator<<(ostream &out, const Time &start)
{
out << start.date();
return out;
}
Time
operator-(const Time &l, const Time &r)
{
timeval tv;
timersub(&l.get(), &r.get(), &tv);
return tv;
}
const Time Time::start;

View file

@ -32,59 +32,34 @@
#include <sys/time.h> #include <sys/time.h>
#include <iosfwd> #include <iosfwd>
#include <string>
namespace Time {
struct _timeval; struct _timeval;
class Start
class Time
{ {
private: protected:
mutable _timeval *start; mutable _timeval *time;
public: public:
Start(); Time();
~Start(); Time(const timeval &val);
Time(const Time &val);
~Time();
const timeval &get() const; const timeval &get() const;
void set(const timeval &val);
void reset(); void reset();
double operator()() const; double operator()() const;
}; std::string date(std::string format = "") const;
class Now
{
private:
mutable _timeval *now;
public: public:
Now(); static const Time start;
~Now();
const timeval &get() const;
double operator()() const;
}; };
class Elapsed Time operator-(const Time &l, const Time &r);
{
private:
mutable _timeval *elapsed;
Start _start;
Now _now;
public: std::ostream &operator<<(std::ostream &out, const Time &time);
Elapsed();
~Elapsed();
const timeval &get() const;
void reset();
double operator()() const;
};
extern Start start;
extern Now now;
extern Elapsed elapsed;
std::ostream &operator<<(std::ostream &out, const Start &start);
std::ostream &operator<<(std::ostream &out, const Now &now);
std::ostream &operator<<(std::ostream &out, const Elapsed &elapsed);
}
#endif // __SIM_TIME_HH__ #endif // __SIM_TIME_HH__

View file

@ -42,6 +42,7 @@
#include "base/misc.hh" #include "base/misc.hh"
#include "base/pollevent.hh" #include "base/pollevent.hh"
#include "base/statistics.hh" #include "base/statistics.hh"
#include "base/time.hh"
#include "cpu/base_cpu.hh" #include "cpu/base_cpu.hh"
#include "cpu/full_cpu/smt.hh" #include "cpu/full_cpu/smt.hh"
#include "sim/async.hh" #include "sim/async.hh"
@ -52,7 +53,6 @@
#include "sim/sim_exit.hh" #include "sim/sim_exit.hh"
#include "sim/sim_object.hh" #include "sim/sim_object.hh"
#include "sim/sim_stats.hh" #include "sim/sim_stats.hh"
#include "sim/sim_time.hh"
using namespace std; using namespace std;

View file

@ -1,164 +0,0 @@
/*
* Copyright (c) 2003 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.
*/
#include <sys/types.h>
#include <sys/time.h>
#include <time.h>
#include <iostream>
#include "sim/sim_time.hh"
using namespace std;
namespace Time
{
struct _timeval
{
timeval tv;
};
double
convert(const timeval &tv)
{
return (double)tv.tv_sec + (double)tv.tv_usec / 1000000.0;
}
Start::Start()
{
start = new _timeval;
::gettimeofday(&start->tv, NULL);
}
Start::~Start()
{
delete start;
}
const timeval &
Start::get() const
{
return start->tv;
}
void
Start::reset()
{
::gettimeofday(&start->tv, NULL);
}
double
Start::operator()() const
{
return convert(get());
}
Now::Now()
: now(0)
{
}
Now::~Now()
{
if (now)
delete now;
}
const timeval &
Now::get() const
{
if (!now)
now = new _timeval;
::gettimeofday(&now->tv, NULL);
return now->tv;
}
double
Now::operator()() const
{
return convert(get());
}
Elapsed::Elapsed()
: elapsed(0)
{}
Elapsed::~Elapsed()
{
if (elapsed)
delete elapsed;
}
const timeval &
Elapsed::get() const
{
if (!elapsed)
elapsed = new _timeval;
timersub(&_now.get(), &_start.get(), &elapsed->tv);
return elapsed->tv;
}
void
Elapsed::reset()
{
_start.reset();
}
double
Elapsed::operator()() const
{
return convert(get());
}
Start start;
Now now;
Elapsed elapsed;
ostream &
operator<<(ostream &out, const Start &start)
{
out << ::ctime((const time_t *)&start.get().tv_sec);
return out;
}
ostream &
operator<<(ostream &out, const Now &now)
{
out << ::ctime((const time_t *)&now.get().tv_sec);
return out;
}
ostream &
operator<<(ostream &out, const Elapsed &elapsed)
{
out << ::ctime((const time_t *)&elapsed.get().tv_sec);
return out;
}
}