DURAND Clovis E2
MARINO Xavier Mai 2017

## PR 214

# PROJET THÉMATIQUE CONCEPTION D'UN MODULE EN VHDL POUR LA GESTION D'UN PMOD OLEDRGB DIGILENT SUR FPGA



ENSEIRB-MATMECA

Bordeaux - Talence

Encadrant : Yannick Bornat

## Table des matières

| Ίŧ           | able                              | des figures                                                                                         | 2  |  |  |  |  |
|--------------|-----------------------------------|-----------------------------------------------------------------------------------------------------|----|--|--|--|--|
| 0            | Int                               | roduction                                                                                           | 4  |  |  |  |  |
|              | 0.1                               | Segmentation et déroulement du projet                                                               | 4  |  |  |  |  |
| 1            | Pm                                | od OLEDrgb                                                                                          | 5  |  |  |  |  |
| <b>2</b>     | Fonctionnement du Pmod OLEDrgb    |                                                                                                     |    |  |  |  |  |
|              | 2.1                               | Liaison UART et outils                                                                              | 6  |  |  |  |  |
|              | 2.2 Séquence d'initialisation     |                                                                                                     |    |  |  |  |  |
|              | 2.3                               | Envoi de données                                                                                    | 6  |  |  |  |  |
| 3            | Module de gestion du Pmod OLEDrgb |                                                                                                     |    |  |  |  |  |
|              | 3.1                               | Module de transmission de données destinées à un protocole d'envoi SPI                              | 7  |  |  |  |  |
|              |                                   | 3.1.1 Principe de fonctionnment du module                                                           | 7  |  |  |  |  |
|              |                                   | 3.1.2 Description et fonctionnement technique                                                       | 8  |  |  |  |  |
|              | 3.2                               | Contrôle d'envoi de commandes et de données                                                         | 9  |  |  |  |  |
|              |                                   | 3.2.1 Principe de fonctionnement de la machine d'état                                               | 9  |  |  |  |  |
|              |                                   | 3.2.2 Description de la machine d'état                                                              | 11 |  |  |  |  |
| 4            | Coı                               | nclusion                                                                                            | 15 |  |  |  |  |
| $\mathbf{R}$ | éfére                             | ences                                                                                               | 16 |  |  |  |  |
| $\mathbf{T}$ | able                              | e des figures                                                                                       |    |  |  |  |  |
|              | 1                                 | Le Pmod OLEDrgb de Digilent utilisé dans ce projet                                                  | 5  |  |  |  |  |
|              | 2                                 | Table de correpsondance des pins du Pmod OLED<br>rgb [3]                                            | 5  |  |  |  |  |
|              | 3                                 | Chronogramme simplifié du fonctionnement du protocole SPI [4] $\ \ldots \ \ldots \ \ldots \ \ldots$ | 7  |  |  |  |  |
|              | 4                                 | Chronogramme du module SPI_controller                                                               | 9  |  |  |  |  |
|              | 5                                 | FSM du module de contrôle du Pmod OLEDrgb                                                           | 10 |  |  |  |  |
|              | 6                                 | Chronogramme représentant le rôle de flag_en                                                        | 12 |  |  |  |  |
|              | 7                                 | Évolution de data_out en dfonction des différents paramètres                                        | 12 |  |  |  |  |
|              | 8                                 | Chronogramme représentant l'ensemble de la séquence synthétisée                                     | 12 |  |  |  |  |
|              | 9                                 | Zoom sur l'envoi des commandes d'initialisation                                                     | 13 |  |  |  |  |

| PR214 | Rapport Projet Thématique                       |    |  |
|-------|-------------------------------------------------|----|--|
|       |                                                 |    |  |
| 10    | Zoom sur la première commande d'initialisation  | 13 |  |
| 11    | Schematic du module de contrôle du PMOD OLEDrob | 1/ |  |

#### 0 Introduction

Au cours de ce projet, un objectif clair nous a été fixé : afficher une image sur un écran OLED couleur d'une résolution 96 x 64, connecté sur une carte Nexys4 de Digilent. Cet écran est monté sur un Pmod (extensions de cartes d'interfaces Entrées/Sorties de chez Digilent). Le cœur du projet est de comprendre comment le Pmod communique avec la carte Nexys4 et de lui envoyer les informations nécessaires à son fonctionnement, telle que la séquence de commandes initialisation de l'écran ou les données de l'image que l'on souhaite afficher.

