Я бачу щось по-справжньому дивне в середовищі Debian з хротованими видами armel
.
Але по-перше, трохи історії… Це довго, але питання складне, і будь-яка потенційна допомога залежить від знання повної історії.
У мене є вбудований ARM SoC, який працює під управлінням Linux - точніше, Debian armel
Lenny на ядрі 2.6.17. Сам дистрибутив Debian легко модернізувати до більш пізніх версій ( sudo apt-get dist-upgrade
) і таким чином може бути доведений до швидкості, до armel
версій
squeeze
або навіть wheezy
.
Проблема полягає в тому, що ядро - це нестандартне ... Запропонований ARM SoC не є частиною основного ядра, тому його в значній мірі занедбано в 2.6.17.
Якщо ви знаєте, як працюють Linux та GLIBC, ви вже можете побачити проблему - версії GLIBC компілюються з мінімально підтримуваною версією ядра ... Яка просунулася минуло 2.6.17. Тож якщо ми спробуємо, наприклад, chroot до Debian вичавити ...
$ # From inside the little ARM machine running Debian Lenny
$ sudo debootstrap --arch armel squeeze /squeeze \
http://ftp.whateverCountry.debian.org/debian
$ sudo -i
# mount -t proc none /squeeze/proc
# mount -t sysfs none /squeeze/sys
# mount -t devpts none /squeeze/dev/pts
# chroot /squeeze
Fatal: Kernel too old
... ми бачимо повідомлення від GLIBC від squeeze
, яке повідомляє нам, що воно не було складено для роботи зі цим старим ядром (2.6.17).
Ця ж проблема трапляється і з wheezy - оскільки вона є новішою, ніж стискання - і фактично відбуватиметься з будь-якою версією Debian відтепер, оскільки їх GLIBC не буде працювати на моєму ядрі 2.6.17.
Спочатку я подумав, що це розрив угоди, але потім я зрозумів, що теоретично можу перекомпілювати GLIBC для роботи зі старшим ядром, який використовує мій SoC ... Але мені знадобиться ідентичне середовище, яке було використано для створення libc6 пакет, наприклад, стиснення Debian.
Я здогадуюсь, компіляція GLIBC та підготовка файлу libc6_2.11.3-4.deb здійснюється за допомогою автоматизованої машини перехресного складання, винайденої богами Debian.
Я не Бог ... і я не міг знайти нічого в Google про те, як стати ним, тобто як використовувати свій Core i5 в якості хоста, щоб перехресно компілювати GLIBC, використовуючи ті самі налаштування, що і упакована версія (всередині Debian squeeze
) використовуючи.
Тому я обдурив це - я зрозумів, як налаштувати ARM-версію Debian на моєму Core i5 (методика, що використовує статичну версію qemu-arm
бінарного файлу).
Після того, як я зареєструвався у своїй версії, розміщеній на x86 Debian-armel-squeeze
, я зміг просто ...
$ cd /var/tmp
$ apt-get source libc6
...
$ # edit this in - compile for my kernel...
$ vi eglibc-2.11.3/debian/sysdeps/linux.mk
...
MIN_KERNEL_SUPPORTED := 2.6.17
...
$ export DEB_BUILD_OPTS="nocheck parallel=1"
$ cd eglibc-2.11.3
$ dpkg-buildpackage -b -d -us -uc
... і через 3 години (Core i5 з розміщеною версією
Debian-armel-squeeze
набагато повільніше, ніж рідна машина ...) я отримав свій пакет libc6 .deb. Можливо, це займе 3 місяці, щоб зробити цю збірку в моєму SoC, тому я не скаржусь.
Повернувшись всередину свого справжнього ARM SoC, я скопіював усі файли libc (.so) нового пакету через типові стискання та спробував chroot ...
# chroot squeeze/
root@ttsiodras:/#
Так! Це спрацювало! (або так здавалося)
Мій власний libc повідомив зсередини chroot:
# /lib/libc.so.6
GNU C Library (Debian EGLIBC 2.11.3-4) stable release version 2.11.3, by Roland McGrath et al.
Copyright (C) 2009 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.
Compiled by GNU CC version 4.4.5.
Compiled on a Linux 2.6.26 system on 2014-10-23.
Available extensions:
crypt add-on version 2.1 by Michael Glad and others
GNU Libidn by Simon Josefsson
Native POSIX Threads Library by Ulrich Drepper et al
Support for some architectures added on, not maintained in glibc core.
BIND-8.2.3-T5B
For bug reporting instructions, please see:
<http://www.debian.org/Bugs/>.
Начебто справи працювали - я скопіював файл, викликав ls
...
Але коли я спробував використати apt-get
для установки деяких додатків squeeze
, я почав отримувати ... деякі несподівані помилки:
# apt-get install indent
Reading package lists... Done
Building dependency tree... Done
The following NEW packages will be installed:
indent
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Need to get 110 kB of archives.
After this operation, 516 kB of additional disk space will be used.
Get:1 http://ftp.gr.debian.org/debian/ squeeze/main indent armel 2.2.11-1 [110 kB]
Fetched 110 kB in 0s (236 kB/s)
tar: ./control: Cannot utime: Function not implemented
tar: ./md5sums: Cannot utime: Function not implemented
tar: .: Cannot utime: Function not implemented
tar: Exiting with failure status due to previous errors
dpkg-deb: subprocess tar returned error exit status 2
dpkg: error processing /var/cache/apt/archives/indent_2.2.11-1_armel.deb (--unpack):
subprocess dpkg-deb --control returned error exit status 2
configured to not write apport reports
rm: cannot remove `/var/lib/dpkg/tmp.ci': Function not implemented
dpkg: error while cleaning up:
subprocess rm cleanup returned error exit status 1
Errors were encountered while processing:
/var/cache/apt/archives/indent_2.2.11-1_armel.deb
E: Sub-process /usr/bin/dpkg returned an error code (1)
О-о-о ... купа Function not implemented
. Це звучить як повідомлення GLIBC про те, що основні речі не працюють ...
Мені вдалося Трасування (не питайте , як) і з'ясували , що всі -at
функції зазнають невдачі: openat
, mkdirat
, renameat
і т.д. - всі вони ENOSYS звітності.
Здається, що я був частково успішним - деякі системні дзвінки провалюються в моєму новому GLIBC.
Чи неможливо скомпілювати a squeeze
чи wheeze
GLIBC для виконання згідно 2.6.17?
Будемо дуже вдячні за будь-які ідеї / вказівки щодо того, що я зробив неправильно та / або як робити далі ...