

# CORRIGÉ



TECH

Examen Session Normale  
02/05/2024

|                                                               |                              |
|---------------------------------------------------------------|------------------------------|
| E. Ansermin, R. Grignon, T. Guidini Gonçalves,<br>M. Masmoudi | Architecture des ordinateurs |
| ING1 GI                                                       | Année 2023–2024              |

**Modalités :**

- Durée : 2h
- Aucun document n'est autorisé, calculatrice autorisée
- Annexe incluse
- Pages 7 et 8 à compléter et à rendre

**Exercice 1 : QCM (3 pts)**

0,5 chaque réponse correcte.

**1. Un circuit séquentiel est ...**

- a. un circuit logique où les sorties à l'instant t dépendent des entrées à l'instant t et de leur état interne.
- b. un circuit logique où les sorties ne sont fonctions que des entrées.
- c. un circuit logique où les sorties à l'instant t dépendent que des entrées à l'instant t.
- d. un circuit logique construit au moyen des circuits combinatoires et de cellules élémentaires de mémorisation.

**2. Le complément de l'expression  $A + \bar{B} \cdot C$  est :**

- a.  $A \cdot \bar{B} + \bar{A} \cdot \bar{C}$
- b.  $\bar{A} \cdot B + \bar{A} \cdot \bar{C}$
- c.  $\bar{A} \cdot \bar{B} + \bar{B} \cdot \bar{C}$
- d.  $A \cdot \bar{B} + \bar{A} \cdot C$

$$\begin{aligned} A + \bar{B} \cdot C &= A + \bar{B} \cdot C = \bar{A} \oplus \bar{B} \cdot C = \\ \bar{A} \cdot (B \oplus \bar{C}) &= \bar{A} B + \bar{A} \cdot \bar{C} \end{aligned}$$

Loi de Morgan

Le ET( $\cdot$ ) est prioritaire

**3. Quels modes d'adressage sont corrects ?**

- a. MOV AL, [BL]
- b. INC 64, AX
- c. MOV BX, 54
- d. INC 01

**4. Le registre FLAG (drapeau ou registre d'Etat) est un ensemble de 16 bits. Quels flags nous rencontrons dans ce registre ?**

- a. ZF (zero flag), SF (sign flag), OF (overflow flag), PF (pointer flag)
- b. SF (sign flag), CF (carry flag), IF (index flag), OF (overflow flag)
- c. CF (carry flag), OF (overflow flag), ZF (zero flag), SF (sign flag)
- d. PF (pointer flag), CF (carry flag), IF (index flag), ZF (zero flag)

$EXP = 01111111 = 127$

$E = 127 - 127 = 0$

### Exercice 2 : Codage (2 pts)

$m = 1,111 \dots$  1. Soit le nombre codé suivant la norme IEEE 754 en simple précision et représenté en hexadécimal BFF3333. Coder ce nombre en décimal.  $\rightarrow 32$  bits

2. Effectuer l'opération suivante en base hexadécimale (marquez les retenues sur la feuille d'examen). 1pt

| Décimal | I | 5 | E | 3 | 2 | Eventuelle retenue | A | 10 | 0 | 16 |
|---------|---|---|---|---|---|--------------------|---|----|---|----|
| 24114   | + | F | 1 | A | C | Opérande 1         | B | 11 | 1 | 17 |
| 61868   | = |   |   |   |   | Opérande 2         | C | 12 | 2 | 18 |
|         |   |   |   |   |   | Résultat           | D | 13 | 3 | 19 |
|         |   |   |   |   |   |                    | E | 14 | 4 | 20 |
|         |   |   |   |   |   |                    | F | 15 | 5 |    |

### Exercice 3 : Circuit Logique : Cheminement de cartons (6 pts)

#### Partie A : Circuit combinatoire

$$-1,11100110011001100110011 \\ = -1,899 \therefore = -1,90$$

Les cartons, en sortie de l'usine de fabrication sont acheminés sur 4 tapis roulants différents (A, B, C, D) jusqu'au chariot de manutention. Chaque tapis transporte des cartons de poids spécifique : A pour 100 Kg, B pour 150 Kg, C pour 250 Kg, et D pour 175 Kg. Chaque tapis ne peut acheminer qu'un seul carton à la fois. Il est équipé d'un capteur qui indique la présence d'un carton en émettant un signal 1. Pour gagner du temps par rapport à l'attente des cartons, un chariot est considéré comme rempli et prêt à être acheminé au poste suivant, lorsqu'il accueille au moins 50% de sa capacité.

