## CNRS - Grenoble INP - UJF

### Generation of Hardware Emulation Platform for Multi-FPGA Based NoC



### Zhiwei GE<sup>1</sup>, Junyan TAN<sup>2</sup>, Virginie FRESSE<sup>2</sup>, Frédéric ROUSSEAU<sup>3</sup>, Suying YAO<sup>1</sup> <sup>1</sup>ASIC Design Center, Tianjin Unversity, <sup>2</sup>Laboratoire Hubert Curien, Université Jean Monnet, <sup>3</sup>TIMA Laboratory



### Background

Multi-FPGA based emulation platform for NoC (Network-on-Chip) gives a solution to the resource limitation of single FPGA based emulation platform. The generic design flow is needed to generate the emulation architecture for multi-FPGA based NoC. **Objective** 

We propose a design flow that generates multi-FPGA based NoC. With the routing IP library for multi-FPGA based 3D NoC, the platform specification, the data transfer specification and emulation blocks, the generation tools can automatically generates a hardware emulation platform for multi-FPGA based NoC.

# Architecture of the multi-FPGA based

S: Source Node D: Destination Node C: Current Node

### GUI of the generation tools

(developed with python)

| NoCgen: the NoC Generation Tool                                                                                                                                                                                                                                                         |                                         |                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                         |                                         | Help                                                                                              |
| About NoCgen                                                                                                                                                                                                                                                                            | NoC Generation tool                     | Hermes files directory<br>Hermes<br>NoC library directory<br>NoC_LIB<br>Destination NoC directory |
|                                                                                                                                                                                                                                                                                         |                                         |                                                                                                   |
| ype of NoC                                                                                                                                                                                                                                                                              |                                         |                                                                                                   |
| 3D_Asyn 💌 Nu                                                                                                                                                                                                                                                                            | umber of FPGAs 2 🚊                      |                                                                                                   |
|                                                                                                                                                                                                                                                                                         |                                         |                                                                                                   |
| Courting Algorithm                                                                                                                                                                                                                                                                      | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |                                                                                                   |
| • XY • WFM • NLM                                                                                                                                                                                                                                                                        | O NFM O W                               | FNM C NLNM C NFNM                                                                                 |
| XY O WFM O NLM  mulation environment                                                                                                                                                                                                                                                    | O NFM O W                               | FNM ONLNM ONFNM                                                                                   |
| ● XY   ○ WFM                                                                                                                                                                                                                                                                            | ONFM OW                                 | FNM ONFNM                                                                                         |
| ● XY ● WFM ● NLM<br>mulation environment<br>■ Emulate<br>● Automatic load                                                                                                                                                                                                               | ONFM OW                                 | FRIM O NILRIM O RENM                                                                              |
| ● XY   ○ WFM                                                                                                                                                                                                                                                                            | ONFM OW                                 | FNM ONENM                                                                                         |
| ● XY ● WFM ● NLM<br>mulation environment<br>■ Emulate<br>● Automatic load                                                                                                                                                                                                               | O NFM O W                               | FRIM O RILRIM O RFRIM                                                                             |
| ● XY ● WFM ● NLM<br>mulation environment<br>■ Emulate<br>● Automatic load<br>● multi-destination<br>● One-destination                                                                                                                                                                   | ONFM OW                                 | FRIM C HILINM C HF/HM                                                                             |
| ● XY ● WFM ● NLM<br>mulation environment<br>■ Emulate<br>● Automatic load<br>● multi-destination                                                                                                                                                                                        |                                         | FRUM O NILBUM O NIFUM                                                                             |
| <ul> <li>♥ Y</li> <li>♥ WFM</li> <li>♥ Emulate</li> <li>○ Automatic load</li> <li>○ multi-destination</li> <li>○ One-destination</li> <li>Data transfert scenario</li> <li>□ From NoC library</li> </ul>                                                                                |                                         |                                                                                                   |
| <ul> <li>● XY</li> <li>● WFM</li> <li>● NLM</li> <li>■ mulation environment</li> <li>○ Automatic load</li> <li>○ multi-destination</li> <li>○ One-destination</li> <li>■ Data transfert scenario</li> <li>□ From NoC library</li> <li>○ (元)</li> <li>○ 編辑</li> </ul>                    |                                         |                                                                                                   |
| <ul> <li>● XY</li> <li>● WFM</li> <li>● NLM</li> <li>■ mulation environment</li> <li>✓ Emulate</li> <li>○ Automatic load</li> <li>○ multi-destination</li> <li>○ One-destination</li> <li>■ Data transfert scenario</li> <li>□ From NoC library</li> <li>④ (元)</li> <li>④ 編辑</li> </ul> |                                         |                                                                                                   |

 $Z_N$ : the index of the FPGA that node N belongs to

#### *N*<sub>MD</sub>: Multi-dimension Node



### Features of multi-FPGA based NoC

### Routing algorithm

Support various routing algorithm, such as XYZ,
 NLM\_MD, WFM\_MD, NFM\_MD in multi-dimension
 ➤ Data transfer

Zhiwei Ge: bourse région Rhône Alpes accueil doc 2011 (LaHC-Tianjin) Junayn Tan: bourse région Rhône Alpes 2007-2011 (TIMA-LaHC) One source, one destination
Multi-source, one destination
One source, multi-destination
Multi-source, multi-destination
GALS (each FPGA has its own frequency)
With the globally asynchronous locally synchronous technique can get the latency info for each clock domain

R H Ô N E - A L P E S

ERECHER

ISLE