Le chiffrement de disque sous linux : Vrai ou faux sentiment de securité

icon

23

pages

icon

Français

icon

Documents

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

icon

23

pages

icon

Français

icon

Documents

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

Le chiffrement de disque sous linux : Vrai
ou faux sentiment de sécurité?
Kevin DENIS kevin2nis@gmail.com,
Ingénieur Arts&Métiers, option Réseaux et Systèmes Informatiques,
Auteur d’articles pour MISC et Linux magazine.
émesConférencedonnéelemercredi7juillet2010,aux11 RMLL,Rencontres
Mondiales du Logiciel Libre :
http://2010.rmll.info
URL de la conférence :.rmll.info/Le-chiffrement-de-disque-sous-linux-vrai-ou-
faux-sentiment-de-securite.html
Work in progress v0.8, le 4 juillet 2010
1 Table des matières
1 Introduction 4
2 Mise en œuvre du chiffrement sous linux 5
2.1 Pourquoi utiliser dm-crypt et cryptsetup . . . . . . . . . . . . 5
2.2 Fonctionnement de . . . . . . . . . . . . . . . . . . 6
2.2.1 Le programme cryptsetup et le module dm-crypt . . . 6
2.2.2 L’extension LUKS de cryptsetup . . . . . . . . . . . . 7
2.2.3 Le chiffrement de disque complet . . . . . . . . . . . . 7
2.2.4 Plausible deniability . . . . . . . . . . . . . . . . . . . 8
2.3 Situation malgré tout insatisfaisante . . . . . . . . . . . . . . 9
2.3.1 Cold Boot attack . . . . . . . . . . . . . . . . . . . . . 9
2.3.2 Attaques en deux temps . . . . . . . . . . . . . . . . . 10
2.3.3 Les poor man solutions . . . . . . . . . . . . . . . . . . 11
2.3.4 Quelle solution fiable? . . . . . . . . . . . . . . . . . . 11
3 L’ajout nécessaire du trusted computing 12
3.1 Le trusted computing : la puce TPM . . . . . . . . . . . . . . 12
3.1.1 Le TCG et la puce TPM . . . . . . . . . . . . . . . . . 12
3.1.2 Le point de ...
Voir icon arrow

Publié par

Nombre de lectures

160

Langue

Français

