commit:     158560fbdabfcabbb9f3d5f83528a6921b067aae
Author:     Bertrand Jacquin <bertrand <AT> jacquin <DOT> bzh>
AuthorDate: Mon Sep 23 19:31:34 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Sat Nov  2 12:45:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=158560fb

sys-firmware/ipxe: set version as from gentoo PV

By default, iPXE build include 1.0.0+ as version which can be confusing
when troubleshooting network boot. Set version as from ebuild PV.

Bug: https://bugs.gentoo.org/940181
Signed-off-by: Bertrand Jacquin <bertrand <AT> jacquin.bzh>
Closes: https://github.com/gentoo/gentoo/pull/38749
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild | 138 ++++++++++++++++++++++
 1 file changed, 138 insertions(+)

diff --git a/sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild 
b/sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild
new file mode 100644
index 000000000000..ba72efe484d6
--- /dev/null
+++ b/sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild
@@ -0,0 +1,138 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit savedconfig secureboot toolchain-funcs
+
+# for 1.21.1_p20230601
+COMMIT_SHA1="4fa4052c7ebb59e4d4aa396f1563c89118623ec7"
+
+DESCRIPTION="Open source network boot (PXE) firmware"
+HOMEPAGE="https://ipxe.org/";
+SRC_URI="
+       !binary? ( https://github.com/${PN}/${PN}/archive/${COMMIT_SHA1}.tar.gz 
-> ${P}.gh.tar.gz )
+       binary? ( https://dev.gentoo.org/~tamiko/distfiles/${P}-bin.tar.xz )"
+S="${WORKDIR}/${PN}-${COMMIT_SHA1}/src"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ppc64 ~riscv ~x86"
+IUSE="+binary uefi32 uefi64 ipv6 iso lkrn +qemu undi usb vmware"
+REQUIRED_USE="!amd64? ( !x86? ( binary ) )"
+
+SOURCE_DEPEND="
+       app-arch/xz-utils
+       dev-lang/perl
+       iso? (
+               app-cdr/cdrtools
+               sys-boot/syslinux
+       )"
+BDEPEND="
+       !binary? (
+               amd64? ( ${SOURCE_DEPEND} )
+               x86? ( ${SOURCE_DEPEND} )
+       )"
+
+pkg_setup() {
+       if use uefi32 || use uefi64; then
+               secureboot_pkg_setup
+       fi
+}
+
+src_configure() {
+       use binary && return
+
+       cat > config/local/general.h <<-EOF || die
+               #undef BANNER_TIMEOUT
+               #define BANNER_TIMEOUT 0
+       EOF
+
+       if use ipv6; then
+               cat >> config/local/general.h <<-EOF || die
+                       #define NET_PROTO_IPV6
+               EOF
+       fi
+
+       if use vmware; then
+               cat >> config/local/general.h <<-EOF || die
+                       #define VMWARE_SETTINGS
+                       #define CONSOLE_VMWARE
+               EOF
+       fi
+
+       restore_config config/local/general.h
+
+       tc-ld-disable-gold
+}
+
+ipxemake() {
+       # Q='' makes the build verbose since that's what everyone loves now
+       emake Q='' \
+               VERSION="${PV}" \
+               CC="$(tc-getCC)" \
+               LD="$(tc-getLD)" \
+               AS="$(tc-getAS)" \
+               AR="$(tc-getAR)" \
+               NM="$(tc-getNM)" \
+               OBJCOPY="$(tc-getOBJCOPY)" \
+               RANLIB="$(tc-getRANLIB)" \
+               OBJDUMP="$(tc-getOBJDUMP)" \
+               HOST_CC="$(tc-getBUILD_CC)" \
+               "$@"
+}
+
+src_compile() {
+       use binary && return
+
+       export NO_WERROR=1
+       if use qemu; then
+               ipxemake bin/808610de.rom # pxe-e1000.rom (old)
+               ipxemake bin/8086100e.rom # pxe-e1000.rom
+               ipxemake bin/80861209.rom # pxe-eepro100.rom
+               ipxemake bin/10500940.rom # pxe-ne2k_pci.rom
+               ipxemake bin/10222000.rom # pxe-pcnet.rom
+               ipxemake bin/10ec8139.rom # pxe-rtl8139.rom
+               ipxemake bin/1af41000.rom # pxe-virtio.rom
+       fi
+
+       if use vmware; then
+               ipxemake bin/8086100f.mrom # e1000
+               ipxemake bin/808610d3.mrom # e1000e
+               ipxemake bin/10222000.mrom # vlance
+               ipxemake bin/15ad07b0.rom # vmxnet3
+       fi
+
+       use uefi32 && ipxemake PLATFORM=efi BIN=bin-i386-efi 
bin-i386-efi/ipxe.efi
+       use uefi64 && ipxemake PLATFORM=efi BIN=bin-x86_64-efi 
bin-x86_64-efi/ipxe.efi
+       use iso && ipxemake bin/ipxe.iso
+       use undi && ipxemake bin/undionly.kpxe
+       use usb && ipxemake bin/ipxe.usb
+       use lkrn && ipxemake bin/ipxe.lkrn
+}
+
+src_install() {
+       insinto /usr/share/ipxe/
+
+       if use qemu || use vmware; then
+               doins bin/*.rom
+       fi
+       use vmware && doins bin/*.mrom
+       use uefi32 && newins bin-i386-efi/ipxe.efi ipxe-i386.efi
+       use uefi64 && newins bin-x86_64-efi/ipxe.efi ipxe-x86_64.efi
+       # Add a symlink for backwards compatiblity, in case both variants are
+       # enabled the x86_64 bit variant takes presedence.
+       use uefi32 && dosym ipxe-i386.efi /usr/share/ipxe/ipxe.efi
+       use uefi64 && dosym ipxe-x86_64.efi /usr/share/ipxe/ipxe.efi
+
+       use iso && doins bin/*.iso
+       use undi && doins bin/*.kpxe
+       use usb && doins bin/*.usb
+       use lkrn && doins bin/*.lkrn
+
+       if use uefi32 || use uefi64; then
+               secureboot_auto_sign --in-place
+       fi
+
+       save_config config/local/general.h
+}

Reply via email to