Skip to content

Guide to using pacman as a package manager for Linux From Scratch

License

Notifications You must be signed in to change notification settings

wsdmatty/lfs-pacman

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Pacman on LFS Version 12.0-systemd (a.k.a Archlinux from Scratch)

Forked from "Pacman on LFS 8.1" By Ben Van Daele.
Based on the guide writen by James Kimball in 2013. Building on Linux From Scratch Licensed under the Creative Commons Attribution-ShareAlike 3.0 License.

Introduction

This guide is divided in five stages, the first one of which starts just before installing tools to your final system.

  • Stage 1 - Installing pacman to your temporary toolchain
  • Stage 2 - Installing pacman with pacman
  • Stage 3 - Installing packages of chapter six of the LFS book
  • Stage 4 - Installing pacman to your final system
  • Stage 5 - Finishing the book

Stage 1 - Installing pacman to your temporary toolchain

This stage begins right after before 7.13. Cleaning up and Saving the Temporary System.

Pacman dependencies

Note We will be installing an old version of Pacman to start, as 6.0 removed support for autotools building.

Pacman depends on the following packages:

  • zlib 3.3.2
  • libarchive 1.22
  • pkg-config 2.0.1
  • fakeroot 1.22, which in turn depends on
  • libcap 2.69

We will also need:

  • Vim 9.0.1677

Some of these are not part of the LFS book, so I've included them with this guide, links below.

Build these packages using the following commands. Just like the LFS book, these commands assume you've extracted the relevant sources and cd'd into the resulting directory.

zlib 1.2.11

./configure --prefix=/usr
make
make install

libarchive 3.3.2

./configure --prefix=/usr --without-xml2 --disable-shared
make
make install

Pkgconf 2.0.1

./configure --prefix=/usr              \
            --disable-static           \
            --docdir=/usr/share/doc/pkgconf-2.0.1
make
make install

libcap 2.69

Prevent static libraries from being installed:

sed -i '/install -m.*STA/d' libcap/Makefile

Compile and install the package:

make prefix=/usr lib=lib
make test
make prefix=/usr lib=lib install

fakeroot 1.32.2

As part of its installation, fakeroot calls ldconfig, which is located in /tools/sbin. /tools/sbin is not part of our PATH, so we must add it now.

  ./configure --prefix=/usr \
    --libdir=/usr/lib/libfakeroot \
    --disable-static \
    --with-ipc=sysv

make
make install

Pacman 5.0.2

./configure --prefix=/usr   \
            --disable-doc     \
            --disable-shared  \
            --sysconfdir=/etc \
            --localstatedir=/var
make
make install

This will have installed, amongst others, the makepkg.conf and pacman.conf config files in /etc; you may want to edit them. For makepkg.conf, be sure that CARCH and CHOST are appropriate, e.g.:

CARCH="x86_64"
CHOST="x86_64-pc-linux-gnu"

You can set your name and email address as the PACKAGER if you want.

Vim (or any text editor)

We wont bother testing VIM as this is just to our temporary tools and it'll be recompiled later.

echo '#define SYS_VIMRC_FILE "/etc/vimrc"' >> src/feature.h
./configure --prefix=/usr
make
make install

Setting up to build packages with pacman

Create a new user by adding the following to /etc/passwd:

lfs:x:1000:999:LFS:/home/lfs:/bin/bash

Where 999 is the ID of the users group. Check /etc/group for the correct ID, or if users is not present in that file, add the following to it.

users:x:999:

Create a home directory:

mkdir -v /home/lfs
chown -Rv lfs:users /home/lfs

Exit your current chroot, then chroot into your new user (make sure 1000, 999 and ben are set to the proper values for your system):

chroot --userspec=1000:999 "$LFS" /bin/env -i \
     HOME=/home/lfs     \
     TERM="$TERM"       \
     PS1='(lfs chroot) \u:\w\$ ' \
     PATH=/bin:/usr/bin:/sbin:/usr/sbin \
     /bin/bash --login +h

You may want to create a builds directory in your home dir. In there, you would then create a directory for each package you're building.

Stage 2 - Installing pacman with pacman

Copy the pacman sources to its build directory, ~/builds/pacman-5.0.2.

Download the necessary build files (PKGBUILD, makepkg.conf and pacman.conf.x86_64) from the Install-Files to the build directory.

The included PKGBUILD has had the following edits made:

  • Removed 'groups' and 'depends' sections (We're not using groups, and as far as pacman knows none of the dependencies are installed.)
  • Edited the 'source' section to point to local tarball and files
  • Removed 'check' section as most of the tests will fail with our current environment

Now run the following command as your non-root user from the build directory:

makepkg --skipchecksums

We're skipping the checksums because we don't have OpenSSL installed yet.

If all goes well, this should have created a file that you can now install as follows, as root this time:

pacman -U --force pacman-5.0.2-2-x86_64.pkg.tar.gz

--force is required as these files already exist and we're intentionally reinstalling overtop of them.

Stage 3 - Installing packages of chapter eight of the LFS book

Now we will continue with the rest of the book, but instead of building and installing the packages manually, we will create packages and then use pacman to install them.

All of the necessary PKGBUILD files can be found in the packages directory, but if you want to learn how to create these, I suggest you only refer to them when you get stuck.

Creating a package

The general process goes like this:

  1. Create a new directory in the builds directory.
  2. Copy all needed files to it (source archive, possibly other files like patches or config files).
  3. Write a PKGBUILD file.
  4. Run makepkg --skipchecksums.
  5. Check the contents of the pkg directory; this is what pacman will install, so you may want to verify that it looks good.
  6. Install the package (as root) with pacman -U $filename

Writing a PKGBUILD file can take some trial and error. Essentially you'll need to copy what the LFS book wants you to do and paste it in the PKGBUILD at the right place, but usually you will not be able to copy things verbatim from the book.

If you're stuck, check the official Arch Linux packages or thePKGBUILD files in the packages directory of this repo.

Tips

Source directory

When calling any of the PKGBUILD functions, makepkg will automatically cd you into the source dir, which is where it will have extracted or symlinked all your source files.

Source tarball

makepkg will automatically extract all archives you specify in the sources array. Typically, your source tarball will have been extracted into a separate directory (although that depends on the tarball itself; the tzdata tarball for instance, extracts directly, without a subdirectory).

This is why the first step of each function will usually be to cd into the directory created during the extraction of the source tarball.

Installing files

When installing files, you cannot install them to the system root, but instead you have to install them in ${pkgdir}. For certain packages this is done by using make DESTDIR=${pkgdir} install instead of make install. Not all packages use DESTDIR, however. If you're not sure how those packages should be built, you can always check the Arch Linux packages or the PKGBUILD files from this repo.

In some cases, the book will tell you to mv a directory. This will work while creating the package, but will cause problems when installing it. You should first create the directory with install -vdm755 $dir_name.

Post-install

Things that the LFS book wants you to do after having called make install will likely need to be placed in an .install file. Check the Arch Linux wiki for more info.

Pacman will execute the functions in the .install file at the end of the installation process.

Notes for individual packages

Some packages require additional steps besides simply converting the LFS instructions into a PKGBUILD. These steps are documented here.

6.9. Glibc-2.26

The book wants you to create some symlinks; I did that manually, as I felt it would be out of place in the package.

The tzdata part of glibc requires zic to be installed to the system, which means after glibc was installed with pacman -U. While I suppose you could directly call the zic binary residing in the src or pkg directories, I thought it would be cleaner to split the tzdata installation to a separate package, much like Arch Linux does.

6.10. Adjusting the Toolchain

I did these steps manually. It didn't feel suitable to (ab)use makepkg/pacman for this purpose.

6.15. Bc-1.07.1

The book wants you to create symlinks for libncurses. I did this manually before building the package.

6.20. GCC-7.2.0

Before building the package, increase the stack size: ulimit -s 32768.

I had to use --force when installing this package, since some libraries already existed on the system.

6.28. Shadow-4.5

I ran passwd manually.

6.34. Bash-4.4

When creating the package, makepkg told me that "Package contains reference to $srcdir". Using grep -R "$(pwd)/src" pkg/, I found out that Bash installs Makefile.inc to /usr/lib/bash/, which contains a reference to the build directory. On an existing Arch Linux installation, /usr/lib/bash/Makefile.inc also contained a reference to a (non-existing) build directory, so I assume this is benign.

Use --force to install this package, since /bin/bash was created as part of 6.6. Creating Essential Files and Symlinks.

I then re-chrooted, using /bin/bash instead of /tools/bin/bash.

6.40. Perl-5.26.0

The LFS book tells you to create /etc/hosts. I've chosen to do this manually, rather than to have the Perl package install this file. It doesn't sound right that Perl should own this file. For reference, in Arch Linux, the hosts file is owned by the filesystem package, which contains the base Arch Linux files, so it makes sense that this is created manually in the case of LFS.

Use --force to install this package, since /usr/bin/perl was created as part of 6.6. Creating Essential Files and Symlinks.

6.50. Coreutils-8.27

For some reason, doing the in place sed (sed -i) on chroot.8 resulted in the file having 000 permissions. I replaced it with a regular sed, redirecting the result to a new file, then using install to copy the file to its destination.

Use --force to install this package, since a number of files already exist (amongst others cat, dd, echo) in /bin (as symlinks to /tools). These were added in 6.6. Creating Essential Files and Symlinks.

6.53. Findutils-4.6.0

As with coreutils, using in place sed set the permissions to 000, so I used the same workaround here.

6.63. Sysklogd-1.5.1

Sysklogd's makefile doesn't support specifying a destination directory when installing (make DESTDIR=/path). I've included a patch that adds this.

Stage 4 - Installing pacman to your final system

Stage four starts immediately after the last package in chapter six, currently vim. Before continuing with the rest of the chapter, build and install pacman and its dependencies.

As part of chapter six you should already have installed most of these packages, except for:

  • libarchive
  • fakeroot
  • pacman

Use your temporary pacman installation to install them. Remember, we're installing to the final system, not to /tools.

Stage 5 - Finishing the book

Finish up the rest of the book manually.

When restarting my machine, the LFS system wouldn't boot properly. It turned out that many binaries and other files were owned by ben, the user with which I built the packages. I have no idea why that happened, but chowning them to root:root allowed my system to boot.

About

Guide to using pacman as a package manager for Linux From Scratch

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 99.7%
  • Vim Script 0.3%