# **NoC**Turnal Networking Solutions

A Daniel Sabogal & Sebastian Sabogal Company

## **Statement of Work**

#### **Task Descriptions**

- Software/NoC Simulation (Daniel)
  - Timed stepping capabilities
  - o Multithreaded (pthread) application
  - Console or GUI demonstration
- Software/NIC Baremetal Driver (Daniel)
  - o Baremetal interface for offloading/accessing packets with the NIC
- HDL/Router (Sebastian)
  - o FIFO: Create user-configurable FIFOs leveraging BRAM for Xilinx devices
  - o Multi-FIFO Structure: Port map FIFOs to form the skeleton of the router
  - o RR & Wormhole:
    - Implement a per-link round-robbin mechanism for packet switching and XY rounting
    - Implement wormhole switching
- HDL/NIC (Daniel)
  - Use FIFOs to buffer packets with send/receive logic
- Testbenching/Router (Sebastian)
  - o Test router implementation
- Testbenching/NIC
  - o Test NIC implementation
- Testbenching/NoC (Daniel & Sebastian)
  - o Test multi-router network
  - o Emulate congestion through multiple IoT devices
  - User configurable traffic or packet offloading
- Integration (Sebastian)
  - o Package HDL into Vivado IP
  - Create Block Designs
  - o Place & Route Constraints to realize NoC on the floorplan
  - o Timing Analysis
- Testing/Baseline (Daniel & Sebastian)
  - o Testing without P&R Constraints
- Testing/Final (Daniel & Sebastian)
  - Testing with P&R Constraints
  - o Fix timing issues

(Note: tasks assigned to Daniel & Sebastian are tightly coupled and involve both engineers)

#### **Deliverables**

- Software Demonstration (2/26)
  - o A software-based simulation demonstrating the correctness of packet routing in the NoC
- HW/SW Partitioning & Test Plan (3/19)
  - o An HDL-based implementation of the router and NIC IP with complete testbenching
  - o Representative testbenching for a full NoC system (multiple routers with emulated IoT devices)
- Baseline Demonstration (4/2)
  - Realization of the NoC without P&R constraints (all components are realized, but are not efficiently partitioned)
- Final Demonstration (4/17)
  - Realization of the NoC with P&R constraints (all components are realized and are efficiently partitioned with timing issues fixed)

#### **Acceptance Tests**

- Preliminary test plan:
  - o A 3x3 2D mesh (9 partitions); each partition has:
    - an IoT device (emulated as a NIC connected to the PS)
  - o a local BRAM
  - o Write phase:
  - Test 0: the PS creates packet(s) for each NIC the will route the packet(s) to the NIC's neighbor (next logical neighbor). This test is functional, but execution time and bandwidth information are obtained.
  - o Test 1: the PS creates packet(s) for each NIC that will route the packet(s) to all NICs present in the network (including self). Execution time and bandwidth information are obtained.
  - Test 2: the PS creates packet(s) to be sent from a NIC on one corner of the NoC to another NIC on the opposite corner of the NoC with no congestion present. Execution time and bandwidth information are obtained.
  - Test B: Behavioral testbench that exercises router operation in simulation.

### Requirements vs. Trace-ability Matrix

| Requirement          | Test 0 | Test 1 | Test 2 | Test B |
|----------------------|--------|--------|--------|--------|
| Baseline             |        |        |        |        |
| Routing              | X      | X      | X      | X      |
| Ordering             | X      |        |        |        |
| Congestion           | X      | X      |        |        |
| Wormhole             | X      | X      |        | X      |
| Zero-load<br>Latency |        |        | X      |        |
| Extra                |        |        |        |        |
| Partition            | X      | X      | X      |        |
| > 100MHz Fmax        | X      | X      | X      |        |

#### **Invoice**

• The successful completion of this work will require 2 payments of A

## **Schedule**



(Note: Tasks are assigned by color: Daniel, Sebastian, Both)