Krei Ubuntu-bildon por ARM "de nulo"

Kiam evoluo ĵus komenciĝas, estas ofte ne klare kiuj pakaĵoj iros al la celaj radikoj.

Alivorte, estas tro frue por kapti LFS, buildroot aŭ yocto (aŭ io alia), sed vi jam devas komenci. Por la riĉuloj (mi havas 4GB eMMC sur pilotspecimenoj) ekzistas eliro por distribui al programistoj distribuon kiu permesos al ili rapide liveri ion, kio nuntempe mankas, kaj tiam ni ĉiam povas kolekti listojn de pakaĵoj kaj krei liston por la celradikoj.

Ĉi tiu artikolo ne estas nova kaj estas simpla kopi-alglua instrukcio.

La celo de la artikolo estas konstrui Ubuntu-radikojn por ARM-tabuloj (en mia kazo, surbaze de Colibri imx7d).

Konstruante bildon

Ni kunvenas la celradikojn por reproduktado.

Malpakado de Ubuntu-Bazo

Ni mem elektas la liberigon laŭ bezono kaj niaj propraj preferoj. Ĉi tie mi donis 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

Kontrolante BINFMT-subtenon en la kerno

Se vi havas komunan distribuon, tiam ekzistas subteno por BINFMT_MISC kaj ĉio estas agordita, se ne, tiam mi certas, ke vi scias kiel ebligi BINFMT-subtenon en la kerno.

Certigu, ke BINFMT_MISC estas ebligita en la kerno:

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

Nun vi devas kontroli la agordojn:

$ 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

Vi povas registri permane uzante, ekzemple, jen ĉi tiuj instrukcioj.

Agordi qemu statikan brakon

Nun ni bezonas statike kunmetitan qemu-instancon.

!!! ATENTU!!!
Se vi planas uzi ujon por konstrui ion, kontrolu:
https://sourceware.org/bugzilla/show_bug.cgi?id=23960
https://bugs.launchpad.net/qemu/+bug/1805913
Tiam por x86_64 gastiganto kaj arma gasto vi devas uzi la i386-version de qemu:
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

Simpla skripto:

ch-monto.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

Ni admiras la rezulton:

$ ./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

Nur por amuzo, ni mezuru la grandecon antaŭ kaj post instalo de la minimuma (por mi) aro da pakaĵoj:

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

Ni ĝisdatigu:

# apt update
# apt upgrade --yes

Ni instalu la pakaĵojn pri kiuj ni interesiĝas:

# 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

Kernel-kapodosieroj kaj moduloj estas aparta afero. Kompreneble, ni ne instalos la ekŝargilon, kernon, modulojn, aparatarbon per Ubuntu. Ili venos al ni de ekstere aŭ ni mem kunvenos ilin aŭ ili estos donitaj al ni de la fabrikanto de la tabulo, ĉiukaze ĉi tio estas ekster la amplekso de ĉi tiu instrukcio.

Iagrade, versio-diverĝo estas akceptebla, sed estas pli bone preni ilin el la kerno-konstruo.

# apt install --yes linux-headers-generic

Ni vidu kio okazis kaj rezultis multe:

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

Ne forgesu agordi pasvorton.

Pakado de la bildo

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

Aldone, ni povas instali etckeeper kun la agordo de aŭtomata puŝo

Nu, ni diru, ke ni distribuis nian asembleon, la laboro komenciĝis pri kiel plej bone kunmeti poste malsamajn versiojn de nia sistemo.

etckeeper povas veni helpi nin.

Sekureco estas persona afero:

  • vi povas protekti certajn branĉojn
  • generi unikan ŝlosilon por ĉiu aparato
  • malŝalti forto-puŝon
  • ktp. ...
# ssh-keygen
# apt install etckeeper
# etckeeper init
# cd /etc
# git remote add origin ...

Ni agordu aŭtomatan puŝon

Ni povas, kompreneble, krei branĉojn sur la aparato anticipe (ni diru, ke ni faras skripton aŭ servon, kiu funkcios la unuan fojon kiam ĝi estas lanĉita).

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

Aŭ ni povas fari ion pli inteligentan...

Maldiligenta vojo

Ni havu ian unikan identigilon, diru la serian numeron de la procesoro (aŭ MAC - seriozaj kompanioj aĉetas la gamon):

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

Tiam ni povas uzi ĝin por la nomo de la branĉo al kiu ni puŝos:

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

Ni kreu simplan skripton:

# 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

Kaj jen ĉio - post iom da tempo ni povas rigardi la ŝanĝojn kaj krei liston de pakaĵoj por la cela firmvaro.

Rekomenditaj materialoj

BINFMT_MISC
Kerna Subteno por diversaj Binaraj Formatoj (binfmt_misc)
Kompilo kun qemu uzanto chroot
Konstruante Ubuntu-radikojn por ARM
Kiel krei kutiman Ubuntu-live de nulo
Crossdev qemu-static-user-chroot
ktp gardisto

getdents64 problemo

readdir() redonas NULL (errno=EOVERFLOW) por 32-bita uzanto-senmova qemu sur 64-bita gastiganto
Ext4 64-bita hash rompas 32-bitan glibc 2.28+
compiler_id_detection malsukcesas por armhf kiam oni uzas QEMU uzantreĝiman emuladon
CMake ne funkcias ĝuste sub qemu-arm

fonto: www.habr.com