Network.cc revision 6700
19520SAndreas.Sandberg@ARM.com/*
29520SAndreas.Sandberg@ARM.com * Copyright (c) 1999-2008 Mark D. Hill and David A. Wood
39520SAndreas.Sandberg@ARM.com * All rights reserved.
49520SAndreas.Sandberg@ARM.com *
59520SAndreas.Sandberg@ARM.com * Redistribution and use in source and binary forms, with or without
69520SAndreas.Sandberg@ARM.com * modification, are permitted provided that the following conditions are
79520SAndreas.Sandberg@ARM.com * met: redistributions of source code must retain the above copyright
89520SAndreas.Sandberg@ARM.com * notice, this list of conditions and the following disclaimer;
99520SAndreas.Sandberg@ARM.com * redistributions in binary form must reproduce the above copyright
109520SAndreas.Sandberg@ARM.com * notice, this list of conditions and the following disclaimer in the
119520SAndreas.Sandberg@ARM.com * documentation and/or other materials provided with the distribution;
129520SAndreas.Sandberg@ARM.com * neither the name of the copyright holders nor the names of its
139520SAndreas.Sandberg@ARM.com * contributors may be used to endorse or promote products derived from
149520SAndreas.Sandberg@ARM.com * this software without specific prior written permission.
159520SAndreas.Sandberg@ARM.com *
169520SAndreas.Sandberg@ARM.com * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
179520SAndreas.Sandberg@ARM.com * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
189520SAndreas.Sandberg@ARM.com * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
199520SAndreas.Sandberg@ARM.com * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
209520SAndreas.Sandberg@ARM.com * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
219520SAndreas.Sandberg@ARM.com * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
229520SAndreas.Sandberg@ARM.com * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
239520SAndreas.Sandberg@ARM.com * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
249520SAndreas.Sandberg@ARM.com * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
259520SAndreas.Sandberg@ARM.com * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
269520SAndreas.Sandberg@ARM.com * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
279520SAndreas.Sandberg@ARM.com */
289520SAndreas.Sandberg@ARM.com
299520SAndreas.Sandberg@ARM.com#include "mem/protocol/MachineType.hh"
309520SAndreas.Sandberg@ARM.com#include "mem/ruby/network/Network.hh"
319520SAndreas.Sandberg@ARM.com
329520SAndreas.Sandberg@ARM.comNetwork::Network(const string & name)
339520SAndreas.Sandberg@ARM.com  :  m_name(name)
349520SAndreas.Sandberg@ARM.com{
359520SAndreas.Sandberg@ARM.com  m_virtual_networks = 0;
369520SAndreas.Sandberg@ARM.com  m_topology_ptr = NULL;
379520SAndreas.Sandberg@ARM.com}
389520SAndreas.Sandberg@ARM.com
399520SAndreas.Sandberg@ARM.comvoid Network::init(const vector<string> & argv)
409520SAndreas.Sandberg@ARM.com{
419520SAndreas.Sandberg@ARM.com  m_nodes = MachineType_base_number(MachineType_NUM); // Total nodes in network
429520SAndreas.Sandberg@ARM.com
439520SAndreas.Sandberg@ARM.com  for (size_t i=0; i<argv.size(); i+=2) {
449520SAndreas.Sandberg@ARM.com   if (argv[i] == "number_of_virtual_networks")
459520SAndreas.Sandberg@ARM.com     m_virtual_networks = atoi(argv[i+1].c_str());
469520SAndreas.Sandberg@ARM.com   else if (argv[i] == "topology")
479520SAndreas.Sandberg@ARM.com     m_topology_ptr = RubySystem::getTopology(argv[i+1]);
489520SAndreas.Sandberg@ARM.com   else if (argv[i] == "buffer_size")
499520SAndreas.Sandberg@ARM.com     m_buffer_size = atoi(argv[i+1].c_str());
509520SAndreas.Sandberg@ARM.com   else if (argv[i] == "endpoint_bandwidth")
519520SAndreas.Sandberg@ARM.com     m_endpoint_bandwidth = atoi(argv[i+1].c_str());
529520SAndreas.Sandberg@ARM.com   else if (argv[i] == "adaptive_routing")
5310259SAndrew.Bardsley@arm.com     m_adaptive_routing = (argv[i+1]=="true");
549520SAndreas.Sandberg@ARM.com   else if (argv[i] == "link_latency")
5510860Sandreas.sandberg@arm.com     m_link_latency = atoi(argv[i+1].c_str());
5611251Sradhika.jagtap@ARM.com   else if (argv[i] == "control_msg_size")
579520SAndreas.Sandberg@ARM.com     m_control_msg_size = atoi(argv[i+1].c_str());
589520SAndreas.Sandberg@ARM.com  }
599520SAndreas.Sandberg@ARM.com
609520SAndreas.Sandberg@ARM.com  m_data_msg_size = RubySystem::getBlockSizeBytes() + m_control_msg_size;
619520SAndreas.Sandberg@ARM.com
629520SAndreas.Sandberg@ARM.com  assert(m_virtual_networks != 0);
639520SAndreas.Sandberg@ARM.com  assert(m_topology_ptr != NULL);
649520SAndreas.Sandberg@ARM.com}
659520SAndreas.Sandberg@ARM.com
669520SAndreas.Sandberg@ARM.comint Network::MessageSizeType_to_int(MessageSizeType size_type)
679520SAndreas.Sandberg@ARM.com{
689520SAndreas.Sandberg@ARM.com  switch(size_type) {
699520SAndreas.Sandberg@ARM.com  case MessageSizeType_Undefined:
709520SAndreas.Sandberg@ARM.com    ERROR_MSG("Can't convert Undefined MessageSizeType to integer");
719520SAndreas.Sandberg@ARM.com    break;
729520SAndreas.Sandberg@ARM.com  case MessageSizeType_Control:
7311688Sandreas.hansson@arm.com  case MessageSizeType_Request_Control:
749520SAndreas.Sandberg@ARM.com  case MessageSizeType_Reissue_Control:
759520SAndreas.Sandberg@ARM.com  case MessageSizeType_Response_Control:
769520SAndreas.Sandberg@ARM.com  case MessageSizeType_Writeback_Control:
779520SAndreas.Sandberg@ARM.com  case MessageSizeType_Forwarded_Control:
789520SAndreas.Sandberg@ARM.com  case MessageSizeType_Invalidate_Control:
799520SAndreas.Sandberg@ARM.com  case MessageSizeType_Unblock_Control:
809520SAndreas.Sandberg@ARM.com  case MessageSizeType_Persistent_Control:
819520SAndreas.Sandberg@ARM.com  case MessageSizeType_Completion_Control:
829520SAndreas.Sandberg@ARM.com    return m_control_msg_size;
839520SAndreas.Sandberg@ARM.com    break;
849520SAndreas.Sandberg@ARM.com  case MessageSizeType_Data:
859520SAndreas.Sandberg@ARM.com  case MessageSizeType_Response_Data:
869520SAndreas.Sandberg@ARM.com  case MessageSizeType_ResponseLocal_Data:
879520SAndreas.Sandberg@ARM.com  case MessageSizeType_ResponseL2hit_Data:
889520SAndreas.Sandberg@ARM.com  case MessageSizeType_Writeback_Data:
899520SAndreas.Sandberg@ARM.com    return m_data_msg_size;
909520SAndreas.Sandberg@ARM.com    break;
919520SAndreas.Sandberg@ARM.com  default:
929520SAndreas.Sandberg@ARM.com    ERROR_MSG("Invalid range for type MessageSizeType");
939520SAndreas.Sandberg@ARM.com    break;
949520SAndreas.Sandberg@ARM.com  }
959520SAndreas.Sandberg@ARM.com  return 0;
969520SAndreas.Sandberg@ARM.com}
979520SAndreas.Sandberg@ARM.com