#### 0.1 Segmentation et déroulement du projet

Le projet a donc été séparé en plusieurs parties.

D'abord, l'étude du composant et de sa datasheet. En effet, le Pmod de Digilent possède sa propre datasheet, mais sur celui-ci est monté un contrôleur spécifique à l'écran OLED : le SSD1331. Il a donc été nécessaire d'appréhender comment celui-ci fonctionnait.

Ensuite, nous avons élaboré un programme d'initialisation et d'utilisation de l'écran. Un microprocesseur basique à été implémenté sur FPGA, nous compilions des programmes écrit en langage C, et nous testions le Pmod de cette façon. Ainsi, en se basant sur ce qu'on a appris des datasheet, nous avons mis au point une séquence de commandes pour initialiser l'écran et pour lui envoyer, via la liaison UART de la carte Nexys4 les données bitmap de l'image. Le but de ces programmes est avant tout de comprendre ce qui doit être décrit en VHDL pour le module de gestion de notre écran OLEDrgb, et ils ne constituent pas notre produit fini.

Enfin, nous avons développé notre module de gestion du Pmod en VHDL. L'environnement de travail choisi est Vivado de Xilinx. En appliquant une ingénierie inverse aux programmes C développés en amont, une architecture précise à été définie, et la conception de tous les blocs composant notre module ont été écrits.

En pratique, l'étude de la datasheet à été un travail permanent, et à donc été faite en parallèle au développement de nos programmes C et de nos descriptions VHDL. Les points de fonctionnement de nos composant qui semblent pour certains relativement simples en apparence mais nous ont posé problème tout de même quand nous avancions dans nos études. A chaque problème de la sorte, il a fallu revoir les points concernés de la datasheet à plusieurs reprises. Pour les problèmes plus complexes, comme la gestion de la communication entre la carte et le Pmod, la datasheet à été d'une grande aide.

## 1 Pmod OLEDrgb

Un Pmod est un périphérique ou extension destinée à être utilisé avec des cartes programmables telles que la Nexys4 de Digilent que nous utilisons dans ce projet. Le Pmod sur lequel notre travail se concentre ici est l'OLEDrgb, un écran OLED (Organic Light-Emitting Diode) [1] d'une résolution de 96 x 64 pixels capable d'afficher 65k couleurs.



FIGURE 1 – Le Pmod OLEDrgb de Digilent utilisé dans ce projet

Pour communiquer avec la carte mère, ce périphérique utilise le protocole SPI (Serial Periphéral Interface Bus). Avec ce protocole, on peut envoyer par paquet les informations et commandes nécessaires au fonctionnement de notre écran OLED. Un contrôleur Solomon Systech SSD1331 [2] est employé pour communiquer entre le Pmod support et le composant de l'écran. Grâce à celui-ci, les commandes envoyées sont exploités et traités. De plus, lorsque que ce contrôleur reçoit des informations, il les stocke dans la RAM de l'écran. Ce contrôleur possède tout un panel de commandes qui permettent d'interagir avec l'écran. (i.e. dessiner un rectangle, un pixel, etc.)

Ce Pmod à un connecteur 12 broches qui se branche sur la carte principale :

|     | Header J1 |                     |     |   |        |                           |  |  |  |  |
|-----|-----------|---------------------|-----|---|--------|---------------------------|--|--|--|--|
| Pin | Signal    | Description         | Pin | 1 | Signal | Description               |  |  |  |  |
| 1   | CS        | Chip Select         | 7   |   | D/C    | Data/Command Control      |  |  |  |  |
| 2   | MOSI      | Master-Out-Slave-In | 8   |   | RES    | Power Reset               |  |  |  |  |
| 3   | NC        | Not Connected       | 9   |   | VCCEN  | Vcc Enable                |  |  |  |  |
| 4   | SCK       | Serial Clock        | 10  |   | PMODEN | Vdd Logic Voltage Control |  |  |  |  |
| 5   | GND       | Power Supply Ground | 11  |   | GND    | Power Supply Ground       |  |  |  |  |
| 6   | VCC       | Power Supply (3.3V) | 12  |   | VCC    | Power Supply (3.3V)       |  |  |  |  |

FIGURE 2 – Table de correpsondance des pins du Pmod OLEDrgb [3]

