## SETR-E2 Conception de circuits

## Document de conception contrôleur d'interruptions

Louison Gouy et Mathis Briard November 2, 2022





## ÉCOLE POLYTECH DE NANTES ELECTRONIQUE ET TECHNLOGIE NUMÉRIQUE

Enseignant référent : Sébastien LE NOURS

Abstract

Abstract

## Contents

|   | 1 Introduction 1.1 Contextualisation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |      | <br> | . 5                                                                        |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|------|----------------------------------------------------------------------------|
| 2 | 2 Cahier des charges 2.1 Objectif du circuit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <br><br> |      | <br> | . 6                                                                        |
| 3 | 3.1 Caractérisation de l'environnement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <br>     | <br> | <br> | <ul><li>. 14</li><li>. 16</li><li>. 18</li><li>. 19</li><li>. 19</li></ul> |
| 4 | 4 Conclusion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |      |      | 20                                                                         |
| A | Acronyms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |      |      | 21                                                                         |
| 5 | 5 Appendix                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |      |      | 23                                                                         |
|   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |      |      |                                                                            |
| L | List of Figures  1 Schéma de câblage de l'IP à concevoir, du contrôleur mémoire 2 Entrées et sorties de l'IP à concevoir 3 Chronogramme spécification du bus 4 Chronogramme spécification signal IT au processeur 5 Chronogramme spécification 2 signaux IT cas 1 6 Chronogramme spécification 2 signaux IT cas 2 7 Planification du projet avec ses jalons 8 Comportement du système à microprocesseur 9 Comportement de l'entité source d'interruptions 10 Entrées et sorties du circuit à concevoir 11 Premier automate du contrôleur d'interruptions 12 Second automate du contrôleur d'interruptions 13 Organisation des registres internes 14 Organisation du registre de branchement | <br>     |      |      | . 7<br>. 9<br>. 10<br>. 11<br>. 11<br>. 13<br>. 14<br>. 14<br>. 17<br>. 17 |

| 4 | Synthèse des spécifications fonctionnelles | 16 |
|---|--------------------------------------------|----|
| 5 | Vecteurs d'interruptions                   | 18 |

## Résumé

La méthodologie de conception de systèmes électroniques est une discipline essentielle lorsqu'il s'agit, dans le cadre d'une future carrière d'ingénieur, de réaliser un produit répondant aux besoins d'un client. Et ce domaine est d'autant plus indispensable dans un monde où les systèmes numériques sont de plus en plus complexes et leur conceptions demandent une bonne structuration et une réelle méthodologie. Ce rapport s'inscrit dans la présentation d'une conception d'un controlleur d'interruption par l'utilisation d'une méthode précise, applicable dans un ensemble de secteurs d'activités comme l'automobile, le médical, l'aéronautique, maritime, que ce soit dans le civil ou le militaire.

#### 1 Introduction

#### 1.1 Contextualisation

La formation ETN (Électronique et technologies numériques) offerte par l'école polytechnique de l'Université de Nantes propose d'aborder diverses branches de l'électronique, du traitement du signal au systèmes à microprocesseur en passant par l'électronique analogique des hautes-fréquences. Cet ensemble de domaines techniques nécessite des compétences en matière de méthodologie de conception. Ce rapport s'inscrit dans la conception d'un appareil de marquage routier avec la méthode MCSE. La méthode MCSE (Méthode de conception des systèmes électroniques), née à Ireste par l'impulsion de Jean-Paul Calvez, cette méthode a été implantée au sein d'un outil nommée CoFluent rachetée par Intel® depuis 2011. Cette méthode fait désormais partie de la culture de la formation et constitue l'outil de conception premier de l'ingénieur ETN.

Ce rapport se décompose en diverses parties. Il s'agira dans un premier temps de rappeler le cahier des charges de la conception ....... Pour l'ensemble de ce rapport, les diverses phases de spécifications et conceptions s'appuient sur les deux ouvrages de Jean-Paul Calvez. [1]

Ce travail de conception à pour but de placer les étudiants dans un contexte industriel. Le cahier des charges fourni prend la forme d'un exemple réel où les spécifications du client sont exprimées.

### 2 Cahier des charges

