2. Installation du pilote NTFS sous FreeBSD 2.2.X

Pour installer ce pilote, vous aurez besoin de recompiler un noyau car les fichiers d'en-tête utilisés seront mis à niveau. Pour autant, aucun changement dans le fichier de configuration ne sera nécessaire. Si vous n'avez pas installé les sources du noyau, vous pouvez soit recourir à sysinstall, ou bien entrer successivement en tant que root :

# mount -t cd9660 /dev/cd0c /mnt
# cd /mnt/src
# cat ssys.?? | tar --unlink -zxpvf - -C /usr/src

Le pilote requiert également les fichiers mntopt.h de l'archive source. Pour extraire son contenu, tapez :

# cd /mnt/src
# cat ssbin.?? | tar --unlink -zxpvf - -C /usr/src sbin/mount

Ensuite, en tant que root, créez un répertoire pour extraire le contenu de l'archive du pilote ntfs :

# cd /tmp
# mkdir ntfs

Téléchargez le fichier d'archive compressé contenant le code source du pilote ainsi que son fichier de mise à jour dans /tmp/ntfs.

Extrayez le contenu de l'archive :

# cd /tmp/ntfs
# tar xzvf ntfs-releng22-0.12beta.tgz

Il se peut que le numéro de version (0.12beta) soit différent.

Recopiez maintenant les fichiers sources à l'endroit adéquat :

# cd src
# cp -p -r * /usr/src

Ensuite, vous devez mettre à niveau les 3 fichiers d'en-tête du système. Utilisez l'option -l (L minuscule) qui permet d'ignorer la différence d'espacement, car j'ai remarqué que l'utilisation des touches TAB et Espace rendait incompatible les fichiers originaux et les fichiers diff.

# cd /usr/src/sys/sys
# patch -l malloc.h /tmp/ntfs/diff/malloc.h.diff
# patch -l mount.h /tmp/ntfs/diff/mount.h.diff
# patch -l vnode.h /tmp/ntfs/diff/vnode.h.diff

Si cette opération réussit, vous verrez s'afficher quelque chose de similaire à :

Hmm...  Looks like a new-style context diff to me...
The text leading up to this was:
--------------------------
|*** ./sys/sys/vnode.h.orig      Fri Jan  1 00:17:30 1999
|--- ./sys/sys/vnode.h  Fri Jan   1 00:17:35 1999
--------------------------
Patching file vnode.h using Plan A...
Hunk #1 succeeded at 58.
done
   

Si malencontreusement, un (ou plusieurs) fichier de mise à jour faisait défaut, sachez que patch fait toujours des copies des fichiers originaux avec le même nom suivi de l'extension .orig.

Maintenant, vous pouvez compiler le pilote. Il est nécessaire d'ajouter BINDIR=/usr/sbin qui n'est pas défini dans le Makefile.

# cd /usr/src/sbin/i386/mount_ntfs
# make
# make BINDIR=/usr/sbin install

Compilez ensuite les modules du noyau :

# cd /usr/src/lkm
# make
# make install

Pour finir, vous devez recompiler le noyau. Si vous utilisez le noyau GENERIC, faites une copie du fichier de configuration du noyau GENERIC (ce n'est pas absolument nécessaire, mias de cette manière le nom du noyau sera mis à jour, et ce sera plus facile pour identifier le noyau avec lequel vous démarrez). J'ai pour habitude d'utiliser des noms assez représentatifs, aussi GENERIC_NTFS me semble approprié :

# cd /usr/src/sys/i386/conf
# cp GENERIC GENERIC_NTFS
# /usr/sbin/config GENERIC_NTFS
# cd ../../compile/GENERIC_NTFS
# make depend
# make
# make install

Ok, parfait, mais avant de redémarrer avec votre nouveau noyau, il faut identifier la tranche - slice - NTFS. Le numéro de cette tranche va dépendre du format de votre disque. Pour l'instant, si vous avez une tranche FAT suivie d'une tranche NTFS et que votre tranche FreeBSD est la dernière, elles seront numérotées (remplacez ``w'' par ``s'' pour les disques SCSI) :

FAT     - wd0s1
NTFS    - wd0s2
FreeBSD - wd0s3
   

Si votre tranche NTFS et votre tranche FreeBSD sont inversées et que vous avez installé NT avant FreeBSD, ce qui est d'ailleurs la méthode recommandée, vos numéros de tranches seront les mêmes, mais pas dans le même ordre :

FAT     - wd0s1
FreeBSD - wd0s3
NTFS    - wd0s2
   

Vous pouvez jeter un coup d'oeil au fichier /etc/fstab pour être sûr du numéro de la tranche FreeBSD (et également de celui de la tranche FAT).

Il y a cependant une exception à tout cela, lorsque votre tranche NTFS est une ``partition logique'' dans une ``partition étendue''. Les ``partitions logiques'' sont toujours numérotées à partir de 5, peut importe le nombre de ``partitions'' sur le disque. Mon disque, par exemple, est agencé comme ceci :

FAT                - sd0s1
FreeBSD            - sd0s3
Extended partition - sd0s2
              NTFS - sd0s5
   

Notez qu'une ``partition étendue'' se voit attribuer une tranche - ``slice'', mais celle-ci ne peut pas être utilisée en tant que telle, c'est-à-dire que vous ne pouvez pas la monter.

Après avoir identifié la tranche NTFS, vous pouvez ajouter une entrée dans le fichier /etc/fstab. Notez que l'option ro signifie que le montage se fera en lecture seule (souvenez-vous que le pilote est en lecture seule). Cette entrée provoquera le montage automatique de la tranche NTFS lors du démarrage. Si vous voulez désactiver cette dernière option, modifiez ro en ro,noauto, sans aucun espace ni avant ni après la virgule ! Vous aurez également besoin d'un point de montage, /ntfs dans cet exemple, ou si vous préferez, /mnt à la place de /ntfs dans le fichier /etc/fstab :

# Device            Mountpoint       FStype    Options          Dump     Pass#
/dev/sd0s5          /ntfs            ntfs      ro               0        0
   

Si vous préferez ne pas monter la ``partition'' au démarrage, montez-la ensuite en tant que root avec la commande :

# mount -t ntfs /dev/sd0s5 /ntfs

Bien entendu, ajustez le fichier de pilote de périphérique ainsi que le point de montage à votre système.

C'est fait ! Il ne reste plus qu'à redémarrer. Si vous avez choisi de monter la ``partition'' au démarrage, vous verrez s'afficher quelques messages de diagnostic tout à fait inoffensifs :

ntfs_init():
ntfs_mountfs(): bps: 512, spc: 1, media: f8, mftrecsz: 2 (2 sects)
ntfs_mountfs(): mftcn: 0x315e5|0x287245
ntfs_mountfs(): case-sens., uid: 0, gid: 0, mode: 777
ntfs_iget(): read $MFT ntnode
ntfs_mountfs(): reading $UpCase....OK
   

Bon courage !

Ce document, ainsi que d'autres peut être téléchargé sur ftp.FreeBSD.org/pub/FreeBSD/doc/.

Pour toutes questions à propos de FreeBSD, lisez la documentation avant de contacter <questions@FreeBSD.org>.
Pour les questions sur cette documentation, contactez <doc@FreeBSD.org>.

Hosting by: Hurra Communications GmbH
Generated: 2007-01-26 18:01:11