# 2η Εργαστηριακή Άσκηση-ce430

Αξελός Χρήστος | AEM 1814 | caxelos@inf.uth.gr|16/11/16

### ΣΤΟΧΟΙ

- Υλοποίηση του πρωτοκόλλου επικοινωνίας UART, transmitter/receiver
- Χωρίζεται η διαδικασί σε 4 μέρη, 1ο η υλοποίηση του baud\_rat, 2ο η υλοποίηση του Transmitter, 3ο η υλοποίηση του receiver και 4ο η συνδεση των δύο για αποστολή 1-bit δεδομένων
- Δεν υλοποίησα το κομμάτι που το output γίνεται input στο 7-led-segment της fpga

### ПЕРІГРАФН

- Η ιεραρχεία των modules είναι η παρακάτω:



- Τα modules TransmittersSystemData και ReceiversSystemData καλούνται από το
  uart\_transmitter και uart\_receiver αντίστοιχα, ενεργοποιούν/απενεργοποιούν την
  αποστολή/λήψη δεδομένων
- Έκανα διαφορετικά αρχεία για το baud rate του αποστολέα και του παραλήπτη, γιατί πρέπει να χουν διαφορετικό fsm για ένα ίδιο baud select
- Για την προσομοίωση, έδωσα ως inputs στο uart\_receiver τα clock, reset εκτος απτο bit αποστολής απτον παραλήπτη, χωρις αυτό να επηρεάζει την περίπτωση αποστολέας και παραλήπτης να τρέχουν σε διαφορετικά ρολόγια

## MEPOΣ 1: Υλοποίηση Baud Controller

### ΥΛΟΠΟΙΗΣΗ BAUD CONTROLLER ΓΙΑ ΤΟΝ ΑΠΟΣΤΟΛΕΑ

- Για την ενεργοποίηση του σήματος αποστολής, χρησιμοποιώ έναν 18-bit μετρητή. Η max τιμή του μετρητή για κάθε baud select, τα σφάλματα και το πως προέκυψαν αναφέρονται στο αρχείο baud\_controller\_transmitter.v
- Αρχικά διαιρώ την συχνότητα 50MHz με το baud rate, το οποίο είναι σε bits/sec. Μετά στρογγυλοποιώ το αποτέλεσμα στον κοντινότερο ακέραιο και σημειώνω το σφάλμα. Το σφάλμα γίνεται μεγιστο(0.36) για τα 3 μικρότερα baud rate, ενώ όσο το baud rate αυξάνεται, το σφάλμα μειώνεται(ελαχιστο 0.02). Χρονικά το σφάλμα είναι σφάλμα\*περίοδος. Για παράδειγμα, όταν το baud rate είναι baud\_rate = 300bits/sec, για ρολόι των 50MHz, γίνεται αποστολή ανά 18'b101000101100001011 κύκλους
- Η υλοποίηση είναι σχετικά απλή, όπου σε ένα always block αυξάνω τον counter κατά ένα.
   Για σήμα reset στο κύκλωμα χρησιμοποιώ το σήμα Tx\_EN, αφού το baud controller λειτουργεί όσο γίνεται αποστολή

### ΥΛΟΠΟΙΗΣΗ BAUD CONTROLLER ΓΙΑ ΤΟΝ ΠΑΡΑΛΗΠΤΗ

- Μοιάζει με τον αντίστοιχο του αποστολέα, αλλά έχει διαφορετικές max τιμές των counter
- Χρησιμοποιώ έναν 16-bit μετρητή αντί για 18-bit, διότι ο παραλήπτης τρέχει σε ταχύτητα 16 φορές πιο γρήγορη απτόν αποστολέα. Δηλαδή για baud rate = 300bits/sec, για ρολόι 50MHz, μπορώ να κάνω δειγματοληψία ανα 14'b1010001011 κύκλους
- Επειδή στον παραλήπτη κάνω δειγματοληψία 3 φορές στα bit 7/16, 8/16, και 9/16 για να προκύψει το τελικό bit, χρησιμοποιώ τον counter reg [15:0] numOfSample με one hot κωδικοποίση και αρχική τιμή 16'b0000\_0000\_0000\_0001, τον οποίο κάνω shift κατα ένα ανά 14'b1010001011 κύκλους(για rate 300bits/sec, clk=50mhz), όταν δηλαδή μπορεί να γίνει δειγματοληψία. Μόλις ο numOfSample γίνει 16'b0000\_0001\_0000\_0000, κάνω το σήμα Rx\_ENABLE = 1 κάνω δειγματοληψία. Λεπτομέρειες για τον υπολογισμό του τελικού bit στέλνει ο αποστολέας εξηγούνται στο Μέρος 3.
- Η παραπάνω υλοποίηση με one hot με βοήθησε σαυτήν την περίπτωση για να δημιουργήσω το σήμα ελέγχου της δειγματοληψίας numOfSample[8]

