## ECE 526L Spring 2021

## Lab 10

## **Serial protocol**

In this experiment, you will create a module that sends a byte serially and receives it in loopback.

Create the serial module based on the symbol and description below:

- Your module receives a byte of data and if send is asserted sends it one bit at a time at each posedge of O\_clk
- For simplicity initially you can assume O\_clk is the same as SYS\_Clk, for extra credit make O\_clk half freq od SYS\_clk
- During transmission Strobe is high and other times it's low
- You should wait for 8 bit times before sending next byte
- On the receive side sample the incoming bits at negedge of I\_clk
- You should use state machines for both receive and transmit functions.
- When byte is fully received you should assert valid for 1 clock

You should create a testbench to test your design:

• Your test bench should fully test the transmit and receive scenarios and show you can transmit a given byte and receive the exact byte back





