Rapport de projet : Architecture des ordinateurs

Benjamin Saint-Sever, Steven Ratton

21 avril 2014

# Table des matières

| 1 | Intr       | roduction                 | 2 |
|---|------------|---------------------------|---|
| 2 | Exercice 1 |                           |   |
|   | 2.1        | implémentation de leal    | 3 |
|   | 2.2        | Architecture séquentielle | 5 |
|   | 2.3        | Architecture pipelines    | 7 |

# Chapitre 1

# Introduction

Le but de ce projet est de montrer la possibilité d'extension de l'architecture y86, en ajoutant des instructions et en manipulant les prédictions de branchement. Ce projet a pour vocation de nous enseigner la programmation de langage machine tout en tirant parti au mieux des capacités des ordinateurs.

# Chapitre 2

# Exercice 1

## 2.1 implémentation de leal

### Description

Le but de ce premier exercice est de créer une nouvelle instruction "leal" pour "load effective address", cette derniere est existante sous l'architecture x86. Cette instruction charge l'adresse de la source dans dest (leal (%regS),%regD). On souhaite que cette instruction permette un déplacement mémoire, leal depl(%regS),regD. L'avantage de cette solution est que l'on peut effectuer cette opération avec une seule instruction. Son equivalent est : "rrmovl %regS,%regD; iaddl depl,%regD"

#### Assembleur

Il est possible d'ajouter cette instruction sans consommer un nouvel opcode, il suffit de reprendre le formalisme de irmovl est de donner une valeur de ifun différente afin de faire la distinction (ifun =1).

Premiere étapes, on insère dans le code assembleur la déclaration de cette nouvelle instruction :

### ${\bf Fichier\ test\_leal.ys:}$

On déplace de 8 à partir de l'adresse du registre %eax et on attribue l'adresse dans le registre %ebx :

```
\begin{array}{c} \text{irmovl } 3\,,\ \%\text{eax} \\ \text{leal } 8(\%\text{eax})\,,\ \%\text{ebx} \\ \text{halt} \end{array}
```

### $\mathbf{Code}\;\mathbf{HCL}:$

On ajoute le code d'instruction irmovl pour identifier leal :

intsig LEAL 'I\_IRMOVL'

## 2.2 Architecture séquentielle

#### Etape FETCH:

On ne modifie rien puisque l'on interprète le même fonctionnement que l'instruction irmovl.

#### Etape Decode:

le contenue du registre 'B' (Source) est attribué à la source A.

```
int srcA = [
    #icode vaut irmovl ou leal, pour obtenir leal -> ifun=1
    (icode == LEAL) && (ifun == 1):rB;
];
```

le contenue du registre 'A' est attribué à la E destination afin d'écrire la nouvelle adresse de destination.

#### **Etape Execute:**

On place ValC dans l'aluA et ValA dans l'aluB, cela permettre d'effectuer le calcul de déplacement :



FIGURE 2.1 – Fetch



FIGURE 2.2 – Decode

# 2.3 Architecture pipelines