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