4ebc0a4f71
fix compile issues; handle new kernel naming scheme in install-grub script; make install-grub script slightly smarter (though still not very smart)
104 lines
3.3 KiB
Bash
104 lines
3.3 KiB
Bash
# Maintainer: Ronald van Haren <ronald.archlinux.org>
|
|
|
|
pkgname=grub
|
|
pkgver=0.97
|
|
pkgrel=18
|
|
pkgdesc="A GNU multiboot boot loader"
|
|
arch=('i686' 'x86_64')
|
|
license=('GPL')
|
|
url="http://www.gnu.org/software/grub/"
|
|
groups=('base')
|
|
depends=('ncurses' 'diffutils' 'sed')
|
|
source=(ftp://alpha.gnu.org/gnu/grub/grub-$pkgver.tar.gz
|
|
menu.lst
|
|
install-grub
|
|
040_all_grub-0.96-nxstack.patch
|
|
05-grub-0.97-initrdaddr.diff
|
|
i2o.patch
|
|
special-devices.patch
|
|
more-raid.patch
|
|
intelmac.patch
|
|
grub-inode-size.patch
|
|
ext4.patch
|
|
grub-0.97-ldflags-objcopy-remove-build-id.patch)
|
|
backup=('boot/grub/menu.lst')
|
|
install=grub.install
|
|
sha1sums=('2580626c4579bd99336d3af4482c346c95dac4fb'
|
|
'734fa37ebe1657bf1f8f74ee4866953ff96f2604'
|
|
'e88a68204c9c9d4bd0b50fa11cab789df4ac55f8'
|
|
'157b81dbad3576536b08642242accfa1aeb093a9'
|
|
'adbb4685c98797ffb4dc83561ec75698991dddbd'
|
|
'f2e0dff29a7c8a45e90aa07298a1b2a9a9d29afc'
|
|
'c5e2c94ed0e759590b9eb38c9d979f075d19d7c0'
|
|
'45fe668a3779664fb292591f426976b6c784d6c8'
|
|
'066d7ab1ae442f88e94c9e4f1867ac6682965d06'
|
|
'0436aa6fa0b6f768289172f983a3f4b69384629e'
|
|
'a36f34e51efed540f1ddafd78e9c9f6d83e4c8d4'
|
|
'61c4b58d2eaa3c1561d8e9d8fc41341ce8882869')
|
|
|
|
|
|
#set destination architecture here
|
|
#DESTARCH="i686"
|
|
DESTARCH="x86_64"
|
|
|
|
|
|
build() {
|
|
cd $srcdir/$pkgname-$pkgver
|
|
|
|
# optimizations break the build -- disable them
|
|
# adding special devices to grub, patches are from fedora
|
|
patch -Np1 -i ../special-devices.patch
|
|
patch -Np1 -i ../i2o.patch
|
|
patch -Np1 -i ../more-raid.patch
|
|
patch -Np1 -i ../intelmac.patch
|
|
# Add support for bigger inode size to e2fs_stage1_5
|
|
patch -Np1 -i ../grub-inode-size.patch
|
|
# Add ext4 support
|
|
# http://www.mail-archive.com/bug-grub@gnu.org/msg11458.html
|
|
patch -Np1 -i ../ext4.patch
|
|
# binutils fix
|
|
patch -Np1 -i ../grub-0.97-ldflags-objcopy-remove-build-id.patch
|
|
|
|
sed -e'/^AC_PROG_CC/ a\AM_PROG_CC_C_O\ ' -i "${srcdir}/${pkgname}-${pkgver}/configure.ac"
|
|
sed -e'/^AC_PROG_CC/ a\AM_PROG_AS\ ' -i "${srcdir}/${pkgname}-${pkgver}/configure.ac"
|
|
|
|
## recreate ./configure script with the required changes in LDFLAGS and objcopy
|
|
aclocal
|
|
autoconf
|
|
autoreconf
|
|
automake
|
|
|
|
#arch64 fixes for static build
|
|
if [ "$CARCH" = "x86_64" ]; then ## correcting problems for new wersion of autotools
|
|
|
|
echo "this package has to be built on i686, won't compile on x86_64"
|
|
sleep 5
|
|
else
|
|
if [ "$DESTARCH" = "x86_64" ]; then
|
|
# patch from gentoo for fixing a segfault
|
|
patch -Np1 -i ../040_all_grub-0.96-nxstack.patch
|
|
# patch from frugalware to make it boot when more than 2GB ram installed
|
|
patch -Np1 -i ../05-grub-0.97-initrdaddr.diff
|
|
CFLAGS="-static" ./configure --prefix=/usr --bindir=/bin --sbindir=/sbin \
|
|
--mandir=/usr/share/man --infodir=/usr/share/info
|
|
else
|
|
CFLAGS= ./configure --prefix=/usr --bindir=/bin --sbindir=/sbin \
|
|
--mandir=/usr/share/man --infodir=/usr/share/info
|
|
fi
|
|
fi
|
|
}
|
|
|
|
package() {
|
|
cd $srcdir/$pkgname-$pkgver
|
|
|
|
CFLAGS= make
|
|
make DESTDIR=$pkgdir install
|
|
install -D -m644 ../menu.lst $pkgdir/boot/grub/menu.lst
|
|
install -D -m755 ../install-grub $pkgdir/sbin/install-grub
|
|
|
|
if [ "$DESTARCH" = "x86_64" ]; then
|
|
# fool makepkg into building a x86_64 package
|
|
export CARCH="x86_64"
|
|
fi
|
|
}
|