# Task 3

The module analysis,

```
// BALL DATE Module, transmit only
module user_tw.Ball {
    clb, tw. // imput clock
    clb, tw. // imput clock
    tendedsta, // imput clock
    tendedsta, // imput clock
    tendedsta, // imput clock
    twone, // twite
    lingut twine
    twone, // twite
    lingut sendedsta;
    /* proports */
    imput sendedsta;
    /* state variables */
    regl?**) bit twine bit
    regl?**) bit twine bit
    regl?**) bit twine bit
    regl twine bit
    /* proports bi
```

In the above part of the uart\_trx file,

The inputs are,

- o Clk
- Txbyte (8 bit outgoing)
- Senddata(triggers the tx)

The outputs are,

- Txdone (the outgoing byte)
- o Tx (the wire)

The parameter analysis,

- The IDLE State maintains the transmitter line, depends on the senddata trigger and resets the txdone
- o The STARTTX state transmits the start bit, loads the buffers with txbyte
- The TXING state sends data bits sequentially, shifts the buffer to next bit and counts the transmitted bits
- $\circ$  The TXDONE state sends the stop bit and the txdoneflag returning to the IDLE state

## The block diagram,



## The circuit diagram,



### The implementation,

```
Terminal-vsduser@vsdsquadron:-/VSDSquadr
File Edit View Terminal Tabs Help
vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$ Isusb
Command 'Isusb' from the usbutls (1:017-1)
Try: sudo apt install <deb name>
vsduser@vsdsquadron:-YSDSquadron_FM/uart_tx$ make clean
rm -rf top.blif top.asc top.bin top.json top.timings
vsduser@vsdsquadron:-YSDSquadron_FM/uart_tx$ make bulld
yosys -DCPU_FREQ=20 -q -p "synth_ice40 -abc9 -device u -dsp -top top -json top.json" top.v

nextpnr-ice40 --force --json top.json --pcf VSDSquadronFM.pcf --asc top.asc --freq 12 --up5k --package sg48 --opt-timing -q
icetime -p VSDSquadronFM.pcf -P sg48 -r top.timings -d up5k -t top.asc
// Reading input_.pcf file..
// Reading input_.pcf file..
// Reading input_asc file..
// Creating timing netlist..
Warning: timing analysis not supported for cell type HFOSC
Warning: timing analysis not supported for cell type RGBA_DRV
// Timing estimate: 20.50 ns (48.79 MHz)
icepack -s top.asc top.bin
vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron:-/VSDSquadron_FM/uart_tx$

vsduser@vsdsquadron
```

These are the steps to be run to ensure the implementation (the LED blinks red, blue, green)



the verification is done by installing picocom

the steps are,

sudo apt install picocom

make terminal

the output will be a continuous series of Ds

```
Teminal -industry/ordequations-0905/guarino, Private, in the control of the contr
```

This is depicted in the video



# WhatsApp Video 2025-03-31 at 08.59.0

FYI double click the video icon above to open.