gem5 v24.0.0.0
Loading...
Searching...
No Matches
tracefile.cc
Go to the documentation of this file.
1/*
2 * Copyright 2018 Google, Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution;
11 * neither the name of the copyright holders nor the names of its
12 * contributors may be used to endorse or promote products derived from
13 * this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
29
30#include <ctime>
31#include <iomanip>
32
34#include "systemc/core/time.hh"
38
39namespace sc_gem5
40{
41
42TraceFile::TraceFile(const std::string &name) :
43 _os(gem5::simout.create(name, true, true)), timeUnitTicks(0),
44 timeUnitValue(0.0), timeUnitUnit(::sc_core::SC_PS), _traceDeltas(false)
45{
47}
48
54
55std::ostream &TraceFile::stream() { return *_os->stream(); }
56
57void
59{
60 timeUnitValue = d;
61 timeUnitUnit = tu;
62
63 double secs = d * TimeUnitScale[tu];
64 for (tu = ::sc_core::SC_SEC; tu > ::sc_core::SC_FS;
65 tu = (::sc_core::sc_time_unit)(tu - 1)) {
66 if (TimeUnitScale[tu] <= secs)
67 break;
68 }
69
70 uint64_t i = static_cast<uint64_t>(secs / TimeUnitScale[tu]);
71 std::ostringstream ss;
72 ss << i << " " << TimeUnitNames[tu] << " (" << _os->name() << ")";
73 SC_REPORT_INFO("(I703) tracing timescale unit set", ss.str().c_str());
74}
75
76void
78{
80 if (timeUnitValue == 0.0) {
81 // The time scale was never set. Use the global time resolution.
83 } else {
85 }
86 timeUnitTicks = time.value();
87}
88
89} // namespace sc_gem5
void close(OutputStream *file)
Closes an output file and free the corresponding OutputFile.
Definition output.cc:147
const std::string & name() const
Get the file name in the output directory.
Definition output.hh:73
std::ostream * stream() const
Get the output underlying output stream.
Definition output.hh:62
sc_dt::uint64 value() const
Definition sc_time.cc:115
void registerTraceFile(TraceFile *tf)
Definition scheduler.hh:398
void unregisterTraceFile(TraceFile *tf)
Definition scheduler.hh:399
::sc_core::sc_time_unit timeUnitUnit
Definition tracefile.hh:197
gem5::OutputStream * _os
Definition tracefile.hh:194
uint64_t timeUnitTicks
Definition tracefile.hh:195
TraceFile(const std::string &name)
Definition tracefile.cc:42
void set_time_unit(double, ::sc_core::sc_time_unit) override
Definition tracefile.cc:58
std::ostream & stream()
Definition tracefile.cc:55
Copyright (c) 2024 - Pranith Kumar Copyright (c) 2020 Inria All rights reserved.
Definition binary32.hh:36
OutputDirectory simout
Definition output.cc:62
sc_time_unit
Definition sc_time.hh:40
@ SC_SEC
Definition sc_time.hh:46
@ SC_FS
Definition sc_time.hh:41
sc_time sc_get_time_resolution()
Definition sc_time.cc:339
const char * TimeUnitNames[]
Definition time.cc:35
double TimeUnitScale[]
Definition time.cc:53
Scheduler scheduler
Definition scheduler.cc:494
#define SC_REPORT_INFO(msg_type, msg)
const std::string & name()
Definition trace.cc:48
std::stringstream ss
Definition trace.test.cc:45

Generated on Tue Jun 18 2024 16:24:07 for gem5 by doxygen 1.11.0