- 2 Fonctionnement du Pmod OLEDrgb
- 2.1 Liaison UART et outils
- 2.2 Séquence d'initialisation
- 2.3 Envoi de données

## 3 Module de gestion du Pmod OLEDrgb

Une fois les différentes séquences de commandes mises en place, nous sommes passé à la description en langage VHDL du module de gestion de l'écran OLED. Ce developpement s'est scindé en la description de quatre modules :

- SPI\_controller : Ce module genère l'ensemble des signaux nécessaires à la transmission d'informations par le biais du protocole SPI.
- MEM\_init : Cette source est une ROM contenant les commandes d'initialisations du microcontrôleur.
- RAM : Cette RAM contient les données de l'image à afficher sur l'écran, elle est à l'image de la RAM présente dans le microcontrôleur. Cependant elle a été décrite avec deux accès pour permettre son utilisation par un utilisateur extérieur.
- FSM : Cette machine d'état conditionne l'envoi des données d'initialisation stockées dans la ROM vers le module SPI, puis celui de l'image stockée dans la RAM.

Les deux mémoires présentées plus haut sont toutes deux composées de données sur 16 bits. Ce format a été choisi car il correspond, pour la RAM, au format de données pour un pixel de l'écran. La RAM est combinatoire en lecture et séquentielle pour l'écriture. L'implémentation de deux horloges distinctes, même si elles sont toutes deux reliées à la même horloge de fonctionnement de la carte, a été nécessaire à la synthèse d'une RAM à double entrée. La ROM quant à elle est purement combinatoire.

#### 3.1 Module de transmission de données destinées à un protocole d'envoi SPI

#### 3.1.1 Principe de fonctionnment du module

Le protocole de communication SPI permet la tranmission de bus de données de 8 bits par le signal MOSI (Master Out Slave In), c'est le signal d'horloge sclk qui permet la lecture des différentes bits du MOSI. En effet, c'est le déclenchement de huit périodes d'horloge qui permet au contrôleur de détecter l'envoi de données. Le protocole SPI possède également une entrée de contrôle CS (Chip Select) et un signal de retour MISO (Master In Slave Out). L'ensemble des signaux sont représentés dans la figure suivante, représentant la caractéristique simplifiée d'un envoi de données par SPI.



FIGURE 3 – Chronogramme simplifié du fonctionnement du protocole SPI [4]

Dans le cas du microcontrôleur SSD1331, la lecture des bits de données est faite sur front montant de sclk. Nous avons pu également tester, lors de notre phase de recherche, qu'aucun passage à l'état logique haut n'était nécessaire pour l'entrée CS entre deux envois de données. Enfin, c'est le bit de poids fort qui est envoyé en premier au contrôleur lors de la transmission d'un octet. À l'aide de l'ensemble des ces informations nous avons pu décrire le module explicité plus haut.

La source prend en entrée les signaux clk et reset communs à tous bloc séquentiels, la donnée d'entrée sur 8 bits, ainsi qu'un signal logique d'activation qui dure une période d'horloge. En sortie, sont générés les signaux nécessaires à la communication en SPI, aisni qu'un signal logique busy qui permettra par la suite de temporiser l'envoi de données.

D'après la datasheet du microcontrôleur, la fréquence de fonctionnment du module SPI ne doit pas dépasser les 6 MHz.

$$f_{max} = 6 \text{ Mhz}$$
  
 $\Rightarrow T_{min} = \frac{1}{6} \mu \text{s}$   
 $\Rightarrow T_{haut_{min}} = \frac{1}{12} \mu \text{s} \sim 83.33 \text{ ns}$ 

Nous avons donc choisi, le premier entier paire, afin d'avoir un signal sclk de rapport cyclique 0.5, satisfaisant la condition précédente, comme facteur de division de la fréquence de fonctionnement principale. La fréquence de fonctionnement de la carte NEXYS4 étant 100 Mhz, l'entier choisit est donc 18.

#### 3.1.2 Description et fonctionnement technique

La description se subdivise en plusieurs processus séquentiels qui génèrent chacun une sortie du module en fonction des entrées.

