|
Publicité ' | |||||||||||||||||||||||
|
|
#1 | ||||
|
Membre régulier
![]() |
Bonjour,
En ce moment je m'interesse a la mmu et j'ai l'impression qu'il me manque un element. Partons du processeur, un arm par exemple on peut representer la chose ainsi : Code :
Code :
Quelle VA va etre donnee a la mmu de mon processeur ? En ayant deux processus, j'ai deux adresses virtuelles qui sont supposees pointer sur des adresses physiques differentes en fonction du contexte en l'occurence le pid. Qui va gerer ce contexte ? Linux ou la MMU du processeur ? N'y a-t-il pas des ambiguites sur les termes virtuelle et physique ? J'ai tendance a me dire que l'adresse virtuelle du processus n'a rien a voir avec celle en entree de la MMU et qu'il y a une couche intermediaire sur laquelle je ne trouve rien (peut etre parce qu'elle n'existe pas !) Et lorsque l'on parle d'adresse physique pour le noyau est-ce vraiment une adresse ou physique au sens materiel ou ne serait-ce pas la VA de la MMU ? Si quelqu'un peut m'eclairer, ce serait gentil. J'ai regarde dans des livres comme LDD ou Understanding the Linux Kernel mais j'ai l'impression qu'il manque un maillon ou alors je suis passe a cote de quelque chose. J'ai l'impression que Linux a sa propre MMU en lisant certains chapitre. |
||||
|
|
00
|
|
|
#2 |
|
Membre régulier
![]() |
Je vous fait un petit retour ayant trouve la reponse. En fait mon erreur venait de ma lecture sur la MMU pour l'archi ARM. Apres cette lecture je voyais la MMU comme un block relativement intelligent mais en fait il n'en n'ai rien !
Le noyau s'occupe de tout gerer dont les tables de correspondance VA<->PA qui sont stockees en RAM. En plus de ces tables, il s'occupe de placer dans un registre (via le CP15 pour l'archi ARM, registre 2 je crois) l'adresse de la table de niveau 1. Du coup la MMU recupere cette adresse et recupere via les differents niveaux de table sa PA. De son cote Linux a pour chaque processus un ensemble de tables de correspondance et vu que c'est lui qui indique a la MMU l'addresse pas de soucis. |
|
|
10
|
Copyright © 2000-2012 - www.developpez.com