[arch-commits] Commit in syslinux/trunk (5 files)

Tobias Powalowski tpowa at nymeria.archlinux.org
Fri Jun 21 20:37:06 UTC 2013


    Date: Friday, June 21, 2013 @ 22:37:06
  Author: tpowa
Revision: 188815

upgpkg: syslinux 6.00-1

bump to latest version, added efi support, moved bios files

Added:
  syslinux/trunk/syslinux-6.00-efi-export-kbdmap.patch
  syslinux/trunk/syslinux-6.00-efi-fix-libcom32.patch
Modified:
  syslinux/trunk/PKGBUILD
  syslinux/trunk/syslinux-install_update
  syslinux/trunk/syslinux.install

---------------------------------------+
 PKGBUILD                              |  196 ++++++++++++++++++++++++--------
 syslinux-6.00-efi-export-kbdmap.patch |   38 ++++++
 syslinux-6.00-efi-fix-libcom32.patch  |   45 +++++++
 syslinux-install_update               |    2 
 syslinux.install                      |   12 +
 5 files changed, 248 insertions(+), 45 deletions(-)

Modified: PKGBUILD
===================================================================
--- PKGBUILD	2013-06-21 19:48:54 UTC (rev 188814)
+++ PKGBUILD	2013-06-21 20:37:06 UTC (rev 188815)
@@ -1,57 +1,167 @@
-# $Id$
-# Maintainer: Thomas Bächler <thomas at archlinux.org>
-# Maintainer: Tobias Powalowski <tpowa at archlinux.org>
+# Maintainer : Tobias Powalowski <tpowa at archlinux.org>
+# Maintainer : Thomas Bächler <thomas at archlinux.org>
+# Contributor: Keshav Padram (the.ridikulus.rat) (aatt) (gemmaeiil) (ddoott) (ccoomm)>
 
-pkgname=syslinux
-pkgver=5.10
-pkgrel=3
-arch=('i686' 'x86_64')
+pkgname="syslinux"
+pkgver="6.00"
+pkgrel="1"
+arch=('x86_64' 'i686')
 pkgdesc="Collection of boot loaders that boot from FAT, ext2/3/4 and btrfs filesystems, from CDs and via PXE"
-url="http://www.syslinux.org"
+url="http://syslinux.zytor.com/"
 license=('GPL2')
+
+makedepends=('python2' 'nasm' 'gnu-efi-libs')
 depends=('perl' 'glibc')
 optdepends=('perl-passwd-md5:  For md5pass'
             'perl-digest-sha1: For sha1pass'
             'mtools:           For mkdiskimage and syslinux support'
             'gptfdisk:         For GPT support'
-            'util-linux:       For isohybrid')
-makedepends=('nasm')
-backup=('boot/syslinux/syslinux.cfg')
-install=syslinux.install
-source=(http://www.kernel.org/pub/linux/utils/boot/syslinux/$pkgname-${pkgver}.tar.bz2
-        syslinux-dont-build-dos-windows-targets.patch
-        syslinux.cfg
-        syslinux-install_update)
-md5sums=('8f51d6a5d2730f534ba90e71f3347bff'
-         '25af85a05e7b212b7fb8b7587175e492'
-         'bbd97c4c735b8e5c52b79572d9296246'
-         '88a04d803bdd019a9a063d00aa008eee')
+            'util-linux:       For isohybrid'
+            'efibootmgr:       For EFI support'
+            'dosfstools:       For EFI support')
 
