Slackware for x86_64 - multilib packages & build instructions
=============================================================

Slackware for the x86_64 architecture (or Slackware64 for short) is a pure
64-bit Operating System, but by design it is "multilib-ready".  This means,
that is it is possible to add a layer of software that will allow you to run
32bit software without changes to either Slackware64 or these 32bit packages.
Furthermore, the multilib-enabled Slackware64 can compile 32bit binaries,
if you add the right software to it.

This README contains instructions on how to use the packages in this
directory to create a multilib Slackware64.

A more extensive documentation is available on the Slackware Documentation
Wiki, https://docs.slackware.com/slackware:multilib where you will also find
the main mirror locations for downloading these packages.

The exciting thing about Slackware64, is that you do not have to compile
all these basic 32-bit packages from scratch.  You simply take them from the
32-bit Slackware package tree!  Further down, I will explain how you can take
a 32-bit Slackware package (say, the "mesa" package) and strip/re-package its
content into a "mesa-compat32" package that you can install onto your 64-bit
Slackware computer straight away.


Enabling multilib
=================

Fast-track (examples assume slackware64-15.0 ... change to your needs).
All of the following commands should be executed as the 'root' user:

* In the location where you found this README, download the subdirectory with
  the name that corresponds to the Slackware version you are running.  For
  Slackware64 15.0 for instance, you would run the following command:
    # lftp -c 'open http://slackware.com/~alien/multilib/ ; mirror -c -e 15.0'
  and then change into the new "15.0" directory which has been created on
  your computer:
    # cd 15.0
* First, you will upgrade your 64bit Slackware gcc and glibc packages to their
  multilib versions by running the command:
    # upgradepkg --reinstall --install-new *.t?z
  in the directory you just changed to (the "15.0" directory in our case).
  This will upgrade gcc and glibc packages, and also install a new package
  called "compat32-tools".
* You are now going to install 32-bit compatibility packages to support all
  the 32-bit programs you may want to run (roughly 60 MB of packages, not all
  that much really!).  These packages are located in the subdirectory called
  "slackware64-compat32" which you also downloaded with the "lftp" command
  shown above.  Run this command:
    # upgradepkg --install-new slackware64-compat32/*-compat32/*.t?z
* This procedure will also work if you already had a multilib setup and have
  upgraded your Slackware to a newer release (new compat32 packages will be
  installed and existing ones will be upgraded).
* Done!  You need to reboot because of the glibc upgrade.

In more detail:

The following packages are replacements for - not additions to - standard
Slackware packages.  You use the "upgradepkg" program to upgrade to my
multilib versions of gcc and glibc.  You will need these in order to run,
and build, 32-bit software on your 64-bit Slackware computer:

==Slackware64 13.0==

* The gcc compiler suite:
  - gcc-4.3.3_multilib-x86_64-4alien.txz
  - gcc-g++-4.3.3_multilib-x86_64-4alien.txz
  - gcc-gfortran-4.3.3_multilib-x86_64-4alien.txz
  - gcc-gnat-4.3.3_multilib-x86_64-4alien.txz
  - gcc-java-4.3.3_multilib-x86_64-4alien.txz
  - gcc-objc-4.3.3_multilib-x86_64-4alien.txz

* The GNU libc libraries:
  - glibc-2.9_multilib-x86_64-5alien_slack13.0.txz
  - glibc-i18n-2.9_multilib-x86_64-5alien_slack13.0.txz
  - glibc-profile-2.9_multilib-x86_64-5alien_slack13.0.txz
  - glibc-solibs-2.9_multilib-x86_64-5alien_slack13.0.txz
  - glibc-zoneinfo-2.9_multilib-noarch-5alien_slack13.0.txz

==Slackware64 13.1==

* The gcc compiler suite:
  - gcc-4.4.4_multilib-x86_64-1alien.txz
  - gcc-g++-4.4.4_multilib-x86_64-1alien.txz
  - gcc-gfortran-4.4.4_multilib-x86_64-1alien.txz
  - gcc-gnat-4.4.4_multilib-x86_64-1alien.txz
  - gcc-java-4.4.4_multilib-x86_64-1alien.txz
  - gcc-objc-4.4.4_multilib-x86_64-1alien.txz

* The GNU libc libraries:
  - glibc-2.11.1_multilib-x86_64-5alien_slack13.1.txz
  - glibc-i18n-2.11.1_multilib-x86_64-5alien_slack13.1.txz
  - glibc-profile-2.11.1_multilib-x86_64-5alien_slack13.1.txz
  - glibc-solibs-2.11.1_multilib-x86_64-5alien_slack13.1.txz
  - glibc-zoneinfo-2.11.1_multilib-noarch-5alien_slack13.1.txz

