# **UART – Hardware communication protocol design**

## **KARNATI PARANJAI**

## IEC2021097

Final Year Student, B-Tech ECE, IIIT ALLAHABAD

## **SAMPLE OUTPUTS**

1) Sample testbench and the corresponding output for **uart module**:

# Testbench:

# Output:



2) Sample Testbench and corresponding output for uart\_transmitter (uart\_tx) module :

Test Bench:

```
always #52080 clk = ~clk; // 100 MHz clk/10416
initial
begin
clk = 0;
#1 reset = 1;
#3 data = 8'b01000001;
#10 transmit = 1;
#104160 transmit = 0;
end
```

## Output:



3) Sample Testbench and corresponding output for uart\_receiver (uart\_rx) module: (without glitch)

Testbench:

```
always #3255 clk = ~clk;
) initial
begin
 clk = 0;
 Rx = 1;
 Reset = 1;
 #7 Reset = 0;
 #10005 Rx = 0;
 //#10000 Rx = 1; // if glitch
 #104160 Rx = 1;
 #104160 Rx = 0;
 #104160 Rx = 1;
 #104160 Rx = 1;
 #104160 Rx = 1;
 #104160 Rx = 0;
 #104160 Rx = 1;
 #104160 Rx = 0;
 #104160 Rx = 1;
 #200000 $finish;
) end
) endmodule
```

# Output:



4) Sample Testbench and corresponding output for the **uart\_rx** module **with a glitch**:

# Test bench:

```
always #3255 clk = ~clk;
initial
begin
clk = 0;
Rx = 1;
Reset = 1;
#7 Reset = 0;
\#10005 \text{ Rx} = 0;
#10000 Rx = 1; // if glitch
//#104160 Rx = 1;
//#104160 Rx = 0;
1//#104160 Rx = 1;
//#104160 Rx = 1;
1//#104160 Rx = 1;
1//#104160 Rx = 0;
//#104160 Rx = 1;
//#104160 Rx = 0;
//#104160 Rx = 1;
#200000 $finish;
end
```

# Output:

