Compare commits
5 Commits
20210208-I
...
main
Author | SHA1 | Date | |
---|---|---|---|
d8b71f3ed5 | |||
46be773a1d | |||
6a3cecda84 | |||
511bed496e | |||
3b68da77aa |
95
README.md
95
README.md
@ -1,37 +1,49 @@
|
|||||||
|
# UNMAINTAINED
|
||||||
|
|
||||||
|
I no longer use void linux, excellent distribution that it is.
|
||||||
|
|
||||||
# Install Scripts for Void Linux on Pinebook Pro
|
# Install Scripts for Void Linux on Pinebook Pro
|
||||||
|
|
||||||
Before using either of the scripts in this repository, read through them to
|
Before using either of the scripts in this repository, read through them to
|
||||||
clearly understand what they do. They are very opinionated and specifically
|
clearly understand what they do. They are very opinionated and specifically
|
||||||
written to cater to my own needs (for example the use of `sudo`, other people
|
written to cater to my own needs (for example the use of `sudo`, other people
|
||||||
might have different setups). It is, however, easy to change things around.
|
might have different setups). It is, however, easy to change things around.
|
||||||
|
|
||||||
By default, the `bootstrap` script creates a minimal installation on the emmc storage,
|
By default, the `bootstrap` script creates a minimal installation on the emmc
|
||||||
with full disk encryption (with an unencrypted boot partition) via lvm on luks. Two volumes `swap` and `root` are created,
|
storage, with full disk encryption (with an unencrypted boot partition) via lvm
|
||||||
the latter is formatted with an xfs filesystem. Additionally one user is created
|
on luks. Two volumes `swap` and `root` are created, the latter is formatted with
|
||||||
(with access to sudo via the wheel group) and keymap, hostname and timezone get set.
|
an xfs filesystem. Additionally one user is created (with access to sudo via the
|
||||||
|
wheel group) and keymap, hostname and timezone get set.
|
||||||
|
|
||||||
This gets you to a booting system, going on from there is out of scope here
|
This gets you to a booting system, going on from there is out of scope here as
|
||||||
as there are many ways to do that (for myself, I use `stow` to set up everything).
|
there are many ways to do that (for myself, I use `stow` to set up everything).
|
||||||
|
|
||||||
An important thing to keep in mind is that not all commands in the `bootstrap`
|
An important thing to keep in mind is that not all commands in the `bootstrap`
|
||||||
script are idempotent, that makes it all the more important to understand what they
|
script are idempotent, that makes it all the more important to understand what
|
||||||
do and to be sure to backup all important data.
|
they do and to be sure to backup all important data.
|
||||||
|
|
||||||
Pre-built images can be downloaded from the [releases](https://code.vanwa.ch/sebastian/void-linux-installer/-/releases) page
|
Pre-built images can be downloaded from the
|
||||||
|
[releases](https://code.vanwa.ch/sebastian/void-linux-installer/-/releases) page
|
||||||
(those might be outdated though).
|
(those might be outdated though).
|
||||||
|
|
||||||
User and password for the live image are the standard void linux one (`root/voidlinux`).
|
User and password for the live image are the standard void linux ones
|
||||||
|
(`root/voidlinux`).
|
||||||
|
|
||||||
# Scripts
|
# Scripts
|
||||||
|
|
||||||
## mk_pbp_img
|
## mk_pbp_img
|
||||||
Create a live image to boot void linux on the pinebook pro. Needs to be run on an
|
|
||||||
existing void linux system (docker might be possible with a working buildx and some adaptions with the mounting of filesystems).
|
Create a live image to boot void linux on the pinebook pro. Needs to be run on
|
||||||
|
an existing void linux system (docker might be possible with a working buildx
|
||||||
|
and some adaptions with the mounting of filesystems).
|
||||||
|
|
||||||
A copy of the [void-mklive](https://github.com/void-linux/void-mklive.git)
|
A copy of the [void-mklive](https://github.com/void-linux/void-mklive.git)
|
||||||
repository is downloaded next to the script into `.void-mklive` and used for
|
repository is downloaded next to the script into `.void-mklive` and used for
|
||||||
building the image.
|
building the image.
|
||||||
|
|
||||||
The script assumes it is running on an `x86_64` architecture, if that is not the case,
|
The script assumes it is running on an `x86_64` architecture, if that is not the
|
||||||
it needs to be changed (this applies to the use of `qemu-aarch64-static` to get a chroot).
|
case, it needs to be changed (this applies to the use of `qemu-aarch64-static`
|
||||||
|
to get a chroot).
|
||||||
|
|
||||||
The following tools need to be accessible in `PATH`:
|
The following tools need to be accessible in `PATH`:
|
||||||
|
|
||||||
@ -41,33 +53,40 @@ The following tools need to be accessible in `PATH`:
|
|||||||
- sudo
|
- sudo
|
||||||
- xz
|
- xz
|
||||||
|
|
||||||
If there is an argument provided to the script, it is treated as the folder to where
|
If there is an argument provided to the script, it is treated as the folder to
|
||||||
the compressed image is written, if no argument is given, the current working
|
where the compressed image is written, if no argument is given, the current
|
||||||
directory is used.
|
working directory is used.
|
||||||
|
|
||||||
After a successful build, the finished image can be found in the directory described
|
After a successful build, the finished image can be found in the directory
|
||||||
above with a filename of `void-pbp.img.xz`
|
described above with a filename of `void-pbp.img.xz`
|
||||||
|
|
||||||
|
Write it to a microSD card as such:
|
||||||
|
|
||||||
Write it to a microSD card as such:
|
|
||||||
- `xz -d < void-pbp.img.xz | sudo dd of=/dev/mmcblk0 bs=4M status=progress`
|
- `xz -d < void-pbp.img.xz | sudo dd of=/dev/mmcblk0 bs=4M status=progress`
|
||||||
- `sudo sync`
|
- `sudo sync`
|
||||||
|
|
||||||
Be ***very*** careful to get the parameter for `of` right, otherwise you can destroy your system.
|
|
||||||
|
|
||||||
MicroSD cards can be fickle, it sometimes is helpful to not take them out immediately, even after running `sync`.
|
Be **_very_** careful to get the parameter for `of` right, otherwise you can
|
||||||
If booting from the card hangs, write the image again onto it or use a different card.
|
destroy your system.
|
||||||
|
|
||||||
|
MicroSD cards can be fickle, it sometimes is helpful to not take them out
|
||||||
|
immediately, even after running `sync`. If booting from the card hangs, write
|
||||||
|
the image again onto it or use a different card.
|
||||||
|
|
||||||
## bootstrap
|
## bootstrap
|
||||||
Install void linux to the internal mmc storage of the pinebook pro or use it for some
|
|
||||||
maintenance task.
|
|
||||||
|
|
||||||
Be aware that the time needs to be set in *UTC*, otherwise package installation might not work.
|
Install void linux to the internal mmc storage of the pinebook pro or use it for
|
||||||
|
some maintenance task.
|
||||||
|
|
||||||
If running on a pinebook pro with an ISO keyboard, run `loadkeys uk` to load the correct keymap.
|
Be aware that the time needs to be set in **\*UTC**, otherwise package
|
||||||
|
installation might not work.
|
||||||
|
|
||||||
|
If running on a pinebook pro with an ISO keyboard, run `loadkeys uk` to load the
|
||||||
|
correct keymap.
|
||||||
|
|
||||||
Run it in either of two ways:
|
Run it in either of two ways:
|
||||||
|
|
||||||
### non-interactive
|
### non-interactive
|
||||||
|
|
||||||
`bootstrap full`
|
`bootstrap full`
|
||||||
|
|
||||||
Run a full installation, this will overwrite all data on the storage.
|
Run a full installation, this will overwrite all data on the storage.
|
||||||
@ -75,14 +94,14 @@ Run a full installation, this will overwrite all data on the storage.
|
|||||||
Runs the `full_install` command internally.
|
Runs the `full_install` command internally.
|
||||||
|
|
||||||
### interactive
|
### interactive
|
||||||
|
|
||||||
`bootstrap`
|
`bootstrap`
|
||||||
|
|
||||||
Run `help` to get a list of commands you can run and quit interactive mode
|
Run `help` to get a list of commands you can run and quit interactive mode with
|
||||||
with typing `exit`.
|
typing `exit`.
|
||||||
|
|
||||||
A useful thing to do here is the `repair` command. Sets up all the needed filesystems
|
A useful thing to do here is the `repair` command. It sets up all the needed
|
||||||
and opens a chroot.
|
filesystems and opens a chroot.
|
||||||
|
|
||||||
Again, it is highly recommended to read what the respective commands do and to adapt
|
|
||||||
them to your own needs.
|
|
||||||
|
|
||||||
|
Again, it is highly recommended to read what the respective commands do and to
|
||||||
|
adapt them to your own needs.
|
||||||
|
73
bootstrap
73
bootstrap
@ -26,12 +26,16 @@ get_value() {
|
|||||||
secure="s"
|
secure="s"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# shellcheck source=/dev/null
|
||||||
. "$CONFIG"
|
. "$CONFIG"
|
||||||
|
|
||||||
if [ -z "${!var_name}" ]; then
|
if [ -z "${!var_name}" ]; then
|
||||||
local def_val="${default_values[$var_name]}"
|
local def_val="${default_values[$var_name]}"
|
||||||
read -${secure}rp "$white$prompt [$def_val]:$nocolour " value
|
read -${secure}rp "$white$prompt [$def_val]:$nocolour " value
|
||||||
|
|
||||||
echo "export $var_name=\"${value:-$def_val}\"" >> "$CONFIG"
|
echo "export $var_name=\"${value:-$def_val}\"" >> "$CONFIG"
|
||||||
|
|
||||||
|
# shellcheck source=/dev/null
|
||||||
. "$CONFIG"
|
. "$CONFIG"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -45,13 +49,15 @@ network() {
|
|||||||
|
|
||||||
ip link set "$wifi_if" up
|
ip link set "$wifi_if" up
|
||||||
|
|
||||||
|
nmcli device wifi list
|
||||||
|
|
||||||
local wifi_ssid
|
local wifi_ssid
|
||||||
wifi_ssid="$(get_value "wifi_ssid" "wifi ssid")"
|
wifi_ssid="$(get_value "wifi_ssid" "wifi ssid")"
|
||||||
local wifi_pw
|
local wifi_pw
|
||||||
wifi_pw="$(get_value "wifi_pw" "wifi password" 1)"
|
wifi_pw="$(get_value "wifi_pw" "wifi password" 1)"
|
||||||
|
|
||||||
wpa_supplicant -B -i "$wifi_if" -c <(wpa_passphrase "$wifi_ssid" "$wifi_pw")
|
nmcli con delete "$wifi_ssid" || true
|
||||||
sv restart dhcpcd
|
nmcli device wifi connect "$wifi_ssid" password "$wifi_pw"
|
||||||
}
|
}
|
||||||
|
|
||||||
datetime() {
|
datetime() {
|
||||||
@ -100,7 +106,7 @@ create_lvm() {
|
|||||||
pvcreate /dev/mapper/void
|
pvcreate /dev/mapper/void
|
||||||
vgcreate void /dev/mapper/void
|
vgcreate void /dev/mapper/void
|
||||||
|
|
||||||
lvcreate -L 4G void -n swap
|
lvcreate -L 48G void -n swap
|
||||||
lvcreate -l 100%FREE void -n root
|
lvcreate -l 100%FREE void -n root
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,13 +119,32 @@ make_filesystems() {
|
|||||||
mkfs.xfs -f -L ROOT /dev/void/root
|
mkfs.xfs -f -L ROOT /dev/void/root
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ensure_mount() {
|
||||||
|
local src="$1"
|
||||||
|
local dest="$2"
|
||||||
|
local with_rbind="$3"
|
||||||
|
|
||||||
|
local rbind=""
|
||||||
|
|
||||||
|
if [ ! -z "$with_rbind" ]; then
|
||||||
|
rbind="--rbind"
|
||||||
|
fi
|
||||||
|
|
||||||
|
mount $rbind "$src" "$dest"
|
||||||
|
|
||||||
|
if [ ! -z "$with_rbind" ]; then
|
||||||
|
mount --make-rslave "$dest"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
mount_filesystems() {
|
mount_filesystems() {
|
||||||
local install_dev
|
local install_dev
|
||||||
install_dev="$(get_value "install_dev" "installation device")"
|
install_dev="$(get_value "install_dev" "installation device")"
|
||||||
|
|
||||||
mount /dev/void/root /mnt
|
ensure_mount "/dev/void/root" "/mnt"
|
||||||
|
|
||||||
mkdir -p /mnt/boot
|
mkdir -p /mnt/boot
|
||||||
mount "$install_dev"p1 /mnt/boot
|
ensure_mount "$install_dev"p1 "/mnt/boot"
|
||||||
|
|
||||||
swapon /dev/void/swap
|
swapon /dev/void/swap
|
||||||
}
|
}
|
||||||
@ -137,17 +162,19 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
mount_special_filesystems() {
|
mount_special_filesystems() {
|
||||||
mount --rbind /sys /mnt/sys && mount --make-rslave /mnt/sys
|
ensure_mount "/sys" "/mnt/sys" 1
|
||||||
mount --rbind /dev /mnt/dev && mount --make-rslave /mnt/dev
|
ensure_mount "/dev" "/mnt/dev" 1
|
||||||
mount --rbind /proc /mnt/proc && mount --make-rslave /mnt/proc
|
ensure_mount "/proc" "/mnt/proc" 1
|
||||||
mount --rbind /tmp /mnt/tmp && mount --make-rslave /mnt/tmp
|
ensure_mount "/tmp" "/mnt/tmp" 1
|
||||||
}
|
}
|
||||||
|
|
||||||
set_fstab() {
|
set_fstab() {
|
||||||
local install_dev
|
local install_dev
|
||||||
install_dev="$(get_value "install_dev" "installation device")"
|
install_dev="$(get_value "install_dev" "installation device")"
|
||||||
|
|
||||||
local boot_uuid="$(blkid | grep ${install_dev}p1 | awk '{print $2}')"
|
local boot_uuid
|
||||||
|
boot_uuid="$(blkid | grep "${install_dev}p1" | awk '{print $2}')"
|
||||||
|
|
||||||
cat >/mnt/etc/fstab <<EOF
|
cat >/mnt/etc/fstab <<EOF
|
||||||
tmpfs /tmp tmpfs defaults,nosuid,nodev 0 0
|
tmpfs /tmp tmpfs defaults,nosuid,nodev 0 0
|
||||||
$boot_uuid /boot vfat defaults 0 0
|
$boot_uuid /boot vfat defaults 0 0
|
||||||
@ -164,7 +191,13 @@ set_boot_scr() {
|
|||||||
local boot_scr="/mnt/boot/boot.scr"
|
local boot_scr="/mnt/boot/boot.scr"
|
||||||
local boot_txt_mine="/mnt/boot/boot.txt.mine"
|
local boot_txt_mine="/mnt/boot/boot.txt.mine"
|
||||||
|
|
||||||
local root_uuid="$(blkid | grep ${install_dev}p2 | awk '{print $2}' | sed 's/"//g')"
|
local mac
|
||||||
|
mac="$(echo -n "06"; dd bs=1 count=5 if=/dev/random 2>/dev/null | hexdump -v -e '/1 " %02X"' | tr '[:upper:]' '[:lower:]')"
|
||||||
|
|
||||||
|
local root_uuid
|
||||||
|
root_uuid="$(blkid | grep "${install_dev}p2" | awk '{print $2}' | sed 's/"//g')"
|
||||||
|
|
||||||
|
sed -i "s/setenv macaddr.*/setenv macadr $mac/g" "$boot_txt"
|
||||||
|
|
||||||
sed -i "s|root=PARTUUID=|root=/dev/void/root rd.auto=1 cryptdevice=${root_uuid}:lvm|g" "$boot_txt"
|
sed -i "s|root=PARTUUID=|root=/dev/void/root rd.auto=1 cryptdevice=${root_uuid}:lvm|g" "$boot_txt"
|
||||||
cp "$boot_txt" "$boot_txt_mine"
|
cp "$boot_txt" "$boot_txt_mine"
|
||||||
@ -205,7 +238,7 @@ set_base_conf() {
|
|||||||
local locale
|
local locale
|
||||||
locale="$(get_value "locale" "locale")"
|
locale="$(get_value "locale" "locale")"
|
||||||
|
|
||||||
echo "$locale" >> /etc/default/libc-locales
|
echo "$locale" >> /mnt/etc/default/libc-locales
|
||||||
|
|
||||||
chroot /mnt /bin/env -i \
|
chroot /mnt /bin/env -i \
|
||||||
timezone="$timezone" \
|
timezone="$timezone" \
|
||||||
@ -262,7 +295,17 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
tidy_up() {
|
tidy_up() {
|
||||||
umount -R /mnt
|
sync
|
||||||
|
|
||||||
|
if grep -qe "/mnt " /proc/mounts; then
|
||||||
|
umount -R /mnt
|
||||||
|
fi
|
||||||
|
|
||||||
|
swapoff /dev/void/swap > /dev/null 2>&1 || true
|
||||||
|
|
||||||
|
vgchange --activate n
|
||||||
|
|
||||||
|
cryptsetup close void > /dev/null 2>&1 || true
|
||||||
}
|
}
|
||||||
|
|
||||||
full_install() {
|
full_install() {
|
||||||
@ -350,7 +393,7 @@ cmd_loop() {
|
|||||||
while [[ "$cmd" != "exit" ]]; do
|
while [[ "$cmd" != "exit" ]]; do
|
||||||
read -rp "${white}>$nocolour " cmd
|
read -rp "${white}>$nocolour " cmd
|
||||||
|
|
||||||
if [[ " ${commands[@]} " =~ " ${cmd} " ]]; then
|
if [[ "${commands[*]}" == *"${cmd}"* ]]; then
|
||||||
$cmd
|
$cmd
|
||||||
else
|
else
|
||||||
if [ "$cmd" != "exit" ]; then
|
if [ "$cmd" != "exit" ]; then
|
||||||
@ -360,6 +403,8 @@ cmd_loop() {
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trap tidy_up 0 SIGHUP SIGINT SIGQUIT SIGABRT SIGTERM
|
||||||
|
|
||||||
if [ "$1" == "full" ]; then
|
if [ "$1" == "full" ]; then
|
||||||
full_install
|
full_install
|
||||||
else
|
else
|
||||||
|
20
mk_pbp_img
20
mk_pbp_img
@ -28,7 +28,7 @@ cleanup_mounts() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
check_tools() {
|
check_tools() {
|
||||||
for tool in ${TOOLS[@]}; do
|
for tool in "${TOOLS[@]}"; do
|
||||||
if ! command -v "$tool" &> /dev/null
|
if ! command -v "$tool" &> /dev/null
|
||||||
then
|
then
|
||||||
echo "$tool could not be found"
|
echo "$tool could not be found"
|
||||||
@ -62,11 +62,15 @@ build_img() {
|
|||||||
cd "$GIT_DIR"
|
cd "$GIT_DIR"
|
||||||
|
|
||||||
sudo ./mkrootfs.sh -o "$rootfs_file" aarch64
|
sudo ./mkrootfs.sh -o "$rootfs_file" aarch64
|
||||||
sudo ./mkplatformfs.sh -p "dracut lvm2 cryptsetup" -o "$platformfs_file" pinebookpro "$rootfs_file"
|
sudo ./mkplatformfs.sh -p "dracut lvm2 cryptsetup dbus NetworkManager" -o "$platformfs_file" pinebookpro "$rootfs_file"
|
||||||
sudo ./mkimage.sh -B 256MiB -o "$img" "$platformfs_file"
|
sudo ./mkimage.sh -B 256MiB -s 3GB -o "$img" "$platformfs_file"
|
||||||
|
|
||||||
|
# shellcheck disable=SC2024
|
||||||
|
# it is correct that the decompressed image is written as the unprivileged user
|
||||||
sudo xz --decompress --stdout "$img.xz" > "$img"
|
sudo xz --decompress --stdout "$img.xz" > "$img"
|
||||||
local loop_dev="$(sudo losetup --show -f -P "$img")"
|
|
||||||
|
local loop_dev
|
||||||
|
loop_dev="$(sudo losetup --show -f -P "$img")"
|
||||||
|
|
||||||
sudo mount "$loop_dev"p2 "$TMP_DIR_MOUNT"
|
sudo mount "$loop_dev"p2 "$TMP_DIR_MOUNT"
|
||||||
sudo mount "$loop_dev"p1 "$TMP_DIR_MOUNT"/boot
|
sudo mount "$loop_dev"p1 "$TMP_DIR_MOUNT"/boot
|
||||||
@ -77,16 +81,18 @@ build_img() {
|
|||||||
sudo cp "$(which qemu-aarch64-static)" "$TMP_DIR_MOUNT/usr/bin/"
|
sudo cp "$(which qemu-aarch64-static)" "$TMP_DIR_MOUNT/usr/bin/"
|
||||||
|
|
||||||
sudo chroot "$TMP_DIR_MOUNT" qemu-aarch64-static /bin/bash <<"EOT"
|
sudo chroot "$TMP_DIR_MOUNT" qemu-aarch64-static /bin/bash <<"EOT"
|
||||||
ln -s /etc/sv/dhcpcd /etc/runit/runsvdir/default/
|
ln -s /etc/sv/dbus /etc/runit/runsvdir/default/
|
||||||
|
ln -s /etc/sv/NetworkManager /etc/runit/runsvdir/default/
|
||||||
|
ln -s /etc/sv/sshd /etc/runit/runsvdir/default/
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
sudo rm "$TMP_DIR_MOUNT/usr/bin/qemu-aarch64-static"
|
sudo rm "$TMP_DIR_MOUNT/usr/bin/qemu-aarch64-static"
|
||||||
cleanup_mounts
|
cleanup_mounts
|
||||||
|
|
||||||
mkdir -p "$OUT_DIR"
|
mkdir -p "$OUT_DIR"
|
||||||
xz --threads=0 --compress --stdout "$img" > "$OUT_DIR/$(basename $img.xz)"
|
xz --threads=0 --compress --stdout "$img" > "$OUT_DIR/$(basename "$img.xz")"
|
||||||
|
|
||||||
echo "built pinebookpro image: $OUT_DIR/$(basename $img.xz)"
|
echo "built pinebookpro image: $OUT_DIR/$(basename "$img.xz")"
|
||||||
}
|
}
|
||||||
|
|
||||||
trap cleanup 0 SIGHUP SIGINT SIGQUIT SIGABRT SIGTERM
|
trap cleanup 0 SIGHUP SIGINT SIGQUIT SIGABRT SIGTERM
|
||||||
|
Loading…
Reference in New Issue
Block a user