sys-boot/egrub: add legacy grub with efi patches (grub-fedora)
(Portage version: 2.2.0_alpha4/svn/Linux x86_64) git-svn-id: https://svn.disconnected-by-peer.at/svn/linamh/trunk/linamh@2739 6952d904-891a-0410-993b-d76249ca496b
This commit is contained in:
		| @@ -1,7 +1,14 @@ | |||||||
| # ChangeLog for sys-boot/grub-efi | # ChangeLog for sys-boot/egrub | ||||||
| # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 | # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 | ||||||
| # $Header: $ | # $Header: $ | ||||||
|  |  | ||||||
|  | *egrub-0.97 (13 Nov 2010) | ||||||
|  |  | ||||||
|  |   13 Nov 2010; Mario Fetka <mario.fetka@gmail.com> +egrub-0.97.ebuild, | ||||||
|  |   +files/grub-0.97-egrub-gentoo-1.patch, egrub-1.98.ebuild, | ||||||
|  |   +files/grub.conf.gentoo: | ||||||
|  |   add legacy grub with efi patches (grub-fedora) | ||||||
|  |  | ||||||
|   12 Nov 2010; Mario Fetka <mario.fetka@gmail.com> grub-efi-1.98.ebuild: |   12 Nov 2010; Mario Fetka <mario.fetka@gmail.com> grub-efi-1.98.ebuild: | ||||||
|   add proper depndencies |   add proper depndencies | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,12 @@ | |||||||
|  | AUX grub-0.97-egrub-gentoo-1.patch 1970 RMD160 3be5062e48586a46306a20c1af4253d7db5ac895 SHA1 77a2ea66029f2676162fbb4a7b3b334a01b47942 SHA256 1ab8977a85d17769f96afa3386698b19a8eca5ca4276155f82ecf5efcde9c4d9 | ||||||
| AUX grub-1.96-genkernel.patch 634 RMD160 bc1fdaa51e3f0e3b777a303e0f1c76987c7e69e5 SHA1 e79384a3ac32bfd74c884ead8133b1691a743316 SHA256 8ee327465d9b6d704a78b0c7b31cfdee7c6e7e9f9897e8d0a86198430f0c6ea0 | AUX grub-1.96-genkernel.patch 634 RMD160 bc1fdaa51e3f0e3b777a303e0f1c76987c7e69e5 SHA1 e79384a3ac32bfd74c884ead8133b1691a743316 SHA256 8ee327465d9b6d704a78b0c7b31cfdee7c6e7e9f9897e8d0a86198430f0c6ea0 | ||||||
| AUX grub-1.98-efi_std_dir-1.patch 1257 RMD160 46f3fff434fee54f05adbad09a2bdfcc73320b5d SHA1 f45fd2f7d2f2c25e922b35cee3d06b7d59f07dcd SHA256 c348128612cc9d39be80a3f4fa4663fa1ed8dd27672494f3c9fcaabc045500c9 | AUX grub-1.98-efi_std_dir-1.patch 1257 RMD160 46f3fff434fee54f05adbad09a2bdfcc73320b5d SHA1 f45fd2f7d2f2c25e922b35cee3d06b7d59f07dcd SHA256 c348128612cc9d39be80a3f4fa4663fa1ed8dd27672494f3c9fcaabc045500c9 | ||||||
|  | AUX grub.conf.gentoo 627 RMD160 d90fb4373bad476f98ec9c5065d6cdfd9e3b706f SHA1 004f2fc04605ec9190de0a87e7df8bbc33daff89 SHA256 914b15af252210a32776196437cd8013e10e57d5780e66877ef3fe9a2b4b9776 | ||||||
|  | DIST egrub-0.97-patches-1.0.tar.bz2 257780 RMD160 c5a13239d0c8d828a8281a41ceda348989a103a7 SHA1 778a2f303131d4dcb041b095aac66175a3e6df5f SHA256 266a633035aba8461d31b5b20b8fa1b07d7fc774119fad1102bb232e710bbcb8 | ||||||
|  | DIST grub-0.97.tar.gz 971783 RMD160 7fb5674edf0c950bd38e94f85ff1e2909aa741f0 SHA1 2580626c4579bd99336d3af4482c346c95dac4fb SHA256 4e1d15d12dbd3e9208111d6b806ad5a9857ca8850c47877d36575b904559260b | ||||||
| DIST grub-1.98.tar.gz 2449386 RMD160 197fb8d7c673bd67ae81eda53a2baa2968cc1e69 SHA1 e83a2c438f4773a2e272c225983c0145e1ffd641 SHA256 bef2c1892e052967b65aab6aa62ac702c0e50ef8848506eacf3c0b2f5007c614 | DIST grub-1.98.tar.gz 2449386 RMD160 197fb8d7c673bd67ae81eda53a2baa2968cc1e69 SHA1 e83a2c438f4773a2e272c225983c0145e1ffd641 SHA256 bef2c1892e052967b65aab6aa62ac702c0e50ef8848506eacf3c0b2f5007c614 | ||||||
| EBUILD grub-efi-1.98.ebuild 3158 RMD160 4a63d61acd117b5ef7b3d775390b5f58bc88227c SHA1 2422ff3fb69f06bf9d610b0a31d1e520075fdb67 SHA256 0d17281ef0be6fa0a8c0a9ae5929989e0835b2e80ac6e7a5356fdc2e1e82bc15 | DIST splash.xpm.gz 33856 RMD160 2fead61f91c368429e80936248bb02af2bdf15ff SHA1 98e679f9698be43426f971f89a088c053e8c804a SHA256 b95600f777331b0dd31d51c68f60f0e846e4c8b628857a41165f4e6b30e6acaf | ||||||
| MISC ChangeLog 331 RMD160 2391c581ea93bda9b099f413baa368b156e95752 SHA1 9fd7482b6c5774ead2822eba6cebe97ee0dc5645 SHA256 da25f8658b461c61d4e2a13838a71b335c8c186b4933f1ec1e4fa1ed2f8edcd5 | EBUILD egrub-0.97.ebuild 8313 RMD160 246d68d3fee060144339c594e2b093870c5a842c SHA1 e4b91d1318c3b1213c7a755f4db83d0414146fc7 SHA256 0c49064f38448a2cdf3f6c3c86db07b8b6600e168114223a2fea9c1ae351e36f | ||||||
|  | EBUILD egrub-1.98.ebuild 3362 RMD160 8b2239b69bcad1cbb517ed26badc84289c3825e3 SHA1 0cc96fc568054450709c91006a18d83fb469f703 SHA256 6576964e1469d54990e44bbe9d44e3a84b3402ec61bad83140a0841d054eadb7 | ||||||
|  | MISC ChangeLog 563 RMD160 f880d297e0f3635078f84a38fd814f44dd83eef1 SHA1 79306f1cb3574f0c3b15ce52e8fb419494918c27 SHA256 2c2cccceeac60289326d84c6987f36e6ae40c7f5218cda2dc0156c9041e1799c | ||||||
| MISC metadata.xml 262 RMD160 afabce9377772aefb54102e9ef237de6bb1561f5 SHA1 c38f9b99d8a84beb40c114283d8d7ddd4ac43d9e SHA256 35a9c56d9c8418806062854a360c27690d25159524df71f28bbd4d644e8706f3 | MISC metadata.xml 262 RMD160 afabce9377772aefb54102e9ef237de6bb1561f5 SHA1 c38f9b99d8a84beb40c114283d8d7ddd4ac43d9e SHA256 35a9c56d9c8418806062854a360c27690d25159524df71f28bbd4d644e8706f3 | ||||||
|   | |||||||
							
								
								
									
										258
									
								
								sys-boot/egrub/egrub-0.97.ebuild
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										258
									
								
								sys-boot/egrub/egrub-0.97.ebuild
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,258 @@ | |||||||
|  | # Copyright 1999-2010 Gentoo Foundation | ||||||
|  | # Distributed under the terms of the GNU General Public License v2 | ||||||
|  | # $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-0.97-r10.ebuild,v 1.6 2010/09/02 21:19:37 robbat2 Exp $ | ||||||
|  |  | ||||||
|  | # XXX: we need to review menu.lst vs grub.conf handling.  We've been converting | ||||||
|  | #      all systems to grub.conf (and symlinking menu.lst to grub.conf), but | ||||||
|  | #      we never updated any of the source code (it still all wants menu.lst), | ||||||
|  | #      and there is no indication that upstream is making the transition. | ||||||
|  |  | ||||||
|  | EAPI=2 | ||||||
|  |  | ||||||
|  | inherit mount-efi eutils flag-o-matic toolchain-funcs autotools linux-info pax-utils | ||||||
|  |  | ||||||
|  | PATCHVER="1.0" # Should match the revision ideally | ||||||
|  | DESCRIPTION="GNU GRUB Legacy boot loader EFI Edition" | ||||||
|  | HOMEPAGE="http://www.gnu.org/software/grub/" | ||||||
|  | SRC_URI="mirror://gentoo/grub-${PV}.tar.gz | ||||||
|  | 	ftp://alpha.gnu.org/gnu/${PN}/grub-${PV}.tar.gz | ||||||
|  | 	mirror://gentoo/splash.xpm.gz | ||||||
|  | 	mirror://gentoo/${P}-patches-${PATCHVER}.tar.bz2 | ||||||
|  | 	http://ftp.disconnected-by-peer.at/efi/${P}-patches-${PATCHVER}.tar.bz2" | ||||||
|  |  | ||||||
|  | LICENSE="GPL-2" | ||||||
|  | SLOT="0" | ||||||
|  | KEYWORDS="~amd64 ~x86" | ||||||
|  | IUSE="custom-cflags" | ||||||
|  |  | ||||||
|  | DEPEND="sys-boot/gnu-efi" | ||||||
|  | RDEPEND="sys-boot/efibootmgr | ||||||
|  | 	sys-fs/dosfstools" | ||||||
|  | PROVIDE="virtual/bootloader" | ||||||
|  |  | ||||||
|  | S="${WORKDIR}"/grub-${PV} | ||||||
|  |  | ||||||
|  | #pkg_setup() { | ||||||
|  | #	local arch="$(tc-arch)" | ||||||
|  | #	case ${arch} in | ||||||
|  | #		amd64) CONFIG_CHECK='~IA32_EMULATION' check_extra_config ;; | ||||||
|  | #	esac | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | src_prepare() { | ||||||
|  | 	# patch breaks booting for some people #111885 | ||||||
|  | #	rm "${WORKDIR}"/patch/400_*reiser4* | ||||||
|  |  | ||||||
|  | 	if [[ -n ${PATCHVER} ]] ; then | ||||||
|  | 		EPATCH_SUFFIX="patch" | ||||||
|  | 		EPATCH_FORCE="yes" epatch "${WORKDIR}"/patch | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	sed -e "s/^gnuefi_path=.*$/gnuefi_path=\/usr\/$(get_libdir)/g" \ | ||||||
|  | 	    -e "s/^LIBGNUEFI=.*$/LIBGNUEFI=\/usr\/$(get_libdir)\/libgnuefi.a/g" \ | ||||||
|  | 	    -i "${S}"/configure.in || die "failed to hack gnu-efi patch" | ||||||
|  |  | ||||||
|  | 	# rename grub tools to not interfer with grub | ||||||
|  | 	epatch "${FILESDIR}"/grub-0.97-egrub-gentoo-1.patch | ||||||
|  |  | ||||||
|  | 	# Grub will not handle a kernel larger than EXTENDED_MEMSIZE Mb as | ||||||
|  | 	# discovered in bug 160801. We can change this, however, using larger values | ||||||
|  | 	# for this variable means that Grub needs more memory to run and boot. For a | ||||||
|  | 	# kernel of size N, Grub needs (N+1)*2.  Advanced users should set a custom | ||||||
|  | 	# value in make.conf, it is possible to make kernels ~16Mb in size, but it | ||||||
|  | 	# needs the kitchen sink built-in. | ||||||
|  | 	local t="custom" | ||||||
|  | 	if [[ -z ${GRUB_MAX_KERNEL_SIZE} ]] ; then | ||||||
|  | 		case $(tc-arch) in | ||||||
|  | 			amd64) GRUB_MAX_KERNEL_SIZE=9 ;; | ||||||
|  | 			x86)   GRUB_MAX_KERNEL_SIZE=5 ;; | ||||||
|  | 		esac | ||||||
|  | 		t="default" | ||||||
|  | 	fi | ||||||
|  | 	einfo "Grub will support the ${t} maximum kernel size of ${GRUB_MAX_KERNEL_SIZE} Mb (GRUB_MAX_KERNEL_SIZE)" | ||||||
|  |  | ||||||
|  | 	sed -i \ | ||||||
|  | 		-e "/^#define.*EXTENDED_MEMSIZE/s,3,${GRUB_MAX_KERNEL_SIZE},g" \ | ||||||
|  | 		"${S}"/grub/asmstub.c \ | ||||||
|  | 		|| die "Failed to hack memory size" | ||||||
|  |  | ||||||
|  | 	eautoreconf | ||||||
|  | } | ||||||
|  |  | ||||||
|  | src_configure() { | ||||||
|  | 	filter-flags -fPIE #168834 | ||||||
|  |  | ||||||
|  | 	unset BLOCK_SIZE #73499 | ||||||
|  |  | ||||||
|  | 	### i686-specific code in the boot loader is a bad idea; disabling to ensure | ||||||
|  | 	### at least some compatibility if the hard drive is moved to an older or | ||||||
|  | 	### incompatible system. | ||||||
|  |  | ||||||
|  | 	# grub-0.95 added -fno-stack-protector detection, to disable ssp for stage2, | ||||||
|  | 	# but the objcopy's (faulty) test fails if -fstack-protector is default. | ||||||
|  | 	# create a cache telling configure that objcopy is ok, and add -C to econf | ||||||
|  | 	# to make use of the cache. | ||||||
|  | 	# | ||||||
|  | 	# CFLAGS has to be undefined running econf, else -fno-stack-protector detection fails. | ||||||
|  | 	# STAGE2_CFLAGS is not allowed to be used on emake command-line, it overwrites | ||||||
|  | 	# -fno-stack-protector detected by configure, removed from netboot's emake. | ||||||
|  | 	use custom-cflags || unset CFLAGS | ||||||
|  |  | ||||||
|  | 	export grub_cv_prog_objcopy_absolute=yes #79734 | ||||||
|  |  | ||||||
|  | 	# Now build the regular grub | ||||||
|  | 	# Note that FFS and UFS2 support are broken for now - stage1_5 files too big | ||||||
|  | 	econf \ | ||||||
|  | 		--libdir=/lib \ | ||||||
|  | 		--datadir=/usr/lib/grub \ | ||||||
|  | 		--exec-prefix=/ \ | ||||||
|  | 		--disable-auto-linux-mem-opt \ | ||||||
|  | 		--with-platform=efi \ | ||||||
|  | 		--without-curses \ | ||||||
|  | 		|| die "econf failed" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | src_compile() { | ||||||
|  | 	emake || die "making regular stuff" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | src_test() { | ||||||
|  | 	# non-default block size also give false pass/fails. | ||||||
|  | 	unset BLOCK_SIZE | ||||||
|  | 	make check || die "make check failed" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | src_install() { | ||||||
|  | 	emake DESTDIR="${D}" install || die | ||||||
|  |  | ||||||
|  | 	# bug 330745 | ||||||
|  | 	pax-mark -m "${D}"/sbin/egrub | ||||||
|  |  | ||||||
|  | 	# dont install nit needed files | ||||||
|  | 	rm -rf "${D}"/usr/lib | ||||||
|  | 	rm -rf "${D}"/usr/share/man/man1 | ||||||
|  | 	rm -rf "${D}"/usr/share/info | ||||||
|  | 	rm "${D}"/usr/share/man/man8/grub-install.8 | ||||||
|  |  | ||||||
|  | 	# rename man pages so they dont interfer with the one from grub | ||||||
|  | 	mv "${D}"/usr/share/man/man8/{,e}grub-crypt.8 | ||||||
|  | 	mv "${D}"/usr/share/man/man8/{,e}grub-md5-crypt.8 | ||||||
|  | 	mv "${D}"/usr/share/man/man8/{,e}grub-terminfo.8 | ||||||
|  | 	mv "${D}"/usr/share/man/man8/{,e}grub.8 | ||||||
|  |  | ||||||
|  | 	dodoc AUTHORS BUGS ChangeLog NEWS README THANKS TODO | ||||||
|  | 	newdoc docs/menu.lst grub.conf.sample | ||||||
|  | 	dodoc "${FILESDIR}"/grub.conf.gentoo | ||||||
|  | 	prepalldocs | ||||||
|  |  | ||||||
|  | 	insinto /usr/share/egrub | ||||||
|  | 	doins "${DISTDIR}"/splash.xpm.gz | ||||||
|  |  | ||||||
|  | 	insinto /boot/efi/EFI/grub | ||||||
|  | 	doins efi/grub.efi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | setup_boot_dir() { | ||||||
|  | 	local boot_dir=$1 | ||||||
|  | 	local dir=${boot_dir} | ||||||
|  |  | ||||||
|  | 	mkdir -p "${dir}" | ||||||
|  | 	#[[ ! -L ${dir}/boot ]] && ln -s . "${dir}/boot" | ||||||
|  | 	dir="${dir}/grub" | ||||||
|  | 	if [[ ! -e ${dir} ]] ; then | ||||||
|  | 		mkdir "${dir}" || die "${dir} does not exist!" | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	# change menu.lst to grub.conf | ||||||
|  | 	if [[ ! -e ${dir}/grub.conf ]] && [[ -e ${dir}/menu.lst ]] ; then | ||||||
|  | 		mv -f "${dir}"/menu.lst "${dir}"/grub.conf | ||||||
|  | 		ewarn | ||||||
|  | 		ewarn "*** IMPORTANT NOTE: menu.lst has been renamed to grub.conf" | ||||||
|  | 		ewarn | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	#if [[ ! -e ${dir}/menu.lst ]]; then | ||||||
|  | 	#	einfo "Linking from new grub.conf name to menu.lst" | ||||||
|  | 	#	ln -snf grub.conf "${dir}"/menu.lst | ||||||
|  | 	#fi | ||||||
|  |  | ||||||
|  | 	#if [[ -e ${dir}/stage2 ]] ; then | ||||||
|  | 	#	mv "${dir}"/stage2{,.old} | ||||||
|  | 	#	ewarn "*** IMPORTANT NOTE: you must run grub and install" | ||||||
|  | 	#	ewarn "the new version's stage1 to your MBR.  Until you do," | ||||||
|  | 	#	ewarn "stage1 and stage2 will still be the old version, but" | ||||||
|  | 	#	ewarn "later stages will be the new version, which could" | ||||||
|  | 	#	ewarn "cause problems such as an unbootable system." | ||||||
|  | 	#	ewarn "This means you must use either grub-install or perform" | ||||||
|  | 	#	ewarn "root/setup manually! For more help, see the handbook:" | ||||||
|  | 	#	ewarn "http://www.gentoo.org/doc/en/handbook/handbook-${ARCH}.xml?part=1&chap=10#grub-install-auto" | ||||||
|  | 	#	ebeep | ||||||
|  | 	#fi | ||||||
|  |  | ||||||
|  | 	#einfo "Copying files from /lib/grub, /usr/lib/grub and /usr/share/grub to ${dir}" | ||||||
|  | 	einfo "Copying files from /usr/share/egrub to ${dir}" | ||||||
|  | 	for x in \ | ||||||
|  | 		"${ROOT}"/usr/share/egrub/* ; do | ||||||
|  | 		[[ -f ${x} ]] && cp -p "${x}" "${dir}"/ | ||||||
|  | 	done | ||||||
|  | #		"${ROOT}"/lib*/grub/*/* \ | ||||||
|  | #		"${ROOT}"/usr/lib*/grub/*/* \ | ||||||
|  |  | ||||||
|  | 	if [[ ! -e ${dir}/grub.conf ]] ; then | ||||||
|  | 		s="${ROOT}/usr/share/doc/${PF}/grub.conf.gentoo" | ||||||
|  | 		[[ -e "${s}" ]] && cat "${s}" >${dir}/grub.conf | ||||||
|  | 		[[ -e "${s}.gz" ]] && zcat "${s}.gz" >${dir}/grub.conf | ||||||
|  | 		[[ -e "${s}.bz2" ]] && bzcat "${s}.bz2" >${dir}/grub.conf | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	# Per bug 218599, we support grub.conf.install for users that want to run a | ||||||
|  | 	# specific set of Grub setup commands rather than the default ones. | ||||||
|  | 	grub_config=${dir}/grub.conf.install | ||||||
|  | 	[[ -e ${grub_config} ]] || grub_config=${dir}/grub.conf | ||||||
|  | 	if [[ -e ${grub_config} ]] ; then | ||||||
|  | 		egrep \ | ||||||
|  | 			-v '^[[:space:]]*(#|$|default|fallback|initrd|password|splashimage|timeout|title)' \ | ||||||
|  | 			"${grub_config}" | \ | ||||||
|  | 		/sbin/egrub --batch \ | ||||||
|  | 			--device-map="${dir}"/device.map \ | ||||||
|  | 			> /dev/null | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	# the grub default commands silently piss themselves if | ||||||
|  | 	# the default file does not exist ahead of time | ||||||
|  | 	if [[ ! -e ${dir}/default ]] ; then | ||||||
|  | 		egrub-set-default --root-directory="${boot_dir}" default | ||||||
|  | 	fi | ||||||
|  | 	einfo "Grub has been installed to ${boot_dir} successfully." | ||||||
|  | } | ||||||
|  |  | ||||||
|  | pkg_postinst() { | ||||||
|  | 	if [[ -n ${DONT_MOUNT_BOOT} ]]; then | ||||||
|  | 		elog "WARNING: you have DONT_MOUNT_BOOT in effect, so you must apply" | ||||||
|  | 		elog "the following instructions for your /boot!" | ||||||
|  | 		elog "Neglecting to do so may cause your system to fail to boot!" | ||||||
|  | 		elog | ||||||
|  | 	else | ||||||
|  | 		setup_boot_dir "${ROOT}"/boot/efi/EFI | ||||||
|  | 		# Trailing output because if this is run from pkg_postinst, it gets mixed into | ||||||
|  | 		# the other output. | ||||||
|  | 		einfo "" | ||||||
|  | 	fi | ||||||
|  | 	elog "To interactively install grub files to another device such as a USB" | ||||||
|  | 	elog "stick, just run the following and specify the directory as prompted:" | ||||||
|  | 	elog "   emerge --config =${PF}" | ||||||
|  | 	elog "Alternately, you can export GRUB_ALT_INSTALLDIR=/path/to/use to tell" | ||||||
|  | 	elog "grub where to install in a non-interactive way." | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | pkg_config() { | ||||||
|  | 	local dir | ||||||
|  | 	if [ ! -d "${GRUB_ALT_INSTALLDIR}" ]; then | ||||||
|  | 		einfo "Enter the directory where you want to setup grub:" | ||||||
|  | 		read dir | ||||||
|  | 	else | ||||||
|  | 		dir="${GRUB_ALT_INSTALLDIR}" | ||||||
|  | 	fi | ||||||
|  | 	setup_boot_dir "${dir}" | ||||||
|  | } | ||||||
| @@ -20,8 +20,8 @@ HOMEPAGE="http://www.gnu.org/software/grub/" | |||||||
|  |  | ||||||
| LICENSE="GPL-3" | LICENSE="GPL-3" | ||||||
| use multislot && SLOT="2" || SLOT="0" | use multislot && SLOT="2" || SLOT="0" | ||||||
| KEYWORDS="~amd64 ~x86" | KEYWORDS="" | ||||||
| IUSE="custom-cflags debug truetype multislot static" | IUSE="custom-cflags debug truetype multislot" | ||||||
|  |  | ||||||
| RDEPEND=">=sys-libs/ncurses-5.2-r5 | RDEPEND=">=sys-libs/ncurses-5.2-r5 | ||||||
| 	dev-libs/lzo | 	dev-libs/lzo | ||||||
| @@ -61,7 +61,6 @@ src_unpack() { | |||||||
|  |  | ||||||
| src_compile() { | src_compile() { | ||||||
| 	use custom-cflags || unset CFLAGS CPPFLAGS LDFLAGS | 	use custom-cflags || unset CFLAGS CPPFLAGS LDFLAGS | ||||||
| 	use static && append-ldflags -static |  | ||||||
|  |  | ||||||
| 	econf \ | 	econf \ | ||||||
| 		--disable-werror \ | 		--disable-werror \ | ||||||
| @@ -82,12 +81,18 @@ src_install() { | |||||||
| 	cat <<-EOF >> "${D}"/lib*/grub/grub-mkconfig_lib | 	cat <<-EOF >> "${D}"/lib*/grub/grub-mkconfig_lib | ||||||
| 	GRUB_DISTRIBUTOR="Gentoo" | 	GRUB_DISTRIBUTOR="Gentoo" | ||||||
| 	EOF | 	EOF | ||||||
|  |  | ||||||
|  | 	sed -i "s:grub-install:egrub-install:" "${D}"/sbin/grub-install || die | ||||||
|  | 	mv "${D}"/sbin/{,e}grub-install || die | ||||||
|  | 	mv "${D}"/sbin/{,e}grub-set-default || die | ||||||
|  | 	mv "${D}"/usr/share/man/man8/{,e}grub-install.8 || die | ||||||
|  | 	mv "${D}"/usr/share/info/{,e}grub.info || die | ||||||
| 	if use multislot ; then | 	if use multislot ; then | ||||||
| 		sed -i "s:grub-install:grub2-install:" "${D}"/sbin/grub-install || die | 		sed -i "s:egrub-install:egrub2-install:" "${D}"/sbin/egrub-install || die | ||||||
| 		mv "${D}"/sbin/grub{,2}-install || die | 		mv "${D}"/sbin/egrub{,2}-install || die | ||||||
| 		mv "${D}"/sbin/grub{,2}-set-default || die | 		mv "${D}"/sbin/egrub{,2}-set-default || die | ||||||
| 		mv "${D}"/usr/share/man/man8/grub{,2}-install.8 || die | 		mv "${D}"/usr/share/man/man8/egrub{,2}-install.8 || die | ||||||
| 		mv "${D}"/usr/share/info/grub{,2}.info || die | 		mv "${D}"/usr/share/info/egrub{,2}.info || die | ||||||
| 	fi | 	fi | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								sys-boot/egrub/files/grub-0.97-egrub-gentoo-1.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								sys-boot/egrub/files/grub-0.97-egrub-gentoo-1.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | |||||||
|  | diff -uNr grub-0.97.orig//configure.in grub-0.97/configure.in | ||||||
|  | --- grub-0.97.orig//configure.in	2010-11-13 15:40:39.000000000 +0100 | ||||||
|  | +++ grub-0.97/configure.in	2010-11-13 16:17:10.000000000 +0100 | ||||||
|  | @@ -755,5 +755,5 @@ | ||||||
|  |  		 docs/Makefile lib/Makefile util/Makefile \ | ||||||
|  |  		 grub/Makefile netboot/Makefile util/grub-crypt \ | ||||||
|  |  		 util/grub-image util/grub-install util/grub-md5-crypt \ | ||||||
|  | -		 util/grub-terminfo]) | ||||||
|  | +		 util/grub-terminfo util/grub-set-default ]) | ||||||
|  |  AC_OUTPUT | ||||||
|  | diff -uNr grub-0.97.orig//grub/Makefile.am grub-0.97/grub/Makefile.am | ||||||
|  | --- grub-0.97.orig//grub/Makefile.am	2010-11-13 15:40:39.000000000 +0100 | ||||||
|  | +++ grub-0.97/grub/Makefile.am	2010-11-13 15:41:30.000000000 +0100 | ||||||
|  | @@ -1,4 +1,4 @@ | ||||||
|  | -sbin_PROGRAMS = grub | ||||||
|  | +sbin_PROGRAMS = egrub | ||||||
|  |   | ||||||
|  |  if SERIAL_SPEED_SIMULATION | ||||||
|  |  SERIAL_FLAGS = -DSUPPORT_SERIAL=1 -DSIMULATE_SLOWNESS_OF_SERIAL=1 | ||||||
|  | @@ -15,5 +15,5 @@ | ||||||
|  |   | ||||||
|  |  AM_CFLAGS = $(GRUB_CFLAGS) | ||||||
|  |   | ||||||
|  | -grub_SOURCES = main.c asmstub.c efitftp.c | ||||||
|  | -grub_LDADD = ../stage2/libgrub.a  ../lib/libcommon.a $(GRUB_LIBS) | ||||||
|  | +egrub_SOURCES = main.c asmstub.c efitftp.c | ||||||
|  | +egrub_LDADD = ../stage2/libgrub.a  ../lib/libcommon.a $(GRUB_LIBS) | ||||||
|  | diff -uNr grub-0.97.orig//util/Makefile.am grub-0.97/util/Makefile.am | ||||||
|  | --- grub-0.97.orig//util/Makefile.am	2010-11-13 15:40:39.000000000 +0100 | ||||||
|  | +++ grub-0.97/util/Makefile.am	2010-11-13 16:16:30.000000000 +0100 | ||||||
|  | @@ -1,7 +1,7 @@ | ||||||
|  |  if !PLATFORM_EFI | ||||||
|  |   | ||||||
|  |  bin_PROGRAMS = mbchk | ||||||
|  | -sbin_SCRIPTS = grub-install grub-md5-crypt grub-terminfo grub-crypt | ||||||
|  | +sbin_SCRIPTS = grub-install grub-md5-crypt grub-terminfo grub-crypt grub-set-default | ||||||
|  |  noinst_SCRIPTS = grub-image mkbimage | ||||||
|  |   | ||||||
|  |  EXTRA_DIST = mkbimage | ||||||
|  | @@ -14,6 +14,18 @@ | ||||||
|  |   | ||||||
|  |  else | ||||||
|  |   | ||||||
|  | -sbin_SCRIPTS = grub-md5-crypt grub-terminfo grub-crypt | ||||||
|  | +sbin_SCRIPTS = egrub-md5-crypt egrub-terminfo egrub-crypt egrub-set-default | ||||||
|  | + | ||||||
|  | +egrub-md5-crypt: | ||||||
|  | +	cp grub-md5-crypt egrub-md5-crypt | ||||||
|  | + | ||||||
|  | +egrub-terminfo: | ||||||
|  | +	cp grub-terminfo egrub-terminfo | ||||||
|  | + | ||||||
|  | +egrub-crypt: | ||||||
|  | +	cp grub-crypt egrub-crypt | ||||||
|  | + | ||||||
|  | +egrub-set-default: | ||||||
|  | +	cp grub-set-default egrub-set-default | ||||||
|  |   | ||||||
|  |  endif | ||||||
							
								
								
									
										16
									
								
								sys-boot/egrub/files/grub.conf.gentoo
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								sys-boot/egrub/files/grub.conf.gentoo
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | # This is a sample grub.conf for use with Genkernel, per the Gentoo handbook | ||||||
|  | # http://www.gentoo.org/doc/en/handbook/handbook-x86.xml?part=1&chap=10#doc_chap2 | ||||||
|  | # If you are not using Genkernel and you need help creating this file, you | ||||||
|  | # should consult the handbook. Alternatively, consult the grub.conf.sample that | ||||||
|  | # is included with the Grub documentation. | ||||||
|  |  | ||||||
|  | default 0 | ||||||
|  | timeout 30 | ||||||
|  | #splashimage=(hd0,0)/boot/grub/splash.xpm.gz | ||||||
|  |  | ||||||
|  | #title Gentoo Linux 2.6.24-r5 | ||||||
|  | #root (hd0,0) | ||||||
|  | #kernel /boot/kernel-genkernel-x86-2.6.24-gentoo-r5 root=/dev/ram0 real_root=/dev/sda3 | ||||||
|  | #initrd /boot/initramfs-genkernel-x86-2.6.24-gentoo-r5 | ||||||
|  |  | ||||||
|  | # vim:ft=conf: | ||||||
		Reference in New Issue
	
	Block a user