On souhaite construire un circuit logique à 4 entrées (A, B, C, D) et une sortie S qui est égale à 1 lorsque le chariot est rempli à 50% ou plus, et égale à 0 dans le cas contraire.

1. Compléter la table de vérité pour un chariot de 700 kg (*Tableau 1*). 1.0
2. En utilisant le tableau de Karnaugh, donner l'équation simplifiée de S. 1.0
3. Considérant que les données des capteurs de tapis A, B, C et D doivent être envoyées à une seule destination Z pour simplifier le câblage et la gestion des signaux, proposez une solution en utilisant un multiplexeur à 2 entrées d'adresse. 1.0

#### Partie B : Circuit séquentiel

L'usine souhaite ajouter un mécanisme qui permet de transporter au maximum 3 cartons sur le chariot. Pour cela, elle souhaite concevoir un circuit séquentiel à base de bascule T pour incrémenter le nombre de cartons sur le chariot (voir *Schéma 1 incomplet*). La sortie du circuit, notée S, sera une valeur comprise entre 0 et 3 et codée sur deux bits, notés Q1 et Q0. Lorsque la valeur de S atteint 3, cela indique que le chariot est plein et doit être acheminé au poste de vérification. On considère qu'un front montant d'horloge correspond à l'ajout d'un carton au chariot.

- 1) Compléter la table de vérité (*Tableau 2*). Une bascule T possède une entrée T (*Toggle*) qui contrôle le changement d'état de la bascule. Si T=0, la sortie garde sa valeur. Si T=1, la bascule change d'état d'une période d'horloge à la période suivante. 1.0
- 2) Déduire les équations logiques de T0 et T1. 1.0

$$T_0 = 1$$

$$T_1 = \bar{Q}_1 \cdot Q_0 + Q_1 \cdot \bar{Q}_0 = \overline{Q_0} (\bar{Q}_1 + Q_1) = \bar{Q}_0$$

2

$$= 1$$

### 3) Compléter le schéma de câblage correspondant (*Schéma 1*). 1.0

#### Exercice 4 : Mémoires (4 pts)

On dispose d'une mémoire vive (RAM) de 8 Mbit, d'une mémoire morte (ROM) de 8 Mbit et de deux périphériques (P1 et P2) adressables respectivement sur 8 Ko et 4 Ko. On désire les rendre accessibles à un microprocesseur via les bus d'adresse (24 bits), de données (8 bits) et de commande. La RAM sera située dans les adresses les plus faibles, viendront ensuite la ROM et les deux périphériques.

- 1.** Déterminer combien de fils (bits) seront utilisés pour adresser chaque mémoire et chaque périphérique. *0,25 chaque*
- 2.** Les quatre bits les plus significatifs du bus d'adresse du microprocesseur (A23 à A20) seront utilisés pour sélectionner parmi les quatre composants à connecter au microprocesseur, comme indiqué dans le tableau ci-dessous.

RAM:  $8 \text{ Mbit} = 8 \cdot \frac{1}{8} \text{ Mo} = 1 \text{ Mo}$   
 $2^{20} \text{ octets}$   
 ROM:  $1 \text{ Mo}$   
 $2^{20} \text{ fils (bits)}$

| A23 | A22 | A21 | A20 | Composant |
|-----|-----|-----|-----|-----------|
| 0   | 0   | 0   | 1   | RAM       |
| 0   | 0   | 1   | 0   | ROM       |
| 0   | 1   | 0   | 0   | P1        |
| 1   | 0   | 0   | 0   | P2        |

*0,25 chaque*  $H\text{bit} = \frac{1}{8} \text{ Mo}$

$P1 = 8 \text{ Ko} = 2^3 \cdot 2^{10} = 2^{13}$

$P2 = 4 \text{ Ko} = 2^2 \cdot 2^{10} = 2^{12}$

$P1 = 13 \text{ fils}$   
 $P2 = 12 \text{ fils}$

Donnez la représentation de l'espace mémoire (les adresses minimale et maximale de chaque composant en hexadécimal).

