

# Simulation d'un Processeur (CPU) - Projet LU2IN006

Un simulateur simplifié de CPU en langage C, réalisé dans le cadre du module LU2IN006 : Structures de données.

## Introduction



Cadre du projet

Module LU2IN006 : Structures de données.



Objectif principal

Implémenter un simulateur simplifié de CPU en C.



Collaboration

Charafeddine EL BOUHALI, Marc-Antoine XIA, Groupe 10



# Objectifs du projet

Comprendre le fonctionnement d'un processeur

Explorer l'architecture et les principes fondamentaux du CPU.

Gérer les composants essentiels

Implémenter la mémoire, les registres et les instructions.

Interpréter le pseudo-assembleur

Traiter les sections .DATA et .CODE du langage.

Implémenter les modes d'adressage

Gérer différents segments mémoire et méthodes d'accès.



## Structure du projet



## Table de hachage

#### Structure

HashMap avec HashEntry pour stocker les données.

Adressage ouvert avec probing linéaire.

#### **Applications**

- Registres
- Segments alloués
- Pool de constantes
- Labels et variables

#### **Avantages**

Accès rapide aux données.

Flexibilité pour différents types d'éléments.



## Gestion de la mémoire

Create, find, remove, destroy.

Liste chaînée Organisation des segments libres. {{\bar{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot{\cdot **Fonctions** 同 回

#### Table de hachage

Suivi des segments alloués.

#### **Fusion**

Optimisation des segments libres adjacents.

## Parsing du pseudo-assembleur



# Segments mémoire simulés



### Simulation CPU



La structure CPU intègre un gestionnaire de mémoire complet et des registres essentiels: AX, BX, CX, DX, IP, ZF, SF, SP, BP et ES.