Ubuntu attēla izveide ARM “no nulles”

Kad izstrāde tikai sākas, bieži vien nav skaidrs, kuras pakotnes nonāks mērķa rootfs.

Citiem vārdiem sakot, ir pāragri izmantot LFS, buildroot vai yocto (vai ko citu), taču jums jau ir jāsāk. Bagātajiem (man ir 4GB eMMC uz izmēģinājuma paraugiem) ir izeja, kā izplatīt izstrādātājiem tādu izplatīšanu, kas ļaus ātri piegādāt kaut ko, kas šobrīd trūkst, un tad mēs vienmēr varam apkopot pakotņu sarakstus un izveidot sarakstu mērķa saknes.

Šis raksts nav jauns, un tas ir vienkāršs kopēšanas un ielīmēšanas norādījums.

Raksta mērķis ir izveidot Ubuntu rootfs ARM dēļiem (manā gadījumā, pamatojoties uz Colibri imx7d).

Tēla veidošana

Mēs apkopojam mērķa saknes replikācijai.

Ubuntu bāzes izpakošana

Izlaidumu mēs izvēlamies paši, pamatojoties uz vajadzībām un savām vēlmēm. Šeit es iedevu 20.

$ mkdir ubuntu20
$ cd ubuntu20
$ mkdir rootfs
$ wget http://cdimage.ubuntu.com/ubuntu-base/releases/20.04/release/ubuntu-base-20.04-base-armhf.tar.gz
$ tar xf ubuntu-base-20.04-base-armhf.tar.gz -C rootfs

Pārbauda BINFMT atbalstu kodolā

Ja jums ir kopīgs sadalījums, tad ir BINFMT_MISC atbalsts un viss ir konfigurēts, ja nē, tad esmu pārliecināts, ka jūs zināt, kā kodolā iespējot BINFMT atbalstu.

Pārliecinieties, vai kodolā ir iespējots BINFMT_MISC:

$ zcat /proc/config.gz | grep BINFMT
CONFIG_BINFMT_ELF=y
CONFIG_COMPAT_BINFMT_ELF=y
CONFIG_BINFMT_SCRIPT=y
CONFIG_BINFMT_MISC=y

Tagad jums ir jāpārbauda iestatījumi:

$ ls /proc/sys/fs/binfmt_misc
qemu-arm  register  status
$ cat /proc/sys/fs/binfmt_misc/qemu-arm
enabled
interpreter /usr/bin/qemu-arm
flags: OC
offset 0
magic 7f454c4601010100000000000000000002002800
mask ffffffffffffff00fffffffffffffffffeffffff

Jūs varat reģistrēties manuāli, izmantojot, piemēram, šeit ir šīs instrukcijas.

Qemu statiskās rokas iestatīšana

Tagad mums ir nepieciešams statiski samontēts qemu gadījums.

!!! UZMANĪBU!!!
Ja plānojat izmantot konteineru, lai kaut ko izveidotu, pārbaudiet:
https://sourceware.org/bugzilla/show_bug.cgi?id=23960
https://bugs.launchpad.net/qemu/+bug/1805913
Pēc tam x86_64 saimniekdatoram un arm viesim ir jāizmanto qemu i386 versija:
http://ftp.ru.debian.org/debian/pool/main/q/qemu/qemu-user-static_5.0-13_i386.deb

$ wget http://ftp.debian.org/debian/pool/main/q/qemu/qemu-user-static_5.0-13_amd64.deb
$ alient -t qemu-user-static_5.0-13_amd64.deb
# путь в rootfs и имя исполняемого файла должно совпадать с /proc/sys/fs/binfmt_misc/qemu-arm
$ mkdir qemu
$ tar xf qemu-user-static-5.0.tgz -C qemu
$ file qemu/usr/bin/qemu-arm-static
qemu/usr/bin/qemu-arm-static: ELF 64-bit LSB executable, x86-64, version 1 (GNU/Linux), statically linked, BuildID[sha1]=be45f9a321cccc5c139cc1991a4042907f9673b6, for GNU/Linux 3.2.0, stripped
$ cp qemu/usr/bin/qemu-arm-static rootfs/usr/bin/qemu-arm
$ file rootfs/usr/bin/qemu-arm
rootfs/usr/bin/qemu-arm: ELF 64-bit LSB executable, x86-64, version 1 (GNU/Linux), statically linked, BuildID[sha1]=be45f9a321cccc5c139cc1991a4042907f9673b6, for GNU/Linux 3.2.0, stripped

chroot

Vienkāršs skripts:

ch-mount.sh

#!/bin/bash

function mnt() {
    echo "MOUNTING"
    sudo mount -t proc /proc proc
    sudo mount --rbind /sys sys
    sudo mount --make-rslave sys
    sudo mount --rbind /dev dev
    sudo mount --make-rslave dev
    sudo mount -o bind /dev/pts dev/pts
    sudo chroot 
}

function umnt() {
    echo "UNMOUNTING"
    sudo umount proc
    sudo umount sys
    sudo umount dev/pts
    sudo umount dev

}

if [ "$1" == "-m" ] && [ -n "$2" ] ;
then
    mnt $1 $2
elif [ "$1" == "-u" ] && [ -n "$2" ];
then
    umnt $1 $2
else
    echo ""
    echo "Either 1'st, 2'nd or both parameters were missing"
    echo ""
    echo "1'st parameter can be one of these: -m(mount) OR -u(umount)"
    echo "2'nd parameter is the full path of rootfs directory(with trailing '/')"
    echo ""
    echo "For example: ch-mount -m /media/sdcard/"
    echo ""
    echo 1st parameter : 
    echo 2nd parameter : 
fi

Mēs apbrīnojam rezultātu:

