blob: d00198ea01ee2aca27cd7854d4e099085b556f20 [file] [log] [blame]
# Name of model to be built and evaluated
ModelName = Router
# Query string to choose what to evaluate (use '\' to enable multiline config)
QueryString = \
Energy>>Router:WriteBuffer@0 \
Energy>>Router:ReadBuffer@0 \
Energy>>Router:TraverseCrossbar->Multicast1@0 \
Energy>>Router:ArbitrateSwitch->ArbitrateStage1@0 \
Energy>>Router:ArbitrateSwitch->ArbitrateStage2@0 \
Energy>>Router:DistributeClock@0 \
NddPower>>Router:Leakage@1 \
Area>>Router:Active@1 \
# Injection rate (# flits per cycle per port), assuming that the router is not
# saturated
InjectionRate = 0.3
# Evaluation string
EvaluateString = \
ejection_rate = $(NumberInputPorts) * $(InjectionRate) / $(NumberOutputPorts); \
buf_rd_dynamic = $(Energy>>Router:ReadBuffer) * $(Frequency); \
buf_wr_dynamic = $(Energy>>Router:WriteBuffer) * $(Frequency); \
buf_static = $(NddPower>>Router->InputPort:Leakage) * $(NumberInputPorts) + ($(NddPower>>Router->PipelineReg0:Leakage) + $(NddPower>>Router->PipelineReg1:Leakage)) * $(NumberInputPorts) * $(NumberBitsPerFlit); \
xbar_o_dynamic = $(Energy>>Router:TraverseCrossbar->Multicast1) * $(Frequency); \
xbar_static = $(NddPower>>Router->Crossbar:Leakage) + $(NddPower>>Router->PipelineReg2_0:Leakage) * $(NumberOutputPorts) * $(NumberBitsPerFlit); \
sa_o_dynamic = ($(Energy>>Router:ArbitrateSwitch->ArbitrateStage1) + $(Energy>>Router:ArbitrateSwitch->ArbitrateStage2)) * $(Frequency); \
sa_static = $(NddPower>>Router->SwitchAllocator:Leakage); \
clock_o_dynamic = $(Energy>>Router:DistributeClock) * $(Frequency); \
clock_static = $(NddPower>>Router->ClockTree:Leakage); \
buffer_dynamic = buf_wr_dynamic * $(InjectionRate) * $(NumberInputPorts) + buf_rd_dynamic * ejection_rate * $(NumberOutputPorts); \
buffer_leakage = buf_static; \
xbar_dynamic = xbar_o_dynamic * ejection_rate * $(NumberOutputPorts); \
xbar_leakage = xbar_static; \
sa_dynamic = sa_o_dynamic * ejection_rate * $(NumberOutputPorts); \
sa_leakage = sa_static; \
clock_dynamic = clock_o_dynamic; \
clock_leakage = clock_static; \
total_dynamic = buffer_dynamic + xbar_dynamic + sa_dynamic + clock_dynamic; \
total_leakage = buffer_leakage + xbar_leakage + sa_leakage + clock_leakage; \
buf_area = ($(Area>>Router->InputPort:Active) + ($(Area>>Router->PipelineReg0:Active) + $(Area>>Router->PipelineReg1:Active)) * $(NumberBitsPerFlit)) * $(NumberInputPorts); \
xbar_area = $(Area>>Router->Crossbar:Active) + $(Area>>Router->Crossbar_Sel_DFF:Active) + $(Area>>Router->PipelineReg2_0:Active) * $(NumberBitsPerFlit) * $(NumberOutputPorts); \
sa_area = $(Area>>Router->SwitchAllocator:Active); \
other_area = $(Area>>Router->ClockTree:Active); \
print "Buffer:"; \
print " Dynamic power: " buffer_dynamic; \
print " Leakage power: " buffer_leakage; \
print "Crossbar:"; \
print " Dynamic power: " xbar_dynamic; \
print " Leakage power: " xbar_leakage; \
print "Switch allocator:"; \
print " Dynamic power: " sa_dynamic; \
print " Leakage power: " sa_leakage; \
print "Clock:"; \
print " Dynamic power: " clock_dynamic; \
print " Leakage power: " clock_leakage; \
print "Total:"; \
print " Dynamic power: " total_dynamic; \
print " Leakage power: " $(NddPower>>Router:Leakage); \
print "Area:"; \
print " Buffer: " buf_area; \
print " Crossbar: " xbar_area; \
print " Switch allocator: " sa_area; \
print " Other: " other_area; \
# Technology file (see other models in tech/models)
ElectricalTechModelFilename = ext/dsent/tech/tech_models/Bulk45LVT.model
###############################################################################
# Timing optimization
###############################################################################
# True if want to perform timing optimization; otherwise, false.
IsPerformTimingOptimization = true
# Nets that the timing optimizer starts from
TimingOptimization->StartNetNames = [*]
# Operating frequency (Hz)
Frequency = 1.0e9
###############################################################################
# Model specifications
###############################################################################
# Number of input ports
NumberInputPorts = 5
# Number of output ports
NumberOutputPorts = 5
# Flit width (bit)
NumberBitsPerFlit = 64
# In this example, we define 2 virtual networks (message classes), VN1 and VN2.
# VN1 VN2
# Number of VCs 2 3
# Number of buffers / VC 4 5
#
# So in total, there are (2 * 4) + (3 * 5) = 23 flit buffers
#
# Number of virtual networks (number of message classes)
NumberVirtualNetworks = 2
# Number of virtual channels per virtual network
NumberVirtualChannelsPerVirtualNetwork = [2, 3]
# Number of buffers per virtual channel
NumberBuffersPerVirtualChannel = [4, 5]
# InputPort
# ---------
# buffer model
InputPort->BufferModel = DFFRAM
# Crossbar
# --------
# crossbar model
CrossbarModel = MultiplexerCrossbar
# Switch allocator
# ----------------
# arbiter model
SwitchAllocator->ArbiterModel = MatrixArbiter
# Clock tree
# ----------
# clock tree model
ClockTreeModel = BroadcastHTree
# number of levels
ClockTree->NumberLevels = 5
# wire layer
ClockTree->WireLayer = Global
# wire width multiplier
ClockTree->WireWidthMultiplier = 1.0