{{{#!html

INDEX

}}} [[PageOutline]] **DOCS** → [__**[wiki:Howto-TP Config]**__] [__**[htdocs:cours/doc_MIPS32.pdf MIPS U]**__] [__**[wiki:Doc-MIPS-Archi-Asm-kernel MIPS K]**__] [__**[http://support.typora.io/Markdown-Reference markdown]**__] [__**[htdocs:files/CR031_TPx_Nom1_Nom2.md.tgz CR.md]**__] \\**COURS** → [__**[htdocs:cours/Archi-2-B1-reboot-2p.pdf 1]**__ __([htdocs:cours/Archi-2-B1-code-2p.pdf +code]__) __([htdocs:cours/Archi-2-B1-outils-2p.pdf +outils]__)] [__**[htdocs:cours/Archi-2-B2-interruptions-2p.pdf 2]**__] [__**[htdocs:cours/Archi-2-B3-cache-archi-2p.pdf 3]**__] [__**[htdocs:cours/Archi-2-B4-cache-perf-2p.pdf 4]**__] [__**[htdocs:cours/Archi-2-B5-threads-2p.pdf 5]**__] [__**[htdocs:cours/Archi-2-B6-alloc-2p.pdf 6]**__] [__**[htdocs:cours/Archi-2-B7-synchro-2p.pdf 7]**__] [__**[htdocs:cours/Archi-2-B8-initiateurs-2p.pdf 8]**__] [__**[htdocs:cours/Archi-2-B9-ZDL-2p.pdf 9]**__] \\**TME → ** [__**[wiki:AS6-TME-B1 1]**__] [__**[wiki:AS6-TME-B2 2]**__] [__**[wiki:AS6-TME-B3 3]**__] [__**[wiki:AS6-TME-B4 4]**__] [__**[wiki:AS6-TME-B5 5]**__] [__**[wiki:AS6-TME-B6 6]**__] [__**[wiki:AS6-TME-B7 7]**__] [__**[wiki:AS6-TME-B8 8]**__] [__**[wiki:AS6-TME-B9 9]**__] \\**CODE → ** [__**[htdocs:files/kO6a2bin.tgz gcc + soc]**__] [__**[htdocs:files/tp1.tgz 1]**__] [__**[htdocs:files/tp2.tgz 2]**__] [__**[htdocs:files/tp3.tgz 3]**__] [__**[htdocs:files/tp4.tgz 4]**__] [__**[htdocs:files/tp5.tgz 5]**__] [__**[htdocs:files/tp6.tgz 6]**__] [__**[htdocs:files/tp7.tgz 7]**__] [__**[htdocs:files/tp8.tgz 8]**__] [__**[htdocs:files/tp9.tgz 9]**__] {{{#!html

Architecture des ordinateurs 2 - LU3IN031 }}} = 1. Objectifs de l'UE Archi-2 L'UE Archi-2 (LU3IN031) est la suite de l'UE Archi-1 (LU3IN029) du tronc commun au premier semestre de L3. Les 3 dernières séances de l'UE Archi-1 présentent l'architecture d'un petit SoC intégrant un MIPS et quelques composants simples. Ce SoC est utilisé comme support d'un embryon de système d'exploitation construit progressivement. À la fin de l'UE, le système d'exploitation démarre et exécute une petite application, mais le noyau contient juste un gestionnaire de syscalls et un gestionnaire d'interruptions. L'UE Archi-2 vise à aller plus loin sur 3 axes : la microarchitecture du processeur, l'architecture du SoC et le système d'exploitation. 1. Pour la microarchitecture, il s'agit de comprendre comment sont réalisés les opérateurs arithmétiques et comment sont exécutées les instructions du MIPS. Vous verrez une technique consistant à décomposer les instructions en micro-instructions élémentaires. 2. Pour l'architecture, il s'agit de comprendre comment accélérer les accès à la mémoire grâce aux caches, et quelles sont les conséquences de l'ajout de composants ayant le droit, à l'instar du MIPS, de faire des lectures et des écritures dans la mémoire. 3. Pour le système d'exploitation, il s'agit de comprendre comment une application peut disposer de plusieurs fils d'exécution (threads) s'exécutant en parallèle, comment la mémoire est dynamiquement allouée au noyau et à l'application, comment les threads d'une application se synchronisent et enfin, on l'espère, comment fonctionne une petite bibliothèque graphique (''cette partie n'est pas encore terminée'') Pour présenter les concepts des systèmes d'exploitation (OS), on utilise généralement une méthode ''top-down''. Les principes des services de l'OS tels que la gestion des fichiers, des processus, des communications inter-processus sont expliqués, puis illustrés sur un système open source de type Unix. Comme c'est complexe, il est juste possible d'en voir une partie, et c'est parfois au détriment de la vue d'ensemble. Pour une UE sur l'architecture des ordinateurs, cette approche n'est pas idéale parce qu'elle est trop éloignée du matériel. C'est pourquoi on utilise une approche ''bottom-up''. Nous partons d’un dossier vide, et nous ajoutons progressivement les services en limitant le nombre de fichiers et la taille des codes. Chaque nouveau service qui s'ajoute s'appuie sur les services précédemment construits. = 2. Cours * Cours A1[https://moodle-sciences-23.sorbonne-universite.fr/pluginfile.php/258255/mod_resource/content/2/Mips_operators.pdf Opérateurs arithmétiques] * Cours A2[https://moodle-sciences-23.sorbonne-universite.fr/pluginfile.php/258256/mod_resource/content/2/Mips_architecture.pdf Architecture microprogrammée du MIPS] * Cours A3[https://moodle-sciences-23.sorbonne-universite.fr/mod/folder/view.php?id=130826 Réalisation du MIPS] * [htdocs:cours/Archi-2-B1-reboot-2p.pdf Cours B1 : Boot et gestionnaire syscall] ([htdocs:cours/Archi-2-B1-code-2p.pdf visite guidé du code]+[htdocs:cours/Archi-2-B1-outils-2p.pdf outils compil.]) * [htdocs:cours/Archi-2-B2-interruptions-2p.pdf Cours B2 : Gestion des interruptions] * [htdocs:cours/Archi-2-B3-cache-archi-2p.pdf Cours B3 : Principe d'un cache de premier niveau (L1)] * [htdocs:cours/Archi-2-B4-cache-perf-2p.pdf Cours B4 : Impact des caches L1 sur les performances] * [htdocs:cours/Archi-2-B5-threads-2p.pdf Cours B5 : Gestion simple des threads] * [htdocs:cours/Archi-2-B6-alloc-2p.pdf Cours B6 : Allocateurs de mémoire dynamique] * [htdocs:cours/Archi-2-B7-synchro-2p.pdf Cours B7 : Mécanismes de synchronisation] * [htdocs:cours/Archi-2-B8-initiateurs-2p.pdf Cours B8 : Périphériques initiateurs et API graphique] {{{#!comment * [htdocs:cours/Archi-2-B9-API-graphique-2p.pdf Cours B9 : Contrôleur et API graphique] }}} = 3. TME Les pages de TME (Travaux sur Machine Encadrés) sont composée de deux parties, une partie TD et une partie TP. * Pour la partie TD, vous avez des questions dont les réponses sont pour la plupart dans le cours. Vous devez y répondre et formuler vos réponses dans le compte-rendu (pensez bien à mettre aussi les questions dans les comptes-rendus). * Pour les TP, il y a plusieurs étapes. Chaque étape représente un nouveau concept et vous trouverez (1) une brève description, (2) une liste des objectifs principaux de l'étape, (3) une liste des fichiers avec un bref commentaire sur chaque fichier, (4) une liste de questions simples dont les réponses sont dans le code, le cours ou le TD et enfin (5) un exercice de codage. Compte-rendus:: Vous allez devoir faire vos compte-rendus en utilisant la syntaxe **!MarkDown**. Vous rendez un compte-rendu par binôme déposé sur **[https://moodle-sciences-23.sorbonne-universite.fr/course/view.php?id=2267#section-3 Moodle]**. Je vous recommande **vivement** de vous créer un compte gratuit sur **[https://hackmd.io HackMD]**. Vous pourrez éditer vos comptes-rendus en constituant une ''team'' sur HackMD avec votre binôme. **Les comptes-rendus devront comporter vos noms**, un modèle est proposé ici → __**[htdocs:files/CR031_TPx_Nom1_Nom2.md.tgz CR031_TPx_Nom1_Nom2.md]**__ Vous avez un corrigé disponible sur **Moodle** qui peut vous aider, mais vous ne devez pas le lire avant d'avoir vraiment tenté de répondre vous-même aux questions. Le corrigé est là pour que vous ne restiez pas bloqué, mais si vous ne cherchez pas à répondre vous-même, ce sera contre-productif. Il n'y a pas forcément toutes les réponses dans les corrigés, en particulier sur la partie TP. Les comptes-rendus sont notés, ce que je souhaite, c'est que vous répondiez par vous-même parce que les questions pourraient être posées à l'examen alors, il est utile que vous arriviez à formuler des réponses par vous-même. Ne recopiez directement pas le corrigé, ça ne permet pas d'apprendre. Après avoir répondu vous-même, vous pouvez regarder la réponse et modifier votre compte rendu. Si vous êtes bloqué et que vous ne comprenez pas non plus la réponse, n'hésitez pas à le dire, c'est qu'elle n'est pas claire et je la modifierai. **Récupération du code du TP** [=#TP] * Vous devez être sur une **machine Linux**. * Vous devez avoir installer l'environnement, sinon relisez [wiki:Howto-TP Configuration de l'environnement] * Pour chaque séance, vous devez récupérer l'archive du code : `tpX.tgz`. Pour cela, allez en haut de la page du **TME** `[X]`, dans la section **INDEX / CODE → ** et cliquez sur le numéro `[X]` de la séance. * Placez l'archive `tpX.tgz` récupérée dans le répertoire kO6-a2 et décompressez-là. * Dans le `terminal`, si vous exécutez la commande **`tree -L 2 $HOME/kO6-a2`**\\Vous devriez obtenir quelque-chose comme ceci : {{{ $HOME/kO6-a2/ $HOME correspond au chemin de votre répertoire racine ├── bin │   ├── almo1.x Simulateur du SoC almo1 │   ├── fb/ Code source de la fenêtre graphique │   ├── gcc/ Cross-compilateur MIPS │   ├── soclib-fb fenêtre graphique exécutée par le simulateur │   ├── SourceMe.sh Script shell pour configurer l'environnement │   ├── test/ test de la plateforme et de l'environnement │   └── tracelog Script awk pour mettre en forme la trace d'exécution ├── Makefile Makefile avec des règles générales (clean ou backup) ├── README.md Infos sur le projet ├── tp1 Premier tp (au début, il n'est pas là, ni les autres) └.. etc. Au début il n'y a rien, puis il y aura : tp2, tp3, etc. }}} **Séances** * [wiki:AS6-TME-B1 TME B1 : Boot et gestionnaire syscall] * [wiki:AS6-TME-B2 TME B2 : Gestionnaire d'interruptions] * [wiki:AS6-TME-B3 TME B3 : Principe d'un cache de premier niveau (L1)] * [wiki:AS6-TME-B4 TME B4 : Impact des caches L1 sur les performances] * [wiki:AS6-TME-B5 TME B5 : Gestionnaire de threads] * [wiki:AS6-TME-B6 TME B6 : Allocateurs de mémoire dynamique] * [wiki:AS6-TME-B7 TME B7 : Mécanismes de synchronisation] * [wiki:AS6-TME-B8 TME B8 : Contrôleur et API graphique, réalisation d'un jeu] {{{#!comment {{{#!html

Les TME suivants sont en relecure :-)

}}} * [wiki:AS6-TME-B8 TME B8 : Périphériques Initiateurs] = 4. Documents * **[htdocs:cours/doc_MIPS32.pdf Documentation MIPS32 architecture et assembleur (mode user)]** 1. Registres de l'architecture externe accessible en mode user (p. 2) 1. Espace d'adressage du MIPS32 (p. 4) 1. Syntaxe et principales directives du langage assembleur (p. 5) 1. Codage des instructions utilisateur du MIPS32 (p. 9) 1. Instructions accessible en mode utilisateur (p. 11) 1. Appels système de simulateur de processeur **Mars** (p. 22) 1. Convention d'appel des fonctions (p. 24) * **[wiki:Doc-MIPS-Archi-Asm-kernel Documentation MIPS32 architecture et assembleur (mode kernel)]** 1. Modes d'exécution du processeur MIPS 2. Registres protégés utilisables seulement en mode kernel 3. Découpage de l'espace d'adressage 4. Instructions protégées 5. Cause d'entrée et de sortie du noyau du système d'exploitation 6. Fonctionnement du registre d'état `c0_sr` 7. Fonctionnement du registre de cause `c0_cause` * **[wiki:Howto-TP Configuration de l'environnement des TP] 1. Environnement de travail pour les TP 1. Prototype virtuel et chaîne de compilation MIPS 1. Compilation et exécution des programmes {{{#!comment * **[wiki:VNC Connexion avec VNC]** Pour le travail à distance * Installation d'un client sur sa machine personnelle * Démarrage d'un serveur sur une machine des salles de TP * Démarrage du client }}} * **Ressources Annexes** * [http://labor-liber.org/en/gnu-linux/development/ Présentation condensée, mais intéressante de la chaine de compilation GCC]