+install="${pkgname}.install"
+
+source=("https://www.kernel.org/pub/linux/utils/boot/syslinux/${pkgname}-${pkgver}.tar.xz"
+        'syslinux-6.00-efi-fix-libcom32.patch'
+        'syslinux-6.00-efi-export-kbdmap.patch'
+        'syslinux.cfg'
+        'syslinux-install_update')
+
+sha1sums=('601036fb00f39ea838ef1cbe3dae8b9bf24fabda'
+          'e24c10acc7a923ba957957b1c2c1cd4b649a4cf4'
+          '44245ab68b607f412738dc222d51e9b8b4bf664b'
+          'b0f174bcc0386fdf699e03d0090e3ac841098010'
+          'b1d915045fe3094f5359df043c53e73a4dc32745')
+
+_build_syslinux_bios() {
+	
+	rm -rf "${srcdir}/${pkgname}-${pkgver}-bios/" || true
+	cp -r "${srcdir}/${pkgname}-${pkgver}" "${srcdir}/${pkgname}-${pkgver}-bios"
+	cd "${srcdir}/${pkgname}-${pkgver}-bios/"
+	
+	## Do not try to build syslinux with our default LDFLAGS, it will fail
+	unset LDFLAGS
+	
+	make PYTHON="python2" bios
+	make PYTHON="python2" bios installer
+	
+}
+
+_build_syslinux_efi64() {
+	
+	rm -rf "${srcdir}/${pkgname}-${pkgver}-efi64/" || true
+	cp -r "${srcdir}/${pkgname}-${pkgver}" "${srcdir}/${pkgname}-${pkgver}-efi64"
+	cd "${srcdir}/${pkgname}-${pkgver}-efi64/"
+	
+	## Unset all compiler FLAGS for efi64 build
+	unset CFLAGS
+	unset CPPFLAGS
+	unset CXXFLAGS
+	unset LDFLAGS
+	unset MAKEFLAGS
+	
+	make PYTHON="python2" efi64
+	make PYTHON="python2" efi64 installer
+	
+}
+
+_build_syslinux_efi32() {
+	
+	rm -rf "${srcdir}/${pkgname}-${pkgver}-efi32/" || true
+	cp -r "${srcdir}/${pkgname}-${pkgver}" "${srcdir}/${pkgname}-${pkgver}-efi32"
+	cd "${srcdir}/${pkgname}-${pkgver}-efi32/"
+	
+	## Unset all compiler FLAGS for efi32 build
+	unset CFLAGS
+	unset CPPFLAGS
+	unset CXXFLAGS
+	unset LDFLAGS
+	unset MAKEFLAGS
+	
+	make PYTHON="python2" efi32
+	make PYTHON="python2" efi32 installer
+	
+}
+
 build() {
-  # Do not try to build syslinux with our default LDFLAGS, it will fail
-  unset LDFLAGS
-  cd "$srcdir"/$pkgname-${pkgver}
-  # Do not try to build the Windows or DOS installers
-  patch -p1 -i "$srcdir"/syslinux-dont-build-dos-windows-targets.patch
-  # Fix FHS manpage path
-  sed 's|/usr/man|/usr/share/man|g' -i mk/syslinux.mk
-  make installer
-  make -C utils
-  make -C com32
+	
+	cd "${srcdir}/${pkgname}-${pkgver}/"
+	
+	## Apply syslinux-6.00-efi-fix-libcom32.patch from git
+	patch -Np1 -i "${srcdir}/syslinux-6.00-efi-fix-libcom32.patch"
+	
+	## Apply syslinux-6.00-efi-export-kbdmap.patch from git
+	patch -Np1 -i "${srcdir}/syslinux-6.00-efi-export-kbdmap.patch"
+	
+	## Do not try to build the Windows or DOS installers
+	sed 's|diag libinstaller dos win32 win64 dosutil txt|libinstaller txt|g' -i "${srcdir}/${pkgname}-${pkgver}/Makefile" || true
+	sed 's|win32/syslinux.exe win64/syslinux64.exe||g' -i "${srcdir}/${pkgname}-${pkgver}/Makefile" || true
+	sed 's|dosutil/*.com dosutil/*.sys||g' -i "${srcdir}/${pkgname}-${pkgver}/Makefile" || true
+	sed 's|dos/syslinux.com||g' -i "${srcdir}/${pkgname}-${pkgver}/Makefile" || true
+	sed 's|INSTALLSUBDIRS = com32 utils dosutil|INSTALLSUBDIRS = com32 utils|g' -i "${srcdir}/${pkgname}-${pkgver}/Makefile" || true
+	
+	## Fix FHS manpage path
+	sed 's|/usr/man|/usr/share/man|g' -i "${srcdir}/${pkgname}-${pkgver}/mk/syslinux.mk" || true
+	
+	## Build syslinux-bios
+	_build_syslinux_bios
+	
+	## Build syslinux-efi
+	if [[ "${CARCH}" == "x86_64" ]]; then
+		_build_syslinux_efi64
+	fi
+	
+	if [[ "${CARCH}" == "i686" ]]; then
+		_build_syslinux_efi32
+	fi
+	
 }
 