- sclk: À chaque détection d'un signal d'enable, huit périodes d'horloge, d'une fréquence de 100/18 Mhz, sont générés par le biais de deux compteurs. Le premier, cpt\_sclk, est majoré par la constante définie plus haut et impose la fréquence de sclk. Le second, cpt\_octet, dénombre le nombre de coup d'horloge déjà générés, il est donc majoré par 8. Cette horloge permettra de séquencer l'envoi successif des 8 bits de données. Le niveau de repos de l'horloge devant être reçu par le microcontrôleur étant le niveau haut et la lecture du bit de donné étant effectuée sur front montant de l'horloge, il nous faut envoyer, en sortie du module, l'inverse du signal ainsi généré.
- SPI\_busy : Le signal d'occupation reste au niveau haut durant les huit périodes "actives" de sclk, le reste du temps il est maintenu à 0.

• MOSI: À chaque détection d'un signal d'enable, la donnée d'entrée est sauvegardée dans une registre à décalage. Ce registre à décalage est incrémenté à chaque front montant de sclk et c'est sa valeur qui est lue afin de mettre à jour le signal de sortie. Dans la source SPI\_controller.vhd, le dernier processus, qui permet l'actualisation du signal MOSI, a été décrit de façon séquentielle. Le signal sdata\_in étant déjà séquentiel et le signal de sortie seulement lu lors de l'activation de sclk, le processus aurait pu être décrit de manière combinatoire. Cependant, la fréquence de fonctionnement du SPI étant très faible devant celle de la carte, ce choix n'a très peu d'impact sur l'optimisation du temps de transmission et aucun sur le bon fonctionnement du module.

Une fois la description terminée, nous avons pu déboguer le code à l'aide de l'outil de simulation de Vivado, duquel est tiré le chronogramme présent en figure X, représentant le fonctionnement du module.



FIGURE 4 – Chronogramme du module SPI\_controller

#### 3.2 Contrôle d'envoi de commandes et de données

#### 3.2.1 Principe de fonctionnement de la machine d'état

Une fois le module de communication SPI terminé, nous nous sommes penché sur la machine d'état qui aura pour rôle d'ordonnancer les différentes étapes du processus d'initialisation, puis l'envoi des données de l'image. En effet, la séquence d'initialisation déterminée plus tôt peut être subdivisée en plusieurs étapes successives :

- Le changement d'état des différentes pins de contrôles du Pmod (DC, RES, VCCEN et PMODEN), séparé ou non par des temporisations. Ces étapes occuperons les états 1 à 6, puis 10 de la machine d'état.
- Une séquence d'envoi de commandes par le biais du protocole SPI. Ces commandes, au nombre de quarante-quatre, sont stockés dans la mémoire évoquée plus haut.
- Et enfin la commande d'allumage de l'écran qui est la dernière étape de l'initialisation.

Nous avons ensuite fait le choix de faire suivre l'initialisation par un tracé de rectangle en utilisant les différentes commandes du microcontrôleur, afin de vérifier le bon focntionnment de la séquence précédente. En effet, la RAM du Pmod étant nettoyée par nos précédentes utilisation, nous n'avions aucun retour visuel

de l'allumage de l'écran.

Enfin, la dernière étape consiste à venir chercher les données de l'image de la RAM de notre module vers celle du contrôleur.La figure X illustre la machine d'état ainsi mise en place, dans un schéma simplifié, sans les différentes conditions de changement d'état.



FIGURE 5 – FSM du module de contrôle du Pmod OLEDrgb

#### 3.2.2 Description de la machine d'état

La machine d'état est composée d'un processus séquentiel qui détermine l'état présent et d'un processus combinatoire qui détermine l'état futur en fonction de l'état présent, des entrées du module et d'un ensemble de signaux internes à la source. L'ensemble des processus qui suivent les deux premiers, sont destinés à générer l'ensemble des signaux de sorties et internes de la FSM, c'est sur ces derniers que nous allons nous pencher.

#### $\rightarrow$ Les compteurs

