ruby: Reorganized Ruby topology and protocol files
--HG-- rename : configs/ruby/MESI_CMP_directory.py => configs/ruby/protocols/MESI_CMP_directory.py rename : configs/ruby/MI_example.py => configs/ruby/protocols/MI_example.py rename : configs/ruby/MOESI_CMP_directory.py => configs/ruby/protocols/MOESI_CMP_directory.py rename : configs/ruby/MOESI_CMP_token.py => configs/ruby/protocols/MOESI_CMP_token.py rename : configs/ruby/MOESI_hammer.py => configs/ruby/protocols/MOESI_hammer.py rename : configs/ruby/networks/MeshDirCorners.py => src/mem/ruby/network/topologies/MeshDirCorners.py
This commit is contained in:
@@ -37,8 +37,8 @@ parser.add_option("--fastmem", action="store_true")
|
|||||||
parser.add_option("--clock", action="store", type="string", default='1GHz')
|
parser.add_option("--clock", action="store", type="string", default='1GHz')
|
||||||
parser.add_option("--num-dirs", type="int", default=1)
|
parser.add_option("--num-dirs", type="int", default=1)
|
||||||
parser.add_option("--num-l2caches", type="int", default=1)
|
parser.add_option("--num-l2caches", type="int", default=1)
|
||||||
parser.add_option("--topology", type="string", default="crossbar",
|
parser.add_option("--topology", type="string", default="Crossbar",
|
||||||
help="'crossbar'|'mesh'")
|
help="check src/mem/ruby/network/topologies for complete set")
|
||||||
parser.add_option("--mesh-rows", type="int", default=1,
|
parser.add_option("--mesh-rows", type="int", default=1,
|
||||||
help="the number of rows in the mesh topology")
|
help="the number of rows in the mesh topology")
|
||||||
parser.add_option("--garnet-network", type="string", default=none,
|
parser.add_option("--garnet-network", type="string", default=none,
|
||||||
|
|||||||
@@ -31,15 +31,11 @@ import m5
|
|||||||
from m5.objects import *
|
from m5.objects import *
|
||||||
from m5.defines import buildEnv
|
from m5.defines import buildEnv
|
||||||
from m5.util import addToPath
|
from m5.util import addToPath
|
||||||
addToPath('../ruby/networks')
|
|
||||||
from MeshDirCorners import *
|
|
||||||
|
|
||||||
protocol = buildEnv['PROTOCOL']
|
|
||||||
|
|
||||||
exec "import %s" % protocol
|
|
||||||
|
|
||||||
def create_system(options, physmem, piobus = None, dma_devices = []):
|
def create_system(options, physmem, piobus = None, dma_devices = []):
|
||||||
|
|
||||||
|
protocol = buildEnv['PROTOCOL']
|
||||||
|
exec "import %s" % protocol
|
||||||
try:
|
try:
|
||||||
(cpu_sequencers, dir_cntrls, all_cntrls) = \
|
(cpu_sequencers, dir_cntrls, all_cntrls) = \
|
||||||
eval("%s.create_system(options, physmem, piobus, dma_devices)" \
|
eval("%s.create_system(options, physmem, piobus, dma_devices)" \
|
||||||
@@ -49,27 +45,16 @@ def create_system(options, physmem, piobus = None, dma_devices = []):
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Important: the topology constructor must be called before the network
|
# Important: the topology must be created before the network and after the
|
||||||
# constructor.
|
# controllers.
|
||||||
#
|
#
|
||||||
if options.topology == "crossbar":
|
exec "import %s" % options.topology
|
||||||
net_topology = makeCrossbar(all_cntrls)
|
try:
|
||||||
elif options.topology == "mesh":
|
net_topology = eval("%s.makeTopology(all_cntrls, options)" % options.topology)
|
||||||
#
|
except:
|
||||||
# The uniform mesh topology assumes one router per cpu
|
print "Error: could not create topology %s" % options.topology
|
||||||
#
|
sys.exit(1)
|
||||||
net_topology = makeMesh(all_cntrls,
|
|
||||||
len(cpu_sequencers),
|
|
||||||
options.mesh_rows)
|
|
||||||
|
|
||||||
elif options.topology == "mesh_dir_corner":
|
|
||||||
#
|
|
||||||
# The uniform mesh topology assumes one router per cpu
|
|
||||||
#
|
|
||||||
net_topology = makeMeshDirCorners(all_cntrls,
|
|
||||||
len(cpu_sequencers),
|
|
||||||
options.mesh_rows)
|
|
||||||
|
|
||||||
if options.garnet_network == "fixed":
|
if options.garnet_network == "fixed":
|
||||||
network = GarnetNetwork_d(topology = net_topology)
|
network = GarnetNetwork_d(topology = net_topology)
|
||||||
elif options.garnet_network == "flexible":
|
elif options.garnet_network == "flexible":
|
||||||
|
|||||||
@@ -56,79 +56,6 @@ class Topology(SimObject):
|
|||||||
print_config = Param.Bool(False,
|
print_config = Param.Bool(False,
|
||||||
"display topology config in the stats file")
|
"display topology config in the stats file")
|
||||||
|
|
||||||
def makeCrossbar(nodes):
|
|
||||||
ext_links = [ExtLink(ext_node=n, int_node=i)
|
|
||||||
for (i, n) in enumerate(nodes)]
|
|
||||||
xbar = len(nodes) # node ID for crossbar switch
|
|
||||||
int_links = [IntLink(node_a=i, node_b=xbar) for i in range(len(nodes))]
|
|
||||||
return Topology(ext_links=ext_links, int_links=int_links,
|
|
||||||
num_int_nodes=len(nodes)+1)
|
|
||||||
|
|
||||||
def makeMesh(nodes, num_routers, num_rows):
|
|
||||||
#
|
|
||||||
# There must be an evenly divisible number of cntrls to routers
|
|
||||||
# Also, obviously the number or rows must be <= the number of routers
|
|
||||||
#
|
|
||||||
cntrls_per_router, remainder = divmod(len(nodes), num_routers)
|
|
||||||
assert(num_rows <= num_routers)
|
|
||||||
num_columns = int(num_routers / num_rows)
|
|
||||||
assert(num_columns * num_rows == num_routers)
|
|
||||||
|
|
||||||
#
|
|
||||||
# Add all but the remainder nodes to the list of nodes to be uniformly
|
|
||||||
# distributed across the network.
|
|
||||||
#
|
|
||||||
network_nodes = []
|
|
||||||
remainder_nodes = []
|
|
||||||
for node_index in xrange(len(nodes)):
|
|
||||||
if node_index < (len(nodes) - remainder):
|
|
||||||
network_nodes.append(nodes[node_index])
|
|
||||||
else:
|
|
||||||
remainder_nodes.append(nodes[node_index])
|
|
||||||
|
|
||||||
#
|
|
||||||
# Connect each node to the appropriate router
|
|
||||||
#
|
|
||||||
ext_links = []
|
|
||||||
for (i, n) in enumerate(network_nodes):
|
|
||||||
cntrl_level, router_id = divmod(i, num_routers)
|
|
||||||
assert(cntrl_level < cntrls_per_router)
|
|
||||||
ext_links.append(ExtLink(ext_node=n, int_node=router_id))
|
|
||||||
|
|
||||||
#
|
|
||||||
# Connect the remainding nodes to router 0. These should only be DMA nodes.
|
|
||||||
#
|
|
||||||
for (i, node) in enumerate(remainder_nodes):
|
|
||||||
assert(node.type == 'DMA_Controller')
|
|
||||||
assert(i < remainder)
|
|
||||||
ext_links.append(ExtLink(ext_node=node, int_node=0))
|
|
||||||
|
|
||||||
#
|
|
||||||
# Create the mesh links. First row (east-west) links then column
|
|
||||||
# (north-south) links
|
|
||||||
#
|
|
||||||
int_links = []
|
|
||||||
for row in xrange(num_rows):
|
|
||||||
for col in xrange(num_columns):
|
|
||||||
if (col + 1 < num_columns):
|
|
||||||
east_id = col + (row * num_columns)
|
|
||||||
west_id = (col + 1) + (row * num_columns)
|
|
||||||
int_links.append(IntLink(node_a=east_id,
|
|
||||||
node_b=west_id,
|
|
||||||
weight=1))
|
|
||||||
for col in xrange(num_columns):
|
|
||||||
for row in xrange(num_rows):
|
|
||||||
if (row + 1 < num_rows):
|
|
||||||
north_id = col + (row * num_columns)
|
|
||||||
south_id = col + ((row + 1) * num_columns)
|
|
||||||
int_links.append(IntLink(node_a=north_id,
|
|
||||||
node_b=south_id,
|
|
||||||
weight=2))
|
|
||||||
|
|
||||||
return Topology(ext_links=ext_links,
|
|
||||||
int_links=int_links,
|
|
||||||
num_int_nodes=num_routers)
|
|
||||||
|
|
||||||
class RubyNetwork(SimObject):
|
class RubyNetwork(SimObject):
|
||||||
type = 'RubyNetwork'
|
type = 'RubyNetwork'
|
||||||
cxx_class = 'Network'
|
cxx_class = 'Network'
|
||||||
|
|||||||
40
src/mem/ruby/network/topologies/Crossbar.py
Normal file
40
src/mem/ruby/network/topologies/Crossbar.py
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
# Copyright (c) 2010 Advanced Micro Devices, Inc.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are
|
||||||
|
# met: redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer;
|
||||||
|
# redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution;
|
||||||
|
# neither the name of the copyright holders nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived from
|
||||||
|
# this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# Authors: Steve Reinhardt
|
||||||
|
|
||||||
|
from m5.params import *
|
||||||
|
from m5.objects import *
|
||||||
|
|
||||||
|
def makeTopology(nodes, options):
|
||||||
|
ext_links = [ExtLink(ext_node=n, int_node=i)
|
||||||
|
for (i, n) in enumerate(nodes)]
|
||||||
|
xbar = len(nodes) # node ID for crossbar switch
|
||||||
|
int_links = [IntLink(node_a=i, node_b=xbar) for i in range(len(nodes))]
|
||||||
|
return Topology(ext_links=ext_links, int_links=int_links,
|
||||||
|
num_int_nodes=len(nodes)+1)
|
||||||
|
|
||||||
|
|
||||||
103
src/mem/ruby/network/topologies/Mesh.py
Normal file
103
src/mem/ruby/network/topologies/Mesh.py
Normal file
@@ -0,0 +1,103 @@
|
|||||||
|
# Copyright (c) 2010 Advanced Micro Devices, Inc.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are
|
||||||
|
# met: redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer;
|
||||||
|
# redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution;
|
||||||
|
# neither the name of the copyright holders nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived from
|
||||||
|
# this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# Authors: Brad Beckmann
|
||||||
|
|
||||||
|
from m5.params import *
|
||||||
|
from m5.objects import *
|
||||||
|
|
||||||
|
#
|
||||||
|
# Makes a generic mesh assuming an equal number of cache and directory cntrls
|
||||||
|
#
|
||||||
|
|
||||||
|
def makeTopology(nodes, options):
|
||||||
|
|
||||||
|
num_routers = options.num_cpus
|
||||||
|
num_rows = options.mesh_rows
|
||||||
|
|
||||||
|
#
|
||||||
|
# There must be an evenly divisible number of cntrls to routers
|
||||||
|
# Also, obviously the number or rows must be <= the number of routers
|
||||||
|
#
|
||||||
|
cntrls_per_router, remainder = divmod(len(nodes), num_routers)
|
||||||
|
assert(num_rows <= num_routers)
|
||||||
|
num_columns = int(num_routers / num_rows)
|
||||||
|
assert(num_columns * num_rows == num_routers)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Add all but the remainder nodes to the list of nodes to be uniformly
|
||||||
|
# distributed across the network.
|
||||||
|
#
|
||||||
|
network_nodes = []
|
||||||
|
remainder_nodes = []
|
||||||
|
for node_index in xrange(len(nodes)):
|
||||||
|
if node_index < (len(nodes) - remainder):
|
||||||
|
network_nodes.append(nodes[node_index])
|
||||||
|
else:
|
||||||
|
remainder_nodes.append(nodes[node_index])
|
||||||
|
|
||||||
|
#
|
||||||
|
# Connect each node to the appropriate router
|
||||||
|
#
|
||||||
|
ext_links = []
|
||||||
|
for (i, n) in enumerate(network_nodes):
|
||||||
|
cntrl_level, router_id = divmod(i, num_routers)
|
||||||
|
assert(cntrl_level < cntrls_per_router)
|
||||||
|
ext_links.append(ExtLink(ext_node=n, int_node=router_id))
|
||||||
|
|
||||||
|
#
|
||||||
|
# Connect the remainding nodes to router 0. These should only be DMA nodes.
|
||||||
|
#
|
||||||
|
for (i, node) in enumerate(remainder_nodes):
|
||||||
|
assert(node.type == 'DMA_Controller')
|
||||||
|
assert(i < remainder)
|
||||||
|
ext_links.append(ExtLink(ext_node=node, int_node=0))
|
||||||
|
|
||||||
|
#
|
||||||
|
# Create the mesh links. First row (east-west) links then column
|
||||||
|
# (north-south) links
|
||||||
|
#
|
||||||
|
int_links = []
|
||||||
|
for row in xrange(num_rows):
|
||||||
|
for col in xrange(num_columns):
|
||||||
|
if (col + 1 < num_columns):
|
||||||
|
east_id = col + (row * num_columns)
|
||||||
|
west_id = (col + 1) + (row * num_columns)
|
||||||
|
int_links.append(IntLink(node_a=east_id,
|
||||||
|
node_b=west_id,
|
||||||
|
weight=1))
|
||||||
|
for col in xrange(num_columns):
|
||||||
|
for row in xrange(num_rows):
|
||||||
|
if (row + 1 < num_rows):
|
||||||
|
north_id = col + (row * num_columns)
|
||||||
|
south_id = col + ((row + 1) * num_columns)
|
||||||
|
int_links.append(IntLink(node_a=north_id,
|
||||||
|
node_b=south_id,
|
||||||
|
weight=2))
|
||||||
|
|
||||||
|
return Topology(ext_links=ext_links,
|
||||||
|
int_links=int_links,
|
||||||
|
num_int_nodes=num_routers)
|
||||||
@@ -35,7 +35,11 @@ from m5.objects import *
|
|||||||
# specified is similar to GEMS old file specified network.
|
# specified is similar to GEMS old file specified network.
|
||||||
#
|
#
|
||||||
|
|
||||||
def makeMeshDirCorners(nodes, num_routers, num_rows):
|
def makeTopology(nodes, options):
|
||||||
|
|
||||||
|
num_routers = options.num_cpus
|
||||||
|
num_rows = options.mesh_rows
|
||||||
|
|
||||||
#
|
#
|
||||||
# First determine which nodes are cache cntrls vs. dirs vs. dma
|
# First determine which nodes are cache cntrls vs. dirs vs. dma
|
||||||
#
|
#
|
||||||
37
src/mem/ruby/network/topologies/SConscript
Normal file
37
src/mem/ruby/network/topologies/SConscript
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
# Copyright (c) 2010 Advanced Micro Devices, Inc.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are
|
||||||
|
# met: redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer;
|
||||||
|
# redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution;
|
||||||
|
# neither the name of the copyright holders nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived from
|
||||||
|
# this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# Authors: Brad Beckmann
|
||||||
|
|
||||||
|
Import('*')
|
||||||
|
|
||||||
|
if not env['RUBY']:
|
||||||
|
Return()
|
||||||
|
|
||||||
|
PySource('', 'Crossbar.py')
|
||||||
|
PySource('', 'Mesh.py')
|
||||||
|
PySource('', 'MeshDirCorners.py')
|
||||||
|
|
||||||
Reference in New Issue
Block a user