- 3.** L'adresse mémoire (1F2)16 est utilisée dans les 4 composants. Donnez l'adresse correspondante en hexadécimal pour chaque composant.

*0,25 chaque*

#### Exercice 5 : Jeux d'instruction (5 pts)

Dans cet exercice, vous devez indiquer quel est l'état des registres IP (instructions), AX, BX et CX (registres), SP (pile), le flag Z (zéro), ainsi que le contenu de la pile, après chaque instruction du code.

Votre source de travail est le code assembleur donné ci-après. Pour chaque ligne d'instruction se trouve les octets de code associés pour que vous puissiez créer le code en mémoire.

La première instruction visible du **code principal** se situe à l'adresse 0x100.

La première instruction de la fonction **add2IntEven** se trouve à l'adresse 0x200.

Nous vous rappelons que les registres IP, SP (pointeur de pile), AX, BX et CX sont des registres 16 bits, que chaque adresse de code est sur 16 bits également, et chaque mot mémoire contient 1 octet.

Le code exécuté est l'appel d'une fonction qui prend en entrée 2 valeurs entières, effectue la somme et retourne un booléen (au sens langage C du terme) pour indiquer si cette somme est paire.

$1F2 = *0001\ 1111\ 0010$

RAM:  $100 *1F2$

ROM:  $200 1F2$

$* 0001 > 0000 0000$

$P1: 400 1F2$

$P2: 800 1F2$

$* 0100 > 0000 0000$

**Information :** l'instruction ‘call’ permet de faire un saut à une adresse d'une fonction, mais pour cela elle se charge silencieusement d'empiler l'adresse de l'instruction qui suit l'instruction ‘call’. Il y a donc une instruction ‘push’ implicite dans ce cas.

**Information :** l'instruction ‘ret’ permet de revenir à la fonction appelante, justement en dépliant l'adresse de retour. C'est l'adresse qui a été empilée lors de l'instruction ‘call’. Il y a donc un ‘pop’ implicite qui est exécuté ici.

### Code assembleur :

```
-----  
; MAIN FUNCTION  
-----  
main:  
    ...  
    ; Save space for the future result  
    push 0x0035  
    opcode = 68 35 00  
(adresse 0x100)  
    ; Store parameters for the function  
    push 0x0018  
    push 0x0048  
    ; perform operation  
    call add2IntEven  
    ; retrieve result 01 for odd even respectively  
    pop cx  
    ...  
-----  
; FUNCTION that sums 2 integers and returns  
; a 01 value to show if the sum is odd/even.  
-----  
add2IntEven:  
    ; store return address  
    pop cx  
(adresse 0x200)  
    ; Get parameters  
    pop ax  
    pop bx  
    ; Add two parameters  
    add ax, bx  
    ; check if result is odd or even  
    and ax, 1  
    je .end  
    mov ax, 0xFFFF  
    .end:  
    ; store return address back  
    push cx  
    ; Store result for caller function  
    add ax, 1  
    mov [sp+2], ax  
    ; return to caller function  
    ret
```

opcode = 59  
opcode = 58  
opcode = 5B  
opcode = 01 D8  
opcode = 25 01 00  
opcode = 74 05  
opcode = B9 FF FF  
opcode = 51  
opcode = 66 05 01 00  
opcode = 89 44 02  
opcode = C3

L'état initial est indiqué dans le tableau ci-dessous (Tableau 3). La première instruction du code est exécutée et l'état après exécution est indiqué également. Compléter le Tableau 3 correspondant aux contenus des différents registres, sachant que chaque ligne représente une étape d'exécution du code assembleur précédent.

## Annexe : Assembleur

| Instruction                    | Description                                                                                                                                            |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>mov destination, source</b> | Copie le contenu de <b>source</b> dans <b>destination</b>                                                                                              |
| <b>push source</b>             | - copie le contenu de <b>source</b> au sommet de la pile<br>- commence par décrémenter <b>sp</b> de 2 puis effectue la copie                           |
| <b>pop destination</b>         | - copie les 2 octets qui se trouvent au sommet de la pile dans <b>destination</b><br>- commence par effectuer la copie puis incrémenter <b>sp</b> de 2 |
| <b>add destination, source</b> | Ajoute le contenu de <b>source</b> à <b>destination</b>                                                                                                |
| <b>and destination, source</b> | Effectue un ET logique bit à bit entre <b>source</b> et <b>destination</b> . Le résultat est stocké dans <b>destination</b> .                          |
| <b>je label</b>                | Je (Jump if Equal) : fait un saut au label spécifié si et seulement si <b>ZF = 1</b> .                                                                 |