- Les temporisations : Afin de satisfaire les différentes temporisations nécessaires à la séquence d'initialisation, nous avons synthétisé trois compteurs permettant la modélisation de trois temporisations d'une durée de 500 ms, 150 ms et 15 μs. Trois processus permettent donc d'incrémenter les différents compteurs dans les états correspondants. Ces derniers ne peuvent être quittés seulement lorsque le compteur atteind sa valeur maximale. Tout come pour la synthèse de sclk, la valeur maximale des compteurs est déterminée grâce à la fréquence de fonctionnment de la carte NEXYS 4.
- Les indices de lecture : L'état numéro 7 de la machine d'état correspond au temps d'occupation du module lors de l'envoi d'un octet en SPI. Entre deux envois de données et donc deux passages à l'état 7, on vient incrémenter l'indice de lecture de la mémoire en cours de lecture, c'est l'état 9 qui se charge de cela. L'état 8 quant à lui, permet l'incrémentation d'un compteur modulo 2 qui désigne successivement les deux octets compris dans une case mémoire. Ainsi, trois processus incrémentent respectivement les compteurs read\_idx\_mem, read\_idx\_ram et cpt\_read. À noter que le compteur read\_idx\_mem possède deux valeurs d'arrêt, puisqu'une partie la mémoire est utilisée pour stocker les commandes d'initialisation et une autre pour les commandes de tracé de rectangle. Ces commandes peuvent d'ailleurs être inhibées dans le code vhdl car inutiles à l'initialisation.

#### $\rightarrow$ Les signaux de sortie

- Vers le Pmod : Les processus qui suivent ont pour rôle de set ou reset les signaux de contrôle du Pmod DC, RES, VCCEN et PMODEN, en fonction de l'état présent.
- Vers le module SPI: Enfin, les trois derniers processus permettent la bon focntionnement du module SPI. En effet l'un d'eux génère le signal data\_en nécessaire à la tranmission de donnée par le module SPI, ce signal est condionné selon un signal flag\_en synthétisé juste avant. Ce dernier est presque à l'image du signal SPI\_busy, cependant il passe au niveau haut un coup d'horloge avant SPI\_busy, ce qui permet à data\_en d'être au niveau haut seulement pendant une période d'horloge. Comme l'illustre la figure X.



FIGURE 6 – Chronogramme représentant le rôle de flag\_en

Le dernier processus est un processus combinatoire, qui, en fonction de DC et cpt\_read, vient relier la sortie de la FSM et donc l'entrée du module SPI, au bon octet de la ROM ou de la RAM. Ce fonctionnnment est illustré dans la figure qui suit.



FIGURE 7 – Évolution de data\_out en dfonction des différents paramètres

On peut voir que, dès que l'envoi de commandes passe en envoi de données, la sortie est reliée à la RAM et non plus à la ROM. Les deux octets de chaque case mémoire sont bien lus grâce au changement d'état de cpt\_read.

Une fois l'ensemble des composants décrits, nous avons pu les instancier et ainsi simuler le fonctionnement globale du module de gestion de l'écran.



FIGURE 8 – Chronogramme représentant l'ensemble de la séquence synthétisée

Sur la figure précente on peut voir au niveau du signal MOSI les différentes étapes d'initialisation. Après environ 150 ms nécessaire à la prise en compte des commutations des signaux de commmandes, au premier pic se trouve l'envoi des commandes d'initialiation via le protocole SPI. Ensuite, après de nouveau environ 150 ms, se trouve le second pic qui correspond à la commandes d'allumage. Enfin, après un temps d'attente de 500 ms, on peut relever un travail continu au niveau du signal MOSI, il s'agit de l'envoi des commandes de tracé du rectangle, puis le rafraichissement continu de l'écran.

Dans les deux figures qui suivent, qui sont un zoom de la précédente, on peut mieux se rendre compte du protocole d'envoi des commandes durant l'initialisation et ainsi vérifier son fonctionnnement.



Figure 9 – Zoom sur l'envoi des commandes d'initialisation



FIGURE 10 – Zoom sur la première commande d'initialisation



 ${\tt FIGURE~11-Schematic~du~module~de~contr\^ole~du~PMOD~OLEDrgb}$ 

# 4 Conclusion

## Références

[1] OLED Wikipedia page for definitions

https://en.wikipedia.org/wiki/OLED

[2] Datasheet du SSD1331, contrôleur de matrice de points OLED/PLED
 https://www.parallax.com/sites/default/files/downloads/28087-SSD1331 1.2.pdf

[3] OLEDrgb Pmod reference sheet and Datasheet

Pmod OLEDrgb Reference Manual.

Digilent, Revised April 26, 2016

[4] Digilent SPI protocol information

https://reference.digilentinc.com/pmod/communication protocols/spi

[5] Definition of Serial Peripherals Interface Bus and how it works

 $https://web.archive.org/web/20150413003534/http://www.ee.nmt.edu/\tilde{t}eare/ee308l/datasheets/S12SPIV3.pdf$ 

Motorola, Inc., Original Release Date: January 21, 2000, Revised: February 04, 2003