Cette partie présente le cahier des charges du périphérique. Elle intègre les quelques points fournis par le sujet auquel s'ajoutent les contraintes imaginées par les étudiants.

#### 2.1 Objectif du circuit

Le contrôleur d'interruptions a pour rôle d'informer le processeur sur l'occurrence d'une interruption valide. Il fournira alors l'adresse de la prochaine instruction à exécuter.

#### 2.2 Fonctionnalités attendues

Les fonctions de service du circuit sont :

- 1. Masquer et démasquer chaque interruption individuellement
- 2. Contenir et permettre la configuration du vecteur d'exception
- 3. Permettre de configurer la priorité des interruptions
- 4. Ne fournir au Central Processing Unit (CPU) que les interruptions valides
- 5. Prendre en compte les priorités dans la génération des demandes au CPU

#### 2.3 Utilisation du circuit

Il s'agit ici de donner l'utilisation du circuit en présentant le schéma de câblage du contrôleur d'interruptions ainsi que la définition des signaux logiques d'entrées et sorties. L'Intellectual property (IP) à concevoir s'interface avec le bus de données, le bus d'adresses ainsi qu'un ensemble de signaux de temporisation et de contrôle. Il est possible de retrouver des signaux de temporisation comme le nWAIT et des signaux de contrôle comme le nRST ou le RnW. Leur rôle est présenté table (1).



Figure 1: Schéma de câblage de l'IP à concevoir, du contrôleur mémoire et du processeur

Le contrôleur d'interruptions est également câblé avec plusieurs autres IPs du SoC. Il y a par exemple le processeur avec lequel le signal nIT\_CPU est commun. D'autre part le contrôleur mémoire est connecté avec le contrôleur d'interruptions par le signal nCS\_IT. L'ensemble des périphériques du SoC peut également envoyer un signal d'interruption représenté par nIT\_ . . . .

Le schéma présenté ci-dessus ne précise pas le sens des signaux. Il n'est donc pas possible de savoir quelles sont les entrées et sorties du contrôleur d'interruptions. Également, les noms des 4 interruptions externes et des 11 autres provenant de divers périphériques ne sont pas donnés. La figure 3 et le tableau 1 présentent les entrées et sorties du point de vue de l'IP à concevoir ainsi que le rôle de chaque signaux.



Figure 2: Entrées et sorties de l'IP à concevoir

| Nom           | Sens             | Rôle                                                |
|---------------|------------------|-----------------------------------------------------|
| clk           | Entrée           | Signal d'horloge                                    |
| nRST          | Entrée           | Signal de réinitialisation                          |
| addr          | Entrée et sortie | Bus d'adresses                                      |
| d_bus         | Entrée et sortie | Bus de données                                      |
| nCS_IT        | Entrée           | Signal de sélection du périphérique en cas          |
|               |                  | d'opérations de lecture ou d'écriture               |
| nAS           | Entrée           | Signal indiquant la présence d'une valeur           |
|               |                  | sur le bus d'adresse                                |
|               |                  | Signal d'écriture ou de lecture                     |
| RnW           | Entrée           | 0 : écriture                                        |
|               |                  | 1: lecture                                          |
|               |                  | Signal indiquant la structure de la mémoire         |
| nBE0          | Entrée           | 0: little-endian                                    |
|               |                  | 1 : big-endian                                      |
|               |                  | Signal indiquant la taille de la donnée             |
| nBE1          | Entrée           | 0:8 bits                                            |
|               |                  | 1: 16 bits                                          |
|               |                  | Signal pour le processeur avertissant               |
| nIT_CPU       | Sortie           | qu'une interruption est demandée de la part d'un    |
|               |                  | périphérique                                        |
| nIT_ext0      | Entrée           | Signal d'interruption extérieure numéro 0           |
| nIT_ext1      | Entrée           | Signal d'interruption extérieure numéro 1           |
| nIT_ext2      | Entrée           | Signal d'interruption extérieure numéro 2           |
| nIT_ext3      | Entrée           | Signal d'interruption extérieure numéro 3           |
| nIT_RTC       | Entrée           | Signal d'interruption provenant du périphérique RTC |
| nIT_TC_PWM    | Entrée           | Signal d'interruption provenant du Timer et PWM     |
| nIT_pos_vit   | Entrée           | Signal d'interruption provenant du                  |
|               |                  | périphérique de mesure position et vitesse          |
| nIT_FFTA      | Entrée           | Signal d'interruption provenant de                  |
|               |                  | l'accélérateur transformée de Fourier discrète      |
| nIT_NNA       | Entrée           | Signal d'interruption provenant de                  |
|               |                  | l'accélérateur réseau de neurones                   |
| nIT_SPI       | Entrée           | Signal d'interruption provenant du                  |
|               |                  | périphérique de communication SPI                   |
| nIT_PCI       | Entrée           | Signal d'interruption provenant du                  |
|               |                  | périphérique de communication PCI                   |
| $nIT_{-}UART$ | Entrée           | Signal d'interruption provenant du                  |
| TER 70.0      | <b>D</b> ( )     | périphérique de communication UART                  |
| nIT_I2C       | Entrée           | Signal d'interruption provenant du                  |
| TID. CAAN     | B / /            | périphérique de communication I2C                   |
| nIT_CAN       | Entrée           | Signal d'interruption provenant du                  |
| III Dari      | B / /            | périphérique de communication CAN                   |
| nIT_DMA       | Entrée           | Signal d'interruption provenant du                  |
|               |                  | périphérique d'accès direct à la mémoire.           |

