diff options
author | Kevin Lim <ktlim@umich.edu> | 2005-05-02 14:16:33 -0400 |
---|---|---|
committer | Kevin Lim <ktlim@umich.edu> | 2005-05-02 14:16:33 -0400 |
commit | 6191d3e4443b5337232a238a3a0dd5d11249e223 (patch) | |
tree | 4adb8d7c510a8b123b285e0cd0cb2d74f093a108 /python/m5/config.py | |
parent | e2ad9e68160659712f017a2aa24cc2acc29cd7f0 (diff) | |
parent | 950ce813c436cd5a70ed44794f0508799c09ed3a (diff) | |
download | gem5-6191d3e4443b5337232a238a3a0dd5d11249e223.tar.xz |
Merge ktlim@zizzer.eecs.umich.edu:/bk/m5
into zamp.eecs.umich.edu:/z/ktlim2/m5
--HG--
extra : convert_revision : ac0788599c365b2d7fe0870f0fea4b62c3b3ef22
Diffstat (limited to 'python/m5/config.py')
-rw-r--r-- | python/m5/config.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/python/m5/config.py b/python/m5/config.py index 74988109b..2db2164fc 100644 --- a/python/m5/config.py +++ b/python/m5/config.py @@ -177,7 +177,7 @@ class Proxy(object): # support multiplying proxies by constants def __mul__(self, other): - if not isinstance(other, int): + if not isinstance(other, (int, float)): raise TypeError, "Proxy multiplier must be integer" if self._multiplier == None: self._multiplier = other @@ -186,13 +186,19 @@ class Proxy(object): self._multiplier *= other return self + __rmul__ = __mul__ + def _mulcheck(self, result): if self._multiplier == None: return result if not isinstance(result, int): - raise TypeError, "Proxy with multiplier resolves to " \ - "non-integer value" - return result * self._multiplier + # this was an error, but for now we'll assume if it's not + # an int it must be a Frequency (yuk) + result = Frequency._convert(result) + # assuming we're dealing with a frequency here, turn it into + # a string and give it a 't' suffix so the Frequency._convert + # doesn't choke on it later. + return ("%d" % int(round((result * self._multiplier)))) + 't' def unproxy(self, base, ptype): obj = base |