## \*\*\*\*\*\*\*DRAFT\*\*\*\*\*

# Testing MyHDL created uart\_tx.v & uart\_rx.v for the CATBOARD

# based UART\_RX.v & UART\_TX.v 04/26/18

\*\*\*\*\*\*\*DRAFT\*\*\*\*\*

Thu Apr 19 2018

Initial code was download from https://www.edaplayground.com/x/Pgf http://www.nandland.com

Command to create *testuart* from *UART\_TB.v UART\_RX.v* UART\_TB/v includes *UART\_TX.v* 

iverilog -o testuart UART\_TB.v UART\_RX.v

vvp testuart VCD info: dumpfile dump.vcd opened for output. Test Passed - Correct Byte Received

This code was created

// Testbench uses a 25 MHz clock // Want to interface to 115200 baud UART // 25000000 / 115200 = 217 Clocks Per Bit. parameter c\_CLOCK\_PERIOD\_NS = 40;



Note the clock period of 40 nsec the time between the white marker and red marker.



```
IDLE, TX_START_BIT, TX_DATA_BITS, TX_STOP_BIT, and C:EANUP.
IDLE, RX_START_BIT, RX_DATA_BITS, RX_STOP_BIT, and C:EANUP.
In MyHDL the case statement was written for uart_tx.
if(r_SM_Main==IDLE):
elif (r_SM_Main==TX_START_BIT):
elif (r SM Main==TX DATA BITS):
elif (r_SM_Main==TX_STOP_BIT):
else:
and the uart rx was similar
if(r_SM_Main==IDLE):
elif (r_SM_Main==RX_START_BIT):
elif (r_SM_Main==RX_DATA_BITS):
elif (r_SM_Main==RX_STOP_BIT):
else:
In the simulation the r_TX_BYTE is set to byte to be transmitted and a 1 clock wide r_TX_DV.
   r_TX_DV <= 1'b1;
   r_TX_Byte \le 8'h3A;
   @(posedge r_Clock);
   r_TX_DV \le 1'b0;
```



Testing at 100 MHz appears okay
Using MyHDL to create *uart\_rx.v* with *uart\_rx.py*& *uart\_tx.v* with *uart\_tx.py* 

iverilog -o testuart tb\_dut\_uart\_txrx.v uart\_rx.v

## vvp testuart

VCD info: dumpfile dump.vcd opened for output. Test Passed - Correct Byte Received

Serveral simulation were tested 0x3F, 0x32, 0x38, 0x3A, 0x41. 3F transmitted & recived



32 transmitted & recived 



#### 38 transmitted & recived



## 00111000 3A transmitted & recived



#### 00111010

#### 41 transmitted & recived

