Root.py revision 7534
14486Sbinkertn@umich.edu# Copyright (c) 2005-2007 The Regents of The University of Michigan 27534Ssteve.reinhardt@amd.com# Copyright (c) 2010 Advanced Micro Devices, Inc. 34486Sbinkertn@umich.edu# All rights reserved. 44486Sbinkertn@umich.edu# 54486Sbinkertn@umich.edu# Redistribution and use in source and binary forms, with or without 64486Sbinkertn@umich.edu# modification, are permitted provided that the following conditions are 74486Sbinkertn@umich.edu# met: redistributions of source code must retain the above copyright 84486Sbinkertn@umich.edu# notice, this list of conditions and the following disclaimer; 94486Sbinkertn@umich.edu# redistributions in binary form must reproduce the above copyright 104486Sbinkertn@umich.edu# notice, this list of conditions and the following disclaimer in the 114486Sbinkertn@umich.edu# documentation and/or other materials provided with the distribution; 124486Sbinkertn@umich.edu# neither the name of the copyright holders nor the names of its 134486Sbinkertn@umich.edu# contributors may be used to endorse or promote products derived from 144486Sbinkertn@umich.edu# this software without specific prior written permission. 154486Sbinkertn@umich.edu# 164486Sbinkertn@umich.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 174486Sbinkertn@umich.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 184486Sbinkertn@umich.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 194486Sbinkertn@umich.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 204486Sbinkertn@umich.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 214486Sbinkertn@umich.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 224486Sbinkertn@umich.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 234486Sbinkertn@umich.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 244486Sbinkertn@umich.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 254486Sbinkertn@umich.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 264486Sbinkertn@umich.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 274486Sbinkertn@umich.edu# 284486Sbinkertn@umich.edu# Authors: Nathan Binkert 294486Sbinkertn@umich.edu 303102SN/Afrom m5.SimObject import SimObject 313102SN/Afrom m5.params import * 327525Ssteve.reinhardt@amd.comfrom m5.util import fatal 331382SN/A 341692SN/Aclass Root(SimObject): 357525Ssteve.reinhardt@amd.com 367525Ssteve.reinhardt@amd.com _the_instance = None 377525Ssteve.reinhardt@amd.com 387525Ssteve.reinhardt@amd.com def __new__(cls, **kwargs): 397525Ssteve.reinhardt@amd.com if Root._the_instance: 407525Ssteve.reinhardt@amd.com fatal("Attempt to allocate multiple instances of Root.") 417525Ssteve.reinhardt@amd.com return None 427525Ssteve.reinhardt@amd.com 437525Ssteve.reinhardt@amd.com # first call: allocate the unique instance 447525Ssteve.reinhardt@amd.com # 457525Ssteve.reinhardt@amd.com # If SimObject ever implements __new__, we may want to pass 467525Ssteve.reinhardt@amd.com # kwargs here, but for now this goes straight to 477525Ssteve.reinhardt@amd.com # object.__new__ which prints an ugly warning if you pass it 487525Ssteve.reinhardt@amd.com # args. Seems like a bad design but that's the way it is. 497525Ssteve.reinhardt@amd.com Root._the_instance = SimObject.__new__(cls) 507525Ssteve.reinhardt@amd.com return Root._the_instance 517525Ssteve.reinhardt@amd.com 527525Ssteve.reinhardt@amd.com @classmethod 537525Ssteve.reinhardt@amd.com def getInstance(cls): 547525Ssteve.reinhardt@amd.com return Root._the_instance 557525Ssteve.reinhardt@amd.com 567525Ssteve.reinhardt@amd.com def path(self): 577525Ssteve.reinhardt@amd.com return 'root' 587525Ssteve.reinhardt@amd.com 591366SN/A type = 'Root' 604167SN/A dummy = Param.Int(0, "We don't support objects without params") 61