Table of Contents

Додавання Multilib в Slackware з архітектурою x86_64

Це стаття містить інструкцію по тому, як створити справжню multilib Slackware64. Multilib 64-розрядний Linux, спроможний запускати як 64-х так і 32-х розрядні програми. Документ Стандарт ієрархії файлової системи описує метод, який є оптимальним для отримання чіткого розділення між 32-х та 64-х бітним програмним забезпеченням в одній системі. Коли була розпочата розробка порту (адаптованої версії) “Slackware64” (офіційний порт під архітектуру x86_64) ми вирішили адаптувати цей стандарт. Тому Slackware64 була налаштована шукати 64-х розрядні бібліотеки у директоріях /lib64 та /usr/lib64. Ось чому я називаю її Slackware64 “multilib-ready” - незважаючи на те, що 32-х розрядні бібліотеки вона буде шукати у директоріях /lib та /usr/lib, 32-х розрядних програм чи бібліотек, з системою Slackware64 не постачається. Користувачу потрібно зробити декілька рухів, перед тим як систему можна буде називати Slackware64 “multilib-enabled”.

Це досягається наступним чином:

  1. Спочатку нам потрібно перейти на multilib версії:
    • glibc (тобто glibc який підтримує запуск як 32-х так і 64-х розрядних програм), а також
    • gcc (так як він спроможний компілювати як 32-х так і 64-х розрядні програми).
  2. Після цього треба взяти системні бібліотеки з 32-х розрядної Slackware та встановити в 64-х розрядну, це завершить процес створення 32-х розрядного програмного шару.
Slackware для архітектури x86_64 (чи скорочено “Slackware64”) це чиста 64-х розрядна операційна система, але вона дуже просто може бути оновлена до multilib. З коробки Slackware64 може виконувати та збирати тільки 64-х розрядне програмне забезпечення.

Коли вийшла Skackware64, вона мала перевагу над 64-розрядними “форками” які були на той час доступні. Ці форки додавали 32-розрядний шар, завдяки перекомпіляції великої кількості своїх пакетів під 32-х розрядну архітектуру. З іншого боку, Slackware, дистрибутив який виходить як 32-х так і в 64-х розрядному вигляді, обидва варіанти розробляються паралельно. Це означає, що вам не доведеться знову збирати 32-х розрядні пакунки з нуля, для того щоб додати сумісність multilib до системи з архітектурою 64. Ви просто берете пакунки з 32-х розрядного дистрибутиву Slackware!
Ось чому ми не додаємо відразу multilib до Slackware64 - натомість ми створюємо передумову, завдяки якій у вас є вибір, та і інструкція по тому як зробити multilib систему.
В розділі нижче, я покажу як взяти пакунки 32-х розрядної Slackware (назвемо їх “mesa”) та переупакуємо їх вміст в пакунки “mesa-compat32”, які можна буде встановити напряму в Slackware64.

Переваги multilib системи

Ось декілька прикладів програмного забезпечення, яке потребує наявності multilib в системі Slackware з архітектурою 64, тому що воно не може бути запущено чи зібрано без сумісного 32-х розрядного шару:

На радість, 64-розрядні програми набувають все більшої популярності. Adobe довгий час не випускав, але з якоїсь миті, нарешті випустив Flash плагін для 64-х розрядних операційних систем. Sun (поглинутий компанією Oracle) випустили 64-х розрядну версію плагіна Java. Ці дві великі події подали сигнал, що треба розробляти 64-х розрядну версію - Slackware64.

Отримання мульти-бібліотечних пакунків

Ви можете завантажити пакет multilib-enabled та скрипти з мого веб-сайту: http://slackware.com/~alien/multilib/ .