100 150 250 175 Pages à compléter et à rendre

| A | B | C | D | S |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 | 1 |
| 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 |

Tableau 1

$$350 \leq S \leq 700$$

S

| T1 | T0 | Q1 | Q0 |
|----|----|----|----|
| 0  | 1  | 0  | 0  |
| 1  | 1  | 0  | 1  |
| 0  | 1  | 1  | 0  |
| 1  | 1  | 1  | 1  |
|    |    | 0  | 0  |

Tableau 2

$T=1$   
 $Q_n$   
 bascul  
 $\rightarrow 0$   
 $\rightarrow 1$   
 $\rightarrow 2$   
 $\rightarrow 3$   
 $\rightarrow 0$

575 Kg  
 350 Kg  
 525 Kg  
 425 Kg  
 500 Kg  
 675 Kg

| CD<br>AB | 00 | 01 | 11 | 10 |
|----------|----|----|----|----|
| 00       |    |    | 1  |    |
| 01       |    |    | 1  | 1  |
| 11       |    | 1  | 1  | 1  |
| 10       |    |    | 1  | 1  |

$$S = BC + CD + A\bar{B} + ABD$$

|   |   |   |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 0 | 1 |
| 1 | 0 | 1 |

|   |   |   |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 1 | 1 |



Schéma 1



14 4 1 2 9 2 FFFA à FFFF

15

| Instruction exécutée         | IP    | AX    | BX    | CX    | SP    | Z | Stack (octet de droite avec l'adresse la plus haute = 0xFFFF) |
|------------------------------|-------|-------|-------|-------|-------|---|---------------------------------------------------------------|
| Etat initial                 | 01 00 | 00 00 | 00 00 | 00 00 | FF FE | 0 | 00 00                                                         |
| push 0x0035<br>68 35 00      | 01 03 | 00 00 | 00 00 | 00 00 | FF FC | 0 | 00 35 00 00                                                   |
| push 0x0018<br>68 18 00      | 01 06 | 00 00 | 00 00 | 00 00 | FFFF  | 0 | 00 18 00 35 00 00                                             |
| push 0x0048<br>68 48 00      | 01 09 | 00 00 | 00 00 | 00 00 | FFF8  | 0 | 00 48 00 18 00 35 00 00                                       |
| call add2IntEven<br>E8 FF 00 | 02 00 | 00 00 | 00 00 | 00 00 | FFFF  | 0 | 01 0C 00 48 00 18 00 35 00 00                                 |
| pop CX<br>59                 | 02 01 | 00 00 | 00 00 | 01 0C | FFF8  | 0 | 00 48 00 18 00 35 00 00                                       |
| pop AX<br>58                 | 02 02 | 00 48 | 00 00 | 01 0C | FFFF  | 0 | 00 18 00 35 00 00                                             |
| pop BX<br>5B                 | 02 03 | 00 48 | 00 18 | 01 0C | FFFC  | 0 | 00 35 00 00                                                   |
| add AX, BX<br>01 D8          | 02 05 | 00 60 | 00 18 | 01 0C | "     | 0 | "                                                             |
| and AX, 1<br>25 01 00        | 02 08 | 00 00 | 00 18 | 01 0C | "     | 1 | "                                                             |
| je .end<br>74 05             | 02 0D | "     | "     | "     | "     | 1 | "                                                             |
| push CX<br>51                | 02 0E | "     | "     | "     | FFFF  | 1 | 01 0C 00 35 00 00                                             |
| add AX, 1<br>66 05 01 00     | 02 12 | 00 01 | "     | "     | "     | 0 | "                                                             |
| mov [SP+2], AX<br>89 44 02   | 02 15 | "     | "     | "     | "     | 0 | 01 0C 00 01 00 00                                             |
| ret<br>C3                    | 01 0C | "     | "     | "     | FFFC  | 0 | 00 01 00 00                                                   |
| pop CX<br>59                 | 01 0D | "     | "     | 00 01 | FFFF  | 0 | 00 00                                                         |

Tableau 3

14 lignes

1-0 pour chaque  
3 lignes