Це стаття містить інструкцію по тому, як створити справжню 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”.
Це досягається наступним чином:
Коли вийшла Skackware64, вона мала перевагу над 64-розрядними “форками” які були на той час доступні. Ці форки додавали 32-розрядний шар, завдяки перекомпіляції великої кількості своїх пакетів під 32-х розрядну архітектуру. З іншого боку, Slackware, дистрибутив який виходить як 32-х так і в 64-х розрядному вигляді, обидва варіанти розробляються паралельно. Це означає, що вам не доведеться знову збирати 32-х розрядні пакунки з нуля, для того щоб додати сумісність multilib до системи з архітектурою 64. Ви просто берете пакунки з 32-х розрядного дистрибутиву Slackware!
Ось чому ми не додаємо відразу multilib до Slackware64 - натомість ми створюємо передумову, завдяки якій у вас є вибір, та і інструкція по тому як зробити multilib систему.
В розділі нижче, я покажу як взяти пакунки 32-х розрядної Slackware (назвемо їх “mesa”) та переупакуємо їх вміст в пакунки “mesa-compat32”, які можна буде встановити напряму в Slackware64.
Ось декілька прикладів програмного забезпечення, яке потребує наявності 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.
Автоматизація:
# slackpkg update # slackpkg upgrade multilib # slackpkg install multilib
Остання команда покаже якщо будь-який новий пакунок було додано до колекції пакунків “compat32”, як наприклад поточні llvm-compat32 та orc-compat32.
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. Якщо ви хочете зрозуміти більш детальніше цей процес, чи вам потрібна інформація по збірці 32-х розрядного ПЗ на Slackware64, вам треба ознайомитись з наступними розділами.
Увага, символ “#
” означає що це командний рядок користувача root.
# SLACKVER=14.2 # mkdir multilib # cd multilib # lftp -c "open http://taper.alienbase.nl/mirrors/people/alien/multilib/ ; mirror -c -e ${SLACKVER}" # cd ${SLACKVER}
# upgradepkg --reinstall --install-new *.t?z
після того як ви перейшли до директорії в яку завантажили ці пакунки.
Ця команда встановить допоміжні пакунки під назвою ”compat32-tools“.
lftp
“ робить це автоматично) ви будете раді пізнати, що необхідні 32-х розрядні пакунки вже перетворенні як треба! Все що від вас потрібно, це виконати команду: # upgradepkg --install-new slackware64-compat32/*-compat32/*.t?z
яка встановить відконвертовані 32-х розрядні пакунки (чи оновить їх, якщо вони вже були встановлені зі старої версії мульти-бібліотечності). Це все!
/home/ftp/pub/slackware/slackware-14.1/slackware/
“./media/SlackDVD/slackware/
“ але цей варіант я тут не використовую).# mkdir slackware64-compat32 ; cd slackware64-compat32
# massconvert32.sh -i /home/ftp/pub/slackware/slackware-14.1/slackware/
# upgradepkg --install-new *-compat32/*.t?z
glibc
та gcc
до чорного списку цього менеджеру. Якщо ви цього не зробите, ви ризикуєте тим, що цей менеджер може замінити, мульти-бібліотечні пакунки на оригінальні з Slackware64!/etc/slackpkg/blacklist
буде достатньо для внесення усіх моїх пакунків до чорного списку (включаючи мульти-бібліотечні пакунки gcc, glibc та усіх compat32
): [0-9]+alien [0-9]+compat32
# massconvert32.sh -u http://someserver.org/path/to/slackware-14.1/slackware
Наступні пакунки glibc/gcc замінять - не додадуть - стандартні пакунки Slackware. Використайте команду ”upgradepkg
“ для оновлення до моїх мільти-бібліотечних версій gcc та glibc. Вони потрібні для запуску (glibc), та збірки (gcc) 32-х розрядного програмного забезпечення на 64-х розрядному комп'ютері зі Slackware:
Ось один додатковий пакунок, який ви встановлюєте програмою “installpkg”:
Оновлення glibc та gcc яке було описано вище, перемикає режим системи з ”multilib-ready“ на ”multilib-enabled“.
Все що вам треба, це встановити 32-х розрядні версії програмного забезпечення для Slackware , щоб в майбутньому ці 32-х розрядні програми знаходили 32-х розрядні бібліотеки які їм потрібні для запуску та роботи.
Цей процес не просто, встановлювання 32-х розрядного ПЗ в Slackware64:
/usr/bin/foo
), вони перезапишуть 64-х розрядні оригінали, коли ви будете встановлювати 32-х розрядний пакунок поверх існуючого 64-х розрядного. Це буде дуже фатально, якщо таке трапиться.Тут треба бути уважнішим, щоб не трапилась плутанина з файлами та їх розрядністю під час встановлення 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-*/
, це допоможе розібратись що до чого. В ньому є низька корисних скриптів, які встановлюються в систему:
x/mesa-7.5-i486-1.txz
) та виконуєте команду # convertpkg-compat32 -i /path/to/mesa-7.5-i486-1.txz
яка створить новий пакунок під назвою mesa-compat32-7.5-x86_64-1.txz
. Новий пакунок (який було створено у директорії '/tmp' у випадку якщо ви не вказали іншу директорію для зберігання) це старий 32-х розрядний пакунок, але з нього вилучено не потрібні частини. Змінено ім’я (mesa стало mesa-compat32) що дозволяє встановити цей пакунок в Slackware64 де вже є 64-х розрядна mesa не перезаписав вже встановлений пакунок.
Скрипт залишає тимчасові файли у директорії ”/tmp/package-<prgnam>-compat32
“ які можна безпечно видалити.
/mnt/dvd
):# massconvert32.sh -i /mnt/dvd/slackware -d ~/compat32
Після цього, у вас з’явиться пакунки близько 60Мб в новій директорії ~/compat32
(ім’я цієї директорії можна налаштовувати, я вибрав таке ім’я лише для прикладу). Ці пакунки включають 32-х розрядні компоненти для мульти-бібліотечної Slackware64.
Їх треба встновити використовуючи ”installpkg
“, зо надасть шар сумісності, поверх Slackware64:
# installpkg ~/compat32/*/*.t?z
Якщо ви виконуєте оновлення з попередньої версії цих пакунків (на приклад ви оновлюєте 64-х розрядну Slackware до нової версії) це означає, що використовувати ”installpkg
“ не можна, а замість цієї команди, треба виконати ”upgradepkg –install-new
“: code>
# 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-х розрядних пакунків.Запуск вже зібраної 32-х розрядної програми, стане можливим, як тільки ви закінчите підготовку системи як показано вище. Залишиться тільки завантажити, встановити та запустити її!
Інколи, буде траплятись, що ви запустите програму яка потребує конкретні 32-х розрядні бібліотеки, яких у вас немає. В цьому випадку, знайдіть ці бібліотеки в 32-х розрядних пакунках Slackware. Використайте скрипт ”convertpkg-compat32“ для конвертації знайденого 32-х розрядного пакунку з необхідними бібліотеками у ”сумісний“ пакунок який можна буде встановити в Slackware64.
В тому випадку, якщо вам необхідно скомпілювати 32-х розрядне програмне забезпечення (wine та grub це яскраві приклади програм, які існують тільки в 32-х розрядному вигляді) знадобиться налаштувати оточення оболонки користувача root, запустивши команду:
# . /etc/profile.d/32dev.sh
Звернуть увагу на “крапку” в початку - це актуальна частина команди! Використання крапки еквівалентно використання команди 'source'.
Виконання цієї команди змінює декілька змінних оточення. Ефект від цього, це зміна пріоритету, 32-х розрядних версій бінарних файлів над 64-х розрядними, на час компіляції 32-х розрядного ПЗ з сирцевого коду. Ефект буде працювати доки ви не вийдете з оболонки користувача root.
В цій модифікованої оболонці, змінних оточення, ви можете використовувати стандартні SlackBuild для створення 32-х розрядних пакунків для Slackware64. Є декілька речей які треба пам’ятати:
# convertpkg-compat32 -i /path/to/your/fresh/foo-VERSION-i486-BUILD.tgz # upgradepkg --install-new /tmp/foo-compat32-VERSION-x86_64-BUILDcompat32.txz
-compat32
“, ви повинні пере-встановити бінарні драйвери X.Org для Nvidia чи Ati. Ці пакунки містять обидва варіанти 32-х та 64-х розрядних бібліотек, для максимальної користі на 64-х розрядній ОС. Якщо ви встановили драйвер з файлами для декількох архітектур, пакунок ”mesa-compat32
“ перезапише деякі 32-х розрядні бібліотеки.
Це список пакунків, які пере-конвертовано в сумісні пакунки ”-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
Ви можете завантажити пакунки мульти-бібліотечності з цих місць:
Удачі!
Ерік