"మొదటి నుండి" ARM కోసం ఉబుంటు చిత్రాన్ని సృష్టించడం

డెవలప్‌మెంట్ ఇప్పుడే ప్రారంభమైనప్పుడు, టార్గెట్ రూట్‌ఫ్‌లకు ఏ ప్యాకేజీలు వెళ్తాయో తరచుగా స్పష్టంగా తెలియదు.

మరో మాటలో చెప్పాలంటే, LFS, బిల్డ్‌రూట్ లేదా యోక్టో (లేదా మరేదైనా) పట్టుకోవడం చాలా తొందరగా ఉంది, కానీ మీరు ఇప్పటికే ప్రారంభించాలి. ధనవంతుల కోసం (పైలట్ శాంపిల్స్‌లో నా దగ్గర 4GB eMMC ఉంది) డెవలపర్‌లకు పంపిణీ చేయడానికి ఒక మార్గం ఉంది, ఇది ప్రస్తుతం తప్పిపోయిన వాటిని త్వరగా బట్వాడా చేయడానికి వీలు కల్పిస్తుంది, ఆపై మేము ఎల్లప్పుడూ ప్యాకేజీల జాబితాలను సేకరించి జాబితాను రూపొందించవచ్చు లక్ష్యం రూట్‌లు.

ఈ కథనం కొత్తది కాదు మరియు సాధారణ కాపీ-పేస్ట్ సూచన.

వ్యాసం యొక్క ఉద్దేశ్యం ARM బోర్డుల కోసం ఉబుంటు రూట్‌ఫ్‌లను రూపొందించడం (నా విషయంలో, Colibri imx7d ఆధారంగా).

చిత్రాన్ని నిర్మించడం

మేము ప్రతిరూపణ కోసం లక్ష్య రూట్‌లను సమీకరించాము.

ఉబుంటు బేస్‌ని అన్‌ప్యాక్ చేస్తోంది

అవసరం మరియు మా స్వంత ప్రాధాన్యతల ఆధారంగా మేము విడుదలను ఎంచుకుంటాము. ఇక్కడ నేను 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

కెర్నల్‌లో BINFMT మద్దతును తనిఖీ చేస్తోంది

మీకు సాధారణ పంపిణీ ఉంటే, BINFMT_MISCకి మద్దతు ఉంది మరియు ప్రతిదీ కాన్ఫిగర్ చేయబడింది, కాకపోతే, కెర్నల్‌లో BINFMT మద్దతును ఎలా ప్రారంభించాలో మీకు తెలుసని నేను ఖచ్చితంగా అనుకుంటున్నాను.

కెర్నల్‌లో 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

ఇప్పుడు మీరు సెట్టింగులను తనిఖీ చేయాలి:

$ 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

మీరు ఉపయోగించి మాన్యువల్‌గా నమోదు చేసుకోవచ్చు, ఉదాహరణకు, ఇక్కడ ఈ సూచనలు ఉన్నాయి.

qemu స్టాటిక్ ఆర్మ్‌ని సెటప్ చేస్తోంది

ఇప్పుడు మనకు స్థిరంగా అసెంబుల్ చేయబడిన qemu ఉదాహరణ అవసరం.

!!! శ్రద్ధ!!!
మీరు ఏదైనా నిర్మించడానికి కంటైనర్‌ను ఉపయోగించాలనుకుంటే, తనిఖీ చేయండి:
https://sourceware.org/bugzilla/show_bug.cgi?id=23960
https://bugs.launchpad.net/qemu/+bug/1805913
అప్పుడు x86_64 హోస్ట్ మరియు ఆర్మ్ గెస్ట్ కోసం మీరు i386 వెర్షన్ 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

క్రూట్

సాధారణ స్క్రిప్ట్:

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

మేము ఫలితాన్ని ఆరాధిస్తాము:

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

వినోదం కోసం, ప్యాకేజీల కనీస (నా కోసం) సెట్‌ను ఇన్‌స్టాల్ చేయడానికి ముందు మరియు తర్వాత పరిమాణాన్ని కొలుద్దాం:

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

అప్‌డేట్ చేద్దాం:

# apt update
# apt upgrade --yes

మనకు ఆసక్తి ఉన్న ప్యాకేజీలను ఇన్‌స్టాల్ చేద్దాం:

# 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

