commit:     4e90970dc09d444ff3277a68ea676e0536fc1aa0
Author:     Matthias Maier <tamiko <AT> gentoo <DOT> org>
AuthorDate: Wed May  3 22:52:28 2017 +0000
Commit:     Matthias Maier <tamiko <AT> gentoo <DOT> org>
CommitDate: Wed May  3 23:07:54 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4e90970d

sys-firmware/seabios: version bump to 1.10.2

 - port to EAPI 6
 - also build/install bios-256k.bin, bug #617422

Package-Manager: Portage-2.3.5, Repoman-2.3.2

 sys-firmware/seabios/Manifest                      |   2 +
 sys-firmware/seabios/files/seabios/README          |   1 +
 .../seabios/files/seabios/config.seabios-128k      |  12 ++
 .../seabios/files/seabios/config.seabios-256k      |   3 +
 sys-firmware/seabios/seabios-1.10.2.ebuild         | 140 +++++++++++++++++++++
 5 files changed, 158 insertions(+)

diff --git a/sys-firmware/seabios/Manifest b/sys-firmware/seabios/Manifest
index d46b9d6b1d7..f966203f9ee 100644
--- a/sys-firmware/seabios/Manifest
+++ b/sys-firmware/seabios/Manifest
@@ -2,6 +2,8 @@ DIST bios.bin-1.10.1.xz 63668 SHA256 
39d39cfa8166d947439081dedebb8c79a159de9b8b5
 DIST bios.bin-1.7.5.gz 78943 SHA256 
2e83e68e6cff73ede1c2490dabad74c177d7b67f9d93a5ed5f2ef39e76dea0ea SHA512 
153a4cf190843540a9a72fcb0cf34f1f9f6ff2efb4b4f700c515dea467b101a8999421b53c2f21599864e2e803ae455a4ae39c7e8be9491c4383b4bfbe734014
 WHIRLPOOL 
2383f5f3a91581b0ee0ff19fd429a67b7fe09db05c456b98aee01ab9008a12d265e56f81b4d60224c7be15a86da9d2288f83a1d83f621b2ff00ab3aaccb277a4
 DIST bios.bin-1.8.2.xz 67428 SHA256 
b4628fdbfc39fd73e7ab0c54dfc26128b6011d34778e381c1b2d2340209be838 SHA512 
2b2339c02134bcbd6e71e8d31f9907a160534a047bc91502c215d3d4c79431b962177ac43d826cc5689d71dfc0995bc8a9a5caf1a35929f308b3c2bdad720c15
 WHIRLPOOL 
050a7880d0da8bb8be1ce3e1262f7e5107a5a426eb31ce9629ef497305e390d348de7ed3c7595248010eb02481a2b4a9e4dca94b3a9c954c18b8a9624f46bbc6
 DIST seabios-1.10.1.tar.gz 588092 SHA256 
5063ddbac61ec4e61a12daa83931c37e5629b1c18502f7c00ed4e696c2a1d2cb SHA512 
b2f1c2b15853b1cc949f741ae13f32fd133efb0d0917e1cdfb253f9cd0bc9bb0b42c592cdd87bc74ccbb12a4301c102ae723ccdb490ea4716e0c9dca3dd3fead
 WHIRLPOOL 
723d4835288566bbb6a3c3b7df2486c0a7f949590404230667a4e4490317591bcdb99dd9b0933770d8c1416c25f6a8d20b153d7410787e19d8ecbd92a7312af9
+DIST seabios-1.10.2-bin.tar.xz 121172 SHA256 
d32e349fcd865d447856be7d7034f47f1e1d11b413d4158f747d68d03175792b SHA512 
a46ce389b8b0fe7182a3dc2954fab7e0ef27ac65823e3785c247ccf77c37eaa746d94f74a4a29a221aa16ab508cf07ec8d399aa612d5c0184b48bce24c663b69
 WHIRLPOOL 
17eaa7ecd4a126e4b021728ab5136d4a918e1ba413a8c56416eeb7202c9d5b1c3439ef2c528e8be3f863b3a218bcb2ffded0b1a037eee0eaf1fc52cb04f228c8
+DIST seabios-1.10.2.tar.gz 589283 SHA256 
89c70b70fa7ab179694efb95c2c89d4f50a39381321cbed5d8302cb9b25e953d SHA512 
ea8396fe247a3bd16b43ab775cf8e23f139673b94e83f450cadb094cc8117ca7e9ef518162d965209d5ab091c96f70ec5cc8ec8d15b638e06c4c8f7a0e1609dc
 WHIRLPOOL 