+_package_syslinux_bios() {
+	
+	cd "${srcdir}/${pkgname}-${pkgver}-bios/"
+	
+	## Install Syslinux bios
+	make INSTALLROOT="${pkgdir}/" AUXDIR="/usr/lib/syslinux/bios/" bios install
+	
+	## Remove syslinux.exe,syslinux64.exe,syslinux.com and dosutil dir
+	rm "/usr/lib/syslinux/bios"/syslinux.{com,exe} || true
+	rm "/usr/lib/syslinux/bios/syslinux64.exe" || true
+	rm -rf "/usr/lib/syslinux/bios/dosutil/" || true
+	
+	## Move extlinux binary to /usr/bin
+	install -d "${pkgdir}/usr/bin"
+	mv "${pkgdir}/sbin/extlinux" "${pkgdir}/usr/bin/extlinux"
+	rm -rf "${pkgdir}/sbin/"
+	
+	## Install docs
+	cp -ar "${srcdir}/${pkgname}-${pkgver}/doc" "${pkgdir}/usr/share/"
+	
+	## Install the default configuration
+	install -D -m0644 "${srcdir}/syslinux.cfg" "${pkgdir}/boot/syslinux/syslinux.cfg"
+	
+	## Install the installation and update script
+	## This script is maintained at git://gist.github.com/772138.git
+	## Script not yet updated for syslinux-efi
+	install -D -m0755 "${srcdir}/syslinux-install_update" "${pkgdir}/usr/bin/syslinux-install_update"
+	
+}
+
 package() {
-  cd "$srcdir"/$pkgname-${pkgver}
-  make INSTALLROOT="$pkgdir" AUXDIR=/usr/lib/syslinux install
-
-  # install docs
-  cp -ar "$srcdir"/$pkgname-${pkgver}/doc "$pkgdir"/usr/share/
-  # Install the default configuration
-  install -D -m644 "$srcdir"/syslinux.cfg "$pkgdir"/boot/syslinux/syslinux.cfg
-  # Install the installation and update script
-  # This script is maintained at git://gist.github.com/772138.git
-  install -D -m755 "$srcdir"/syslinux-install_update "$pkgdir"/usr/bin/syslinux-install_update
-  # move extlinux binary to /usr/bin
-  mv "$pkgdir"/sbin/extlinux "$pkgdir"/usr/bin/extlinux
-  rmdir "$pkgdir"/sbin
+	
+	cd "${srcdir}/${pkgname}-${pkgver}/"
+	
+	_package_syslinux_bios
+	
+	if [[ "${CARCH}" == "x86_64" ]]; then
+		cd "${srcdir}/${pkgname}-${pkgver}-efi64/"
+		make INSTALLROOT="${pkgdir}/" AUXDIR="/usr/lib/syslinux/" efi64 install
+	fi
+	
+	if [[ "${CARCH}" == "i686" ]]; then
+		cd "${srcdir}/${pkgname}-${pkgver}-efi32/"
+		make INSTALLROOT="${pkgdir}/" AUXDIR="/usr/lib/syslinux/" efi32 install
+	fi
+	
 }