Table 1: Sens et rôle des signaux

Les noms des signaux présentent un suffixe n signifiant que ceux-ci sont actifs à l'état bas. Par exemple, le signal de sélection nCS\_IT est actif à l'état bas. Ainsi un signal de sélection à l'état logique 0 signifie que le contrôleur d'interruptions est sélectionné pour une opération de lecture ou d'écriture dans un des registres.

Conventionner ces signaux comme actif à l'état bas n'est pas anodin. Historiquement,

pour des anciennes technologies Transistor-transistor logic (TTL), les signaux actifs à l'état bas sont davantage robustes aux bruits. À titre d'exemple, un signal de sélection CS actif à l'état haut sélectionne un périphérique lorsque celui-ci est à l'état logique 1. Pour des raisons purement physiques (glitch sur le signal, baisse de tension à cause de la résistivité des interconnexions, chute de l'alimentation à cause d'un fort tirage de courant), ce signal à l'état 1 peut passer à l'état de haute impédance Z, voire à l'état bas. Un tel problème causerait la perdre de données à lire où écrire mais plus généralement des problèmes de sécurité.

#### 2.4 Chronogrammes caractéristiques

Cette partie détaille les contraintes temporelles via à vis des entrées sorties. Il est possible d'identifier deux types d'échanges pour ce périphérique. Le premier via le bus est illustré avec le chronogramme figure 3.



Figure 3: Chronogramme spécification du bus

On retrouve une partie des signaux définis dans la figure 2. Lors du premier front d'horloge une valeur est placée sur le bus d'adresse comme l'indique sa valeur et nAS. Le périphérique doit alors lire ou écrire la valeur correspondante sur le bus de données avant le prochain front montant. C'est ce qu'indique la flèche centrale sur cette figure. Respecter cette contrainte permettra d'assurer la compatibilité entre les entités communiquant sur le bus. Ce dernier permet un échange bidirectionnel entre le processeur et le contrôleur. Il servira à accéder par lecture et écriture aux différents registres. Parmi eux, on identifie le vecteur d'exception qui sauvegarde les adresses mémoire auxquelles le processeur va brancher. Le registre de masquage permettra de désactiver individuellement chaque entrée. La priorité par défaut de chaque entrée pourra également être modifiée.

Le second type de communication a pour but de notifier le CPU lors d'interruptions. Elles peuvent provenir des autres périphériques présents dans le microcontrôleur ou de sources externes. L'objectif est d'informer le processeur via le signal nIT\_CPU en suivant le régime de priorités. La politique de sensibilité du périphérique est l'état des signaux et non les fronts. La gestion d'une interruption commence lorsque le signal émmeteur passe à l'état bas et s'achève lorsque qu'il passe à l'état haut. L'état du signal doit être maintenu au minimum pendant un cyle d'horloge pour qu'il soit valide.



Figure 4: Chronogramme spécification signal IT au processeur

