commit:     d453d858c6647c8e2ead875cb96a9a348cc95d78
Author:     Tomas Mozes <hydrapolic <AT> gmail <DOT> com>
AuthorDate: Thu Sep 27 08:18:15 2018 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Tue Oct  2 11:03:02 2018 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d453d858

app-emulation/xen-pvgrub: bump to 4.10.2

Signed-off-by: Tomáš Mózes <hydrapolic <AT> gmail.com>
Package-Manager: Portage-2.3.50, Repoman-2.3.11
Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 app-emulation/xen-pvgrub/Manifest                  |   1 +
 .../xen-pvgrub/files/xen-4.10-externals.patch      |  74 ++++++++++
 app-emulation/xen-pvgrub/xen-pvgrub-4.10.2.ebuild  | 163 +++++++++++++++++++++
 3 files changed, 238 insertions(+)

diff --git a/app-emulation/xen-pvgrub/Manifest 
b/app-emulation/xen-pvgrub/Manifest
index e7131adde7f..a701d239cfc 100644
--- a/app-emulation/xen-pvgrub/Manifest
+++ b/app-emulation/xen-pvgrub/Manifest
@@ -5,6 +5,7 @@ DIST pciutils-2.2.9.tar.bz2 212265 BLAKE2B 
014b664e90c64e7255c9e21fc25a2cc60d57f
 DIST polarssl-1.1.4-gpl.tgz 611340 BLAKE2B 
613da06dda9e4b86db5a4d616a0a0afee98c907c3c6b352eed3d9e500fc5739e62eb4f6fc32ff02579c6a6de9bd49fcd2c8bd8b2d158a5050cbaa82118d61ef0
 SHA512 
88da614e4d3f4409c4fd3bb3e44c7587ba051e3fed4e33d526069a67e8180212e1ea22da984656f50e290049f60ddca65383e5983c0f8884f648d71f698303ad
 DIST xen-4.10.1-upstream-patches-2.tar.xz 117588 BLAKE2B 
ddcd58964117652b50f3524d89089e2e9b14a8399fb5bd2db5d12827035ab94cedbfd5d65134d8953e4062a50e0e8a9b320e9c34008db8fd364456f47fd9cd26
 SHA512 
49ee8497af3753f3d611bf12c65fb7a79abb018862f1af096e9dde3ddfe8780bb95fc3da338c8d5f16a5d6d233d606d4cf8025a3d0e2897bf2668a1d5b27b198
 DIST xen-4.10.1.tar.gz 24674240 BLAKE2B 
f9a7e0c637db865ab32ad6b6185ab96022903aff65a18e194286a3fc372d4a45f6682cd636b7ac5b4fa0125e54ed51f8876a411d498cf75791718fd088c4a6d2
 SHA512 
236c02bee69e33644703ed26d323d4c491a91fc05bd0ee0990a7368579f7c82f5bb4510845bf80348fd923024d7d60d521f593dfd0365d971dc592f8ef10fbea
+DIST xen-4.10.2.tar.gz 24697204 BLAKE2B 
b331d3ad8d7842446f7d2da5dd31560f636aa1408dd3cc8798dff35b868ef5a609d17e97ef4355e1e5aa825a5abc74103796f9a8015037f0a564ffcebd825722
 SHA512 
2e301b4d6eb106fcb52203bc1208c8fd1fc7bb5d795166c0f86e4085227050301f7daa6f21db440c47bc2ca2c7f87d9b96753cfdf3fa724e0416b5679b84c163
 DIST xen-4.11.0-upstream-patches-1.tar.xz 56664 BLAKE2B 
27579f4e628bb0d3fdd59f7e133e9134d4ca175842dfdae3a3f765b133254239ae3bca94d75dd655735b5bcbd67f9b8d444dd227028642e6e459e57ed8a20341
 SHA512 
e90b8e7fa9433e93b1620a776833a6d3578babebe5d73dcaae11186f473945a2270046932ab314a9c6049d3b460a655456f487a5b59730fe88a4f08d482c47a1
 DIST xen-4.11.0.tar.gz 25131533 BLAKE2B 
892639b8bcd9b9956104e4d5137ffd88e17f92d965fa967b4af8d74a4fddcc21c6971c53026e0fb5ce833ab2c25c68f827abcac0b7b1dcebc21dca645c465573
 SHA512 
33d431c194f10d5ee767558404a1f80a66b3df019012b0bbd587fcbc9524e1bba7ea04269020ce891fe9d211d2f81c63bf78abedcdbe1595aee26251c803a50a
 DIST xen-4.9.2.tar.gz 23392753 BLAKE2B 
5f96f0e5062eff8ac2971eef85ea2bae0e94e7542151237937a1cf7e74690bb0ce1c952e830d2fc13b3277f70b9ed1de511afe4f780ad7b3be0c58742ece39b2
 SHA512 
