Préparer les fichiers pour amorcer depuis le réseau avec TFTP Si votre machine est connectée à un réseau local, vous pouvez l'amorcer directement à partir d'une autre machine de ce réseau en utilisant TFTP. Pour cela, les fichiers d'amorçage doivent être placés à un endroit spécifique de cette machine et elle doit savoir amorcer votre propre machine. Vous devez configurer un serveur TFTP et, pour beaucoup de machines, un serveur DHCP, un serveur RARP ou un serveur BOOTP. Le protocole de recherche des adresses inverses (Reverse address Resolution Protocol ou RARP) est une solution pour indiquer à votre client l'adresse IP qu'il doit utiliser pour lui-même. Une autre solution est d'utiliser le protocole BOOTP. BOOTP est un protocole IP qui indique à un ordinateur quelle est son adresse IP et lui dit où obtenir sur le réseau une image d'amorçage. Il existe désormais une autre solution pour les systèmes VMEbus : l'adresse IP peut être configurée manuellement dans la ROM d'amorçage. Le protocole DHCP (« Dynamic Host Configuration Protocole », Protocole de configuration dynamique des hôtes) est une extension bien plus flexible de BOOTP (et respectant la compatibilité ascendante). Certains systèmes ne peuvent être configurés que par DHCP. Pour les PowerPC, si vous avez une machine Power Macintosh NewWorld, il vaut mieux utiliser DHCP plutôt que BOOTP. Certaines machines récentes ne peuvent pas s'amorcer avec BOOTP. À la différence du microprogramme Open Firmware que l'on trouve sur les machines SPARC et PowerPC, la console SRM n'utilisera pas RARP pour obtenir les adresses IP ; vous devrez donc utiliser BOOTP pour amorcer votre Alpha Les systèmes Alpha peuvent aussi s'amorcer depuis le réseau en utilisant MOP DECNet (« Maintenance Operations Protocol », protocole des opérations de maintenance), mais l'on n'en dira rien ici. Il est vraisemblable que votre opérateur local OpenVMS sera ravi de vous assister si vous ne pouvez résister à l'envie d'utiliser MOP pour amorcer Linux sur votre Alpha. depuis le réseau. Vous pouvez aussi entrer directement depuis la console VRM la configuration IP des interfaces réseau. Quelques vieilles machines HPPA (p. ex. 715/75) utilisent RBOOTD plutôt que BOOTP. Un paquet rbootd est disponible dans l'archive Debian. Le protocole trivial de transfert des fichiers (« Trivial File Transfert Protocol » ou TFTP) est utilisé pour transférer l'image d'amorçage au client. Théoriquement, tout serveur sur les plateformes qui implémentent ces protocoles peut être utilisé. Dans les exemples qui vont suivre, on donnera les commandes pour SunOS 4.x, SunOS 5.x (mieux connu sous le nom de Solaris) et GNU/Linux. Pour utiliser la méthode de démarrage par l'exécution d'un environnement de pré-amorçage (PXE) de TFTP, vous avez besoin d'un serveur TFTP avec tsize. Sur un serveur &debian;, les paquets atftpd et tftpd-hpa sont bons ; nous vous conseillons tftpd-hpa. &tftp-rarp.xml; &tftp-bootp.xml; &tftp-dhcp.xml; Activer le serveur TFTP Pour faire fonctionner le serveur TFTP, vous devez vous assurer au préalable que tftpd est activé. Ce dernier est généralement activé grâce à la ligne suivante dans /etc/inetd.conf : tftp dgram udp wait root /usr/sbin/tcpd in.tftpd /tftpboot Les paquets Debian, quand ils sont installés, placent correctement cette ligne. Les serveurs TFTP utilisaient habituellement le répertoire /tftpboot pour stocker les images. Cependant les paquets &debian; se servent d'autres répertoires pour obéir au standard sur l'organisation des fichiers. Par exemple, tftpd-hpa utilise par défaut /var/lib/tftpboot. Vous aurez à modifier les exemples de cette section. Lisez le fichier /etc/inetd.conf et mémorisez le répertoire passé en argument à in.tftpd L'option -l autorise certaines versions de in.tftpd à enregistrer toutes les requêtes dans le journal du système ; c'est extrêmement pratique en cas d'erreur d'amorçage.  ; vous en aurez besoin ultérieurement. Si vous avez dû modifier /etc/inetd.conf, vous devrez le signaler au processus inetd. Sur une machine Debian, lancez /etc/init.d/inetd reload ; sur les autres machines, retrouvez le numéro de processus de inetd et tuez-le avec la commande kill -HUP inetd-pid. Si vous voulez installer Debian sur une machine SGI et si votre serveur TFTP est une machine GNU/Linux avec Linux 2.4.X, il vous faudra effectuer la manœuvre suivante sur votre serveur : # echo 1 > /proc/sys/net/ipv4/ip_no_pmtu_disc de façon à empêcher la détection du MTU, sinon la PROM de la machine SGI ne pourra pas télécharger le nouveau noyau. En outre, assurez-vous que les paquets TFTP transitent par un port source inférieur à 32767 ou bien le téléchargement s'arrêtera après le premier paquet. Vous pouvez toujours contourner ce bogue de la PROM grâce au noyau 2.4.X en ajustant # echo "2048 32767" > /proc/sys/net/ipv4/ip_local_port_range pour fixer l'intervalle des ports source que le serveur TFTP peut utiliser. Mettre les images TFTP en place Ensuite, placez les images TFTP dont vous avez besoin (décrites dans la ) dans le répertoire des images d'amorçage de tftpd. Généralement, ce répertoire s'appelle /tftpboot. Vous aurez à faire un lien depuis ce fichier vers le fichier que tftpd utilisera pour amorcer le client. Malheureusement, le nom du fichier est déterminé par le client TFTP et il n'y a pas vraiment de standard. Sur les machines Power Macintosh NewWorld, vous devrez configurer le programme d'amorçage yaboot comme une image d'amorçage TFTP. Yaboot chargera les images du noyau et du disque virtuel à travers TFTP. Pour amorcer sur le réseau, utilisez yaboot-netboot.conf. Renommez-le simplement en yaboot.conf dans le répertoire TFTP. Pour le démarrage PXE, tout ce dont vous avez besoin est dans l'archive netboot/netboot.tar.gz. Extrayez les fichiers dans le répertoire de l'image tftpd. Assurez-vous que le serveur DHCP donnera bien le fichier pxelinux.0 comme fichier d'amorçage à tftpd. Pour le démarrage PXE, tout ce dont vous avez besoin est dans l'archive netboot/netboot.tar.gz. Extrayez les fichiers dans le répertoire de l'image tftpd. Assurez-vous que le serveur DHCP donnera bien le fichier /debian-installer/ia64/elilo.efi comme fichier d'amorçage à tftpd. Images TFTP pour les DECstation Pour les DECstation, il y a des fichiers tftpimage pour chaque sous-architecture ; ils contiennent à la fois un noyau et un installateur en un seul fichier. La convention de nommage est subarchitecture/netboot-boot.img. Copiez l'image tftp que vous allez utiliser dans /tftpboot/tftpboot.img si vous travaillez avec l'exemple de configuration de BOOTP/DHCP décrit plus haut. Le microprogramme des DECstation autorise l'amorçage via TFTP par la commande boot #/tftp# est le numéro de périphérique « TurboChannel » sur lequel amorcer. Sur la plupart des DECstation, c'est le numéro 3. Si le serveur BOOTP/DHCP ne fournit pas le nom du fichier ou si vous avez besoin de passer des paramètres supplémentaires, cela peut se faire avec la syntaxe suivante : boot #/tftp/filename param1=value1 param2=value2 ... Plusieurs révisions des microprogrammes des DECstation ont un problème avec l'amorçage sur le réseau : le transfert débute mais après un certain temps, il s'arrête avec a.out err. Il peut y avoir plusieurs causes : Le microprogramme ne répond pas à une requête ARP durant un transfert TFTP. Cela conduit à un timeout d'ARP et le transfert s'arrête. La solution est d'ajouter l'adresse MAC de la carte Ethernet dans la table ARP du serveur TFTP. On peut le faire avec arp -s IP-address MAC-address en tant que root sur la machine serveur TFTP. On peut lire l'adresse MAC de la DECstation en entrant cnfg à l'invite du microprogramme de la DECstation. Le microprogramme impose une taille limite aux fichiers utilisés pour amorcer par TFTP. Il y aussi des révisions de microprogramme qui ne peuvent pas s'amorcer du tout par TFTP, voyez les pages web de NetBSD. Amorçage TFTP pour Alpha Sur Alpha, vous devez spécifier le nom de fichier (le chemin étant relatif au répertoire de l'image d'amorçage) en utilisant l'argument -file de la commande boot de SRM ou en configurant la variable d'environnement BOOT_FILE. Vous pouvez aussi passer le nom de fichier via BOOTP (pour dhcpd ISC, utilisez la directive filename). À la différence d'Open Firmware, il n'y a pas de nom de fichier par défaut dans SRM et vous devez utiliser l'une de ces méthodes pour spécifier un nom de fichier. Amorçage TFTP pour SPARC Certaines architectures SPARC ajoutent au nom de fichier la sous-architecture, comme SUN4M ou SUN4C. Ainsi, si votre sous-architecture système est SUN4C et que son adresseIP est 192.168.1.3, le nom de fichier sera C0A80103.SUN4C. Cependant, pour certaines architectures, le fichier recherché est simplement client-ip-in-hex. Pour déterminer facilement ce nom et en supposant que l'adresse IP est 10.0.0.4, lancez un interpréteur de commandes et faites : $ printf '%.2x%.2x%.2x%.2x\n' 10 0 0 4 Il suffira de mettre les lettres en majuscule et d'ajouter le nom de la sous-architecture pour obtenir le nom du fichier. Vous pouvez aussi forcer certains systèmes SPARC à rechercher un nom de fichier spécifique en l'ajoutant à la fin de la commande d'amorçage de OpenPROM, p. ex. boot net my-sparc.image. Ce fichier doit bien sûr être présent dans un répertoire connu du serveur TFTP. Amorçage TFTP pour BVM/Motorola Pour BVM et les systèmes VMEbus Motorola, recopiez les fichiers &bvme6000-tftp-files; dans /tftpboot/. Ensuite, configurez votre ROM d'amorçage et votre serveur BOOTP pour charger en premier les fichiers tftplilo.bvme ou tftplilo.mvme du serveur TFTP. Reportez-vous au fichier tftplilo.txt de votre sous-architecture pour obtenir des informations supplémentaires sur la configuration de votre système. Amorçage TFTP pour SGI Sur les machines SGI, vous pouvez compter sur bootpd pour obtenir le nom du fichier TFTP. Il est donné soit par bf= dans /etc/bootptab ou bien par l'option filename= dans /etc/dhcpd.conf. Amorcer avec TFTP les cartes Broadcom BCM91250A et BCM91480B Il n'est pas utile de configurer DHCP car vous indiquerez à CFE l'adresse exacte du fichier qui doit être chargé.