Le chronogramme figure 5 illustre le cas d'un signal d'interruption provenant d'un périphérique et la séquence induite concernant le signal nIT\_CPU. Une demande d'interruption s'identifie par le passage à l'état bas de nIT\_xxx. Après quelques cycles de traitement visant à confirmer la validité de la requête en consultant le registre de masquage, le processeur est informé, lui aussi, par le passage à l'état bas sur nIT\_CPU. Il sauvegarde alors le contexte et lit le registre de branchement. Cette action agit comme un acquittement et le signal nIT\_CPU est passé à l'état haut. Le processeur se charge d'informer le périphérique émetteur, souvent à la fin de la routine, afin qu'il baisse le drapeau dans son registre d'état. Tant que cela n'est pas fait, aucune demande d'interruption de niveau inférieur ou égal ne sera transmis. Le chronogramme figure 5 illustre justement le cas d'une demande moins prioritaire qui apparaît durant l'exécution d'une première.



Figure 5: Chronogramme spécification 2 signaux IT cas 1

Dans cette situation, le périphérique d'indice 1 est plus prioritaire que celui d'indice 2. La demande est faite comme précédemment en passant le signal nIT\_xx1 à l'état bas. Le contrôleur réagit alors en informant le processeur. Pendant cette opération, une seconde interruption de niveau inférieur apparaît. Aucune réaction n'est attendu de la part du contrôleur qui attend la fin de l'exécution précédente pour générer un front descendant sur nIT\_CPU. Le traitement se déroule alors comme auparavant. Il est intéressant de porter l'attention sur la place que joue le signal nIT\_xx1 dans ce cas. Son passage à l'état haut autorise de nouveau l'occurrence des interruptions de niveau inférieur ou égal. Il reviendra donc au développeur de placer cet acquittement en fin de routine d'interruption sans quoi la priorisation ne sera pas garantie. Pour poursuivre la description des contraintes temporelles, on peut identifier un second cas venant de paire avec le précédent. Le chronogramme figure 6 illustre la situation où une demande **plus prioritaire** apparaît durant l'exécution d'une première.



Figure 6: Chronogramme spécification 2 signaux IT cas 2

De nouveau, dans ce cas, le périphérique d'indice 1 est plus prioritaire que celui d'indice 2. Une première demande provient du signal nIT\_xx2. Mais durant son traitement, il apparaît, une seconde interruption de niveau supérieur. Le contrôleur attend alors la lecture du processeur pour la première avant de l'informer pour la seconde. Cela est primordial pour éviter toute incohérence dans l'état des registres. Lorsque le processeur a effectué la lecture servant d'acquittement, il est de nouveau notifié. Le signal nIT\_CPU doit alors rester au minimum un cycle horloge à l'état bas afin de générer un front descendant synchrone. La suite du cycle se passe comme précédemment pour le contrôleur d'IT. C'est le processeur qui gère le rétablissement du contexte de l'interruption de plus faible priorité.

Nous venons de présenter trois situations de gestion d'interruptions. Cette analyse est loin d'être exhaustive, principalement en raison de l'infinité des instants d'occurrence possibles. Il semble toutefois que les cas traités couvrent l'ensemble des séquences d'événements. Pour vérifier la conformité d'un cas quelconque, il sera alors possible de s'y référer en identifiant la situation et en adaptant l'échelle temporelle.

#### 2.5 Contraintes du projet

La section qui suit traite de la gestion du projet. Il s'agit de préciser la planification du projet avec des divers livrables à fournir à des dates précises. La figure (7) ci-dessous est le plan de développement du projet. Les losanges bleus sont les jalons à fournir. La conception de cet IP a débuté le 5 octobre 2022, c'est-à-dire à la 40<sup>ème</sup> semaine de l'année. Le rendu de l'IP et du rapport de conception s'effectuera la semaine 49.



Figure 7: Planification du projet avec ses jalons

Également, le projet est contraint d'un point de vue ressources disponibles. La liste suivante présente les ressources attribuées pour la conception de ce contrôleur d'interruptions.

- 2 concepteurs
- Outils EDA de Mentor Graphics (propriété de Siemens EDA)

 $\bullet\,$  Carte d'évaluation ZYNQ-7 basé sur un FPGA Zynq-7000

