mirror of
git://slackware.nl/current.git
synced 2025-01-27 07:59:56 +01:00
41196c6ff1
a/kernel-generic-6.12.3-x86_64-1.txz: Upgraded. a/mkinitrd-1.4.11-x86_64-53.txz: Rebuilt. /etc/default/geninitrd: added option AUTO_UPDATE_GRUB=true to run update-grub after generating the initrd. Move the remove-orphaned-initrds section from geninitrd to setup.01.mkinitrd. setup.01.mkinitrd: support AUTO_UPDATE_GRUB. Suppress warnings from libdevmapper when setup.01.mkinitrd is run within upgradepkg's flock locking. a/pkgtools-15.1-noarch-20.txz: Rebuilt. pkgtool: set INSIDE_INSTALLER in the Setup section to match the expected behavior. Thanks to Mechanikx. upgradepkg: allow text produced by install scripts to reach the console in --terse mode. d/kernel-headers-6.12.3-x86-1.txz: Upgraded. k/kernel-source-6.12.3-noarch-1.txz: Upgraded. l/PyQt-builder-1.17.0-x86_64-1.txz: Upgraded. l/sof-firmware-2024.09.2-noarch-1.txz: Upgraded. l/xapian-core-1.4.27-x86_64-1.txz: Upgraded. x/mesa-24.3.1-x86_64-2.txz: Rebuilt. Revert commit 4c065158927d7bacc5eb1e4f2491b1db93f1dc12: [PATCH] dri: revert INVALID modifier special-casing. This fixes a crash with AMD RX 470 through 590. Thanks to genss for the bug report. xfce/xfce4-pulseaudio-plugin-0.4.9-x86_64-1.txz: Upgraded. isolinux/initrd.img: Rebuilt. kernels/*: Upgraded. usb-and-pxe-installers/usbboot.img: Rebuilt. |
||
---|---|---|
.. | ||
sources | ||
build_installer.sh | ||
ChangeLog.txt | ||
installer.SlackBuild | ||
module-blacklist | ||
README | ||
repack_installer.SlackBuild |
The build_installer.sh script ============================= The 'build_installer.sh' script has the following characteristics: * It works for all Slackware ARCH'es (tested with i586 and x86_64) * It can be started from any directory, because resulting output files will be written to the current directory. This means that the script directory can be on a read-only filesystem. * It can update a pre-existing initrd.img file with kernel modules for a new kernel in one single command * It can build a complete Slackware installer set (initrd.img , usbboot.img and pxelinux.cfg_default files) from scratch * It can create a tarball containing a 'skeleton' for an initrd, which does not contain any ARCH specific binary code; only the directory structure, symlinks, configuration files and scripts. This skeleton can be used as a base for creating a new initrd from scratch, in which case no previous initrd.img file needs to be present to obtain the scripts etc from. The skeleton file will be called 'skeleton_initrd.tar.gz' and will be written to the current directory. Command line parameters and detailed usage ========================================== Running "./build_installer.sh -h" shows this message: # ----------------------------------------------------------------------------# Usage: build_installer.sh <parameters> Parameters: -h|--help Show this help -c|--compressmods Compress the kernel modules inside the initrd.img -m|--multiple Multiple initrd files (for SMP and non-SMP kernels) -n|--netmods Add network modules to the initrd -nc|--no-compressmods Do _not_ compress kernel modules -nm|--no-multiple Do _not_ create multiple initrd files -nn|--no-netmods Do _not_ add network modules to the initrd -np|--no-pcmciamods Do _not_ add pcmcia modules to the initrd -nr|--no-recompile Do _not_ recompile /re-add binaries -nu|--no-usbboot Do _not_ create a USB boot image -p|--pcmciamods Add pcmcia modules to the initrd -q|--quiet Be (fairly) quiet during progress -r|--recompile Recompile /re-add binaries (busybox,bash,dropbear as well as any required bin/lib from Slackware packages) -s|--skeleton Stop after creating a skeleton_initrd.tar.gz (which only contains directories and scripts) -u|--usbboot Create a USB boot image -v|--verbose Be (very) verbose during progress -I|--initrd <file> Specify location of the initrd.img file -S|--slackroot <dir> Specify location of the Slackware directory tree Actions to be taken (ARCH=x86_64): * Be (very) verbose during progress * Recompile /re-add binaries * Add network modules to the initrd * Add pcmcia modules to the initrd * Compress all kernel modules * Do _not_ split the initrd * Create a USB boot image Use Slackware root: /mnt/nfs/door/non-public/slackware-current Use initrd file: /mnt/nfs/door/non-public/slackware-current/isolinux/initrd.img # Note: [1] If you want to build your own specific bash, busybox and dropbear # # instead of using the sources provided by the Slackware tree, # # you should have these sources ready below # # ./sources/{bash,busybox,dropbear} # # Delete the directory if you don't want to use it! # # [2] If you want to use your own _skeleton_ initrd (containing only # # the directory layout plus all the scripts) you just make it # # available as ./sources/initrd/skeleton_initrd.tar.gz # # # # The script will look for the directory 'sources' first in your # # working directory, and next in the script's directory (whatever is # # found in your working directory takes precedence). # # ----------------------------------------------------------------------------# The default actions performed by the script may be different for each ARCH - they are parametrized in the script and can be modified by adding commandline switches to the script's invocation. The examples below use explicit switches to make them are valid commands for all ARCHes. Examples of usage ================== (1) Specify a different ARCH than the default, and point the script to a non-default root directory of the Slackware tree: # ARCH=i486 SLACKROOT=~ftp/pub/slackware-current ./build_installer.sh (2) Slackware gets a new kernel, and the initrd needs to be updated with new modules: # ./build_installer.sh -n -p -nr -u This command adds updated net/pcmcia modules to the initrd.img (and removes old modules of course), will not recompile any of the binary software inside (notably bash, busybox and dropbear) and will create a USB boot image as the final action. Output files are created in the current directory. (3) Strip Slackware's existing initrd.img until it's skeleton remains: # ./build_installer.sh -s This command takes the file '$SLACKROOT/isolinux/initrd.img' and writes the resulting 'skeleton_initrd.tar.gz' to the current directory. NOTE: If you ever need to create a skeleton tarball, be sure to use a 32bit slackware tree's initrd.img file for this. That way, the pathname 'slackware' will be present in the tarball, and the build_installer.sh script will be able to translate that to an ARCH-specific directory name like for instance "slackware64" for the x86_64 platform. Even on x86_64 you can run this command: # ARCH=i486 SLACKROOT=/stuff/slackware32 ./build_installer.sh -s to use a 32bit initrd.img file as the source. (4) Create a new initrd.img file from scratch, using a pre-existing skeleton initrd tarball, and my own busybox sources/patches (while using the sources for bash and dropbear that are present in the slackware directory tree): # mkdir -p ./sources/{busybox,initrd} # cp /home/slackware64/installer/skeleton_initrd.tar.gz ./sources/initrd/ # cp -a my_busybox_stuff/* ./sources/busybox/ # ARCH=x86_64 ./build_installer.sh -c -n -p -u This will build initrd.img from the ground up, compiling binaries for bash, busybox and dropbear (used in the installer) from their sources and extracting library/binary files from several of the Slackware packages found in the slackware directory tree. Network and pcmcia kernel modules will be added and compressed (cutting down the client's RAM requirements with 9 MB during installation), and finally a USB bootable image named 'usbboot.img' will be created.