Cet article rappelle le fonctionnement des entrées/sorties du processeur sur une architecture de type PC. On y détaille les différents composants impliqués, leurs rôles et la façon dont ils sont utilisés par un système d'exploitation. La seconde partie se concentre sur les faiblesses de ces mécanismes et les vulnérabilités induites. Nous concluons l'article par les contre-mesures disponibles. « Architecture PC » désigne dans notre cas un système équipé d'un processeur x86 et d'un bus PCI ou PCI Express.
1. L’architecture PC
1.1 Le chipset
Sur une architecture de type PC, les entrées/sorties du processeur se font au travers d’un composant appelé chipset. Celui-ci connecte le processeur aux différents périphériques tels que la mémoire vive, la carte graphique, les cartes réseau, les disques durs, etc. Il contient en général des contrôleurs pour différents bus (USB, PCI, SATA, etc.) ainsi que la logique pour leurs interconnexions. Il est en général divisé en deux parties (figure 1 : le northbridge [1] (fournissant les accès aux périphériques rapides tels que la mémoire et la carte graphique) et le southbridge [2] (bus PCI, contrôleurs USB, SATA, etc.) reliés entre eux par un bus appelé DMI (Direct Media Interface) chez Intel. Le processeur est relié au northbridge par le FSB (Front-Side Bus, par opposition au Back-Side Bus qui relie les différents cœurs et le cache de niveau 2 partagés entre les cœurs à l’intérieur du processeur).
- Accédez à tous les contenus de Connect en illimité
- Découvrez des listes de lecture et des contenus Premium
- Consultez les nouveaux articles en avant-première