mirror of
https://github.com/flatcar/scripts.git
synced 2026-05-05 12:16:41 +02:00
sys-firmware/ipxe: Sync with Gentoo
It's from Gentoo commit 5dc42e275c2e745e338c6c7ab9ee1a111a9e56ee.
This commit is contained in:
parent
901285757a
commit
4f0e6de254
138
sdk_container/src/third_party/portage-stable/sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild
vendored
Normal file
138
sdk_container/src/third_party/portage-stable/sys-firmware/ipxe/ipxe-1.21.1_p20230601-r1.ebuild
vendored
Normal file
@ -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
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user