1df63d9b5940d8e1b099f75ff090505088104dc0d599ba9403c5ceb2caabf0f92023ae5bebe06ee5ad95d44e22ae540b0c9d9000fa7859801044ccd999d6efce
 DIST seabios-1.7.5.tar.gz 537566 SHA256 
858d9eda4ad91efa1c45a5a401d560ef9ca8dd172f03b0a106f06661c252dc51 SHA512 
ecf5fb9ac44dde6e4ac00baa6c920dde51b923f23dd74e62c5a02eceaf235e57b885975c5a8bd0927e268115c72bd1143a080fdfd4eff4e168ebeaa30436280e
 WHIRLPOOL 
5e1e99b3bd82a8607c5986fde4592c7437bec4bd78abd5873710f6c431d075436725e8d0d32e9f0dd2921c9d84b8613108b21d31c5309a73e337ead7adf35e90
 DIST seabios-1.8.2.tar.gz 538497 SHA256 
f59479307fdae840de398b75aacb2333c8eba24a5964d68c77e32ca6c987ee61 SHA512 
798d222d5f5725a805cde9e6000b5ce714d0551fd4a3c2642cc6e77b2bdab1a9e239939a358a23bbe0e00112f5ad70696c87d20b90655463c835541fc04e1a00
 WHIRLPOOL 
9cda0ad502a59dd718c543b759ac3fcf5acb4adee70c3da9bfea95ab188415acf6425827de77f45421ec3be8fd9e0c37fb486e62828217ba3e83f88d942a3f4a
 DIST seabios_1.7.5-1_all.deb 112098 SHA256 
61bab13a733e8087147ae4798f0053c6d632866e332a1ee3af2265e4f57ced36 SHA512 
891a26e084ccac8e9badce5a58eeadfb958af9d5ed087a99998f92153718e8231c14abfae0ed86bde870aa9e2f29fd93d5cc04515695e6f2d7b9fcaaef11bfce
 WHIRLPOOL 
d47ad79e7bd701862d059d86c7cb3b730b0303c5170ec52a481df5326cad0cd98ea78fcdb2730623b6b65289d9042f4685991eb515402543083cd8228f849959

diff --git a/sys-firmware/seabios/files/seabios/README 
b/sys-firmware/seabios/files/seabios/README
new file mode 100644
index 00000000000..7030949c181
--- /dev/null
+++ b/sys-firmware/seabios/files/seabios/README
@@ -0,0 +1 @@
+The config.vga-xxx files come from the qemu/roms/ tree.

diff --git a/sys-firmware/seabios/files/seabios/config.seabios-128k 
b/sys-firmware/seabios/files/seabios/config.seabios-128k
new file mode 100644
index 00000000000..93203af0ded
--- /dev/null
+++ b/sys-firmware/seabios/files/seabios/config.seabios-128k
@@ -0,0 +1,12 @@
+# for qemu machine types 1.7 + older
+# need to turn off features (xhci,uas) to make it fit into 128k
+CONFIG_QEMU=y
+CONFIG_ROM_SIZE=128
+CONFIG_BOOTSPLASH=n
+CONFIG_XEN=n
+CONFIG_USB_OHCI=n
+CONFIG_USB_XHCI=n
+CONFIG_USB_UAS=n
+CONFIG_SDCARD=n
+CONFIG_TCGBIOS=n
+CONFIG_MPT_SCSI=n

diff --git a/sys-firmware/seabios/files/seabios/config.seabios-256k 
b/sys-firmware/seabios/files/seabios/config.seabios-256k
new file mode 100644
index 00000000000..65e5015c2f1
--- /dev/null
+++ b/sys-firmware/seabios/files/seabios/config.seabios-256k
@@ -0,0 +1,3 @@
+# for qemu machine types 2.0 + newer
+CONFIG_QEMU=y
+CONFIG_ROM_SIZE=256

