From: Gabe Black Date: Sat, 22 Sep 2018 14:30:28 +0000 (-0700) Subject: systemc: Print an Info when setting a tracefile's time unit. X-Git-Tag: v19.0.0.0~1566 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=dc599a0176f12b6fe17084258a1ec8adef6774d8;p=gem5.git systemc: Print an Info when setting a tracefile's time unit. This matches Accellera's output for the tests. Change-Id: Ie67fd673a980b8ca2fdcd8f357ff7993a9091221 Reviewed-on: https://gem5-review.googlesource.com/c/12972 Reviewed-by: Gabe Black Maintainer: Gabe Black --- diff --git a/src/systemc/utils/tracefile.cc b/src/systemc/utils/tracefile.cc index 20091c307..25d7ea6f3 100644 --- a/src/systemc/utils/tracefile.cc +++ b/src/systemc/utils/tracefile.cc @@ -35,6 +35,7 @@ #include "base/logging.hh" #include "base/output.hh" #include "sim/core.hh" +#include "systemc/core/time.hh" #include "systemc/ext/core/sc_main.hh" #include "systemc/ext/utils/functions.hh" @@ -58,6 +59,18 @@ TraceFile::set_time_unit(double d, ::sc_core::sc_time_unit tu) { timeUnitValue = d; timeUnitUnit = tu; + + double secs = d * TimeUnitScale[tu]; + for (tu = ::sc_core::SC_SEC; tu > ::sc_core::SC_FS; + tu = (::sc_core::sc_time_unit)(tu - 1)) { + if (TimeUnitScale[tu] <= secs) + break; + } + + uint64_t i = static_cast(secs / TimeUnitScale[tu]); + std::ostringstream ss; + ss << i << " " << TimeUnitNames[tu] << " (" << _os->name() << ")"; + SC_REPORT_INFO("(I703) tracing timescale unit set", ss.str().c_str()); } void