కెర్నల్ హెడర్ ఫైల్స్ మరియు మాడ్యూల్స్ ఒక ప్రత్యేక విషయం. వాస్తవానికి, మేము ఉబుంటు ద్వారా బూట్‌లోడర్, కెర్నల్, మాడ్యూల్స్, డివైస్ ట్రీని ఇన్‌స్టాల్ చేయము. వారు బయటి నుండి మా వద్దకు వస్తారు లేదా మేము వాటిని మనమే సమీకరించుకుంటాము లేదా అవి బోర్డు తయారీదారుచే మాకు ఇవ్వబడతాయి, ఏ సందర్భంలోనైనా ఇది ఈ సూచనల పరిధికి మించినది.

కొంత వరకు, వెర్షన్ డైవర్జెన్స్ ఆమోదయోగ్యమైనది, అయితే వాటిని కెర్నల్ బిల్డ్ నుండి తీసుకోవడం మంచిది.

# apt install --yes linux-headers-generic

ఏమి జరిగిందో చూద్దాం మరియు ఇది చాలా తేలింది:

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

పాస్‌వర్డ్‌ని సెట్ చేయడం మర్చిపోవద్దు.

చిత్రాన్ని ప్యాక్ చేస్తోంది

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

Дополнительно можем поставить etckeeper с настройкой autopush

సరే, మేము మా అసెంబ్లీని పంపిణీ చేసాము అని అనుకుందాం, మా సిస్టమ్ యొక్క తరువాతి విభిన్న సంస్కరణలను ఎలా సమీకరించాలనే దానిపై పని ప్రారంభమైంది.

etc కీపర్ మా సహాయానికి రావచ్చు.

భద్రత అనేది వ్యక్తిగత విషయం:

  • మీరు కొన్ని శాఖలను రక్షించవచ్చు
  • ప్రతి పరికరం కోసం ఒక ప్రత్యేక కీని రూపొందించండి
  • ఫోర్స్ పుష్ డిసేబుల్
  • మొదలైనవి ...
# ssh-keygen
# apt install etckeeper
# etckeeper init
# cd /etc
# git remote add origin ...

ఆటోపుష్‌ని సెటప్ చేద్దాం

మేము, వాస్తవానికి, పరికరంలో ముందుగానే శాఖలను సృష్టించగలము (మేము ఒక స్క్రిప్ట్ లేదా సేవను ప్రారంభించాము, అది మొదటిసారిగా అమలు చేయబడుతుందని అనుకుందాం).

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

లేదా మనం తెలివిగా ఏదైనా చేయగలం...

సోమరి మార్గం

ప్రాసెసర్ యొక్క క్రమ సంఖ్యను చెప్పండి (లేదా MAC - తీవ్రమైన కంపెనీలు పరిధిని కొనుగోలు చేస్తాయి):

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

అప్పుడు మనం పుష్ చేసే శాఖ పేరు కోసం దీనిని ఉపయోగించవచ్చు:

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

సరళమైన స్క్రిప్ట్‌ని క్రియేట్ చేద్దాం:

# 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

మరియు అంతే - కొంతకాలం తర్వాత మేము మార్పులను చూడవచ్చు మరియు లక్ష్య ఫర్మ్‌వేర్ కోసం ప్యాకేజీల జాబితాను సృష్టించవచ్చు.

సిఫార్సు చేయబడిన పదార్థాలు

BINFMT_MISC
ఇతర బైనరీ ఫార్మాట్‌ల కోసం కెర్నల్ మద్దతు (binfmt_misc)
qemu వినియోగదారు chrootతో కంపైల్ చేస్తోంది
ARM కోసం ఉబుంటు రూట్‌ఫ్‌లను రూపొందించడం
మొదటి నుండి కస్టమ్ ఉబుంటు లైవ్‌ను ఎలా సృష్టించాలి
Crossdev qemu-static-user-chroot
మొదలైనవాడు

getdents64 సమస్య

readdir() 32-బిట్ హోస్ట్‌లో 64-బిట్ యూజర్ స్టాటిక్ క్యూము కోసం NULL (errno=EOVERFLOW)ని అందిస్తుంది
Ext4 64 బిట్ హాష్ 32 బిట్ glibc 2.28+ని విచ్ఛిన్నం చేస్తుంది
QEMU యూజర్-మోడ్ ఎమ్యులేషన్‌ని ఉపయోగిస్తున్నప్పుడు armhf కోసం compiler_id_detection విఫలమవుతుంది
qemu-arm కింద CMake సరిగ్గా పని చేయదు

మూలం: www.habr.com