Στιγμιότυπο ενεργοποίησης αποστολέα

|                           |                    |      |              |                     |              |               |                   |                |              | 17,494.33 ns    |                  |
|---------------------------|--------------------|------|--------------|---------------------|--------------|---------------|-------------------|----------------|--------------|-----------------|------------------|
| Name                      | Value              | 1    | 17,150 ns    | 17,200 ns           | 17,250 ns    | 17,300 ns     | 17,350 ns         | 17,400 ns      | 17,450 ns    | 17,500 ns       | 17,550 ns  1     |
| l <mark>₁ cik</mark>      | 0                  |      |              |                     |              |               |                   |                |              |                 |                  |
| 🌆 reset                   | 1                  |      |              |                     |              |               |                   |                |              |                 |                  |
| Transmitters baud control |                    |      |              |                     |              |               |                   |                |              |                 |                  |
| Tx_baud_select[2:0]       | 111                |      |              |                     |              |               | 111               |                |              |                 |                  |
| Tx_sample_ENABLE          | 0                  |      |              |                     |              |               |                   |                |              |                 |                  |
| ▶ 📷 counter[17:0]         | 000000000110110010 | (000 | 0000001 0000 | 0000001 \(000000000 | 1 0000000001 | 0000000001 00 | 00000001 🔾 000000 | 0001 000000000 | 1 0000000001 | . 0000000000 \0 | 00000000\0000000 |
| Receivers baud control    |                    |      |              |                     |              |               |                   |                |              |                 |                  |
| Rx_baud_select[2:0]       | 111                |      |              |                     |              |               | 111               |                |              |                 |                  |
| ample_ENABLE              | 0                  |      |              |                     |              |               |                   |                |              |                 |                  |
| ▶ Signature [13:0]        | 00000000000000     |      |              |                     |              |               | 00000000000000    |                |              |                 |                  |
| mumOfSample[15:0]         | 0000000000000001   |      |              |                     |              | 00            | 0000000000000001  |                |              |                 |                  |
|                           |                    |      |              |                     |              |               |                   |                |              |                 | السنساة          |

Στιγμιότυπο ενεργοποίησης δειγματοληψίας



# MEPOΣ 2: Υλοποίηση uart transmitter

### ΥΛΟΠΟΙΗΣΗ

- Κύριο module της υλοποίησης είναι το module uart\_transmitter.v, το οποίο συνδέεται εξωτερικά με το uart\_receiver.v, όπου στέλνει το bit επικοινωνίας, ενώ εσωτερικά καλεί τα modules TransmittersSystemData, οπου λαμβάνει byte πληροφορίας, το baud\_controller για τον χρονισμό της αποστολής κάθε bit στον receiver
- Για την έναρξη της επικοινωνίας, στέλνω το σήμα Tx\_BUSY από τον transmitter στο σύστημα του, για να του δείξει αν στέλνει δεδομένα στον receiver ή όχι
- Εφόσο ο transmitter δεν στέλνει στον receiver(Tx\_BUSY=0) και πρέπει να σταλθούν δεδομένα, τότε ενεργοποιεί το σήμα Tx\_EN σε ένα και παράλληλα στέλνει ένα byte πληροφορίας για να σταλθεί σειριακά στον receiver μέσω του σήματος Tx\_WR=1 για έναν κύκλο ρολογιού
- Ο receiver αναγνωρίζει το Tx\_EN=1 και στέλνει το startBit στον receiver, ενώ ειδοποιεί το σύστημα να μην στείλει ακομά το επόμενο byte(Tx\_BUSY=1) έως ότου στέλει το stop bit στον receiver και απενεργοποιήσει το Tx\_BUSY
- Στο uart\_transmitter.v, χρησιμοποιώ έναν 4bit counter καταστάσεων με αρχική τιμή counter = 4'b0000 και αυξάνεται κατά ένα. Για counter=0, στέλνεται το startBit, για 1μεχρι8 τα δεδομένα, για 9 το parity bit και για 10 το stop μπιτ. Αλλαγές στις καταστάσεις γίνονται μόνο όταν ο αποστολέας είναι ενεργοποιημένος και το σήμα Tx\_enable είναι ενεργοποιημένο. Ο υπολογισμός του parity bit προκύπτει απτην συνθήκη if (data = 1) parity = ~parity
- Παρακάτω φαίνονται στιγμιότυπα αποστολής του ψηφίου 1 και φόρτωσης νέας 8άδας απτο σύστημα για αποστολή:



Στο παραπάνω σχήμα, την χρονικη στιγμη 52,300ns ενεργοποιείται το Tx\_ENABLE και στον επόμενο κύκλο στέλνεται το bit 1. Ταυτόχρονα μεταβάλλεται και parity bit και ο sampleCounter. Τα υπόλοιπα σήματα δεν μεταβάλλονται αφού συνεχίζεται η αποστολή προς τον δέκτη

Παρακάτω φαίνεται στιγμιότυπο αποστολής του stop bit και αποστολής από το σύστημα της νέας 8αδας bit



- Την χρονική στιγμή 191,500.00 ns, το σύμα Tx\_sample\_ENABLE γίνεται 1 και στον επόμενο κύκλο στέλνεται στέλνεται το Tx\_EN γίνεται 0 και σταματά η επικοινωνία με τον δέκτη. Ταυτόχρονο το Tx\_WR γίνεται 1 για να σταλθούν στον επόμενο κύκλο δεδομένα απτο σύστημα. Την στιγμη 191,589, το Tx\_DATA γίνεται 10001001 για να σταλθούν αργότερα στον παραλήπτη
- Την χρονική στιγμή 191,500.00 ns, το σύμα Tx\_sample\_ENABLE γίνεται 1 και στον επόμενο κύκλο στέλνεται στέλνεται το Tx\_EN γίνεται 0 και σταματά η επικοινωνία με τον δέκτη. Ταυτόχρονο το Tx\_WR γίνεται 1 για να σταλθούν στον επόμενο κύκλο δεδομένα

## MEPOΣ 3: Υλοποίηση uart receiver

### ΥΛΟΠΟΙΗΣΗ

- Κύριο module είναι το uart\_receiver.v, το οποίο δέχεται ένα bit πήροφορίας απτόν δέκτη, ενώ καλεί το σύστημα(ReceiversSystemData.v) για την αποθηκευσω των byte
- Αρχικά ανιχνεύω το startBit την ίδια στιγμή που στέλνεται χωρίς καθυστέριση),
   χρησιμοποιώντας 2 flip flop όπως με το debounce για να ανιχεύσω την αλλαγή
- Μόλις ανιχνευτεί το startBit, ενεργοποιείται ο baud\_controller του receiver που αναφέρεται πιο πριν, έχοντας ως σήμα reset το Rx\_EN=1
- Για την δειγματοληψία χρησιμοποιώ τα 3 κεντρικότερα bit



- Υπάρχουν αντίστοιχα σήματα στον δέκτη, Rx\_EN και Rx\_Sample\_EN, για ενεργοποίηση του δέκτη και της δειγματοληψίας
- Στο uart\_receiver.v κάνω τους ελέγχους για την εγκυρότητα των δεδόμενων, αν υπολογιστεί λάθως το parityBit και αντι για 1 το stopBit είναι 0. Στην περίπτωση αυυτή ενεργοποιώ τα σήματα Rx\_PERROR και Rx\_FERROR. Σε αντίθετη περίπτωση ενεργοποιείται το σήμα Rx\_VALID
- Η διαδικασία λήψης ξεκινά με την αποστολή του startBit από τον δέκτη στο σύστημα. Μόλις ανιχνευτεί, ενεργοποιείται το σήμα Rx\_EN και ξεκινά η λειτουργία του baud\_controller. Το Rx\_EN

παραμένει 1 όσο γίνεται δειγματοληψία. Μόλις τελειώσει η δειγματοληψία του stopBit, το Rx\_EN γίνεται 0 και κάνουμε reset τον baud\_controller

- Στο παρακάτω σιγμιότυπο φαίνεται η ανίχνευση του startBit από τον δέκτη την χρονική στιγμή 17,540ns. Στον αμέσως επόμενο κύκλο ενεργοποιείται το Rx\_EN και ξεκινά η δειγματοληψία



• Ιδιαίτερη περίπτωση είναι η αποστολή του stopBit και απενεργοποίηση του δέκτη



Την χρονική στιγμή 206,180ns γίνεται η δειγματοληψία του stopBit 1, ενώ τον αμέσως επόμενο κύκλο ενεργοποιείται το σήμα Rx\_Valid για αποστολή δεδομένων στην μνήμη του συστήματος.
 Οι 2 κύκλοι αντί για έναν που είναι ενεργοποιημένο το σήμα δεν επηρρεάζει την λειτουργία του δέκτη, διότι προηγείται η απενεργοποίηση του δέκτη πρώτα(Rx\_VALID). Την στιγμή 206,250ns που σταματά την δειγματοληψία ο δέκτης, γίνεται η αποστολή της 8αδας bit στο σύστημα

# MEPOΣ 4: Σύνδεση uart\_receiver με τον transmitter

- Η σύνδεση των 2 κυκλωμάτων γίνεται καλώντας απτον transmitter ένα instance του receiver με εισόδους το RxD. Για την προσομοίωση μόνο περνάω και τα clock, reset απτόν transmitter στον receiver
- Τα συστήμα πλαισίου δοκιμής στην εκφωνηση της άσκησης είναι τα Συστήματα των transmitter και receiver. Παρακάτω φαίνεται η αποστολή λήψη μυνημάτων με το Tx\_DATA[0:7] να είναι η τιμή του transmitter, ενώ ο transmitter το λαμβάνει αυτό 2 κύκλους μετά, στο outToLEDs[0:7]

|                        |                                  | 100.00 ns                               |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
|------------------------|----------------------------------|-----------------------------------------|-------------------|----------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------|------------------|--------------|
| Name                   | Value                            | 0 ns                                    | 200,000 ns        | 400,000 ns                                                                       | 600,000 ns                             | 800,000 ns                                   | 1,000,000 ns                             | 1,200,000 ns                                                                     | 1,400,000 ns     | 1,600,0      |
| 🍱 clk                  | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| _                      | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| П <sub>®</sub> тх_виsу | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| Tx_sample_ENABLE       | 0                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  | 1111         |
| Tx_baud_select[2:0]    | 111                              |                                         |                   |                                                                                  |                                        |                                              | 111                                      |                                                                                  |                  |              |
| 106                    | 10101010                         | 10101010                                | 10001001          | 01010101                                                                         | 11001100                               | 10101010                                     | 10001001                                 | 01010101 1                                                                       | 1001100 10       | 101010       |
| 100                    | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| 100 -                  | 0                                |                                         |                   |                                                                                  | :                                      | 1                                            | :                                        | :                                                                                |                  |              |
| ¹₽ TxD                 | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| Tx_BUSY_REG            | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
|                        | 1010                             | 000000000000000000000000000000000000000 | XXXXXXXXXXXXXXXXX | <b>\$</b> \$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$ | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | <i></i> 000000000000000000000000000000000000 | \$00000000000000000000000000000000000000 | <b>\$</b> \$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$\$ | XXXXXXXXXXXXXXXX | <b>XXXXX</b> |
| 🖟 parity               | 0                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| receiver               |                                  |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| _                      | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| •                      | 1                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| / Odtrozebijom         | 11111111<br>nyTestBench/uart Tx/ | 1111                                    |                   | 10101010                                                                         | 10001001                               | 01010101                                     | 11001100                                 | 10101010                                                                         | 10001001         | 01010101     |
| ta startbitround       | ly lestberich/dart_ix/           | uart_receivero/k3D/                     | eset              |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
|                        | 0                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| -                      | 0                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| -                      | 0                                |                                         |                   | :                                                                                | :                                      | :                                            |                                          |                                                                                  |                  |              |
|                        | 111                              |                                         |                   |                                                                                  |                                        |                                              | 111                                      |                                                                                  |                  |              |
| <b>■</b> =             | 0                                |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
| ▶ 🚮 dataCounter[1:0]   | 11                               | 11                                      | 01                | 11                                                                               | 01                                     | 11                                           | 01                                       | 11                                                                               | 01               | 11           |
|                        |                                  |                                         |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |
|                        |                                  | X1: 100.00 ns                           |                   |                                                                                  |                                        |                                              |                                          |                                                                                  |                  |              |