### 3 Spécifications

#### 3.1 Caractérisation de l'environnement

Il s'agit dans cette partie de caractériser l'environnement c'est-à-dire de d'identifier les entités interagissant avec le circuit à concevoir et décrire leur évolution à l'aide d'automates. L'environnement du circuit à concevoir est constitué de trois entités :

- Le processeur
- Le contrôleur mémoire fournissant le signal de sélection nCS\_IT.
- Les 15 entités informant au contrôleur d'interruptions la présence d'une interruption. Ce groupe d'entités est appelé "source d'interruptions".

L'ensemble processeur + contrôleur mémoire peut configurer le contrôleur d'interruptions et opérer des écritures et lectures au sein de ses registres. Cet ensemble sera par la suite nommé "système à microprocesseur". L'entité source d'interruptions envoie au circuit à concevoir la présence d'une interruption à traiter.



Figure 8: Comportement du système à microprocesseur

La figure ci-dessus représente le comportement de l'entité système à microprocesseur. Celui-ci possède trois cycles de fonctionnement. Le processeur peut opérer des cycles de lecture et d'écriture dans les registres du contrôleur d'interruptions. Le souhait d'écriture ou de lecture s'effectue par la mise à l'état bas du signal nCS\_IT. La fin de ces cycles est notifiée par la mise à l'état haut du signal nAS. Le terme "données" peut signifier la valeur des registres de configuration et également l'adresse de branchements.



Figure 9: Comportement de l'entité source d'interruptions

La figure ci-dessus est l'automate de l'entité source d'interruptions. Lorsque la condition d'interruption est valide, le périphérique génère un signal en direction du contrôleur d'interruptions. Ce signal reste actif jusqu'à la lecture du flag d'interruption de la part du processeur.

#### 3.2 Entrées et sorties du composant

La caractérisation de l'environnement sous forme d'automates donne les relations d'entrées et sorties du circuit à concevoir avec les diverses entités. Il est alors possible de présenter de manière structurelle le circuit à concevoir et les entités de l'environnement.



Figure 10: Entrées et sorties du circuit à concevoir

Le tableau ci-dessous récapitule les relations avec leur sens, leur catégorie et leur type.

| Entités                       | Relation  | Catégorie    | Sens   | Type         |
|-------------------------------|-----------|--------------|--------|--------------|
|                               | Branch    | Permanent    | Sortie | Def_Branch   |
|                               | Ack_Read  | Évènementiel | Entrée | Def_Ack      |
| Système à microprocesseur     | ConfigWr  | Permanent    | Entrée | Def_ConfigWr |
|                               | ConfigRd  | Permanent    | Sortie | Def_ConfigRd |
|                               | $IT\_CPU$ | Permanent    | Sortie | Def_IT       |
| Source d'interruptions [1:15] | IT [1:15] | Permanent    | Entrée | Def_IT       |

Table 2: Sens et rôle des signaux

La relation Ack\_Read est de type Def\_Ack, une donnée de type booléen (true : la lecture de l'adresse de branchement est terminée, false sinon). IT[1:15] est un tableau de 15 éléments de type Def\_IT, une donnée de type booléen (true : une interruption est reçu de la part de n-ième l'IP, false sinon). IT\_CPU est également de type Def\_IT (true : une interruption doit être traitée par le CPU, false sinon). Chaque autre relation est une composition de sous-relations comme définie ci-après.

$$Branch = \left[ \begin{array}{c|c} ID & @blx \end{array} \right]$$
 
