1 # Copyright (c) 2007 The Regents of The University of Michigan
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.
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.
27 from __future__
import print_function
34 from m5
.util
import warn
36 # fix the global frequency
37 def fixGlobalFrequency():
39 _m5
.core
.fixClockFrequency()
41 def setGlobalFrequency(ticksPerSecond
):
42 from m5
.util
import convert
45 if isinstance(ticksPerSecond
, (int, long)):
47 elif isinstance(ticksPerSecond
, float):
49 elif isinstance(ticksPerSecond
, str):
50 tps
= round(convert
.anyToFrequency(ticksPerSecond
))
53 "wrong type '%s' for ticksPerSecond" % type(ticksPerSecond
))
54 _m5
.core
.setClockFrequency(int(tps
))
56 # how big does a rounding error need to be before we warn about it?
57 frequency_tolerance
= 0.001 # 0.1%
59 def fromSeconds(value
):
62 if not isinstance(value
, float):
63 raise TypeError("can't convert '%s' to type tick" % type(value
))
65 # once someone needs to convert to seconds, the global frequency
67 if not _m5
.core
.clockFrequencyFixed():
69 "In order to do conversions, the global frequency must be fixed")
74 # convert the value from time to ticks
75 value
*= _m5
.core
.getClockFrequency()
78 decimal
.Decimal(value
).to_integral_value( decimal
.ROUND_HALF_UP
))
79 err
= (value
- int_value
) / value
80 if err
> frequency_tolerance
:
81 warn("rounding error > tolerance\n %f rounded to %d", value
,
85 __all__
= [ 'setGlobalFrequency', 'fixGlobalFrequency', 'fromSeconds',
86 'frequency_tolerance' ]