Le chiffrement de disque sous linux : Vrai ou faux sentiment de sécurité ?
Kevin DENIS kevin2nis@gmail.com , Ingénieur Arts&Métiers, option Réseaux et Systèmes Informatiques, Auteur d’articles pour MISC et Linux magazine.
Conférence donnée le mercredi 7 juillet 2010, aux 11 émes RMLL, Rencontres Mondiales du Logiciel Libre : http://2010.rmll.info URL de la conférence : http://2010.rmll.info/Le-chiffrement-de-disque-sous-linux-vrai-ou-faux-sentiment-de-securite.html
Work in progress v0.8, le 4 juillet 2010
1
Table des matières 1 Introduction 4 2 Mise en œuvre du chiffrement sous linux 5 2.1 Pourquoi utiliser dm-crypt et cryptsetup . . . . . . . . . . . . 5 2.2 Fonctionnement de dm-crypt . . . . . . . . . . . . . . . . . . 6 2.2.1 Le programme cryptsetup et le module dm-crypt . . . 6 2.2.2 L’extension LUKS de cryptsetup . . . . . . . . . . . . 7 2.2.3 Le chiffrement de disque complet . . . . . . . . . . . . 7 2.2.4 Plausible deniability . . . . . . . . . . . . . . . . . . . 8 2.3 Situation malgré tout insatisfaisante . . . . . . . . . . . . . . 9 2.3.1 Cold Boot attack . . . . . . . . . . . . . . . . . . . . . 9 2.3.2 Attaques en deux temps . . . . . . . . . . . . . . . . . 10 2.3.3 Les poor man solutions . . . . . . . . . . . . . . . . . . 11 2.3.4 Quelle solution fiable ? . . . . . . . . . . . . . . . . . . 11 3 L’ajout nécessaire du trusted computing 12 3.1 Le trusted computing : la puce TPM . . . . . . . . . . . . . . 12 3.1.1 Le TCG et la puce TPM . . . . . . . . . . . . . . . . . 12 3.1.2 Le point de vue de GNU . . . . . . . . . . . . . . . . . 13 3.2 Outils pour utiliser la puce TPM . . . . . . . . . . . . . . . . 14 3.2.1 Disponibilité de la puce TPM . . . . . . . . . . . . . . 14 3.2.2 tcsd, tpm-tools et la librairie tss . . . . . . . . . . . . 15 3.2.3 Les mesures du TPM : les registres PCR . . . . . . . . 16 3.2.4 TrustedGrub . . . . . . . . . . . . . . . . . . . . . . . 16 3.3 Utilisation des métriques TPM pour vérifier le boot . . . . . . 18 3.3.1 Aucune méthode n’existe à ce jour . . . . . . . . . . . 18 3.3.2 Création d’un initramfs spécialisé . . . . . . . . . . . . 19 3.3.3 Installation en deux temps d’une distribution . . . . . 19 3.4 Validité de la solution . . . . . . . . . . . . . . . . . . . . . . 20 3.4.1 Rejeu des attaques précédemment nommées . . . . . . 21 3.4.2 Récupération de données en cas de problème . . . . . 21 3.4.3 Industrialisation de la solution . . . . . . . . . . . . . 21 3.4.4 Upgrade de la distribution . . . . . . . . . . . . . . . . 22 4 Conclusion 22
2
Abstract de l’article : Cet article vise à démontrer que le chiffrement de disque sous linux, réalisé via l’utilisation du module noyau dm-crypt et du programme cryptsetup, fait l’objet d’une faille conceptuelle. En effet, le programme déchiffrant le disque réside sur une partition en clair. Il s’ensuit qu’un attaquant peut le modifier à sa guise pour obtenir le mot de passe des partitions chiffrées, ou pour placer un programme malveillant suite au déchiffrement des partitions. Pour répondre à cette faille, le trusted computing est nécessaire, plus particulièrement la puce TPM et ses mesures des métriques du démarrage. Ainsi, les outils utilisant cette puce (TrustedGrub, trousers et tpm-tools) permettent de présenter une méthode novatrice pour obtenir un boot sécurisé d’une machine. Cette méthode assure que système démarré est bien un système sain et non un système modifié par un attaquant.
Mots-clé : Linux, sécurité informatique, chiffrement, dm-crypt, TPM, trusted computing, TrustedGrub, trousers, tpm-tools, Evil Maid.
3
1 Introduction La sécurité d’une machine est faible lorsqu’elle est physiquement accessible. En effet, n’importe quel utilisateur peut démarrer la machine en ajoutant au bootloader la commande init=/bin/bash , lui donnant ainsi immédiatement des droits root. Une autre méthode tout aussi simple consiste à démarrer depuis un liveCD et de monter les partitions afin de lire les données, les modifier, ou ajouter des programmes malveillants. Le chiffrement de disque est une réponse fiable pour éviter ces risques. Il protège les données lorsque le disque est éteint et empêche donc toute perte de confidentialité et d’intégrité des données enregistrées sur celui-ci. Les ordinateurs portables sont une cible évidente, du fait de leur risque de vol ou perte. Le voleur aura le matériel, mais il n’accédera pas aux données. Les machines de bureaux peuvent également être chiffrées car il est courant que de multiples personnes gravitent autour de celles-ci. Un collègue indélicat peut très simplement devenir administrateur de votre machine. Un troisième type de machine pour lesquelles le chiffrement joue un rôle important sont les machines virtuelles. Leur disque dur n’est qu’un fichier situé généralement sur un datastore ou sur un partage réseau. Toute personne accédant à ce partage accède aussi à vos données. Les seules machines n’ayant rien à gagner à être chiffrées sont les serveurs allumés 24h/24 situés dans des pièces fermées où les accès sont surveillés et maîtrisés. Cet article est construit en deux parties. La première explique comment le chiffrement de disque sous linux est rendu possible en justifiant le choix de dm-crypt. Des exemples d’utilisation sont donnés, ainsi qu’un procédé original de plausible deniability 1 . La critique majeure de ce système est ensuite étudiée : le programme de déchiffrement de la partition peut très facilement être remplacé par un autre, maîtrisé par l’attaquant, laissant toute latitude à ce dernier pour dupliquer le mot de passe de déchiffrement ou pour toute autre action malveillante. La deuxième partie explique l’apport majeur du trusted computing . En effet, la puce TPM est indépendante du système d’exploitation et permet de valider les programmes lancés lors du boot. Comme aucune méthode n’existe, j’ai inventé une manière de valider le démarrage de manière sécurisée à l’aide de TrustedGrub et des outils tpm-tools. Cette méthode combine l’utilisation d’une clé utilisateur et des métriques du boot faites par la puce TPM. Enfin, cette méthode est vérifiée pour valider son niveau de sécurité.
1. Procédé empêchant un attaquant de prouver qu’une méthode cryptographique est utilisée pour cacher des données, http://en.wikipedia.org/wiki/Plausible_deniability 4
2 Mise en œuvre du chiffrement sous linux Le chiffrement des données peut se réaliser de deux façons distinctes. La première consiste à chiffrer manuellement chaque fichier confidentiel : cette solution a pour inconvénient de devoir trouver des programmes compatibles et d’obliger à chiffrer/ déchiffrer/ rechiffrer à chaque opération et de n’oublier aucun fichier. La seconde consiste à chiffrer l’intégralité des partitions au niveau du pilote de périphérique. C’est cette seconde méthode qui est exposée dans cet article. Cette première partie fournit les raisons qui penchent en faveur de l’uti-lisation de cryptsetup 2 , pour enchaîner sur la manière dont le chiffrement fonctionne à l’aide du module noyau dm-crypt , device mapper crypt , et du programme cryptsetup qui permet de paramétrer le chiffrement. Divers cas d’utilisation sont donnés, principalement celui permettant le Full Disk Encryption (FDE, ou chiffrement complet de disque) et une présentation inno-vante de plausible deniablity est expliquée en utilisant simplement ces outils. Plusieurs attaques seront ensuite menées contre ce procédé de chiffrement, avec les contre-mesures associées. Ces attaques montreront que l’utilisation seule d’un procédé de FDE n’est pas suffisant pour garantir une sécurité suffisante aux données stockées sur le disque. 2.1 Pourquoi utiliser dm-crypt et cryptsetup Un certain nombre de procédés de chiffrement de volumes, partitions, disques, ou images disques, sont disponibles sous linux. Une liste relative-ment complète est fournie par wikipedia : http://en.wikipedia.org/wiki/ Comparison_of_disk_encryption_software 3 . Pour les partitions, les documentations mentionnent généralement : – Cryptoloop et Loop-AES : deux programmes qui sont aujourd’hui considérés comme obsolètes. Ils permettent d’utiliser une image disque (loop) chiffrée. – TrueCrypt : de http://www.truecrypt.org , un logiciel open-source permettant de chiffrer des partitions ou des images disques. Il fonctionne sous linux, Mac OS et Windows. – Cryptsetup : http://www.saout.de/misc/dm-crypt/ , qui se compose d’un module intégré au noyau linux, et d’un programme permettant de l’utiliser. Ce programme bénéficie d’une extension LUKS signifiant Linux Unified Key Setup . Cryptsetup permet de chiffrer des images disques via un périphérique loop, ou des partitions. Le choix de Cryptsetup pour chiffrer un disque est naturel. En effet, il a été créé en remplacement de cryptoloop 4 : "Device-mapper is a new 2. http://www.saout.de/misc/dm-crypt/ 3. Tous les OS sont compris dans cette liste, pas uniquement linux. 4. http://www.saout.de/misc/dm-crypt/ 5
infrastructure in the Linux 2.6 kernel that provides a generic way to create virtual layers of block devices that can do different things on top of real block devices. dm-crypt is such a device-mapper target that provides transparent encryption" Alors que cryptoloop ou loopAES étaient plutôt orientés dans le chiffrement des images disques, cryptsetup a été écrit pour chiffrer des partitions. Cryptsetup utilise un module noyau, dm-crypt, intégré depuis longtemps dans le noyau standard. Enfin, la troisième raison et sans doute la meilleure, reste la raison du choix des distributions. En effet, toutes les distributions les plus courantes proposent dès l’installation de chiffrer le disque à l’aide de cryptsetup. Le chapitre suivant explique comment fonctionnent dm-crypt et cryptse-tup. Biblio http://www.saout.de/misc/dm-crypt/ http://alien.slackbook.org/dokuwiki/doku.php?id=slackware:setup 2.2 Fonctionnement de dm-crypt Le chiffrement de disque est effectué par le noyau via son module dm-crypt, son paramétrage se fait via le programme cryptsetup. De manière analogue aux autres extensions device-mapper 5 , dm-crypt est une couche supplémentaire située entre le filesytem et l’écriture sur le disque physique. Si la clé de déchiffrement est présente, alors les écritures et lectures sur le disque sont chiffrées et déchiffrées au vol. 2.2.1 Le programme cryptsetup et le module dm-crypt Cryptsetup est le composant côté administrateur permettant d’utiliser dm-crypt. Son fonctionnement est simple : c r y p t s e t u p [ - - c i p h e r < cipher >] [ - - key - f i l e < file >] c r e a t e $ N A M E / de v / $ P A R T I T I O N – Le cipher est à choisir parmi la liste des méthodes de chiffrement connues du noyau : ls /lib/modules/‘uname -r‘/kernel/crypto ou bien : zgrep CRYPTO /proc/config.gz . Par défaut, l’AES 256 est utilisé. – Si le fichier de clé est omis, alors un mot de passe est demandé de manière interactive sur la ligne de commande. – Le mot clé create permet de créer ou d’ouvrir le fichier block spécial /dev/mapper/$NAME qui est la vision déchiffrée de /dev/$PARTITION par la clé fournie. Ce mode de fonctionnement est très simple à appréhender. Les octets sont toujours chiffrés sur le disque, et déchiffrés à la volée lors des accès systèmes. Cela remplit parfaitement les objectifs en matière de sécurité. Si un attaquant 5. http://sourceware.org/dm/
6
récupère le disque sans le mot de passe, il n’aura pas accès aux données. Cette manière de faire est également parfaitement indépendante du système de fichiers, des données ou de l’utilisation de la partition. dm-crypt ne s’occupe que du flot d’octets sans s’intéresser à son contenu. Le système linux communique avec la version en clair des données. Toutefois, cette méthode présente plusieurs limites. Le mot de passe est fourni par un utilisateur. Si l’utilisateur n’y prend pas garde, il peut utiliser un mot de passe faible, permettant ainsi à un attaquant de réaliser une attaque par force brute sur la partition. Ensuite, il n’existe qu’une clé unique, le mot de passe. Si l’utilisateur le perd ou souhaite le changer, il n’existe aucun moyen de le faire si ce n’est tout sauvegarder, de recréer un mapping avec nouveau mot de passe et de réinjecter la sauvegarde. Enfin, il n’existe aucun moyen de vérifier ou non la validité du mot de passe. Le chiffrement étant effectué par flot, tout mot de passe est accepté, seul le résultat du déchiffrement est incohérent en cas de mot de passe erroné. 2.2.2 L’extension LUKS de cryptsetup Cryptsetup s’est donc vu adjoindre LUKS qui signifie Linux Unified Key Setup pour répondre à ces limitations. c r y p t s e t u p < l u k s action > [ A r g u m e n t ] Les actions et arguments sont fournis par la page de manuel. Les ajouts de LUKS sont les suivants : tout d’abord, LUKS se réserve un espace en en-tête de partition. Cet espace est constitué de huit slots, et du mot de passe de chiffrement de la partition généré par cryptsetup de manière à ce qu’il rende les attaques par dictionnaire ou force brute inutiles. Chacun des slots est protégé par mot de passe et son accès permet l’utilisation de la clé de déchiffrement qui ouvre la partition. Les avantages sont intéressants : pas de risque d’attaque de force brute sur les données de la partition 6 , possibilité simple d’ajouter ou supprimer un mot de passe. LUKS est également capable de vérifier la validité d’un mot de passe ou pas. Enfin, l’en-tête connu des partitions LUKS permet à différents systèmes de réagir correctement lors de la découverte de celui-ci 7 . 2.2.3 Le chiffrement de disque complet L’utilisation du chiffrement pour une distribution est simple. Le disque est généralement coupé en deux partitions. La première, de petite taille, /boot contient le bootloader, le noyau ainsi qu’un initrd. La seconde est chiffrée via LUKS. Pour éviter d’utiliser autant de mots de passes que de partitions, les distributions utilisent généralement un chiffrement au dessus 6. Il reste à l’attaquant les mots de passe des slots à forcer. 7. Lors de l’insertion d’une clé USB chiffrée via LUKS, un environnement de bureau pourra le détecter et présenter un pop-up demandant le mot de passe, par exemple.
7
d’un LVM. Ainsi, un mot de passe unique permet le déchiffrement du LVM, qui lui-même est découpé en plusieurs partitions : la racine (/) le swap et /home par exemple. Lors du boot, le ramdisk initial détecte la partition chiffrée et demande un mot de passe à l’utilisateur. Si le mot de passe est correct, alors le déchiffrement a lieu, le mapping est réalisé et le démarrage peut continuer. Pour un utilisateur, la situation semble idéale. Le disque est chiffré de manière transparente. Le chiffrement ne consomme que très peu de puissance CPU 8 . Lorsque la machine est éteinte, elle peut être perdue sans qu’il n’existe le moindre risque que les données présentes sur le disque soient dévoilées 9 . Bien entendu sous réserves que l’administrateur a choisi un cipher susement fort et un mot de passe non trivial. 2.2.4 Plausible deniability Le plausible deniability est une notion qui a été popularisée par True-crypt 10 . Le principe repose sur l’impossibilité pour un attaquant de prouver que des données chiffrées sont présentes sur un disque 11 . TrueCrypt permet de placer des données chiffrées à l’intérieur d’un premier conteneur chiffré. Ainsi, un utilisateur forcé à révéler son mot de passe peut le fournir, puisque ce mot de passe n’ouvrira que le premier conteneur, n’ayant que des données pseudo-confidentielles. Sous certaines conditions précises, cryptsetup permet aussi de faire de la plausible deniability. Tout d’abord, il faut créer un conteneur, partition réelle, ou fichier repré-sentant un disque. Ce disque est rempli préalablement de données aléatoires. Sur ce disque, un chiffrement de type cryptsetup Luks est créé. Ensuite, il faut créer un deuxième conteneur bien plus loin sur le disque, ce qui est aisément réalisable grâce à l’outil losetup qui permet de démarrer à un offset précis. A cet offset , un second conteneur. Personne ne peut distinguer à ce second offset des données chiffrées de l’aléatoire :
8. http://www.saout.de/tikiwiki/tiki-index.php?page=UserPageChonhulio par exemple qui donne des réductions de temps de lecture/écriture brute assez faible. 9. Il ne faut pas négliger non plus le problème de fin de vie des machines. Si le disque est chiffré, il est alors possible de distribuer les machines à des personnes tierces (associations, amis) sans que les données soient ’at risk’ après un simple formatage. 10. http://www.truecrypt.org/docs/?s=plausible-deniability 11. Un des principes d’un chiffrement fiable repose sur l’impossibilité de différencier un flux chiffré d’un flux aléatoire. 8
En-tête Cryptsetup LUKS Fichiers plus ou moins importants Fichiers secrets pDaérbtiuttiodneclahiréeDébutdelapartitionchiréesansLuks Les précautions à prendre sont les suivantes : – Ne pas utiliser le premier conteneur. En effet, le premier conteneur écrira sur l’intégralité du disque si on y prête pas garde. – Le choix du système de fichiers n’est pas libre pour le premier conteneur. Par exemple, ext duplique son superblock en plusieurs endroits du disque. Si ce superblock disparaît à partir d’un seuil, cela peut soulever des doutes. Le filesystem FAT n’a pas ce problème. – Ne pas utiliser LUKS pour le second conteneur. En effet, l’en-tête Luks est un en-tête connu. S’il est détectable en milieu de partition, alors cela signifie que des données sont présentes. L’utilisation de cryptsetup seul est obligatoire. Pour ces raisons, il est conseillé d’utiliser un fichier plutôt qu’une partition. Sous les réserves exposées, la plausible deniability est parfaite, et personne ne peut prouver qu’il existe un second conteneur dans le premier ayant des données secrètes. Biblio Article linux magazine numéro 101 : "Le chiffrement de disque sous linux" , par Kevin DENIS. 2.3 Situation malgré tout insatisfaisante Le chiffrement de disque est mis en œuvre comme indiqué dans la do-cumentation. Les attaquants ’naïfs’ peuvent chercher à attaquer AES ou le procédé de chiffrement utilisé, mais je considère dans cet article que les choix fait par l’administrateur sont corrects. Je laisse également de côté les keyloggers hardware. Le risque est réel sur les machines de bureau, bien plus faible sur les portables du fait de leur miniaturisation rendant ce genre d’ajout difficile. Dès lors, deux types d’attaques restent réalisables, cold boot attack et les attaques en deux temps. 2.3.1 Cold Boot attack Une attaque indirecte a été développée par l’université de Princeton : http://citp.princeton.edu/memory/ et repose sur la rémanence des don-nées en RAM. En effet, la clé de déchiffrement est en mémoire afin de pouvoir accéder aux données. Un attaquant face à une machine aux disques chiffrés
9
et allumée peut rebooter brutalement la machine sur un autre OS, et dumper ensuite le contenu de la RAM pour retrouver à l’intérieur la clé. Contrairement à une croyance courante, la RAM n’est pas remise à zéro lors de l’extinction d’une machine. L’attaque a été perfectionnée en noyant les barrettes de RAM dans de l’azote liquide, ce qui pousse la rémanence des données à l’intérieur de celle-ci à plus de dix minutes. Différents proof of concepts ont été développés, ciblant la majorité des procédés de chiffrement sous différents OS. Ceci dit, le principe du chiffre-ment n’est pas vraiment remis en cause. Il est acquis que le chiffrement de disque protège les données lorsque le disque est éteint. Cette attaque modifie légèrement ce principe : Le chiffrement protège les données lorsque le disque est éteint depuis plusieurs instants. Il reste toutefois une autre surface d’attaque, bien plus problématique. En effet, le programme réalisant le déchiffrement de la partition repose sur une partition en clair, non protégée ! 2.3.2 Attaques en deux temps Un attaquant peut contourner le chiffrement en deux temps. Tout d’abord, remplacer le programme de déchiffrement par un autre qui enregistre le mot 12 de passe fourni quelque part, puis déchiffre ensuite les partitions . Ce risque n’est pas que purement théorique. Joanna Rutkowska, chercheuse en sécurité du poste de travail l’a non seulement démontré, mais à de plus écrit un programme réalisant ces actions en visant TrueCrypt sous Windows 13 . Le risque est identique sous linux, et un proof of concept a été publié dans MISC N˚48 consistant à modifier l’initrd d’une distribution debian afin de logger sur la partition /boot le mot de passe. Si nous reprenons les cas d’usage donnés en introduction, il est clair qu’ils sont tous impactés par cette faille. Il suffit de pouvoir accéder deux fois à une machine. Un ordinateur portable est souvent laissé sans surveillance : Joanna Rutkowska prend comme exemple un conférencier qui dépose son ordinateur portable dans une chambre d’hôtel et une femme de ménage malicieuse : EvilMaid qui a donc accès plusieurs fois à l’ordinateur. Une machine desktop reste dans un bureau alors que des personnes gravitent encore autour. La machine virtuelle est identiquement impactée par l’administrateur du datastore. La source du risque est clairement identifiable : L’utilisateur fait confiance au programme à qui il fournit la clé mais ce programme n’a jamais été vérifié. Une autre famille de failles s’appelle les MBR attacks 14 , basées sur la
12. Cette faille conceptuelle touche linux, mais également tous les OS qui chiffrent leurs disques ! 13. http://theinvisiblethings.blogspot.com/2009/10/evil-maid-goes-after-truecrypt.html 14. Voir biblio
10
même logique, sauf qu’au lieu de modifier l’initrd de linux, il est modifié le MBR de la machine dans le même but : logger le mot de passe quelque part. Afin d’éviter ces failles, il devient nécessaire de pouvoir s’assurer que le programme de déchiffrement n’a pas été modifié. Les vérifications habi-tuelles, hachage ou signature sont battues en brèche pour les mêmes raisons qu’évoquées précedemment. Le programme de vérification peut également être modifié par l’attaquant pour produire une signature valide. Il s’ensuit que lors d’un vol de portable, il n’est nullement garanti que les données confidentielles le restent. . . En effet, si le vol est consécutif à une attaque EvilMaid, la confidentialité est rompue. Et comment l’administrateur peut-il savoir après le vol si la machine avait été infectée ? Comment l’admi-nistrateur peut-il faire confiance à sa machine de bureau ? Il est tout à fait plausible qu’un attaquant ait pu ajouter un rootkit alors que l’administrateur avait éteint sa machine 15 . La plausible deniability ne répond pas non plus à ces failles. Puisques les programmes de déchiffrement de disque sont considé-rés comme étant sous l’emprise d’un attaquant, la plausible deniability sera pareillement déjouée. 2.3.3 Les poor man solutions Comme l’indique Joanna Rutkoswka sur son blog 16 , il n’existe que des poor man solutions . Un utilisateur avisé et isolé pourra développer un bout de code ou une méthode non connue de l’attaquant, lui permettant ainsi de constater que son démarrage est modifié. Mais l’inconvénient de cette méthode est qu’elle ne passe pas à l’échelle, que ce soit dans les scripts d’installation d’une distribution ou une politique d’entreprise. La sécurité par l’obscurité n’est jamais la bonne solution. Il est aussi possible d’utiliser une clé USB contenant le bootloader, le noyau et l’initrd, mais cette clé doit être surveillée en permanence. Les protections types mots de passe BIOS ne sont pas non plus suffisantes. Des mots de passe administrateurs permettent d’outrepasser les mots de passe admins, informations librement consultables par internet, ce qui n’empêche pas non plus le démontage / remontage des machines. 2.3.4 Quelle solution fiable ? Une autre solution plus radicale consiste à ne jamais laisser sa machine sans surveillance mais dans ce cas, on peut s’interroger sur l’utilité du chiffrement. . . La solution rigoureuse serait qu’une entité tierce, non maîtrisable par l’attaquant puisse valider que le programme de déchiffrement est sain. Cette méthode existe et s’appelle le trusted computing.
15. Le pirate n’a que l’embarras du choix. Par exemple un initrd modifié pourrait ajouter une clé dans le fichier /root/.ssh/a _ y . . . uthorized ke 16. Voir liens en biblio
11
Voir icon more
Alternate Text