e06aec25439abcc548c174ba8e271c23031ea704bcc2480905140aa68490064fbb1c58d9c4174f6617b4f7bbcddfda284317df6f480a6e5b5b5a2c71fbe0ac93

diff --git a/app-emulation/xen-pvgrub/files/xen-4.10-externals.patch 
b/app-emulation/xen-pvgrub/files/xen-4.10-externals.patch
new file mode 100644
index 00000000000..b206144e304
--- /dev/null
+++ b/app-emulation/xen-pvgrub/files/xen-4.10-externals.patch
@@ -0,0 +1,74 @@
+--- a/stubdom/Makefile 2013-07-09 18:46:56.000000000 +0800
++++ b/stubdom/Makefile 2013-07-21 16:07:08.094663570 +0800
+@@ -68,12 +68,12 @@
+ ##############
+ 
+ newlib-$(NEWLIB_VERSION).tar.gz:
+-      $(FETCHER) $@ $(NEWLIB_URL)/$@
+ 
+ newlib-$(NEWLIB_VERSION): newlib-$(NEWLIB_VERSION).tar.gz
+       tar xzf $<
+       patch -d $@ -p0 < newlib.patch
+       patch -d $@ -p0 < newlib-chk.patch
++      patch -d $@ -p0 < newlib-implicits.patch
+       patch -d $@ -p1 < newlib-stdint-size_max-fix-from-1.17.0.patch
+       find $@ -type f | xargs perl -i.bak \
+               -pe 's/\b_(tzname|daylight|timezone)\b/$$1/g'
+@@ -85,7 +85,7 @@
+ $(NEWLIB_STAMPFILE): mk-headers-$(XEN_TARGET_ARCH) newlib-$(NEWLIB_VERSION)
+       mkdir -p newlib-$(XEN_TARGET_ARCH)
+       ( cd newlib-$(XEN_TARGET_ARCH) && \
+-        CC_FOR_TARGET="$(CC) $(TARGET_CPPFLAGS) $(TARGET_CFLAGS) 
$(NEWLIB_CFLAGS)" AR_FOR_TARGET=$(AR) LD_FOR_TARGET=$(LD) 
RANLIB_FOR_TARGET=$(RANLIB) ../newlib-$(NEWLIB_VERSION)/configure 
--prefix=$(CROSS_PREFIX) --verbose --target=$(GNU_TARGET_ARCH)-xen-elf 
--enable-newlib-io-long-long --disable-multilib && \
++      CC_FOR_TARGET="$(CC) $(TARGET_CPPFLAGS) $(TARGET_CFLAGS) 
$(NEWLIB_CFLAGS)" AR_FOR_TARGET=$(AR) LD_FOR_TARGET=$(LD) LDFLAGS= 
RANLIB_FOR_TARGET=$(RANLIB) ../newlib-$(NEWLIB_VERSION)/configure 
--prefix=$(CROSS_PREFIX) --verbose --target=$(GNU_TARGET_ARCH)-xen-elf 
--enable-newlib-io-long-long --disable-multilib && \
+         $(MAKE) DESTDIR= && \
+         $(MAKE) DESTDIR= install )
+ 
+@@ -94,7 +94,6 @@
+ ############
+ 
+ zlib-$(ZLIB_VERSION).tar.gz:
+-      $(FETCHER) $@ $(ZLIB_URL)/$@
+ 
+ zlib-$(XEN_TARGET_ARCH): zlib-$(ZLIB_VERSION).tar.gz 
+       tar xzf $<
+@@ -105,7 +104,7 @@
+ cross-zlib: $(ZLIB_STAMPFILE)
+ $(ZLIB_STAMPFILE): zlib-$(XEN_TARGET_ARCH) $(NEWLIB_STAMPFILE)
+       ( cd $< && \
+-        CFLAGS="$(TARGET_CPPFLAGS) $(TARGET_CFLAGS)" CC=$(CC) ./configure 
--prefix=$(CROSS_PREFIX)/$(GNU_TARGET_ARCH)-xen-elf && \
++        CFLAGS="$(TARGET_CPPFLAGS) $(TARGET_CFLAGS)" CC="$(CC)" ./configure 
--prefix=$(CROSS_PREFIX)/$(GNU_TARGET_ARCH)-xen-elf && \
+         $(MAKE) DESTDIR= libz.a && \
+         $(MAKE) DESTDIR= install )
+ 
+@@ -114,7 +113,6 @@
+ ##############
+ 
+ pciutils-$(LIBPCI_VERSION).tar.bz2:
+-      $(FETCHER) $@ $(LIBPCI_URL)/$@
+ 
+ pciutils-$(XEN_TARGET_ARCH): pciutils-$(LIBPCI_VERSION).tar.bz2
+       tar xjf $<
+@@ -142,7 +140,6 @@
+ ######
+ 
+ lwip-$(LWIP_VERSION).tar.gz:
+-      $(FETCHER) $@ $(LWIP_URL)/$@
+ 
+ lwip-$(XEN_TARGET_ARCH): lwip-$(LWIP_VERSION).tar.gz
+       tar xzf $<
+@@ -180,7 +177,6 @@
+ # cross-polarssl
+ #############
+ polarssl-$(POLARSSL_VERSION)-gpl.tgz:
+-      $(FETCHER) $@ $(POLARSSL_URL)/$@
+ 
+ polarssl-$(XEN_TARGET_ARCH): polarssl-$(POLARSSL_VERSION)-gpl.tgz
+       tar xzf $<
+@@ -385,7 +382,6 @@
+ ######
+ 
+ grub-$(GRUB_VERSION).tar.gz:
+-      $(FETCHER) $@ $(GRUB_URL)/$@
+ 
+ grub-upstream: grub-$(GRUB_VERSION).tar.gz
+       tar xzf $<

