From 53eb33023aefd8e4b6ac5a2e6c43348c7129cbe1 Mon Sep 17 00:00:00 2001 From: dtb Date: Sun, 4 Dec 2022 23:50:53 -0500 Subject: [PATCH] overhaul bootstrapping sections --- wiki/unix/alpine.m4 | 24 +++++++++++----------- wiki/unix/arch.m4 | 44 +++++++++++++++++------------------------ wiki/unix/bootloader.m4 | 1 + wiki/unix/index.m4 | 2 ++ wiki/unix/linux.m4 | 43 ++++++++++++++++++++++++++++++++++++++++ 5 files changed, 75 insertions(+), 39 deletions(-) create mode 100644 wiki/unix/bootloader.m4 diff --git a/wiki/unix/alpine.m4 b/wiki/unix/alpine.m4 index 80ad351..a1e3f56 100644 --- a/wiki/unix/alpine.m4 +++ b/wiki/unix/alpine.m4 @@ -10,7 +10,7 @@ _bentr(`_link(`Alpine Package Keeper', `https://wiki.alpinelinux.org/wiki/Alpine _bentr(`Alpine repositories content search') ') _subsubheader(`Adding software') -_man(`apk_add(8)') +_man(`apk-add(8)') _subsubheader(`Repositories')

See _man(`apk-repositories(5)'). @@ -45,22 +45,20 @@ To always install doc packages with program packages, _code(`apk add docs'). _subheader(`Bootstrapping')

-Alpine's bootstrapping procedure is quite manual; you should probably use _program(`setup-alpine'). -However, it is possible and quite easy to perform the steps manually. +_program(`setup-alpine') exists to automate installation. +

+_passage(`Eunakria on the Alpine Linux Discord server', +`

setup-alpine is jank.

') +

+To bootstrap _man(`apk(8)') do the following:

    -
  1. Copy over the contents of _file(`/etc/apk/keys') to _file(`/mnt/etc/apk/keys')
  2. -
  3. -Fill out _man(`apk-repositories(5)') on the mount. -
  4. -
  5. -Run _command(`apk --root /mnt add --initdb alpine-base'). -
  6. +
  7. Copy _man(`apk-keys(5)') to the analogous location on the mounted volume.
  8. +
  9. Fill out _man(`apk-repositories(5)') on the mount.
  10. +
  11. Use _man(`apk-add(8)') to initialize the package database on the mount (_command(`apk --root [mount] add --initdb alpine-base').

-Make sure to bind mount (_command(`mount -o bind')) _file(`/dev/'), _file(`/proc/'), and _file(`/sys/') to the corresponding locations on the bootstrap prefix -and copy _file(`/etc/resolv.conf') over before _ref(`#posix#chroot(1)')ing into the bootstrap directory and finalizing setup. -Remember to set up users, _ref(`#fstab(5)'), the kernel, device management, and the bootloader if necessary. +Copy _file(`/etc/resolv.conf') over (and bind _file(`/dev/'), _file(`/proc/'), and _file(`/sys/')) before _ref(`#posix#chroot(1)')ing.

_subheader(`postmarketOS') diff --git a/wiki/unix/arch.m4 b/wiki/unix/arch.m4 index 999d52d..445a7ab 100644 --- a/wiki/unix/arch.m4 +++ b/wiki/unix/arch.m4 @@ -2,33 +2,32 @@ _header(`Arch')

Arch is known for using the latest versions of programs, which has given it an undeserved reputation of instability.

+ +_subheader(`AUR') +

+You will need _package(`base-devel'). +

+ _subheader(`Bootstrapping')

-Use _man(`pacstrap(8)'). +See _ref(`#linux#bootstrapping'). +Use _man(`pacstrap(8)') on Arch and _man(`basestrap(8)') on Artix.

-At a minimum you need the _code(`base') package. -Select a kernel and install the corresponding package; _code(`linux'), _code(`linux-lts'), or another Linux configuration or fork. -The Arch wiki says you need to install _code(`linux-firmware'), this isn't strictly necessary but it is recommended. +Arch's base package is _package(`base'). +Additionally, a kernel such as _package(`linux') or _package(`linux-lts') will be necessary. +The Arch wiki says _package(`linux-firmware') is necessary; it's not on many hardware configurations but it's recommended. Install _code(`base-devel') if you plan on using the AUR or if you don't know what the AUR is yet. +On Artix you also need to select the _ref(`#linux#initialization') system: _package(`66'), _package(`dinit'), _package(`openrc'), _package(`runit'), or _package(`s6-base'). +The Artix wiki says the initialization-specific _ref(`#linux#logind') package is necessary; it's not but it's recommended.

-It's also a good idea to install any utilities you'll need on the bootstrapped system. -Text editors, network managers or utilities, and other administration tools, for example. -Manual utilities such as _code(`man-db') and others would also be useful. +On the bootstrapped system, after chrooting in, uncomment a local mirror in _file(`/etc/pacman.d/mirrorlist-arch'). +Then configure _file(`/etc/pacman.conf') to use that mirror list.

-
Ubiquitous packages missing
-

From the annals of my notes, 2021-06-04:

+_passage(`Config block conveyed to Leyla by an Arch package maintainer, shared to the Tebibyte Media Discord server 2021-06-04T1746+0500', +`
-Had an issue with pacman missing some ubiquitous packages (esr's 'ascii', xorg-xev, etc).
-This fixed it. I don't really know why - maybe some issues with my repos?
-This was cleanly installed artix-openrc.
-
-[5:46 PM] Bassman Leyla: So what I did is I went into /etc/pacman.d/mirrorlist-arch and uncommented a local mirror
-[5:46 PM] Bassman Leyla: Then I appended a config block a package maintainer gave me onto /etc/pacman.conf
-[5:46 PM] Bassman Leyla: I'll paste it in
-[5:47 PM] Bassman Leyla:
-'''
 #
 # ARCHLINUX
 #
@@ -50,8 +49,8 @@ Include = /etc/pacman.d/mirrorlist-arch
 
 #[multilib]
 #Include = /etc/pacman.d/mirrorlist-arch
-'''
 
+') _subheader(`Artix') _bibliography(` @@ -61,10 +60,3 @@ _bentr(`Artix Linux (Wik

Artix is a Linux software distribution based on Arch that doesn't mandate SystemD as its initialization system.

-_subsubheader(`Bootstrapping') -

-This process differs from Arch's bootstrapping process. -Artix uses _man(`basestrap(8)') rather than _man(`pacstrap(8)'); -you need to select the initialization you want to use: _code(`66'), _code(`dinit'), _code(`openrc'), _code(`runit'), or _code(`s6-base'), as a package separate from _code(`base'); -and Artix's official wiki says you need to install the appropriate _link(`#logind', `_code(`elogind')') package (_code(`elogind-[initialization system]') e.g. _code(`elogind-66')) but like _code(`linux-firmware') though it is helpful it isn't strictly necessary. -

diff --git a/wiki/unix/bootloader.m4 b/wiki/unix/bootloader.m4 new file mode 100644 index 0000000..3c02140 --- /dev/null +++ b/wiki/unix/bootloader.m4 @@ -0,0 +1 @@ +_header(`Bootloader') diff --git a/wiki/unix/index.m4 b/wiki/unix/index.m4 index f07eb44..20843b0 100644 --- a/wiki/unix/index.m4 +++ b/wiki/unix/index.m4 @@ -15,6 +15,8 @@ include(`arch.m4') include(`archives.m4') +include(`bootloader.m4') + include(`C.m4') include(`culture.m4') diff --git a/wiki/unix/linux.m4 b/wiki/unix/linux.m4 index ea2d0dc..1f6f47f 100644 --- a/wiki/unix/linux.m4 +++ b/wiki/unix/linux.m4 @@ -25,6 +25,11 @@ _bentr(`_link(`acpid', `https://sourceforge.net/projects/acpid2/')') _man(`acpid(8)') is a daemon that can automatically manage ACPI events on Linux.

+_subheader(`a.out') +_bibliography(` +_bentr(`_link(`Re: [PATCH] x86: Remove a.out support', `https://lwn.net/ml/linux-kernel/202203161523.857B469@keescook/')') +') + _subheader(`Audio')

Most audio servers recommend that they be run in userspace with user privileges, with PulseAudio going so far as to exiting when run as root without additional configuration. @@ -74,6 +79,38 @@ On Alpine you'll need the _program(`pulseaudio'), _program(`pulseaudio-alsa'), a Start _man(`pulseaudio(1)') when you want audio, ideally in your _file(`.xinitrc').

+_subheader(`Bootstrapping') +

+Usually the first program a computer will run is the _ref(`#bootloader'), +which loads the kernel and usually the _ref(`#linux#initramfs') which will handle mounting the system storage. +Then the _ref(`#linux#initialization') system is started, which handles daemons, some of which will handle login. +

+

+Bootstrapping Linux involves booting an operating system, usually off a temporary storage medium, mounting the intended system storage, +and installing the operating system on the intended storage. +Sometimes distributions come with software that mostly automates this. +

+_passage(`veronika on the Alpine Linux Discord server, 2022-12-04T1111+0400',` +

bootstrapping things is only useful for rare cases where you actually don`'t want to use the base packages that the installer gets for you automatically, and the installer doesn`'t get in your way of making your own system, instead it suggests you install certain packages, and asks what packages you want installed. If you`'re installing a desktop environment, it will probably ask you which meta package you want (or at least that`'s how I remember it working).

+

If you have an installer to do the same things with less steps for you, you should use it. Automation is progress, automation is the whole point of all this computer stuff. If you can automate it or make it easier, you probably should, unless you want some control over the process. For example, instead of checking the charge and running a command to put your laptop into battery saver mode, you make a program do it for you. Convenience is key to happy and painless computing

+') +

+If running very thin installation media, for example, a _ref(`#debian') network install CD, or just need the most up-to-date software possible, +the first step will be to connect to the Internet. +

+

+Next, if your chosen Linux distribution has a package manager, configure it, use it to initialize the file system on the intended system storage, +and install the necessary system packages to the storage. +Usually distributions have a single base package, like _ref(`#arch')'s _package(`base') or _ref(`#alpine')'s _package(`alpine-base'). +If it doesn't include any of them, install separately a kernel, initialization system, and userland. +

+

+Bind mount (_command(`mount -o bind')) _file(`/dev/'), _file(`/proc/'), and _file(`/sys/') to the corresponding locations on the volume to bootstrap +(_code(`for d in dev proc sys; do mount -o bind /$d /[mount]/$d; done')), +then _ref(`#posix#chroot(1)') in and complete the system setup. +Set up additional configuration necessary to boot (including _ref(`#fstab(5)'), _man(`hostname(5)'), _man(`hosts(5)'), and anything necessary for the kernel or initialization). +

+ _subheader(`Device Management') _bibliography(` _bentr(`_link(`udev', `https://en.wikipedia.org/wiki/Udev') (Wikipedia)') @@ -88,6 +125,12 @@ _subsubheader(_ref(`#alpine')) _subsubheader(_ref(`#arch')) _subsubheader(_ref(`#debian')) +_subheader(`Initialization') +_subsubheader(`OpenRC') +_subsubheader(`Runit') +_subsubheader(`S6') +_subsubheader(`Systemd') + _subheader(`initramfs') _bibliography(` _bentr(`_link(`Initial ramdisk', `https://en.wikipedia.org/wiki/Initial_ramdisk') (Wikipedia)')