Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/void-linux/void-mklive
The Void Linux live image maker
https://github.com/void-linux/void-mklive
hacktoberfest voidlinux
Last synced: 3 days ago
JSON representation
The Void Linux live image maker
- Host: GitHub
- URL: https://github.com/void-linux/void-mklive
- Owner: void-linux
- License: other
- Created: 2018-06-15T15:25:59.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2025-01-01T19:52:11.000Z (13 days ago)
- Last Synced: 2025-01-05T00:06:03.123Z (10 days ago)
- Topics: hacktoberfest, voidlinux
- Language: Shell
- Homepage: https://voidlinux.org
- Size: 796 KB
- Stars: 337
- Watchers: 29
- Forks: 196
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
- awesome-systools - void-mklive
README
# The Void Linux live image/rootfs generator and installer
## Overview
This repository contains several utilities:
* [*mklive.sh*](#mklivesh) - The Void Linux live image generator for x86
* [*mkiso.sh*](#mkisosh) - Wrapper script to generate bootable and installable live
images for i686, x86_64, and aarch64.
* [*mkrootfs.sh*](#mkrootfssh) - The Void Linux rootfs generator for all platforms
* [*mkplatformfs.sh*](#mkplatformfssh) - The Void Linux filesystem tool to produce
a rootfs for a particular platform
* [*mkimage.sh*](#mkimagesh) - The Void Linux image generator for ARM platforms
* [*mknet.sh*](#mknetsh) - Script to generate netboot tarballs for Void
* *installer.sh* - The Void Linux el-cheapo installer for x86
* *release.sh* - interacts with GitHub CI to generate and sign images for releases### Workflow
#### Generating x86 live ISOs
To generate a live ISO like the officially-published ones, use
[*mkiso.sh*](#mkisosh). To generate a more basic live ISO
(which does not include things like `void-installer`), use [*mklive.sh*](#mklivesh).#### Generating ROOTFS tarballs
ROOTFS tarballs contain a basic Void Linux root filesystem without a kernel.
These can be useful for doing a [chroot install](https://docs.voidlinux.org/installation/guides/chroot.html)
or for [chroots and containers](https://docs.voidlinux.org/config/containers-and-vms/chroot.html).Use [*mkrootfs.sh*](#mkrootfssh) to generate a Void Linux ROOTFS.
#### Generating platform-specific tarballs
Platform-specific ROOTFS tarballs, or PLATFORMFS tarballs, contain a basic Void
Linux root filesystem including a kernel. These are commonly used for bootstrapping
ARM systems or other environments that require platform-specific kernels, like
Raspberry Pis.First create a ROOTFS for the desired architecture, then use
[*mkplatformfs.sh*](#mkplatformfssh) to generate a Void Linux PLATFORMFS.#### Generating ARM images
Platform-specific filesystem images contain a basic filesystem layout (`/` and
`/boot` partitions), ready to be copied to the target drive with `dd`. These are
not "live" images like those available on x86 platforms, and do not need
installation like live ISOs.To generate these images, first create a PLATFORMFS for the desired platform,
then use [*mkimage.sh*](#mkimagesh) to generate the image.## Dependencies
Note that void-mklive is not guaranteed to work on distributions other than Void
Linux, or in containers.* Compression type for the initramfs image (by default: liblz4 for lz4, xz)
* xbps>=0.45
* qemu-user-static binaries (for mkrootfs)
* bash## Kernel Command-line Parameters
`void-mklive`-based live images support several kernel command-line arguments
that can change the behavior of the live system:- `live.autologin` will skip the initial login screen on `tty1`.
- `live.user` will change the username of the non-root user from the default
`anon`. The password remains `voidlinux`.
- `live.shell` sets the default shell for the non-root user in the live environment.
- `live.accessibility` enables accessibility features like the console screenreader
`espeakup` in the live environment.
- `console` can be set to `ttyS0`, `hvc0`, or `hvsi0` to enable `agetty` on that
serial console.
- `locale.LANG` will set the `LANG` environment variable. Defaults to `en_US.UTF-8`.
- `vconsole.keymap` will set the console keymap. Defaults to `us`.### Examples:
- `live.autologin live.user=foo live.shell=/bin/bash` would create the user `foo`
with the default shell `/bin/bash` on boot, and log them in automatically on `tty1`
- `live.shell=/bin/bash` would set the default shell for the `anon` user to `/bin/bash`
- `console=ttyS0 vconsole.keymap=cf` would enable `ttyS0` and set the keymap in
the console to `cf`
- `locale.LANG=fr_CA.UTF-8` would set the live system's language to `fr_CA.UTF-8`## Usage
### mkiso.sh
```
Usage: mkiso.sh [options ...] [-- mklive options ...]Wrapper script around mklive.sh for several standard flavors of live images.
Adds void-installer and other helpful utilities to the generated images.OPTIONS
-a Set XBPS_ARCH in the image
-b One of base, enlightenment, xfce, mate, cinnamon, gnome, kde,
lxde, or lxqt (default: base). May be specified multiple times
to build multiple variants
-d Override the datestamp on the generated image (YYYYMMDD format)
-t
Equivalent to setting -a, -b, and -d
-r Use this XBPS repository. May be specified multiple times
-h Show this help and exit
-V Show version and exitOther options can be passed directly to mklive.sh by specifying them after the --.
See mklive.sh -h for more details.
```### mklive.sh
```
Usage: mklive.sh [options]Generates a basic live ISO image of Void Linux. This ISO image can be written
to a CD/DVD-ROM or any USB stick.To generate a more complete live ISO image, use mkiso.sh.
OPTIONS
-a Set XBPS_ARCH in the ISO image
-b Set an alternative base package (default: base-system)
-r Use this XBPS repository. May be specified multiple times
-c Use this XBPS cache directory (default: ./xbps-cachedir-)
-k Default keymap to use (default: us)
-l Default locale to use (default: en_US.UTF-8)
-i
Compression type for the initramfs image (default: xz)
-s Compression type for the squashfs image (default: xz)
-o Output file name for the ISO image (default: automatic)
-p " ..." Install additional packages in the ISO image
-g " ..." Ignore packages when building the ISO image
-I Include directory structure under given path in the ROOTFS
-S " ..." Enable services in the ISO image
-e Default shell of the root user (must be absolute path).
Set the live.shell kernel argument to change the default shell of anon.
-C " ..." Add additional kernel command line arguments
-P " ..."
Platforms to enable for aarch64 EFI ISO images (available: pinebookpro, x13s)
-T Modify the bootloader title (default: Void Linux)
-v linux Install a custom Linux version on ISO image (default: linux metapackage).
Also accepts linux metapackages (linux-mainline, linux-lts).
-K Do not remove builddir
-h Show this help and exit
-V Show version and exit
```### mkrootfs.sh
```
Usage: mkrootfs.sh [options]Generate a Void Linux ROOTFS tarball for the specified architecture.
Supported architectures:
i686, i686-musl, x86_64, x86_64-musl,
armv5tel, armv5tel-musl, armv6l, armv6l-musl, armv7l, armv7l-musl
aarch64, aarch64-musl,
mipsel, mipsel-musl,
ppc, ppc-musl, ppc64le, ppc64le-musl, ppc64, ppc64-musl
riscv64, riscv64-muslOPTIONS
-b Set an alternative base-system package (default: base-container-full)
-c Set XBPS cache directory (default: ./xbps-cachedir-)
-C Full path to the XBPS configuration file
-r Use this XBPS repository. May be specified multiple times
-o Filename to write the ROOTFS to (default: automatic)
-x Number of threads to use for image compression (default: dynamic)
-h Show this help and exit
-V Show version and exit
```### mkplatformfs.sh
```
Usage: mkplatformfs.sh [options]Generates a platform-specific ROOTFS tarball from a generic Void Linux ROOTFS
generated by mkrootfs.sh.Supported platforms: i686, x86_64, GCP,
rpi-armv6l, rpi-armv7l, rpi-aarch64,
pinebookpro, pinephone, rock64, rockpro64OPTIONS
-b Set an alternative base-system package (default: base-system)
-c Set the XBPS cache directory (default: ./xbps-cachedir-)
-C Full path to the XBPS configuration file
-k Call ' ' after building the ROOTFS
-n Do not compress the image, instead print out the ROOTFS directory
-o Filename to write the PLATFORMFS archive to (default: automatic)
-p " ..." Additional packages to install into the ROOTFS
-r Use this XBPS repository. May be specified multiple times
-x Number of threads to use for image compression (default: dynamic)
-h Show this help and exit
-V Show version and exit
```### mkimage.sh
```
Usage: mkimage.sh [options]Generates a filesystem image suitable for writing with dd from a PLATFORMFS
tarball generated by mkplatformfs.sh. The filesystem layout is configurable,
but customization of the installed system should be done when generating the
PLATFORMFS. The resulting image will have 2 partitions, /boot and /.OPTIONS
-b /boot filesystem type (default: vfat)
-B /boot filesystem size (default: 256MiB)
-r / filesystem type (default: ext4)
-s Total image size (default: 768MiB)
-o Image filename (default: guessed automatically)
-x Number of threads to use for image compression (default: dynamic)
-h Show this help and exit
-V Show version and exitAccepted size suffixes: KiB, MiB, GiB, TiB, EiB.
The argument expects a tarball generated by mkplatformfs.sh.
The platform is guessed automatically by its name.
```### mknet.sh
```
Usage: mknet.sh [options]Generates a network-bootable tarball from a Void Linux ROOTFS generated by mkrootfs.
OPTIONS
-r Use this XBPS repository. May be specified multiple times
-c Use this XBPS cache directory (default: )
-i
Compression type for the initramfs image (default: xz)
-o Output file name for the netboot tarball (default: automatic)
-K linux Install a custom Linux version on ISO image (default: linux metapackage)
-k Default keymap to use (default: us)
-l Default locale to use (default: en_US.UTF-8)
-C " ..." Add additional kernel command line arguments
-T Modify the bootloader title (default: Void Linux)
-S Set a custom splash image for the bootloader (default: data/splash.png)
-h Show this help and exit
-V Show version and exit
```