diff --git a/app-emulation/xen-pvgrub/xen-pvgrub-4.10.2.ebuild 
b/app-emulation/xen-pvgrub/xen-pvgrub-4.10.2.ebuild
new file mode 100644
index 00000000000..f4536845d19
--- /dev/null
+++ b/app-emulation/xen-pvgrub/xen-pvgrub-4.10.2.ebuild
@@ -0,0 +1,163 @@
+# Copyright 1999-2018 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+PYTHON_COMPAT=( python2_7 )
+PYTHON_REQ_USE='xml,threads'
+
+inherit flag-o-matic multilib python-single-r1 toolchain-funcs
+
+XEN_EXTFILES_URL="http://xenbits.xensource.com/xen-extfiles";
+LIBPCI_URL=ftp://atrey.karlin.mff.cuni.cz/pub/linux/pci
+GRUB_URL=mirror://gnu-alpha/grub
+
+UPSTREAM_VER=
+[[ -n ${UPSTREAM_VER} ]] && \
+       
UPSTREAM_PATCHSET_URI="https://dev.gentoo.org/~dlan/distfiles/${P/-pvgrub/}-upstream-patches-${UPSTREAM_VER}.tar.xz
+               
https://github.com/hydrapolic/gentoo-dist/raw/master/xen/${P/-pvgrub/}-upstream-patches-${UPSTREAM_VER}.tar.xz";
+
+SRC_URI="
+               
https://downloads.xenproject.org/release/xen/${PV}/xen-${PV}.tar.gz
+               $GRUB_URL/grub-0.97.tar.gz
+               $XEN_EXTFILES_URL/zlib-1.2.3.tar.gz
+               $LIBPCI_URL/pciutils-2.2.9.tar.bz2
+               $XEN_EXTFILES_URL/lwip-1.3.0.tar.gz
+               $XEN_EXTFILES_URL/newlib/newlib-1.16.0.tar.gz
+               $XEN_EXTFILES_URL/polarssl-1.1.4-gpl.tgz
+               ${UPSTREAM_PATCHSET_URI}"
+
+S="${WORKDIR}/xen-${PV}"
+
+DESCRIPTION="allows to boot Xen domU kernels from a menu.lst laying inside 
guest filesystem"
+HOMEPAGE="https://www.xenproject.org";
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+IUSE="custom-cflags"
+
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+DEPEND="sys-devel/gettext
+       sys-devel/bin86
+       sys-apps/texinfo
+       x11-libs/pixman"
+
+RDEPEND="${PYTHON_DEPS}
+       >=app-emulation/xen-tools-${PV}"
+
+pkg_setup() {
+       python-single-r1_pkg_setup
+}
+
+retar-externals() {
+       # Purely to unclutter src_prepare
+       local set="grub-0.97.tar.gz lwip-1.3.0.tar.gz newlib-1.16.0.tar.gz 
polarssl-1.1.4-gpl.tgz zlib-1.2.3.tar.gz"
+
+       # eapply can't patch in $WORKDIR, requires a sed; Bug #455194. 
Patchable, but sed informative
+       sed -e s':AR=${AR-"ar rc"}:AR=${AR-"ar"}:' \
+               -i "${WORKDIR}"/zlib-1.2.3/configure
+       sed -e 's:^AR=ar rc:AR=ar:' \
+               -e s':$(AR) $@:$(AR) rc $@:' \
+               -i "${WORKDIR}"/zlib-1.2.3/{Makefile,Makefile.in}
+       einfo "zlib Makefile edited"
+
+       cd "${WORKDIR}"
+       tar czp zlib-1.2.3 -f zlib-1.2.3.tar.gz
+       tar czp grub-0.97 -f grub-0.97.tar.gz
+       tar czp lwip -f lwip-1.3.0.tar.gz
+       tar czp newlib-1.16.0 -f newlib-1.16.0.tar.gz
+       tar czp polarssl-1.1.4 -f polarssl-1.1.4-gpl.tgz
+       mv $set "${S}"/stubdom/
+       einfo "tarballs moved to source"
+}
+
+src_prepare() {
+       # Upstream's patchset
+       if [[ -n ${UPSTREAM_VER} ]]; then
+               einfo "Try to apply Xen Upstream patch set"
+               EPATCH_SUFFIX="patch" \
+               EPATCH_FORCE="yes" \
+               EPATCH_OPTS="-p1" \
+                       eapply "${WORKDIR}"/patches-upstream
+       fi
+
+       # if the user *really* wants to use their own custom-cflags, let them
+       if use custom-cflags; then
+               einfo "User wants their own CFLAGS - removing defaults"
+               # try and remove all the default custom-cflags
+               find "${S}" -name Makefile -o -name Rules.mk -o -name Config.mk 
-exec sed \
+                       -e 's/CFLAGS\(.*\)=\(.*\)-O3\(.*\)/CFLAGS\1=\2\3/' \
+                       -e 
's/CFLAGS\(.*\)=\(.*\)-march=i686\(.*\)/CFLAGS\1=\2\3/' \
+                       -e 
's/CFLAGS\(.*\)=\(.*\)-fomit-frame-pointer\(.*\)/CFLAGS\1=\2\3/' \
+                       -e 's/CFLAGS\(.*\)=\(.*\)-g3*\s\(.*\)/CFLAGS\1=\2 \3/' \
+                       -e 's/CFLAGS\(.*\)=\(.*\)-O2\(.*\)/CFLAGS\1=\2\3/' \
+                       -i {} \;
+       fi
+
+       # Patch the unmergeable newlib, fix most of the leftover gcc QA issues
+       cp "${FILESDIR}"/newlib-implicits.patch stubdom || die
+
+       # Patch stubdom/Makefile to patch insource newlib & prevent internal 
downloading
+       eapply "${FILESDIR}"/${PN/-pvgrub/}-4.10-externals.patch
+
+       # fix jobserver in Makefile
+       eapply "${FILESDIR}"/${PN}-4.8-jserver.patch
+
+       #Substitute for internal downloading. pciutils copied only due to the 
only .bz2
+       cp "${DISTDIR}"/pciutils-2.2.9.tar.bz2 ./stubdom/ || die "pciutils not 
copied to stubdom"
+       retar-externals || die "re-tar procedure failed"
+
+       default
+}
+
+src_configure() {
+       local myconf="--prefix=${PREFIX}/usr \
+               --libdir=${PREFIX}/usr/$(get_libdir) \
+               --libexecdir=${PREFIX}/usr/libexec \
+               --disable-werror \
+               --disable-xen"
+
+       econf ${myconf}
+}
+
+src_compile() {
+       use custom-cflags || unset CFLAGS
+       if test-flag-CC -fno-strict-overflow; then
+               append-flags -fno-strict-overflow
+       fi
+
+       emake CC="$(tc-getCC)" LD="$(tc-getLD)" AR="$(tc-getAR)" -C 
tools/include
+       emake CC="$(tc-getCC)" LD="$(tc-getLD)" AR="$(tc-getAR)" -C tools/libs
+
+       if use x86; then
+               emake CC="$(tc-getCC)" LD="$(tc-getLD)" AR="$(tc-getAR)" \
+               XEN_TARGET_ARCH="x86_32" -C stubdom pv-grub
+       elif use amd64; then
+               emake CC="$(tc-getCC)" LD="$(tc-getLD)" AR="$(tc-getAR)" \
+               XEN_TARGET_ARCH="x86_64" -C stubdom pv-grub
+               if has_multilib_profile; then
+                       multilib_toolchain_setup x86
+                       emake CC="$(tc-getCC)" AR="$(tc-getAR)" \
+                       XEN_TARGET_ARCH="x86_32" -C stubdom pv-grub
+               fi
+       fi
+}
+
+src_install() {
+       if use x86; then
+               emake XEN_TARGET_ARCH="x86_32" DESTDIR="${D}" -C stubdom 
install-grub
+       fi
+       if use amd64; then
+               emake XEN_TARGET_ARCH="x86_64" DESTDIR="${D}" -C stubdom 
install-grub
+               if has_multilib_profile; then
+                       emake XEN_TARGET_ARCH="x86_32" DESTDIR="${D}" -C 
stubdom install-grub
+               fi
+       fi
+}
+
+pkg_postinst() {
+       elog "Official Xen Guide and the offical wiki page:"
+       elog "https://wiki.gentoo.org/wiki/Xen";
+       elog "https://wiki.xen.org/wiki/Main_Page";
+}

Reply via email to