SimpleLink.cc revision 8257
15647Sgblack@eecs.umich.edu/* 25647Sgblack@eecs.umich.edu * Copyright (c) 2011 Advanced Micro Devices, Inc. 35647Sgblack@eecs.umich.edu * All rights reserved. 45647Sgblack@eecs.umich.edu * 57087Snate@binkert.org * Redistribution and use in source and binary forms, with or without 67087Snate@binkert.org * modification, are permitted provided that the following conditions are 77087Snate@binkert.org * met: redistributions of source code must retain the above copyright 87087Snate@binkert.org * notice, this list of conditions and the following disclaimer; 97087Snate@binkert.org * redistributions in binary form must reproduce the above copyright 107087Snate@binkert.org * notice, this list of conditions and the following disclaimer in the 117087Snate@binkert.org * documentation and/or other materials provided with the distribution; 127087Snate@binkert.org * neither the name of the copyright holders nor the names of its 135647Sgblack@eecs.umich.edu * contributors may be used to endorse or promote products derived from 147087Snate@binkert.org * this software without specific prior written permission. 157087Snate@binkert.org * 167087Snate@binkert.org * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 177087Snate@binkert.org * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 187087Snate@binkert.org * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 197087Snate@binkert.org * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 207087Snate@binkert.org * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 217087Snate@binkert.org * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 225647Sgblack@eecs.umich.edu * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 237087Snate@binkert.org * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 245647Sgblack@eecs.umich.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 255647Sgblack@eecs.umich.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 265647Sgblack@eecs.umich.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 275647Sgblack@eecs.umich.edu */ 285647Sgblack@eecs.umich.edu 295647Sgblack@eecs.umich.edu#include "mem/ruby/network/BasicLink.hh" 305647Sgblack@eecs.umich.edu 315647Sgblack@eecs.umich.eduBasicLink::BasicLink(const Params *p) 325647Sgblack@eecs.umich.edu : SimObject(p) 335647Sgblack@eecs.umich.edu{ 345647Sgblack@eecs.umich.edu m_latency = p->latency; 355647Sgblack@eecs.umich.edu m_bw_multiplier = p->bw_multiplier; 365647Sgblack@eecs.umich.edu m_weight = p->weight; 375647Sgblack@eecs.umich.edu} 385647Sgblack@eecs.umich.edu 395647Sgblack@eecs.umich.eduvoid 408229Snate@binkert.orgBasicLink::init() 415647Sgblack@eecs.umich.edu{ 425654Sgblack@eecs.umich.edu} 435647Sgblack@eecs.umich.edu 448232Snate@binkert.orgvoid 456137Sgblack@eecs.umich.eduBasicLink::print(std::ostream& out) const 466137Sgblack@eecs.umich.edu{ 476137Sgblack@eecs.umich.edu out << name(); 485654Sgblack@eecs.umich.edu} 496046Sgblack@eecs.umich.edu 505647Sgblack@eecs.umich.eduBasicLink * 515648Sgblack@eecs.umich.eduBasicLinkParams::create() 525648Sgblack@eecs.umich.edu{ 535647Sgblack@eecs.umich.edu return new BasicLink(this); 545647Sgblack@eecs.umich.edu} 555647Sgblack@eecs.umich.edu 565647Sgblack@eecs.umich.eduBasicExtLink::BasicExtLink(const Params *p) 575647Sgblack@eecs.umich.edu : BasicLink(p) 585647Sgblack@eecs.umich.edu{ 595647Sgblack@eecs.umich.edu m_int_node = p->int_node; 605647Sgblack@eecs.umich.edu m_ext_node = p->ext_node; 615647Sgblack@eecs.umich.edu} 625648Sgblack@eecs.umich.edu 635647Sgblack@eecs.umich.eduBasicExtLink * 645648Sgblack@eecs.umich.eduBasicExtLinkParams::create() 655648Sgblack@eecs.umich.edu{ 665648Sgblack@eecs.umich.edu return new BasicExtLink(this); 675648Sgblack@eecs.umich.edu} 685648Sgblack@eecs.umich.edu 695648Sgblack@eecs.umich.eduBasicIntLink::BasicIntLink(const Params *p) 705648Sgblack@eecs.umich.edu : BasicLink(p) 715648Sgblack@eecs.umich.edu{ 725648Sgblack@eecs.umich.edu m_node_a = p->node_a; 735648Sgblack@eecs.umich.edu m_node_b = p->node_b; 745648Sgblack@eecs.umich.edu} 755648Sgblack@eecs.umich.edu 765648Sgblack@eecs.umich.eduBasicIntLink * 775648Sgblack@eecs.umich.eduBasicIntLinkParams::create() 785648Sgblack@eecs.umich.edu{ 795648Sgblack@eecs.umich.edu return new BasicIntLink(this); 805648Sgblack@eecs.umich.edu} 815648Sgblack@eecs.umich.edu