Added: syslinux-6.00-efi-export-kbdmap.patch
===================================================================
--- syslinux-6.00-efi-export-kbdmap.patch	                        (rev 0)
+++ syslinux-6.00-efi-export-kbdmap.patch	2013-06-21 20:37:06 UTC (rev 188815)
@@ -0,0 +1,38 @@
+From 2a81889c7d680fbe51de63dbbeb4e8c290ec46fa Mon Sep 17 00:00:00 2001
+From: Matt Fleming <matt.fleming at intel.com>
+Date: Fri, 21 Jun 2013 07:14:24 +0000
+Subject: efi: Tag symbols with __export
+
+I missed some symbols previously that are required to be exported when
+loading vesamenu.c32.
+
+Signed-off-by: Matt Fleming <matt.fleming at intel.com>
+---
+diff --git a/efi/main.c b/efi/main.c
+index 51ff9f3..71333a4 100644
+--- a/efi/main.c
++++ b/efi/main.c
+@@ -21,7 +21,7 @@ uint32_t _IdleTimer = 0;
+ char __lowmem_heap[32];
+ uint32_t BIOS_timer_next;
+ uint32_t timer_irq;
+-uint8_t KbdMap[256];
++__export uint8_t KbdMap[256];
+ char aux_seg[256];
+ 
+ static inline EFI_STATUS
+diff --git a/efi/vesa.c b/efi/vesa.c
+index d259f60..b4a541b 100644
+--- a/efi/vesa.c
++++ b/efi/vesa.c
+@@ -297,7 +297,7 @@ static int efi_vesacon_font_query(uint8_t **font)
+     return cp865_8x16_font_height;
+ }
+ 
+-int __vesacon_i915resolution(int x, int y)
++__export int __vesacon_i915resolution(int x, int y)
+ {
+ 	/* We don't support this function */
+ 	return 1;
+--
+cgit v0.9.2

Added: syslinux-6.00-efi-fix-libcom32.patch
===================================================================
--- syslinux-6.00-efi-fix-libcom32.patch	                        (rev 0)
+++ syslinux-6.00-efi-fix-libcom32.patch	2013-06-21 20:37:06 UTC (rev 188815)
@@ -0,0 +1,45 @@
+From 013ef7679a573b3b3454f914f3a7f865991db9f2 Mon Sep 17 00:00:00 2001
+From: Matt Fleming <matt.fleming at intel.com>
+Date: Fri, 21 Jun 2013 07:13:16 +0000
+Subject: efi: Export __bcopyxx_len
+
+We need to provide a __bcopyxx_len symbol for EFI because it's
+referenced in generic code in libcom32.c32. Without this change,
+libcom32.c32 will fail to load under EFI.
+
+Signed-off-by: Matt Fleming <matt.fleming at intel.com>
+---
+diff --git a/core/include/core.h b/core/include/core.h
+index 5736d39..127ac65 100644
+--- a/core/include/core.h
++++ b/core/include/core.h
+@@ -26,6 +26,7 @@ extern char cmd_line[];
+ extern char ConfigFile[];
+ extern char syslinux_banner[];
+ extern char copyright_str[];
++extern unsigned int __bcopyxx_len;
+ 
+ /*
+  * Mark symbols that are only used by BIOS as __weak until we can move
+@@ -35,7 +36,6 @@ extern char copyright_str[];
+ extern __weak uint16_t BIOSName;
+ extern __weak char KernelName[];
+ extern __weak char StackBuf[];
+-extern __weak unsigned int __bcopyxx_len;
+ 
+ extern uint8_t KbdMap[256];
+ 
+diff --git a/efi/main.c b/efi/main.c
+index 438e88c..51ff9f3 100644
+--- a/efi/main.c
++++ b/efi/main.c
+@@ -153,6 +153,7 @@ void pxenv(void)
+ uint16_t BIOS_fbm = 1;
+ far_ptr_t InitStack;
+ far_ptr_t PXEEntry;
++__export unsigned int __bcopyxx_len = 0;
+ 
+ void gpxe_unload(void)
+ {
+--
+cgit v0.9.2

Modified: syslinux-install_update
===================================================================
--- syslinux-install_update	2013-06-21 19:48:54 UTC (rev 188814)
+++ syslinux-install_update	2013-06-21 20:37:06 UTC (rev 188815)
@@ -26,7 +26,7 @@
 #
 shopt -s nullglob
 
-libpath="/usr/lib/syslinux"
+libpath="/usr/lib/syslinux/bios"
 bootpath="/boot/syslinux"
 extlinux="/usr/bin/extlinux"
 

Modified: syslinux.install
===================================================================
--- syslinux.install	2013-06-21 19:48:54 UTC (rev 188814)
+++ syslinux.install	2013-06-21 20:37:06 UTC (rev 188815)
@@ -1,8 +1,18 @@
 post_install() {
-  echo "==> If you want to use syslinux as your bootloader"
+  echo "==> If you want to use syslinux as your BIOS bootloader"
   echo "==> edit /boot/syslinux/syslinux.cfg and run"
   echo "==>   # /usr/bin/syslinux-install_update -i -a -m"
   echo "==> to install it."
+  
+  cat << EOF
+Syslinux efi64 and efi32 files have been installed at
+/usr/lib/syslinux/{efi64,efi32}/ respectively.
+
+To install, copy /usr/lib/syslinux/efi64 to (ESP)/EFI/syslinux and
+syslinux.cfg to (ESP)/EFI/syslinux/syslinux.cfg and add a boot entry
+using efibootmgr for (ESP)/EFI/syslinux/syslinux.efi
+EOF
+
 }
 
 post_upgrade() {




More information about the arch-commits mailing list