==Slackware64 13.37==

* The gcc compiler suite:
  - gcc-4.5.2_multilib-x86_64-2alien.txz
  - gcc-g++-4.5.2_multilib-x86_64-2alien.txz
  - gcc-gfortran-4.5.2_multilib-x86_64-2alien.txz
  - gcc-gnat-4.5.2_multilib-x86_64-2alien.txz
  - gcc-java-4.5.2_multilib-x86_64-2alien.txz
  - gcc-objc-4.5.2_multilib-x86_64-2alien.txz

* The GNU libc libraries:
  - glibc-2.13_multilib-x86_64-7alien.txz
  - glibc-i18n-2.13_multilib-x86_64-7alien.txz
  - glibc-profile-2.13_multilib-x86_64-7alien.txz
  - glibc-solibs-2.13_multilib-x86_64-7alien.txz
  - glibc-zoneinfo-2013d_multilib-noarch-7alien.txz

==Slackware64 14.0==

* The gcc compiler suite:
  - gcc-g++-4.7.1_multilib-x86_64-1alien.txz
  - gcc-gfortran-4.7.1_multilib-x86_64-1alien.txz
  - gcc-gnat-4.7.1_multilib-x86_64-1alien.txz
  - gcc-go-4.7.1_multilib-x86_64-1alien.txz
  - gcc-java-4.7.1_multilib-x86_64-1alien.txz
  - gcc-objc-4.7.1_multilib-x86_64-1alien.txz

* The GNU libc libraries:
  - glibc-2.15_multilib-x86_64-8alien.txz
  - glibc-i18n-2.15_multilib-x86_64-8alien.txz
  - glibc-profile-2.15_multilib-x86_64-8alien.txz
  - glibc-solibs-2.15_multilib-x86_64-8alien.txz
  - glibc-zoneinfo-2013d_2013d_multilib-noarch-8alien.txz

==Slackware64 14.1==

* The gcc compiler suite:
  - gcc-4.8.2_multilib-x86_64-1alien.txz
  - gcc-g++-4.8.2_multilib-x86_64-1alien.txz
  - gcc-gfortran-4.8.2_multilib-x86_64-1alien.txz
  - gcc-gnat-4.8.2_multilib-x86_64-1alien.txz
  - gcc-go-4.8.2_multilib-x86_64-1alien.txz
  - gcc-java-4.8.2_multilib-x86_64-1alien.txz
  - gcc-objc-4.8.2_multilib-x86_64-1alien.txz

* The GNU libc libraries:
  - glibc-2.17_multilib-x86_64-7alien.txz
  - glibc-i18n-2.17_multilib-x86_64-7alien.txz
  - glibc-profile-2.17_multilib-x86_64-7alien.txz
  - glibc-solibs-2.17_multilib-x86_64-7alien.txz
  - glibc-zoneinfo-2013d_multilib-noarch-7alien.txz

==Slackware64 14.2==

* The gcc compiler suite:
  - gcc-5.5.0_multilib-x86_64-1alien.txz
  - gcc-g++-5.5.0_multilib-x86_64-1alien.txz
  - gcc-gfortran-5.5.0_multilib-x86_64-1alien.txz
  - gcc-gnat-5.5.0_multilib-x86_64-1alien.txz
  - gcc-go-5.5.0_multilib-x86_64-1alien.txz
  - gcc-java-5.5.0_multilib-x86_64-1alien.txz
  - gcc-objc-5.5.0_multilib-x86_64-1alien.txz

* The GNU libc libraries:
  - glibc-2.23_multilib-x86_64-4alien.txz
  - glibc-i18n-2.23_multilib-x86_64-4alien.txz
  - glibc-profile-2.23_multilib-x86_64-4alien.txz
  - glibc-solibs-2.23_multilib-x86_64-4alien.txz

==Slackware64 15.0 ==

* The gcc compiler suite:
  - gcc-11.2.0_multilib-x86_64-2alien.txz
  - gcc-brig-11.2.0_multilib-x86_64-2alien.txz
  - gcc-g++-11.2.0_multilib-x86_64-2alien.txz
  - gcc-gdc-11.2.0_multilib-x86_64-2alien.txz
  - gcc-gfortran-11.2.0_multilib-x86_64-2alien.txz
  - gcc-gnat-11.2.0_multilib-x86_64-2alien.txz
  - gcc-go-11.2.0_multilib-x86_64-2alien.txz
  - gcc-objc-11.2.0_multilib-x86_64-2alien.txz

* The GNU libc libraries:
  - aaa_glibc-solibs-2.33_multilib-x86_64-7alien.txz
  - glibc-2.33_multilib-x86_64-7alien.txz
  - glibc-i18n-2.33_multilib-x86_64-7alien.txz
  - glibc-profile-2.33_multilib-x86_64-7alien.txz

==Slackware64 current==

Slackware 15.0 is the last release that needs separate (alien's) multilib
versions of gcc and glibc.
On August 30, 2024, Pat Volkerding added multilib capability to Slackware's
own gcc and glibc packages. What you still need to add to your system is
the collection of -compat32 packages.

=======================================================================

There is one more package (compat32-tools); you install it using the
"installpkg" program:

* The compat32-tools package is a "32-bit toolkit" (containing scripts that
  facilitate the creation of 32bit packages):
  - compat32-tools-3.9-noarch-28alien.tgz 

* The above packages cover the essentials for getting ready to run and compile
  32-bit software on Slackware64.  But in order to be able to actually run
  software, you need a "layer" of additional 32-bit support libraries as well.
  These libraries are taken from standard Slackware 32-bit packages using the
  scripts that are part of my "compat32-tools" package.
* You use the "massconvert32.sh" script for this conversion;
  Suppose you have downloaded a local copy of 32-bit Slackware, and it is
  available in the directory: /home/ftp/pub/slackware/slackware-15.0
  then you would run the command:
    # massconvert32.sh -i /home/ftp/pub/slackware/slackware-15.0/slackware
  and the result is a number of subdirectories in your current directory,
  containing "compat32" packages which you can install directly (they will not
  conflict with your 64-bit packages).
* You can also instruct the "massconvert32.sh" script to download everything
  you need from an external Slackware mirror, if you do not have (or do not
  want to download) a complete local copy of Slackware:
    # massconvert32.sh -u http://slackware.mirrors.tds.net/pub/slackware/slackware-15.0/slackware"
* Or if you are lazy you can just download the "slackware64-compat32" directory
  in which I provide all these converted packages for you.  It is a subdirectory
  of the directory that contains the multilib gcc and glibc packages.


Adding 32-bit programs
======================

The scripts in the "compat32-tools" package need some explanation.
The package installs a detailed 'README' in the /usr/doc/compat32-tools-*/
directory that will help you on your way.  Basically, you get three scripts
to run:
  - /etc/profile.d/32dev.sh
    This is the same script that also comes with Slamd64 and which configures
    an environment that you need for compiling 32-bit software (by preferring
    the 32-bit compilers and libraries over their 64-bit versions)
  - /usr/sbin/convertpkg-compat32
    This script takes a 32-bit Slackware package and converts it to a
    '-compat32' package that you can install (using "installpkg") on
    Slackware64, alongside a 64-bit version of the same software.
  - /usr/sbin/massconvert32.sh
    This script contains an internal list of essential 32-bit Slackware
    packages.  It uses the previously mentioned "convertpkg-compat32" script
    to grab every package on its internal package list, and converts them
    into '-compat32' packages.  You will end up with about 60 MB of packages
    that you must install next, using the command "upgradepkg --install-new".
    These 'compat32' packages create a 32-bit compatibility layer on top of
    Slackware64.
    The "massconvert32.sh" script can either download these 32-bit packages
    from an external Slackware mirror, or else it can use a local Slackware
    mirror if you have one in your LAN.
    Optionally you can specify an output directory for the newly created
    packages; by default they will be created in your current directory.  


Running 32-bit programs
=======================

Running a 32-bit program is easy after the above system preparation - just
download, install and start it.  You may find that you still miss a 32-bit
Slackware library; in that case, use the "convertpkg-compat32" script to
convert the original 32-bit Slackware package and install the resulting
32bit compatibility package on Slackware64.


Compiling 32-bit programs
=========================

In case you need to compile a 32-bit program (wine and grub are two examples
of open source programs that are 32-bit only) you first configure your
shell environment by running the command:

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

Note the 'dot' in front of the filename - that is actually part of the
commandline!  It will change or create several environment variables so
that 32-bit versions of binaries are preferred.  Once you are done compiling
32-bit software, you should logout of your root shell in order to get rid of
the modified build environment.

In this changed environment, you will be able to use standard SlackBuilds to
build 32-bit packages for Slackware64.
There's a couple of things to keep in mind:

(1) You have to define the ARCH variable as 'i586' because even on your
    'x86_64' computer you are compiling a 32-bit program! 
    This is related to the triplet of '$ARCH-slackware-linux' which 
    is normally used in the 'configure' command.
    (a) As an exception, you will have to compile the 'wine' package with
        'ARCH=x86_64' because you will install this package directly on
        your multilib computer without converting to a 'compat32' package.

(2) If you want to install this 32-bit package on Slackware64-multilib,
    you will have to convert it to a 'compat32' package: 

      # convertpkg-compat32 -i /path/to/your/fresh/foo-VERSION-i586-BUILD.tgz
      # upgradepkg --install-new /tmp/foo-compat32-VERSION-x86_64-BUILDcompat32.txz


Keeping your multilib up-to-date
================================

If you use slackpkg to keep your Slackware uptodate, then you may benefit from
adding slackpkg+ (http://slakfinder.org/slackpkg+.html), an extension to
slackpkg which allows you to manage package updates, not just for Slackware,
but also for 3rd party repositories which adhere to the Slackware repository
format.
The Multilib repository is compatible with slackpkg+, and its configuration
file has instructions on how to enable multilib repository support.  
If you do not use slackpkg, then your best option is to keep a local mirror
of the multilib repository for your Slackware version, and regularly run:
  # cd /path/to/multilib/slackware_version_dir/
  # upgradepkg --install-new *.t?z
  # upgradepkg --install-new slackware64-compat32/*-compat32/*.t?z
If you do use slackpkg but do not want to add slackpkg+ then you need to do
the above but also take precautions so that slackpkg does not remove or
replace the multilib packages. Add these lines to /etc/slackpkg/blacklist to
prevent this behaviour:
  [0-9]+alien
  [0-9]+compat32


Acknowledgements
================

A lot of thanks should go to Fred Emmott, who created Slamd64, the original
unofficial 64-bit fork of Slackware.  Although Slackware64 was not based
on Fred's work, I still learnt most of what I know about setting up the
32-bit part of a multilib Linux from his writings that are found in Slamd64.

Cross Linux From Scratch. The CLFS Wiki
(http://trac.cross-lfs.org/wiki/read#ReadtheCrossLinuxFromScratchBookOnline)
is a 'must-read' if you want to understand how to port Linux to a new
architecture. I took several ideas, concepts and patches from them when
creating Slackware64 from scratch, and again when I created my multilib
gcc/glibc packages from scratch (my README on this multilib-from-scratch
is available in the ./source directory).


Have fun!

Eric

=============================================================================
Eric Hameleers <alien@slackware.com> 30-aug-2024
[ICO]NameLast modifiedSizeDescription

[DIR]Parent Directory  -  
[DIR]13.0/29-Oct-2024 13:35 -  
[DIR]13.1/29-Oct-2024 13:35 -  
[DIR]13.37/29-Oct-2024 13:35 -  
[DIR]14.0/29-Oct-2024 13:36 -  
[DIR]14.1/29-Oct-2024 13:36 -  
[DIR]14.2/29-Oct-2024 13:37 -  
[DIR]15.0/29-Oct-2024 13:38 -  
[TXT]CHECKSUMS.md529-Oct-2024 13:44 1.0M 
[TXT]CHECKSUMS.md5.asc29-Oct-2024 13:44 224  
[   ]CHECKSUMS.md5.gz29-Oct-2024 13:44 216K 
[TXT]CHECKSUMS.md5.gz.asc29-Oct-2024 13:44 224  
[   ]ChangeLog.rss29-Oct-2024 13:34 11K 
[TXT]ChangeLog.txt29-Oct-2024 13:31 154K 
[   ]ChangeLog.txt.gz29-Oct-2024 13:44 20K 
[TXT]FILELIST.TXT29-Oct-2024 13:44 1.1M 
[   ]GPG-KEY07-May-2018 12:14 17K 
[   ]MANIFEST.bz229-Oct-2024 13:44 1.8M 
[TXT]PACKAGES.TXT29-Oct-2024 13:44 1.0M 
[   ]PACKAGES.TXT.gz29-Oct-2024 13:44 192K 
[   ]README30-Aug-2024 13:30 15K 
[DIR]current/29-Oct-2024 13:40 -  
[DIR]source/19-Apr-2024 10:50 -  
[DIR]testing/29-Oct-2024 13:40 -  

Apache/2.2.22 Server at www.slackware.com Port 80