$ ./ch-mount.sh -m rootfs/
# cat /etc/os-release
NAME="Ubuntu"
VERSION="20.04 LTS (Focal Fossa)"
ID=ubuntu
ID_LIKE=debian
PRETTY_NAME="Ubuntu 20.04 LTS"
VERSION_ID="20.04"
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
VERSION_CODENAME=focal
UBUNTU_CODENAME=focal
# uname -a
Linux NShubin 5.5.9-gentoo-x86_64 #1 SMP PREEMPT Mon Mar 16 14:34:52 MSK 2020 armv7l armv7l armv7l GNU/Linux

Izklaidei izmērīsim izmēru pirms un pēc minimālā (man) pakotņu komplekta instalēšanas:

# du -d 0 -h / 2>/dev/null
63M     /

Atjaunināsim:

# apt update
# apt upgrade --yes

Instalēsim mums interesējošās pakotnes:

# SYSTEMD_IGNORE_CHROOT=yes apt install --yes autoconf kmod socat ifupdown ethtool iputils-ping net-tools ssh g++ iproute2 dhcpcd5 incron ser2net udev systemd gcc minicom vim cmake make mtd-utils util-linux git strace gdb libiio-dev iiod

Kodola galvenes faili un moduļi ir atsevišķa lieta. Protams, caur Ubuntu mēs neinstalēsim sāknēšanas ielādētāju, kodolu, moduļus, ierīču koku. Tie atnāks pie mums no ārpuses vai mēs paši saliksim, vai arī tos mums iedos plātņu ražotājs, jebkurā gadījumā tas ir ārpus šīs instrukcijas.

Zināmā mērā versiju atšķirības ir pieņemamas, taču labāk tās ņemt no kodola versijas.

# apt install --yes linux-headers-generic

Apskatīsim, kas notika, un tas izrādījās daudz:

# apt clean
# du -d 0 -h / 2>/dev/null
770M    /

Neaizmirstiet iestatīt paroli.

Attēla iepakošana

$ sudo tar -C rootfs --transform "s|^./||" --numeric-owner --owner=0 --group=0 -c ./ | tar --delete ./ | gzip > rootfs.tar.gz

Turklāt mēs varam instalēt etckeeper ar autopush iestatījumu

Nu, pieņemsim, ka mēs izplatījām savu montāžu, sākās darbs pie tā, kā vislabāk salikt vēlāk dažādas mūsu sistēmas versijas.

etckeeper var nākt mums palīgā.

Drošība ir personiska lieta:

  • jūs varat aizsargāt noteiktus zarus
  • ģenerēt unikālu atslēgu katrai ierīcei
  • atspējot spēka spiedienu
  • utt. ...
# ssh-keygen
# apt install etckeeper
# etckeeper init
# cd /etc
# git remote add origin ...

Iestatīsim automātisko push

Mēs, protams, varam ierīcē izveidot filiāles jau iepriekš (pieņemsim, ka mēs izveidojam skriptu vai pakalpojumu, kas darbosies, kad tas tiks palaists pirmo reizi).

# cat /etc/etckeeper/etckeeper.conf
PUSH_REMOTE="origin"

Vai arī varam darīt kaut ko gudrāku...

Slinks veids

Ļaujiet mums izveidot kādu unikālu identifikatoru, piemēram, procesora sērijas numuru (vai MAC — nopietni uzņēmumi pērk diapazonu):

cat / proc / cpuinfo

# cat /proc/cpuinfo
processor       : 0
model name      : ARMv7 Processor rev 5 (v7l)
BogoMIPS        : 60.36
Features        : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstrm 
CPU implementer : 0x41
CPU architecture: 7
CPU variant     : 0x0
CPU part        : 0xc07
CPU revision    : 5

processor       : 1
model name      : ARMv7 Processor rev 5 (v7l)
BogoMIPS        : 60.36
Features        : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstrm 
CPU implementer : 0x41
CPU architecture: 7
CPU variant     : 0x0
CPU part        : 0xc07
CPU revision    : 5

Hardware        : Freescale i.MX7 Dual (Device Tree)
Revision        : 0000
Serial          : 06372509

Tad mēs to varam izmantot filiāles nosaukumam, uz kuru mēs nosūtīsim:

# cat /proc/cpuinfo | grep Serial | cut -d':' -f 2 | tr -d [:blank:]
06372509

Izveidosim vienkāršu skriptu:

# cat /etc/etckeeper/commit.d/40myown-push
#!/bin/sh
set -e

if [ "$VCS" = git ] && [ -d .git ]; then
  branch=$(cat /proc/cpuinfo | grep Serial | cut -d':' -f 2 | tr -d [:blank:])
  cd /etc/
  git push origin master:${branch}
fi

Un tas arī viss - pēc kāda laika mēs varam apskatīt izmaiņas un izveidot pakotņu sarakstu mērķa programmaparatūrai.

Ieteicamie materiāli

BINFMT_MISC
Kodola atbalsts dažādiem binārajiem formātiem (binfmt_misc)
Kompilēšana ar qemu lietotāja chroot
Ubuntu saknes izveide ARM
Kā izveidot pielāgotu Ubuntu tiešraidē no nulles
Crossdev qemu-static-user-chroot
utt apsaimniekotājs

getdents64 problēma

readdir() atgriež NULL (errno=EOVERFLOW) 32 bitu lietotāja statiskajam qemu 64 bitu resursdatorā
Ext4 64 bitu hash pārtrauc 32 bitu glibc 2.28+
compiler_id_detection neizdodas armhf, izmantojot QEMU lietotāja režīma emulāciju
CMake nedarbojas pareizi zem qemu-arm

Avots: www.habr.com