syslinux: Add version 6.03 03/32003/2
authorSaul Wold <sgw@linux.intel.com>
Fri, 12 Dec 2014 23:14:43 +0000 (15:14 -0800)
committerronan(Eurogiciel) Le Martret <ronan.lemartret@open.eurogiciel.org>
Mon, 15 Dec 2014 08:38:40 +0000 (00:38 -0800)
Change-Id: I00775347958bdf21740b26c2bbfb48a31b8d8465
Signed-off-by: Saul Wold <sgw@linux.intel.com>
meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-fix-parallel-building-issue.patch [new file with mode: 0644]
meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-libupload-depend-lib.patch [new file with mode: 0644]
meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-remove-clean-script.patch [new file with mode: 0644]
meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux_6.03.bb [new file with mode: 0644]

diff --git a/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-fix-parallel-building-issue.patch b/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-fix-parallel-building-issue.patch
new file mode 100644 (file)
index 0000000..312b1e8
--- /dev/null
@@ -0,0 +1,35 @@
+syslinux-native: fix parallel building issue
+
+There might be an error when parallel build:
+
+[snip]
+cp: cannot create directory `tmp/sysroots/x86_64-linux/usr/share/
+syslinux/com32/include/gplinclude': No such file or directory
+make[4]: *** [install] Error 1
+make[3]: *** [gpllib] Error 2
+[snip]
+
+This is a potential issue. In ${S}/com32/gpllib/Makefile file,
+install target wants to copy $(SRC)/../gplinclude to
+$(INSTALLROOT)$(COM32DIR)/include/ directory, but in ${S}/com32/lib/Makefile
+file, the install target will remove $(INSTALLROOT)$(COM32DIR)/include
+directory. We need to do com32/lib first.
+
+The patch make com32/gpllib depends on com32/lib to fix this issue.
+
+Upstream-Status: Pending
+
+Signed-off-by: Chong Lu <Chong.Lu@windriver.com>
+---
+ com32/Makefile |    1 +
+ 1 file changed, 1 insertion(+)
+
+Index: syslinux-6.03/com32/Makefile
+===================================================================
+--- syslinux-6.03.orig/com32/Makefile
++++ syslinux-6.03/com32/Makefile
+@@ -21,3 +21,4 @@ rosh: lib libutil
+ samples: libutil elflink/ldlinux
+ sysdump: lib libutil libupload gpllib
+ lua/src: cmenu modules
++gpllib: lib
diff --git a/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-libupload-depend-lib.patch b/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-libupload-depend-lib.patch
new file mode 100644 (file)
index 0000000..c0714b5
--- /dev/null
@@ -0,0 +1,34 @@
+From 490fc3bbd65c2c252c1fdf3da0fac9898aa9eea6 Mon Sep 17 00:00:00 2001
+From: Robert Yang <liezhi.yang@windriver.com>
+Date: Fri, 15 Aug 2014 21:09:16 -0700
+Subject: [PATCH] com32/Makefile: fix parallel issue
+
+Fixed:
+cp -r syslinux-6.01/com32/libupload/*.h image/usr/share/syslinux/com32/include/
+[snip]
+rm -rf image/usr/share/syslinux/com32/include
+[snip]
+cp: cannot create regular file `image/usr/share/syslinux/com32/include/serial.h': No such file or directory
+
+The cp is happened in the "libupload" dir, while "rm -fr" is happend in
+"lib" dir, let "libupload" depend "lib" will fix the problem.
+
+Upstream-Status: Pending
+
+Signed-off-by: Robert Yang <liezhi.yang@windriver.com>
+---
+ com32/Makefile |    1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/com32/Makefile b/com32/Makefile
+index 9a1721b..f172db2 100644
+--- a/com32/Makefile
++++ b/com32/Makefile
+@@ -21,3 +21,4 @@ rosh: lib libutil
+ samples: libutil elflink/ldlinux
+ sysdump: libupload gpllib
+ gpllib: lib
++libupload: lib
+-- 
+1.7.9.5
+
diff --git a/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-remove-clean-script.patch b/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux/syslinux-remove-clean-script.patch
new file mode 100644 (file)
index 0000000..d564c0e
--- /dev/null
@@ -0,0 +1,12 @@
+Index: syslinux-6.03/efi/Makefile
+===================================================================
+--- syslinux-6.03.orig/efi/Makefile
++++ syslinux-6.03/efi/Makefile
+@@ -101,7 +101,6 @@ tidy dist:
+       rm -f *.so *.o wrapper
+       find . \( -name \*.o -o -name \*.a -o -name .\*.d -o -name \*.tmp \) -print0 | \
+               xargs -0r rm -f
+-      $(topdir)/efi/clean-gnu-efi.sh $(EFI_SUBARCH) $(objdir)
+ clean: tidy
diff --git a/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux_6.03.bb b/meta-tizen-adaptation/meta/recipes-devtools/syslinux/syslinux_6.03.bb
new file mode 100644 (file)
index 0000000..caf7ba2
--- /dev/null
@@ -0,0 +1,80 @@
+SUMMARY = "Multi-purpose linux bootloader"
+HOMEPAGE = "http://syslinux.zytor.com/"
+LICENSE = "GPLv2+"
+LIC_FILES_CHKSUM = "file://COPYING;md5=0636e73ff0215e8d672dc4c32c317bb3 \
+                    file://README;beginline=35;endline=41;md5=558f2c71cb1fb9ba511ccd4858e48e8a"
+
+# If you really want to run syslinux, you need mtools.  We just want the
+# ldlinux.* stuff for now, so skip mtools-native
+DEPENDS = "nasm-native util-linux"
+
+# Added for meta-tizen-adaptation-oe-core
+FILESPATH_append = ":${COREBASE}/meta/recipes-extended/${BPN}/files"
+
+SRC_URI = "${KERNELORG_MIRROR}/linux/utils/boot/syslinux/6.xx/syslinux-${PV}.tar.xz \
+           file://syslinux-fix-parallel-building-issue.patch \
+           file://syslinux-libupload-depend-lib.patch \
+           file://syslinux-remove-clean-script.patch \
+           "
+
+SRC_URI[md5sum] = "92a253df9211e9c20172796ecf388f13"
+SRC_URI[sha256sum] = "26d3986d2bea109d5dc0e4f8c4822a459276cf021125e8c9f23c3cca5d8c850e"
+
+COMPATIBLE_HOST = '(x86_64|i.86).*-(linux|freebsd.*)'
+# Don't let the sanity checker trip on the 32 bit real mode BIOS binaries
+INSANE_SKIP_${PN}-misc = "arch"
+INSANE_SKIP_${PN}-chain = "arch"
+
+EXTRA_OEMAKE = " \
+       BINDIR=${bindir} SBINDIR=${sbindir} LIBDIR=${libdir} \
+       DATADIR=${datadir} MANDIR=${mandir} INCDIR=${includedir} \
+"
+# syslinux uses $LD for linking, strip `-Wl,' so it can work
+export LDFLAGS = "`echo $LDFLAGS | sed 's/-Wl,//g'`"
+
+do_configure() {
+       # drop win32 targets or build fails
+       sed -e 's,win32/\S*,,g' -i Makefile
+
+       # clean installer executables included in source tarball
+       oe_runmake clean firmware="efi32" EFIINC="${includedir}"
+       # NOTE: There is a temporary work around above to specify
+       #       the efi32 as the firmware else the pre-built bios
+       #       files get erased contrary to the doc/distib.txt
+       #       In the future this should be "bios" and not "efi32".
+}
+
+do_compile() {
+       # Make sure the recompile is OK.
+       # Though the ${B} should always exist, still check it before find and rm.
+       [ -d "${B}" ] && find ${B} -name '.*.d' -type f -exec rm -f {} \;
+
+       # Rebuild only the installer; keep precompiled bootloaders
+       # as per author's request (doc/distrib.txt)
+       oe_runmake CC="${CC} ${CFLAGS}" LDFLAGS="${LDFLAGS}" firmware="bios" installer
+}
+
+do_install() {
+       oe_runmake CC="${CC} ${CFLAGS}" install INSTALLROOT="${D}" firmware="bios"
+
+       install -d ${D}${datadir}/syslinux/
+       install -m 644 ${S}/bios/core/ldlinux.sys ${D}${datadir}/syslinux/
+       install -m 644 ${S}/bios/core/ldlinux.bss ${D}${datadir}/syslinux/
+}
+
+PACKAGES += "${PN}-extlinux ${PN}-mbr ${PN}-chain ${PN}-pxelinux ${PN}-isolinux ${PN}-misc"
+
+RDEPENDS_${PN} += "mtools"
+RDEPENDS_${PN}-misc += "perl"
+
+FILES_${PN} = "${bindir}/syslinux"
+FILES_${PN}-extlinux = "${sbindir}/extlinux"
+FILES_${PN}-mbr = "${datadir}/${BPN}/mbr.bin"
+FILES_${PN}-chain = "${datadir}/${BPN}/chain.c32"
+FILES_${PN}-isolinux = "${datadir}/${BPN}/isolinux.bin"
+FILES_${PN}-pxelinux = "${datadir}/${BPN}/pxelinux.0"
+FILES_${PN}-dev += "${datadir}/${BPN}/com32/lib*${SOLIBS} ${datadir}/${BPN}/com32/include ${datadir}/${BPN}/com32/com32.ld"
+FILES_${PN}-staticdev += "${datadir}/${BPN}/com32/lib*.a ${libdir}/${BPN}/com32/lib*.a"
+FILES_${PN}-misc = "${datadir}/${BPN}/* ${libdir}/${BPN}/* ${bindir}/*"
+
+BBCLASSEXTEND = "native nativesdk"