ARM لاءِ Ubuntu تصوير ٺاهڻ ”شروع کان“

جڏهن ترقي صرف شروع ٿئي ٿي، اهو اڪثر واضح ناهي ته ڪهڙا پيڪيجز ٽارگيٽ روٽفس ڏانهن ويندا.

ٻين لفظن ۾، LFS، buildroot يا yocto (يا ٻيو ڪجهه) تي قبضو ڪرڻ تمام جلدي آهي، پر توهان کي پهريان ئي شروع ڪرڻ جي ضرورت آهي. اميرن لاءِ (مون وٽ پائلٽ نمونن تي 4GB اي ايم ايم سي آهي) ڊولپرز کي ورهائڻ جو هڪ طريقو آهي جيڪو انهن کي جلدي ڪجهه پهچائڻ جي اجازت ڏيندو جيڪو في الحال غائب آهي، ۽ پوءِ اسان هميشه پيڪيجز جي لسٽ گڏ ڪري سگهون ٿا ۽ هڪ فهرست ٺاهي سگهون ٿا. ٽارگيٽ rootfs.

Данная статья не несет в себе новизны и представляет из себя простую copy-paste инструкцию.

آرٽيڪل جو مقصد ARM بورڊز لاءِ Ubuntu rootfs ٺاهڻ آهي (منهنجي صورت ۾، Colibri imx7d جي بنياد تي).

تصوير ٺاھڻ

اسان نقل لاءِ ٽارگيٽ روٽفس گڏ ڪندا آهيون.

Ubuntu بيس کي ڪڍڻ

اسان ضرورت ۽ اسان جي پنهنجي ترجيحن جي بنياد تي پاڻ کي ڇڏڻ جو انتخاب ڪندا آهيون. هتي مون کي 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

ڪنييل هيڊر فائلون ۽ ماڊل هڪ الڳ معاملو آهن. يقينن، اسان بوٽ لوڊر، ڪنييل، ماڊلز، ڊيوائس ٽري Ubuntu ذريعي انسٽال نه ڪنداسين. اهي ٻاهران اسان وٽ ايندا يا اسان انهن کي پاڻ گڏ ڪنداسين يا اهي اسان کي بورڊ ٺاهيندڙ طرفان ڏنا ويندا، ڪنهن به صورت ۾ اها هن هدايت جي دائري کان ٻاهر آهي.

ڪنهن حد تائين، نسخي جي ڦيرڦار قابل قبول آهي، پر اهو بهتر آهي ته انهن کي ڪنيبل تعمير کان وٺي.

# 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 انسٽال ڪري سگھون ٿا

خير، اچو ته چئو ته اسان اسان جي اسيمبلي کي ورهايو، ڪم شروع ڪيو ته ڪيئن اسان جي سسٽم جي مختلف ورزن کي گڏ ڪرڻ لاء بهترين.

etckeeper اسان جي مدد لاء اچي سگهي ٿو.

حفاظت هڪ ذاتي معاملو آهي:

  • توهان ڪجهه شاخن جي حفاظت ڪري سگهو ٿا
  • هر ڊوائيس لاء هڪ منفرد چيڪ ٺاهي
  • زور زبردستي کي بند ڪرڻ
  • وغيره ...
# 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
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 user chroot سان گڏ ڪرڻ
ARM لاءِ Ubuntu rootfs جي تعمير
ڪيئن ٺاھيو ڪسٽم Ubuntu لائيو شروع کان
Crossdev qemu-static-user-chroot
وغيره سنڀاليندڙ

getdents64 مسئلو

readdir() 32-bit ميزبان تي 64-bit استعمال ڪندڙ-static qemu لاءِ NULL (errno=EOVERFLOW) ڏي ٿو
Ext4 64 bit hash breaks 32 bit glibc 2.28+
compiler_id_detection armhf لاءِ ناڪام ٿيندو جڏهن QEMU يوزر موڊ ايموليشن استعمال ڪندي
CMake qemu-arm تحت صحيح ڪم نٿو ڪري

جو ذريعو: www.habr.com