diff --git a/sys-firmware/seabios/seabios-1.10.2.ebuild 
b/sys-firmware/seabios/seabios-1.10.2.ebuild
new file mode 100644
index 00000000000..ad50dcd7ec5
--- /dev/null
+++ b/sys-firmware/seabios/seabios-1.10.2.ebuild
@@ -0,0 +1,140 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="6"
+
+PYTHON_COMPAT=( python{2_7,3_{4,5}} )
+
+inherit eutils toolchain-funcs python-any-r1
+
+# SeaBIOS maintainers sometimes don't release stable tarballs or stable
+# binaries to generate the stable tarball the following is necessary:
+# git clone git://git.seabios.org/seabios.git && cd seabios
+# git archive --output seabios-${PV}.tar.gz --prefix seabios-${PV}/ rel-${PV}
+
+if [[ ${PV} == *9999* || -n "${EGIT_COMMIT}" ]] ; then
+       EGIT_REPO_URI="git://git.seabios.org/seabios.git"
+       inherit git-r3
+else
+       KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 
~s390 ~sh ~sparc ~x86 ~amd64-fbsd ~x86-fbsd"
+
+       # Binary versions taken from fedora:
+       # 
http://download.fedoraproject.org/pub/fedora/linux/development/rawhide/Everything/x86_64/os/Packages/s/
+       #   seabios-bin-1.10.2-1.fc27.noarch.rpm
+       #   seavgabios-bin-1.10.2-1.fc27.noarch.rpm
+       SRC_URI="
+               !binary? ( 
https://code.coreboot.org/p/seabios/downloads/get/${P}.tar.gz )
+               binary? ( 
https://dev.gentoo.org/~tamiko/distfiles/${P}-bin.tar.xz )"
+fi
+
+DESCRIPTION="Open Source implementation of a 16-bit x86 BIOS"
+HOMEPAGE="https://www.seabios.org/";
+
+LICENSE="LGPL-3 GPL-3"
+SLOT="0"
+IUSE="+binary debug +seavgabios"
+
+REQUIRED_USE="debug? ( !binary )
+       !amd64? ( !x86? ( binary ) )"
+
+# The amd64/x86 check is needed to workaround #570892.
+SOURCE_DEPEND="
+       >=sys-power/iasl-20060912
+       ${PYTHON_DEPS}"
+DEPEND="
+       !binary? (
+               amd64? ( ${SOURCE_DEPEND} )
+               x86? ( ${SOURCE_DEPEND} )
+       )"
+RDEPEND=""
+
+pkg_pretend() {
+       if ! use binary; then
+               ewarn "You have decided to compile your own SeaBIOS. This is 
not"
+               ewarn "supported by upstream unless you use their recommended"
+               ewarn "toolchain (which you are not)."
+               elog
+               ewarn "If you are intending to use this build with QEMU, 
realize"
+               ewarn "you will not receive any support if you have compiled 
your"
+               ewarn "own SeaBIOS. Virtual machines subtly fail based on 
changes"
+               ewarn "in SeaBIOS."
+       fi
+}
+
+pkg_setup() {
+       use binary || python-any-r1_pkg_setup
+}
+
+src_unpack() {
+       default
+
+       # This simplifies the logic between binary & source builds.
+       mkdir -p "${S}"
+}
+
+src_configure() {
+       use binary && return
+
+       tc-ld-disable-gold #438058
+
+       if use debug ; then
+               echo "CONFIG_DEBUG_LEVEL=8" >.config
+       fi
+       _emake config
+}
+
+_emake() {
+       LANG=C \
+       emake V=1 \
+               CC="$(tc-getCC)" \
+               LD="$(tc-getLD)" \
+               AR="$(tc-getAR)" \
+               OBJCOPY="$(tc-getOBJCOPY)" \
+               RANLIB="$(tc-getRANLIB)" \
+               OBJDUMP="$(tc-getOBJDUMP)" \
+               HOST_CC="$(tc-getBUILD_CC)" \
+               VERSION="Gentoo/${EGIT_COMMIT:-${PVR}}" \
+               "$@"
+}
+
+src_compile() {
+       use binary && return
+
+       for t in 128k 256k ; do
+               cp "${FILESDIR}/seabios/config.seabios-${t}" .config || die
+               _emake oldnoconfig
+               _emake out/bios.bin
+               mv out/bios.bin ../bios-${t}.bin || die
+       done
+
+       if use seavgabios ; then
+               local config t targets=(
+                       cirrus
+                       isavga
+                       qxl
+                       stdvga
+                       virtio
+                       vmware
+               )
+               for t in "${targets[@]}" ; do
+                       emake clean distclean
+                       cp "${FILESDIR}/seavgabios/config.vga-${t}" .config || 
die
+                       _emake oldnoconfig
+                       _emake out/vgabios.bin
+                       cp out/vgabios.bin ../vgabios-${t}.bin || die
+               done
+       fi
+}
+
+src_install() {
+
+       insinto /usr/share/seabios
+       use binary && doins ../bios.bin
+       use !binary && newins ../bios-128k.bin bios.bin
+       doins ../bios-256k.bin
+
+       if use seavgabios ; then
+               insinto /usr/share/seavgabios
+               doins ../vgabios*.bin
+       fi
+}

Reply via email to