summaryrefslogtreecommitdiff
path: root/src/mem/ruby
diff options
context:
space:
mode:
authorNilay Vaish <nilay@cs.wisc.edu>2014-01-04 00:03:34 -0600
committerNilay Vaish <nilay@cs.wisc.edu>2014-01-04 00:03:34 -0600
commit4070b00875a5fcc3cde61ff0b32fbee882998189 (patch)
tree245f49626f3abf0c378397025638adc7afaee9b5 /src/mem/ruby
parentbb6d7d402b5cc610ed879e9e7ecb251e353149e6 (diff)
downloadgem5-4070b00875a5fcc3cde61ff0b32fbee882998189.tar.xz
ruby: add a three level MESI protocol.
The first two levels (L0, L1) are private to the core, the third level (L2)is possibly shared. The protocol supports clustered designs. For example, one can have two sets of two cores. Each core has an L0 and L1 cache. There are two L2 controllers where each set accesses only one of the L2 controllers.
Diffstat (limited to 'src/mem/ruby')
-rw-r--r--src/mem/ruby/slicc_interface/RubySlicc_ComponentMapping.hh7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/mem/ruby/slicc_interface/RubySlicc_ComponentMapping.hh b/src/mem/ruby/slicc_interface/RubySlicc_ComponentMapping.hh
index 4df57c712..95b9869dd 100644
--- a/src/mem/ruby/slicc_interface/RubySlicc_ComponentMapping.hh
+++ b/src/mem/ruby/slicc_interface/RubySlicc_ComponentMapping.hh
@@ -96,4 +96,11 @@ machineCount(MachineType machType)
return MachineType_base_count(machType);
}
+inline MachineID
+createMachineID(MachineType type, NodeID id)
+{
+ MachineID mach = {type, id};
+ return mach;
+}
+
#endif // __MEM_RUBY_SLICC_INTERFACE_COMPONENTMAPPINGS_HH__