Go to:
Gentoo Home
Documentation
Forums
Lists
Bugs
Planet
Store
Wiki
Get Gentoo!
Gentoo's Bugzilla – Attachment 148783 Details for
Bug 204830
sys-boot/grub-0.97: Add tpm support
Home
|
New
–
[Ex]
|
Browse
|
Search
|
Privacy Policy
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
grub with tpm (ima) and tpm-debug (imatest) support
grub-0.97-r4.ebuild (text/plain), 5.36 KB, created by
Robert A.
on 2008-04-05 19:31:54 UTC
(
hide
)
Description:
grub with tpm (ima) and tpm-debug (imatest) support
Filename:
MIME Type:
Creator:
Robert A.
Created:
2008-04-05 19:31:54 UTC
Size:
5.36 KB
patch
obsolete
># Copyright 1999-2008 Gentoo Foundation ># Distributed under the terms of the GNU General Public License v2 ># $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-0.97-r4.ebuild,v 1.5 2008/03/09 23:13:40 vapier Exp $ > >inherit mount-boot eutils flag-o-matic toolchain-funcs autotools > >IMAVER="${P}-13-ima-1.1.0.0" >PATCHVER="1.4" >DESCRIPTION="GNU GRUB Legacy boot loader" >HOMEPAGE="http://www.gnu.org/software/grub/" >SRC_URI="mirror://gentoo/${P}.tar.gz > ftp://alpha.gnu.org/gnu/${PN}/${P}.tar.gz > mirror://gentoo/splash.xpm.gz > mirror://gentoo/${P}-patches-${PATCHVER}.tar.bz2 > tpm? ( mirror://sourceforge/trousers/${IMAVER}.tgz )" > >LICENSE="GPL-2" >SLOT="0" >KEYWORDS="amd64 x86 ~x86-fbsd" >IUSE="static netboot custom-cflags tpm tpm-debug" > >DEPEND=">=sys-libs/ncurses-5.2-r5" >PROVIDE="virtual/bootloader" > >src_unpack() { > unpack ${A} > cd "${S}" > > # patch breaks booting for some people #111885 > rm "${WORKDIR}"/patch/400_* > > epatch "${FILESDIR}"/grub-0.97-gpt.patch > > if [[ -n ${PATCHVER} ]] ; then > EPATCH_SUFFIX="patch" > epatch "${WORKDIR}"/patch > eautoreconf > fi > > if use tpm ; then > # The IMA patches fail on configure.ac due to incompatible patches, this > # cleans out the bit of their patch that fails. > cd "${WORKDIR}/${IMAVER}" > epatch "${FILESDIR}/${P}-ima-gentoo.patch" > cd "${S}" > epatch "${WORKDIR}/${IMAVER}/${IMAVER}.patch" > eautoreconf > fi >} > >src_compile() { > filter-flags -fPIE #168834 > > use amd64 && multilib_toolchain_setup x86 > > 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 > use static && append-ldflags -static > > # build the net-bootable grub first, but only if "netboot" is set > if use netboot ; then > econf \ > --libdir=/lib \ > --datadir=/usr/lib/grub \ > --exec-prefix=/ \ > $(use_enable tpm ima) \ > $(use_enable tpm-debug imatest) \ > --disable-auto-linux-mem-opt \ > --enable-diskless \ > --enable-{3c{5{03,07,09,29,95},90x},cs89x0,davicom,depca,eepro{,100}} \ > --enable-{epic100,exos205,ni5210,lance,ne2100,ni{50,65}10,natsemi} \ > --enable-{ne,ns8390,wd,otulip,rtl8139,sis900,sk-g16,smc9000,tiara} \ > --enable-{tulip,via-rhine,w89c840} || die "netboot econf failed" > > emake w89c840_o_CFLAGS="-O" || die "making netboot stuff" > > mv -f stage2/{nbgrub,pxegrub} "${S}"/ > mv -f stage2/stage2 stage2/stage2.netboot > > make clean || die "make clean failed" > fi > > # 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=/ \ > $(use_enable tpm ima) \ > $(use_enable tpm-debug imatest) \ > --disable-auto-linux-mem-opt || die "econf failed" > 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() { > make DESTDIR="${D}" install || die > if use netboot ; then > exeinto /usr/lib/grub/${CHOST} > doexe nbgrub pxegrub stage2/stage2.netboot || die "netboot install" > fi > > insinto /boot/grub > doins "${DISTDIR}"/splash.xpm.gz > newins docs/menu.lst grub.conf.sample > > dodoc AUTHORS BUGS ChangeLog NEWS README THANKS TODO > newdoc docs/menu.lst grub.conf.sample >} > >setup_boot_dir() { > local boot_dir=$1 > local dir=${boot_dir} > > [[ ! -e ${dir} ]] && die "${dir} does not exist!" > 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 > > [[ -e ${dir}/stage2 ]] && mv "${dir}"/stage2{,.old} > > einfo "Copying files from /lib/grub and /usr/lib/grub to ${dir}" > for x in "${ROOT}"/lib*/grub/*/* "${ROOT}"/usr/lib*/grub/*/* ; do > [[ -f "${x}" ]] && cp -p "${x}" "${dir}"/ > done > > if [[ -e ${dir}/grub.conf ]] ; then > egrep \ > -v '^[[:space:]]*(#|$|default|fallback|initrd|password|splashimage|timeout|title)' \ > "${dir}"/grub.conf | \ > /sbin/grub --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 > grub-set-default --root-directory="${boot_dir}" default > fi >} > >pkg_postinst() { > [[ -n ${DONT_MOUNT_BOOT} ]] && return 0 > setup_boot_dir "${ROOT}"/boot > einfo "To install grub files to another device (like a usb stick), just run:" > einfo " emerge --config =${PF}" >} > >pkg_config() { > local dir > einfo "Enter the directory where you want to setup grub: " > read dir > setup_boot_dir "${dir}" >}
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Raw
Actions:
View
Attachments on
bug 204830
:
140411
|
140414
|
148479
|
148481
|
148693
|
148783
|
170901
|
170903
|
170905