## **TUTORIAL-Flow**

Data packets are queued in the input FIFOs (First In First Out buffers). Packets await their opportunity to inject into the ring, and travel around the ring to exit at their destination.



The design is very little code because it is constructed from M4 macros for the FIFOs (m4+simple\_bypass\_fifo\_v2) the Ring (m4+simple\_ring) and a testbench (m4+router testbench).

Before exploring how this transaction flow is coded, let's see what it can do. Let's imagine, we need to add data protection to the packet by adding a parity field.

With that simple two-line change, you implemented or changed 19 lines of RTL! These changes carried the new parity field through the FIFOs, into the ring, and out. In a real-world design, a simple change like this could change hundreds of lines of RTL!

diff ring\_parity/top.tlv ring\_parity\_8port/top.tlv 41c41

- < m4\_define\_hier(M4\_PORT, 4, 0) // Defines constants for /port[3:0].
- > m4\_define\_hier(M4\_PORT, 8, 0) // Defines constants for /port[3:0].

## 4port



## 8port

