Table des matières:
- Étape 1: Exigences
- Étape 2: Configuration de l'hôte pour construire le noyau et construire le noyau dans l'HTE
- Étape 3: Reconstruisez Boot.img dans l'HTE
- Étape 4: Création du système de fichiers racine dans l'HTE
- Étape 5: Création du serveur NFS dans l'HTE et copie des fichiers
- Étape 6: Mise à jour de l'image de démarrage de Dragonboard 410c et configuration des interfaces réseau
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-13 06:57
Objectifs:
- Installez la chaîne d'outils et recompilez le noyau pour insérer la prise en charge du gadget USB Ethernet CDC;
- Recréez boot.img à partir de Linaro pour démarrer le CDC Ethernet USB;
- Créer un serveur NFS pour héberger le système de fichiers racine;
- Configuration IP dans DEVICE et HOST.
Étape 1: Exigences
Vous aurez besoin des éléments suivants:
- Un DragonBoard™ 410c (nommé ici DEVICE);
- Un PC utilisant Ubuntu 16.04.3 mis à jour (nommé ici HOST) avec connexion Internet et emplacement pour carte SDC;
- Une installation propre de Linaro-developer version 431 - Lien: Snapshot Linaro Debian v431
- Un moniteur HDMI;
- Un clavier USB;
- Une carte SD de 8 Go;
- Un câble USB, uUSB USB pour connecter l'APPAREIL sur HOST.
Étape 2: Configuration de l'hôte pour construire le noyau et construire le noyau dans l'HTE
Tout d'abord, nous allons créer tous les répertoires avant de continuer. Donc:
$ cd ~
$ mkdir db410remoteroot $ cd db410remoteroot $ chaîne d'outils mkdir $ mkdir db410c-modules
Malheureusement, le noyau Linux utilisé par Linaro (Version 431) ne prend pas en charge le gadget Ethernet USB, à cause de cela, le noyau Linux doit être reconstruit pour cette version spécifique. Téléchargez la chaîne d'outils Linaro pour créer et déployer le noyau Linux sur Dragonboard410c à partir de la machine hôte x86.
$ wget
$ tar -xf gcc-*-x86_64_aarch64-linux-gnu.tar.xz -C./toolchain --strip-components=1
Installez maintenant les packages nécessaires à la compilation du noyau:
$ sudo apt update && sudo apt-get install git build-essential abootimg kernel-package fakeroot libncurses5-dev libssl-dev ccache
Obtenez le référentiel Linux de l'équipe de débarquement de clone de la source du noyau Linux:
$ git clone
$ cd kernel $ git checkout origin/release/qcomlt-4.14 -b my-custom-4.14
Maintenant, définissez les variables d'environnement de compilation:
$ export ARCH=arm64
$ export CROSS_COMPILE=$(pwd)/../toolchain/bin/aarch64-linux-gnu-
À ce stade, nous devons ajouter les modules à USB Ethernet CDC dans le noyau. Je l'ai déjà fait et vous pouvez l'obtenir à la fin de cette étape. J'ai supprimé certains éléments mais ça marche.
Avant de compiler, veuillez corriger un bogue du noyau dans drivers/mmc/host/sdhci-msm.c en changeant la structure de la ligne 1150 en:
struct statique const sdhci_ops sdhci_msm_ops = {
. Reset = sdhci_reset,.set_clock = sdhci_msm_set_clock,.get_min_clock = sdhci_msm_get_min_clock,.get_max_clock = sdhci_msm_get_max_clock,.set_bus_width = sdhci_set_bus_width,.set_uhs_signaling = sdhci_msm_set_uhs_signaling,.voltage_switch = sdhci_msm_voltage_switch, #ifdef CONFIG_MMC_SDHCI_IO_ACCESSORS.write_w = sdhci_msm_write_w, #endif};
Décompressez configfile.zip, copiez le fichier.config dans le répertoire du noyau, construisez le noyau, les modules et installez les modules dans un répertoire:
$ make -j$(nproc) Image.gz dtbs
$ make -j$(nproc) modules $ make modules_install INSTALL_MOD_PATH=../db410c-modules
Référence: 96Boards Documentation
Étape 3: Reconstruisez Boot.img dans l'HTE
Dans cette étape, nous devons ouvrir l'image initrd, mettre les modules construits à l'intérieur de l'image, configurer le système pour démarrer ces modules et reconstruire un initrd.img avec une nouvelle ligne de commande du noyau pour démarrer le système de fichiers racine à distance.
Donc, tout d'abord, nous devons télécharger initrd.img depuis le site Web de Linaro:
$ cd..
$ mkdir inird_nfs $ cd initrd_nfs $ wget -O ramdisk.img
Maintenant, après le téléchargement, décompressez et extrayez l'initrd:
$ zcat ramdisk.img | cpio -idmv
Dans ce répertoire, nous avons le système de fichiers racine utilisé par le noyau lors de l'initialisation, nous allons donc configurer les modules CDC Ethernet USB et les paramètres distants NFS tels que l'adresse IP du serveur NFS et ethernet (usb) nécessaires ici.
Maintenant, configurons quelques fichiers:
conf/initramfs.conf:
MODULES=la plupart
BUSYBOX=auto COMPRESS=gzip DEVICE=usb0 NFSROOT=auto RUNSIZE=10%
Créez le répertoire init-premount dans le répertoire scripts/
$ mkdir scripts/init-premount
et ajoutez les fichiers dans le répertoire que vous venez de créer:
ORDRE
/scripts/init-premount/usb "$@"
[-e /conf/param.conf] &&. /conf/param.conf
USB
#!/bin/sh
PREREQ="" prereqs() { echo "$PEREQ" } case $1 dans # obtenir les prérequis prereqs) prereqs exit 0;; esac modprobe usb_f_ecm modprobe libcomposite modprobe usb_f_rndis modprobe g_ether
N'oubliez pas d'utiliser chmod dans le fichier usb pour le rendre exécutable:
$ chmod +x scripts/init-premount/usb
Maintenant, copiez tous les répertoires avec les modules de db410c-modules (STEP 2) vers lib/modules dans initrd:
$ cp -R../db410-modules/lib usr/
Supprimez tous les fichiers dans lib/modules/4.14.96-xxxx-dirty à l'exception de tous les fichiers module.* et cette liste de fichiers:
kernel/drivers/usb/gadget/legacy/g_ether.ko
kernel/drivers/usb/gadget/legacy/g_mass_storage.ko kernel/drivers/usb/gadget/legacy/g_cdc.ko kernel/drivers/usb/gadget/legacy/g_serial.ko kernel/drivers/usb/gadget/function/usb_f_mass_storage.ko kernel/drivers/usb/gadget/function/usb_f_acm.ko kernel/drivers/usb/gadget/function/u_ether.ko kernel/drivers/usb/gadget/function/usb_f_obex.ko kernel/drivers/usb/gadget/function /usb_f_serial.ko kernel/drivers/usb/gadget/function/usb_f_ecm.ko kernel/drivers/usb/gadget/function/usb_f_rndis.ko kernel/drivers/usb/gadget/function/u_serial.ko kernel/drivers/usb/gadget /function/usb_f_fs.ko kernel/drivers/usb/gadget/function/usb_f_ecm_subset.ko kernel/drivers/usb/gadget/libcomposite.ko
Ces fichiers sont tous les modules nécessaires pour démarrer USB Ethernet CDC.
Enfin remballez et compressez l'image initrd:
$ trouver. | cpio -o -H nouveauc | gzip -9 >../kernel/initrd_nfs.img
Au moins, l'image du noyau et le fichier DTB doivent être compressés dans une image de démarrage Android. Une telle image peut être générée avec l'outil abootimg.
Allons dans le répertoire du noyau et utilisons la commande ci-dessous pour créer l'image et ajouter DTB dans l'image du noyau compressé:
$ cd../noyau
$ cat arch/$ARCH/boot/Image.gz arch/$ARCH/boot/dts/qcom/apq8016-sbc.dtb > Image.gz+dtb
Et enfin, générez l'image de démarrage (ici notre rootfs se trouve une partition distante en 10.42.0.1)
abootimg --create boot-db410c.img -k Image.gz+dtb -r initrd_nfs.img -c pagesize=2048
-c kerneladdr=0x80008000 -c ramdiskaddr=0x810000000 -c cmdline="root=/dev/nfs nfsroot=10.42.0.1:/srv/nfs/rootfs ip=10.42.0.2:10.42.0.1:10.42.0.1:255.255.255.0:db410c:usb0:off rw rootwait console=tty0 console=ttyMSM0, 115200n8"
Les références:
- https://access.redhat.com/solutions/24029
- 96Boîtes Documentation
Étape 4: Création du système de fichiers racine dans l'HTE
Maintenant, nous avons une nouvelle image de démarrage pour mettre à jour le dragonboard 410c. Mais nous avons besoin d'un système de fichiers racine sur le serveur distant pour démarrer les modules, les services et les applications. Dans cette étape, nous allons créer un répertoire partagé dans l'hôte pour enregistrer toutes ces données. De cette façon, téléchargeons un système de fichiers rootfs depuis le site linaro avec la même version que celle utilisée dans initrd. Donc, revenez en arrière et téléchargez l'image rootfs de linaro-developer avec la version 431.
$ cd..
$ wget
Décompresser ce fichier
$ décompressez dragonboard-410c-sdcard-developer-buster-431.zip
En utilisant ce fichier, écrivons toutes les images dans une carte SD pour accéder à toutes les partitions et copier les fichiers rootfs. Assurez-vous donc que les données de la carte uSDCard sont sauvegardées, car tout ce qui se trouve sur la carte SDC sera perdu.
Pour trouver le nom de votre appareil SDCard, supprimez la SDCard et exécutez la commande suivante:
$ lsblk
Enregistrez dans votre esprit tous les noms de disques reconnus. Insérez maintenant la carte SD, attendez un moment et exécutez à nouveau la commande:
$ lsblk
Notez le disque nouvellement reconnu. Ce sera votre carte SD. Rappelez-vous votre nom et modifiez le paramètre "of=" pour le nom de votre périphérique SDCard et assurez-vous d'utiliser le nom du périphérique sans la partition, p.e.: /dev/mmcblk0
$ sudo dd if=dragonboard-410c-sdcard-developer-buster-431.img of=/dev/XXX bs=4M oflag=sync status=progress
Remarques:
- Cette commande prendra un certain temps à s'exécuter. Soyez patient et évitez de manipuler le terminal jusqu'à la fin du processus.
- Une fois que la carte SD a fini de clignoter, retirez-la de l'ordinateur hôte.
Référence: documentation 96boards
Étape 5: Création du serveur NFS dans l'HTE et copie des fichiers
À ce stade, nous avons une image de démarrage à flasher dans dragonboard 410c et une carte SDC avec un système de fichiers rootfs pour nos modules, services et applications. L'étape suivante consiste à créer un répertoire distant pour connecter le périphérique Ethernet USB avec le système de fichiers rootfs HOST. Cela peut être fait en utilisant un package d'Ubuntu nommé nfs-kernel-server.
Ce package installe un service NFS dans Ubuntu permettant de partager certains répertoires pour certains appareils sur le réseau, nous pouvons configurer quel répertoire sera utilisé pour chaque appareil en utilisant votre IP.
Alors, installons le package et configurons-le.
$ sudo apt-get install nfs-kernel-server
Le service NFS démarre automatiquement. Pour contrôler les services NFS, utilisez:
$ sudo service nfs-kernel-server restart // pour redémarrer, ou utilisez 'stop' ou 'start' selon vos besoins.
Pour vérifier l'état du service NFS à partir de la ligne de commande, utilisez:
$ sudo service nfs-kernel-server status
nfsd en cours d'exécution // Le service est actif nfsd ne fonctionne pas // Le service est en panne
Maintenant, créons un répertoire supérieur /srv/nfs et créons un sous-répertoire sous celui-ci pour chaque système de fichiers racine monté NFS requis. Ici, nous incluons un système de fichiers racine partagé pour conserver le nôtre:
$ sudo mkdir -p /srv/nfs
$ sudo mkdir -p /srv/nfs/rootfs
Désormais, le serveur NFS nécessite que /etc/exports soit configuré correctement, pour contrôler l'accès à chaque répertoire du système de fichiers NFS à des hôtes spécifiques. Dans ce cas, les hôtes sont identifiés par leur adresse IP. Ainsi, pour chaque système de fichiers racine créé, ajoutez la ligne de contrôle d'exportation à /etc/exports, en ajustant votre adresse IP locale et votre schéma de nommage de répertoire si nécessaire. Dans ce tutoriel, nous utilisons toujours cela:
/srv/nfs/rootfs 10.42.0.2(rw, sync, no_root_squash, no_subtree_check)
Insérez à nouveau votre carte SDC, montez-la et copiez tout le système de fichiers rootfs dans /srv/nfs/rootfs, redémarrez le service NFS pour mettre à jour le répertoire en utilisant les nouveaux fichiers copiés.
De plus, nous devons copier les nouveaux fichiers de modules dans le système de fichiers rootfs car nous avons compilé le noyau à l'étape 2. Copiez donc tous les répertoires de ~/db410c-modules/ dans /srv/nfs/rootfs.
$ sudo cp -R ~/db410c-modules/* /srv/nfs/rootfs/
Assurez-vous que ces répertoires sont rendus visibles par le service NFS. Soit:
$ sudo exportfs -a
Référence: Système de fichiers racine TFTP/NFS
Étape 6: Mise à jour de l'image de démarrage de Dragonboard 410c et configuration des interfaces réseau
Nous avons fait au début toutes les étapes pour implémenter un système de fichiers rootfs distant, maintenant nous devons mettre à jour l'image de démarrage à l'intérieur de dragonboard 410c, pour cela, connectez votre câble USB sur PC et sur le connecteur uUSB de dragonboard. Assurez-vous donc que fastboot est configuré sur l'ordinateur hôte, sinon installez-le en utilisant:
$ sudo apt installer fastboot
Maintenant, pour mettre à jour l'image, démarrez le dragonboard en mode fastboot en suivant ces étapes:
- Appuyez sur le bouton Vol (-) de la DragonBoard 410c et maintenez-le enfoncé, il s'agit du bouton S4. DragonBoard™ 410c ne doit toujours PAS être allumé
- Tout en maintenant le bouton Vol (-) enfoncé, allumez la DragonBoard 410c en la branchant
- Une fois la DragonBoard 410c branchée, relâchez votre appui sur le bouton Vol (-).
- Attendez environ 20 secondes.
- La carte devrait démarrer en mode de démarrage rapide.
À partir de la fenêtre du terminal de la machine hôte connectée, exécutez les commandes suivantes:
$ appareils de démarrage rapide sudo
Typiquement, il s'affichera comme ci-dessous
de82318 démarrage rapide
À ce stade, vous devez être connecté à votre DragonBoard 410c avec un câble USB vers microUSB. Votre DragonBoard 410c doit être démarré en mode de démarrage rapide et prêt à être flashé avec les images appropriées. Mettons à jour l'image de démarrage avec la nôtre image de démarrage:
$ sudo fastboot flash boot ~/db410remoteroot/kernel/initrd_nfs.img
Et, redémarrez la carte
$ sudo redémarrage rapide
Maintenant, votre HOST détectera une nouvelle interface nommée usb0, mais il n'a pas encore d'IP. Alors, ajoutez une IP statique à cette interface en utilisant:
$ sudo ifconfig usb0 10.42.0.1 netmask 255.255.255.0 up
Ou entrez dans "Configuration" sur HOST, dans l'élément "réseau", en définissant USB Ethernet une adresse IP statique sur cette interface.
Maintenant, redémarrez à nouveau le dragonboard et vérifiez le démarrage du système, en essayant de vous connecter en utilisant ssh:
$ ssh [email protected]
Les références:
- 96cartes documentation
- HowtoForge - Article 6