Крім декількох README файлів (ця стаття з Wiki є поліпшеною версією тих README файлів), ви знайдете по одній під-дерикторії на кожен 64-розрядний випуск Slackware, відносно кореневої папки “multilib”. Також існує директорія під назвою “source”. В папці “source” знаходиться сирцевий код пакунків, та скрипти для збірки SlackBuild.
Але дійсно цікаве - бінарні пакунки, які доступні в під-директорії <slackware_номер_релізу> яка знаходиться під кореневою директорією. Кожна така директорія містить під-директорію “slackware64-compat32” де ви знайдете перезібрані 32-розрядні пакунки, готові для встановлення на 64-х розрядну Slackware.

Підтримання пакунків муьлти-бібліотечності в актуальному стані

Для того, щоб бути в курсі оновлень, Я наполягаю на тому, щоб ви слідкували за журналом змін (RSS новинами) які я обслуговую для моїх мульти-бібліотечних пакунків. За звичай, я оновлюю пакунки glibc та gcc наступного дня, після оновлення цих пакунків у Slackware.

Автоматизація:

  1. Перевірте інструмент compat32pkg Себастєна Балета, який автоматизує цей процес, на зразок як це робить slackpkg.
  2. Якщо ви віддаєте перевагу slackpkg, для керування пакетами, то варто, перевірити slackpkg+, це додаток до slackpkg, який керує пакунками, які ви встановили зі стороннього репозіторія - включаючи мільти-бібліотечність. Коли все правильно налаштовано, то підтримка оновленої версії мільти-бібліотечності дуже просте:
    # slackpkg update
    # slackpkg upgrade multilib
    # slackpkg install multilib

    Остання команда покаже якщо будь-який новий пакунок було додано до колекції пакунків “compat32”, як наприклад поточні llvm-compat32 та orc-compat32.

    • Як за звичай виглядає налаштування - для комп'ютера з запущеною Slackware-current, та використовуючи тестовий репозіторій Alien BOB-а для KDE. PKGS_PRIORITY Забезпечує, що мільти-бібліотечні пакунки для gcc та glibc має перевагу, над оригінальним від Slackware. Ключове слово “multilib” яке означає ім'я репозіторія, має бути таким самим ім'ям, яке використовувалось вище в команді “slackpkg”. Обране ім'я “multilib” довільне, воно могло б, точно так же бути “compat32”, до тих пір, поки ви використовуєте його послідовно.
      Зміст файлу для прикладу “/etc/slackpkg/slackpkgplus.conf” буде:
      SLACKPKGPLUS=on
      VERBOSE=1
      ALLOW32BIT=off
      USEBL=1
      WGETOPTS="--timeout=5 --tries=1"
      GREYLIST=on
      PKGS_PRIORITY=( multilib restricted alienbob ktown )
      REPOPLUS=( slackpkgplus multilib restricted alienbob ktown )
      MIRRORPLUS['multilib']=http://bear.alienbase.nl/mirrors/people/alien/multilib/current/
      MIRRORPLUS['alienbob']=http://bear.alienbase.nl/mirrors/people/alien/sbrepos/current/x86_64/
      MIRRORPLUS['restricted']=http://bear.alienbase.nl/mirrors/people/alien/restricted_sbrepos/current/x86_64/
      MIRRORPLUS['ktown']=http://bear.alienbase.nl/mirrors/alien-kde/current/latest/x86_64/
      MIRRORPLUS['slackpkgplus']=http://slakfinder.org/slackpkg+/

Включення підтримки мульти-бібліотечності в Slackware64

Інструкція по швидкому методу

Цей розділ містить основні інструкції щодо додавання повної мульти-бібліотечної сумісності в систему Slackware64. Якщо ви хочете зрозуміти більш детальніше цей процес, чи вам потрібна інформація по збірці 32-х розрядного ПЗ на Slackware64, вам треба ознайомитись з наступними розділами.
Увага, символ “#” означає що це командний рядок користувача root.

