Example on Minimal Gentoo PXE boot with focus on using iPXE
This is to show and use how Gentoo can be booted over PXE since Gentoo bug #396467 was resolved in 24ad50
Quick QEMU test: qemu-system-x86_64 -enable-kvm -M q35 -m 1024 -cpu host -nic user,model=virtio,tftp=.,bootfile=http://gentoo.ipxe.se/boot.ipxe -boot menu=on -usb
This uses iPXE, manual steps:
* Get into the iPXE shell (from PXE boot or even from one of the disk images)
* Get ip dhcp
* Start Gentoo chain http://gentoo.ipxe.se/boot.ipxe
If a file is referred to in a iPXE script, and not given as absolute path it tries to load from the "last path"
* kernel gentoo root=/dev/ram0 init=/linuxrc dokeymap looptype=squashfs loop=/image.squashfs cdroot initrd=initrd.magic vga=791
- download gentoo kernel image, and append standard cmdline as seen in isolinux/grub, the initrd= is required for the kernel to find the init file in EFI mode boot
* initrd combined.igz
- downloads combined.igz into memory - you can give the full path over http or tftp if you want to.
* boot
- boot
Script to simplify testing: test_w_qemu.sh useonline
See Issue #4 for more work on EFI
Working on this, See Gentoo bug #494300 and issue #2. There is also forum post
Grab or create boot.ipxe
script with the minimal configuration.
Use gentoocd_unpack.sh
to download latest iso and unpack needed files.
If you want to extract them yourself then it ise these files you need
* /boot/gentoo
* /boot/gentoo.igz
* /image.squashfs
And finaly create the combined initrd using (cat boot/gentoo.igz; (echo image.squashfs | cpio -H newc -o)) > combined.igz
Needed services are BOOTP/DHCP and TFTP. Refer to these services individually. You might also want to have a HTTP server for better performance. "PXE server" might refer to the one machine that serves both of these services.
Install a simple to use tftp server
# install atftp
emerge -uv1 net-ftp/atftp
# ensure we have tftp root directory
mkdir -p /tftproot
# add it to startup
rc-update add atftp default
# make sure it is running
/etc/init.d/atftp restart
# move to tftp root directory
pushd /tftproot
# Prepare iPXE files
for i in ipxe.efi snponly.efi undionly.kpxe ipxe.pxe; do wget -nc http://boot.ipxe.org/$i; done
# Optional Prepare Grub
grub-mknetdir --net-directory .
# Optional Prepare pxelinux
emerge -uv1 syslinux
cp /usr/share/syslinux/pxelinux.0 .
cp /usr/share/syslinux/ldlinux.c32 .
# TODO copy over configs for grub/pxelinux
popd
Use one of these, not both
This configuration as a great start for iPXE, official documentation can also be helpful. If you are in control of your DHCP server, then this is the best option.
If you can not replace your DHCP server then you can instead run Proxy DHCP. Full configuration for dnsmasq in proxydhcp mode
# Disable DNS server
port=0
# Configure proxy mode and interface
dhcp-range=${interface_subnet},proxy
interface=${interface_name}
# Enable PXE menu for non iPXE clients
dhcp-match=set:ipxe-ok,175,19
pxe-service=tag:!ipxe-ok,X86PC,PXE,undionly.kpxe,${tftp_server_ip}
pxe-service=tag:!ipxe-ok,BC_EFI,PXE,snponly.efi,${tftp_server_ip}
pxe-service=tag:!ipxe-ok,X86-64_EFI,PXE,snponly.efi,${tftp_server_ip}
# Send script to valid iPXE clients
dhcp-boot=tag:ipxe-ok,http://gentoo.ipxe.se/boot.ipxe,,0.0.0.1
Above server side generated combined.igz
has been used. It is also possible to do this client side.
* initrd gentoo.igz
* kernel gentoo {insert options} initrd=initrd.magic
* initrd image.squashfs /image.squashfs
Last initrd Appends squashfs with CPIO header to the ram data, the second argument tells which name to use in CPIO archive
As mentioned initrd=
is required in EFI mode, initrd.magic
is a special file in iPXE EFI since e5f025 that combines all initrd files into one CPIO archive, pcbios has done the same concatination for a long time.
(cat gentoo.igz; (echo image.squashfs | cpio -H newc -o)) > combined.igz
(cat gentoo.igz; (echo image.squashfs | cpio -H newc -o | xz --check=crc32 -vT0)) > combined.igz
(xz -d gentoo.igz -c; (echo image.squashfs | cpio -H newc -o)) | xz --check=crc32 -vT0 > combined.igz
TODO investigate memory usage, what is the best way for the kernel in terms of free memory?
1.1KB 2021-08-28 00:31:33 LICENSE 5.7KB 2021-11-30 13:34:06 README.md 2.2KB 2021-08-28 00:32:05 altcombine.ipxe 1.4KB 2021-08-28 00:32:05 boot.ipxe 276B 2021-08-28 00:31:33 boot/grub/grub.cfg 394MB 2022-01-06 13:18:29 combined.igz 982B 2021-08-28 00:32:05 combined.ipxe 4.1MB 2022-01-02 19:26:07 gentoo 8.8MB 2022-01-02 19:33:48 gentoo.igz 2.7KB 2021-11-30 13:12:24 gentoocd_unpack.sh 385MB 2022-01-02 19:35:33 image.squashfs 432MB 2021-08-08 19:56:46 install-amd64-minimal-20210808T170546Z.iso 432MB 2021-08-15 19:47:00 install-amd64-minimal-20210815T170549Z.iso 432MB 2021-08-22 19:49:45 install-amd64-minimal-20210822T170550Z.iso 432MB 2021-08-29 19:48:17 install-amd64-minimal-20210829T170531Z.iso 436MB 2021-11-30 13:20:42 install-amd64-minimal-20211128T170532Z.iso 436MB 2021-12-10 18:12:13 install-amd64-minimal-20211205T170532Z.iso 436MB 2022-01-06 13:18:19 install-amd64-minimal-20220102T170545Z.iso 403B 2021-08-28 00:31:33 pxelinux.cfg/default 1.5KB 2021-08-28 00:36:45 test_w_qemu.sh