$$ConfigWr = \left[ \begin{array}{c|c} @blx & priorit\'e & masque \end{array} \right]$$
 
$$ConfigRd = \left[ \begin{array}{c|c} ID & @blx & priorit\'e & masque & pending & traitement \end{array} \right]$$

ID représente l'identifiant de l'interruption. @blx est la sous-relation qui précise l'adresse de branchement de la sous-routine de l'interruption à traiter. La relation priorité indique la priorité attribuée pour une interruption, masque précise si l'interruption est masquée ou non. En ce qui concerne pending, il s'agit d'une sous-relation qui informe si une interruption est mise en attente pour être traitée ultérieurement. Enfin, traitement prends en compte si une interruption a déjà été traitée ou non avant que celle-ci soit clear par l'IP concernée.

| Sous-relation | Type           | Donnée                              |  |  |  |  |  |  |  |  |
|---------------|----------------|-------------------------------------|--|--|--|--|--|--|--|--|
|               |                | Entier de 0 à 15                    |  |  |  |  |  |  |  |  |
| ID            | Def_ID         | 0: Idle                             |  |  |  |  |  |  |  |  |
|               |                | 1-15 : IT                           |  |  |  |  |  |  |  |  |
| @blx          | Def_@blx       | Entier de 0 à 4 194 303             |  |  |  |  |  |  |  |  |
|               |                | Entier de 0 à 8                     |  |  |  |  |  |  |  |  |
| priorité      | Def_priorité   | 8 : Idle                            |  |  |  |  |  |  |  |  |
|               |                | 0 : le plus prioritaire             |  |  |  |  |  |  |  |  |
|               |                | 7 : le moins prioritaire            |  |  |  |  |  |  |  |  |
|               |                | Booléen                             |  |  |  |  |  |  |  |  |
| masque        | Def_masque     | true : IT masquée (prise en compte) |  |  |  |  |  |  |  |  |
|               |                | false : non masquée                 |  |  |  |  |  |  |  |  |
|               |                | Booléen                             |  |  |  |  |  |  |  |  |
| pending       | Def_pending    | true : IT mise en attente           |  |  |  |  |  |  |  |  |
|               |                | false sinon                         |  |  |  |  |  |  |  |  |
|               |                | Booléen                             |  |  |  |  |  |  |  |  |
| traitement    | Def_traitement | true : IT à traiter                 |  |  |  |  |  |  |  |  |
|               |                | false : IT déjà traitée             |  |  |  |  |  |  |  |  |

Table 3: Sous-relations et type de données

Il est possible d'introduire une relation interne nommée infoIT. Le k-ième élément de infoIT correspond à la k-ième interruption, c'est-à-dire la valeur de ID. Cet indice k varie de 0 (Idle) à 15 (1-15 représentant les 15 interruptions).

#### 3.3 Spécifications fonctionnelles

Les spécifications fonctionnelles comprennent la liste des fonctions du système pour l'application (fonctions externes) et la description du comportement du système et de l'environnement pour ces fonctions [2].

La fonction première du contrôleur d'interruption est d'informer le processeur lorsqu'une interruption valide survient. Une interruption valide est définie comme étant non masquée et de niveau suffisant pour être prise en compte. La gestion des niveaux de priorité est la seconde fonction à considérer. Elle est directement induite par la première. Une interruption en cours ne peut être interrompue que par une interruption de niveau strictement supérieur. Lorsque le processeur acquitte la fin du traitement, les interruptions de niveaux inférieurs ou égaux peuvent être à nouveau considérées comme valides. Le contrôleur fournir un niveau de priorité par défaut pour chaque source. La troisième fonction concerne le masquage des sources d'interruption individuellement. Une source masquée ne génèrera pas de signal au processeur. Un événement déjà en cours de traitement par le contrôleur ne pourra être masqué. Si un signal d'interruption est généré alors qu'il est masqué, il est ignoré, mais s'il est démasqué alors qu'il est toujours actif alors il sera pris en compte. (A confirmer) La quatrième fonction principale spécifie le vecteur d'exception. Le contrôleur lorsque qu'il informe le processeur doit immédiatement lui indiquer vers quelle adresse il doit brancher. Il est possible de configurer une adresse par source. Sa configuration doit se faire lorsque le contrôleur est désactivé. Si aucune adresse n'est présente pour une source donnée alors une par défaut sera attribuée.

| nom | Description                          |
|-----|--------------------------------------|
| fn1 | Informer le processeur               |
| fn2 | Gérer les niveaux de priorité        |
| fn3 | Masquer individuellement les sources |
| fn4 | Configurer le vecteur d'exception    |

Table 4: Synthèse des spécifications fonctionnelles

Le tableau 4 synthétise les spécifications fonctionnelles. Il permet de contrôler que chaque point est bien traité tout au long de la conception. Il n'est cependant pas précis et devra être traité avec la description détaillée ci-dessus.



Figure 11: Premier automate du contrôleur d'interruptions



Figure 12: Second automate du contrôleur d'interruptions

## 3.4 Spécification des registres

| ID | Interruptions correspondantes |
|----|-------------------------------|
| 0  | Idle                          |
| 1  | nIT_ext0                      |
| 2  | nIT_ext1                      |
| 3  | $nIT\_ext2$                   |
| 4  | nIT_ext3                      |
| 5  | nIT_RTC                       |
| 6  | nIT_TC_PWM                    |
| 7  | nIT_pos_vit                   |
| 8  | nIT_FFTA                      |
| 9  | nIT_NNA                       |
| 10 | nIT_SPI                       |
| 11 | nIT_PCI                       |
| 12 | nIT_UART                      |
| 13 | nIT_I2C                       |
| 14 | nIT_CAN                       |
| 15 | nIT_DMA                       |

Table 5: Vecteurs d'interruptions



Figure 13: Organisation des registres internes

|                      |     |     |     |     |     |     |     |     |     | @blx |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |                      |
|----------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----------------------|
|                      | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22  | b21 | b20 | b19 | b18 | b17 | b16 | b15 | b14 | b13 | b12 | b11 | b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |                      |
| Adresse<br>base+0x18 | в   |     |     |     |     |     |     |     |     |      | х   | X   | X   | х   | X   | X   | X   | Х   | X   | X   | X   | X   | X  | X  | х  | х  | Х  | х  | X  | Х  | X  | X  | Adresse<br>base+0x16 |
| Adresse<br>base+0x20 |     |     |     |     |     |     |     |     |     |      | х   | Х   | х   | х   | Х   | Х   | X   | Х   | Х   | X   | Х   | X   | X  | X  | х  | Х  | Х  | Х  | Х  | х  | Х  | Х  |                      |
| Adresse<br>base+0x22 | 2   |     |     |     |     |     |     |     |     |      | х   | X   | X   | х   | х   | х   | X   | х   | х   | х   | х   | Х   | х  | X  | х  | х  | х  | х  | х  | х  | х  | х  |                      |
|                      |     |     |     |     |     |     |     |     |     |      |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |    |    |    |    |                      |
| Adresse<br>base+0x48 | в   |     |     |     |     |     |     |     |     |      | х   | x   | x   | x   | х   | х   | x   | x   | х   | х   | х   | х   | X  | X  | х  | х  | X  | X  | Х  | x  | х  | х  |                      |

Figure 14: Organisation du registre de branchement

## 3.5 Écriture des procédures de base pour l'emploi du circuit

(Du C à écrire (faire une lib low-level) je te laisse le plaisir de le faire)

- 3.6 Spécifications opératoires
- 3.7 Spécifications technologiques

#### 4 Conclusion

Pour conclure, la méthode MCSE apporte un outil complet offrant de nombreux avantages. Le principale étant d'effectuer une bonne structuration de sa conception, mais également de raisonner en faisant abstraction de la technologie utilisée. Cela permet de ne pas se confiner dans une solution technique. Également, la partie spécification est très utile pour dégrossir le cahier des charges ou pour réduire la complexité de conceptions lourdes, d'éviter les erreurs. Cependant la méthode MCSE n'est pas applicable à des conceptions très basiques et simples. C'est en effet plus efficace de s'abstenir de cet outil car celui-ci est chronophage, et il est parfois nécessaire de réitérer l'ensemble du processus lorsqu'un problème de conception est identifié. Entre autres, l'outil qu'est la méthode MCSE est puissant mais difficile à maîtriser car celui-ci demande une grande expérience.

 $\mathrm{CPU}$ 

IΡ

TTL

## Acronyms

 ${f CPU}$  Central Processing Unit 5

**IP** Intellectual property 5

 $\mathbf{TTL}$  Transistor-transistor logic 5

[3]

## References

- [1] J.P. Calvez. Spécification et conception des systèmes une méthodologie. 1991.
- [2] J.P. Calvez. Spécification et conception des systèmes étude de cas. 1991.
- [3] STMicroelectronics. Reference manual rm0376. Technical report, STMicroelectronics, February 2022.

# 5 Appendix