```
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; Both the UART\_TX and UART\_RX are a case statement 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):

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 <= 8'h3A;
@(posedge r_Clock);
r_TX_DV <= 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



00111111 32 transmitted & recived 00110010



### 38 transmitted & recived



# 00111000 3A transmitted & recived



#### 00111010

### 41 transmitted & recived

