A Novel Approach for Network on Chip Emulation by Genko, Nicolas et al.
A Novel Approach for
Network on Chip Emulation
Nicolas Genko, LSI/EPFL Switzerland
David Atienza, DACYA/UCM Spain
Giovanni De Micheli, LSI/EPFL Switzerland
Luca Benini, DEIS/Bologna Italy
José Mendias, DACYA/UCM Spain
Roman Hermida, DACYA/UCM Spain














• Provide a structured methodology for
realizing on chip communication schemes
– Modularity
– Flexibility
• Overcome the limitations of busses
– Performance and power do not scale up
• Support reliable operation







4Motivation -- NoC Emulation
• NoCs are designed for:
– On-chip multiprocessing (regular networks)
– Specific applications (ad hoc networks)
• Design tools:
– Synthesis: create NoC circuitry from architectural templates
(e.g., Xpipes)
– Analysis: validate functionality and performance
• Software simulation (cycle accurate)








• NoC software simulation:
– High level models in C/C++  [H.-Sheng et al; Kolso et al]
– Evaluate latency NoCs      [Siguenza et al; Angiolini et al]
– Evaluate throughput NoCs  [Wiklund et al; Pestana et al]
• NoC implementation on FPGAs:
– For functional validation    [Marescaux et al; Moraes et al]
– Show effectiveness NoCs         [Kumar et al; Pinto et al]







6NoC Emulation on FPGA
• Emulation on FPGA enables functional and
performance validation of NoC based systems
– Accurate execution model
– Probing for profiling and gathering of statistics
• The emulation can achieve important speedups
compared to cycle accurate simulation:
– Up to four orders of magnitude faster




















• A platform which instantiate a NoC on FPGA
with modules for emulation:
– Traffic generators & receptors
– NoC switches
– Traffic analyzers
– Network interfaces (NIs) to cores can be included
• A system which is controlled by a processor
– The processor configures and controls the traffic
pattern to be emulated and analyzes the


















Serial interfaceVirtex-II Pro FPGA
•2 Power PC Cores
•3 M programmable gates
10
Emulated NoC Architectures







– Network of switches





























– Access routing tables
– Assemble packets
– Split into flits
•Receive
– Synchronize















Architecture 1-- Network of Switches
• A Processor (PowerPC):




Displays on the PC screen
the information extracted
• The Emulation Platform:
– Traffic generators
– Traffic receptors








• Several types of traffic:
– Stochastic traffic:
• Uniform model
• Burst model (with a two state Markov chain)
– Trace-driven traffic (real workload)
• Several types of statistics:
– Measurement of latency of packets
– Congestion counter (not-acknowledged flits)
• Routing policy evaluation:
– The routing policy is programmed by software







Emulation of a Network of Switches
15






– NIs to cores
• Slave core receptiveness
– Modeled by a two-state (on/off)
Markov chain
• Traffic analyzers monitor









Emulation of NoC with interfaces
• Trace-based traffic:
– Master cores generate traffic according to traces provided
by the processor from real applications
• Statistics generated by this platform:
– Master cores measure average operation execution time
– Slave cores measure packets latency through the NoC
– Traffic analyzers measure ACK & NACK activities on links
• Main use of emulation platform:
– Tuning of a NoC for a specific application




























(4 switches + 4 master
cores + 4 slave cores)




(6 switches + 4 traffic
generators + 4 traffic
receptors)




























Emulation Network of Switches
• Example of statistics:
– Average latency of packets
• Parameters of the emulation – Burst traffic:
– Average number of packets/burst








Emulation NoC with NIs
• Statistics:
– Ratio Ack/(Ack+Nack).
– Average latency of
packets on the NoC
• Emulation parameters:
– OCP activity























• Mixed HW/SW framework that helps designers to
design and validate ad-hoc NoCs
• Two architectures:
– Emulation of a network of switches.
– Emulation of a complete NoC with OCP-compliant
interfaces
• The FPGA emulation enables to tune NoC parameters
with realistic inputs (experiments based on traces from




– OCP traffic pattern influence
•Introduction
•General
Approach
•Applications
•Results
•Conclusions
Thank you
•Introduction
•General
Approach
•Applications
•Results
•Conclusions
•Questions