Якщо ви використовуєте пакетні менеджери, такі як slackpkg, ви повинні додати усі пакети з назвою glibc та gcc до чорного списку цього менеджеру. Якщо ви цього не зробите, ви ризикуєте тим, що цей менеджер може замінити, мульти-бібліотечні пакунки на оригінальні з Slackware64!
Якщо у вас запущено Slackware 13.37 чи вище, в цих версіях slackpkg, є підтримка регулярних виражень у файлі чорного списку. В цьому випадку, однієї стрічки у файлі /etc/slackpkg/blacklist буде достатньо для внесення усіх моїх пакунків до чорного списку (включаючи мульти-бібліотечні пакунки gcc, glibc та усіх compat32):
[0-9]+alien
[0-9]+compat32
Якщо ви працюєте на Slackware 13.1 чи новіше, та ви завантажили пакунок з інструментами compat32-tools для цієї версії Slackware, скрипт massconvert32.sh може використовувати віддалений веб сервер, для завантаження 32-х розрядних пакунків Slackware, замість завантаження їх до локального дзеркала чи з DVD. Вкажіть параметр ”-u“ як адресу URL віддаленого сервера:
# massconvert32.sh -u http://someserver.org/path/to/slackware-14.1/slackware

Детальніша інструкція

Оновлення glibc та gcc

Наступні пакунки glibc/gcc замінять - не додадуть - стандартні пакунки Slackware. Використайте команду ”upgradepkg“ для оновлення до моїх мільти-бібліотечних версій gcc та glibc. Вони потрібні для запуску (glibc), та збірки (gcc) 32-х розрядного програмного забезпечення на 64-х розрядному комп'ютері зі Slackware:

Slackware64 13.0

Slackware64 13.1

Slackware64 13.37

Slackware64 14.0

Slackware64 14.1

Slackware64 current

Ось один додатковий пакунок, який ви встановлюєте програмою “installpkg”:

Slamd64 має відокремлені версії 64-х та 32-х розрядні мульти-бібліотечні версії пакунків gcc/glibc.
Але, я вірю, в те, що найкраще не розділяти ці пакунки. Я слідую за принципом з Slakcware64 там свій пакунок binutils, який використовує 64-х та 32-розрядний мульти-бібліотечний сумісний шар в одному пакунку.

Додавання 32-х розрядних бібліотек Slackware

Оновлення glibc та gcc яке було описано вище, перемикає режим системи з ”multilib-ready“ на ”multilib-enabled“.
Все що вам треба, це встановити 32-х розрядні версії програмного забезпечення для Slackware , щоб в майбутньому ці 32-х розрядні програми знаходили 32-х розрядні бібліотеки які їм потрібні для запуску та роботи.

Цей процес не просто, встановлювання 32-х розрядного ПЗ в Slackware64:

Тут треба бути уважнішим, щоб не трапилась плутанина з файлами та їх розрядністю під час встановлення 32-х розрядних пакунків. Але вам треба 32-х розрядний пакунок, який не конфліктує з вже встановленим 64-х розрядним в системі. Його назва “32-х розрядний сумісний пакунок”.

Я вирішив, буде марно витрачено трафік, якщо я створю сумісні 32-х розрядні пакунки для Slackware. Та і велика вірогідність що ви придбали диск з Slackware 14.1 DVD, і у вас вже є обидві 64-х та 32-х розрядні версії цієї системи… чи є доступ до дерева пакунків Slackware яке доступно для безкоштовного завантаження ;-)

Напроти, я написав скрипт (частина нього написана Фредом Емотом для Slamd64) та включено до пакунка ”compat32-tools“. Цей скрипт запропонує, розпакувати вміст 32-х розрядного пакунку, та створення з нього нового пакунка, який можна буде встановлювати на 64-х розрядну Slackware.

Пакунок ”compat32-tools“ вимагає деякого розуміння.
Тому протчіть файл 'README' в директорії /usr/doc/compat32-tools-*/, це допоможе розібратись що до чого. В ньому є низька корисних скриптів, які встановлюються в систему:

# upgradepkg –install-new ~/compat32/*/*.t?z </code> параметр ”–install-new“ необхідний для, того щоб додати нові пакунки compat32 які були додані між версіями.

Коли встановлюються пакунки compat32, можна побачити помилки про відсутні файли в /etc. Це “так заплановано”, ці помилки можна проігнорувати. Ці повідомлення, говорять нам про той факт, що файли в /etc були видалені з пакунків ”-compat32“ в процесі конвертації (окрім pango та gtk+2). Мається на увазі, що файли в /etc, вже встановлені від оригінальних 64-х розрядних пакунків.
Приклад цієї “помилки” в пакунку cups-compat32:
Executing install script for cups-compat32-1.3.11-x86_64-1.txz.
install/doinst.sh: line 5: [: too many arguments
cat: etc/cups/interfaces: Is a directory
cat: etc/cups/ppd: Is a directory
cat: etc/cups/ssl: Is a directory
cat: etc/cups/*.new: No such file or directory
cat: etc/dbus-1/system.d/cups.conf.new: No such file or directory
chmod: cannot access `etc/rc.d/rc.cups.new': No such file or directory
cat: etc/rc.d/rc.cups.new: No such file or directory
Package cups-compat32-1.3.11-x86_64-1.txz installed.
Якщо ви плануєте використати скрипт convertpkg-compat32 для конвертації не-Slackware пакунка в -compat32, Я повинен вас попередити. Цей інструмент було створено лише для однієї задачі, це створення з 32-х розрядних пакунків в набір мільти-бібліотечності для Slackware64. Та такі дії як, вилучення деяких компонентів з оригінальних 32-х розрядних пакунків - компоненти які були встановлені як частина оригінальних 64-х розрядних пакунків.
В багатьох випадках, коли ви завантажуєте не-Slackware 32-х розрядний пакунок, та хочете щоб він запрацював на Slackware64, найліпше буде знайти сирцевий код цієї програми, та зібрати 64-х розрядну версію цього пакунка. Альтернативно, ви можете просто встановити оригінальній 32-х розрядний пакунок, замість “його конвертації”, та спробувати його запустити з командного рядка, щоб побачити помилки про відсутні 32х розрядні бібліотеки, які потрібно дістати з офіційних пакунків Slackware.

Запуск 32-х розрядних програм

Запуск вже зібраної 32-х розрядної програми, стане можливим, як тільки ви закінчите підготовку системи як показано вище. Залишиться тільки завантажити, встановити та запустити її!

Інколи, буде траплятись, що ви запустите програму яка потребує конкретні 32-х розрядні бібліотеки, яких у вас немає. В цьому випадку, знайдіть ці бібліотеки в 32-х розрядних пакунках Slackware. Використайте скрипт ”convertpkg-compat32“ для конвертації знайденого 32-х розрядного пакунку з необхідними бібліотеками у ”сумісний“ пакунок який можна буде встановити в Slackware64.

Компіляція 32-х розрядних програм

В тому випадку, якщо вам необхідно скомпілювати 32-х розрядне програмне забезпечення (wine та grub це яскраві приклади програм, які існують тільки в 32-х розрядному вигляді) знадобиться налаштувати оточення оболонки користувача root, запустивши команду:

# . /etc/profile.d/32dev.sh

Звернуть увагу на “крапку” в початку - це актуальна частина команди! Використання крапки еквівалентно використання команди 'source'.
Виконання цієї команди змінює декілька змінних оточення. Ефект від цього, це зміна пріоритету, 32-х розрядних версій бінарних файлів над 64-х розрядними, на час компіляції 32-х розрядного ПЗ з сирцевого коду. Ефект буде працювати доки ви не вийдете з оболонки користувача root.

В цій модифікованої оболонці, змінних оточення, ви можете використовувати стандартні SlackBuild для створення 32-х розрядних пакунків для Slackware64. Є декілька речей які треба пам’ятати:

  1. Ви повинні встановити значення змінної ARCH в 'i486', тому що, навіть на комп’ютері з архітектурою 'x86_64', ви збираєте 32-х розрядне ПЗ!
    Це пов’язано з triplet змінною “$ARCH-slackware-linux” який за звичай використовується в команді “configure”.
  2. Як виняток, ви повинні компілювати пакунок “wine” з змінною 'ARCH=x86_64', так як цей пакунок буде встановлюватись напряму в мульти-бібліотечну систему, без переконвертації в сумісний 'compat32' пакунок.
  3. Якщо ви хочете встановити цей 32-х розрядний пакунок в систему Slackware64-multilib, ви повинні спочатку конвертувати його в сумісний пакунок 'compat32':
    # convertpkg-compat32 -i /path/to/your/fresh/foo-VERSION-i486-BUILD.tgz
    # upgradepkg --install-new /tmp/foo-compat32-VERSION-x86_64-BUILDcompat32.txz

Застереження

Пакунки пере-конвертовані скриптом massconvert32.sh

Це список пакунків, які пере-конвертовано в сумісні пакунки ”-compat32“ скриптом massconvert32.sh. Увага, деякі з цих пакунків, не є частиною Slackware 13.0 чи 13.1, вони біли добавлені, з більш нових версій Slackware, вони можуть спричинити деякі сповіщення про помилки ”* FAIL: package 'package_name' was not found!*“ під час запуску цього скрипту на старих версіях Slackware. Навпаки вірно - деякі пакунки були вилучені в нових версіях Slackware які спричиняють сповіщення ”* FAIL: package 'package_name' was not found!*“. Не піклуйтесь про це.

# Серія A/:
 
aaa_elflibs
attr
bzip2
cups
cxxlibs
dbus
e2fsprogs
openssl-solibs
udev
util-linux
 
# Серія AP/:
 
flac
mariadb
mpg123
mysql
sqlite
 
# Серія D/:
 
libtool
 
# Серія L/:
 
alsa-lib
alsa-oss
atk
audiofile
cairo
dbus-glib
esound
expat
freetype
fribidi
gamin
gdk-pixbuf2
giflib
glib2
gmp
gnome-keyring
gtk+2
gst-plugins-base
gst-plugins-good
gstreamer
hal
harfbuzz
icu4c
jasper
lcms
lcms2
libart_lgpl
libelf
libexif
libffi
libglade
libgphoto2
libidn
libieee1284
libjpeg
libmng
libmpc
libogg
libpcap
libpng
libsamplerate
libsndfile
libtasn1
libtermcap
libtiff
libusb
libvorbis
libxml2
libxslt
ncurses
pango
popt
qt
readline
sdl
seamonkey-solibs
startup-notification
svgalib
v4l-utils
zlib
 
# Серія N/:
 
curl
cyrus-sasl
gnutls
libgcrypt
libgpg-error
nettle
openldap-client
openssl
p11-kit
 
# Серія X/:
 
fontconfig
freeglut
glew
glu
libFS
libICE
libSM
libX11
libXScrnSaver
libXTrap
libXau
libXaw
libXcomposite
libXcursor
libXdamage
libXdmcp
libXevie
libXext
libXfixes
libXfont
libXfontcache
libXft
libXi
libXinerama
libXmu
libXp
libXpm
libXprintUtil
libXrandr
libXrender
libXres
libXt
libXtst
libXv
libXvMC
libXxf86dga
libXxf86misc
libXxf86vm
libdmx
libdrm
libfontenc
libpciaccess
libxcb
mesa
pixman
xcb-util
 
# Серія XAP/:
 
sane
xsane

Дзеркала для завантаження пакунків мульти-бібліотечності

Ви можете завантажити пакунки мульти-бібліотечності з цих місць:

Сторонні інструменти

Переклади

Подяки

Удачі!

Ерік

Джерела