boot/syslinux: add option to install the EFI image
syslinux can now also build an EFI application. If the target is 64-bit, we build the 64-bit EFI app, otherwise we build the 32-bit EFI app. Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr> Cc: Frank Hunleth <fhunleth@troodon-software.com> Tested-by: Frank Hunleth <fhunleth@troodon-software.com> Tested-by: Romain Naour <romain.naour@openwide.fr> Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
This commit is contained in:
parent
93be225d92
commit
4fb1d4b3e3
@ -10,21 +10,32 @@ config BR2_TARGET_SYSLINUX
|
|||||||
|
|
||||||
if BR2_TARGET_SYSLINUX
|
if BR2_TARGET_SYSLINUX
|
||||||
|
|
||||||
|
config BR2_TARGET_SYSLINUX_LEGACY_BIOS
|
||||||
|
bool
|
||||||
|
|
||||||
choice
|
choice
|
||||||
bool "Image to install"
|
bool "Image to install"
|
||||||
|
|
||||||
config BR2_TARGET_SYSLINUX_ISOLINUX
|
config BR2_TARGET_SYSLINUX_ISOLINUX
|
||||||
bool "isolinux"
|
bool "isolinux"
|
||||||
|
select BR2_TARGET_SYSLINUX_LEGACY_BIOS
|
||||||
help
|
help
|
||||||
Install the legacy-BIOS 'isolinux' image, to boot off
|
Install the legacy-BIOS 'isolinux' image, to boot off
|
||||||
optical media (CDROM, DVD.)
|
optical media (CDROM, DVD.)
|
||||||
|
|
||||||
config BR2_TARGET_SYSLINUX_PXELINUX
|
config BR2_TARGET_SYSLINUX_PXELINUX
|
||||||
bool "pxelinux"
|
bool "pxelinux"
|
||||||
|
select BR2_TARGET_SYSLINUX_LEGACY_BIOS
|
||||||
help
|
help
|
||||||
Install the legacy-BIOS 'pxelinux' image, to boot off
|
Install the legacy-BIOS 'pxelinux' image, to boot off
|
||||||
the network using PXE.
|
the network using PXE.
|
||||||
|
|
||||||
|
config BR2_TARGET_SYSLINUX_EFI
|
||||||
|
bool "efi"
|
||||||
|
select BR2_PACKAGE_GNU_EFI
|
||||||
|
help
|
||||||
|
Install the 'efi' image, to boot from an EFI environment.
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
endif # BR2_TARGET_SYSLINUX
|
endif # BR2_TARGET_SYSLINUX
|
||||||
|
37
boot/syslinux/syslinux-000-user-headers-from-sysroot.patch
Normal file
37
boot/syslinux/syslinux-000-user-headers-from-sysroot.patch
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
efi: look for headers and libs in the sysroot
|
||||||
|
|
||||||
|
Currently, syslinux hard-codes search paths to /usr/.... directories.
|
||||||
|
This does not play well in cross-compilation.
|
||||||
|
|
||||||
|
If $SYSROOT is defined, prepend it to the search paths.
|
||||||
|
|
||||||
|
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
|
||||||
|
|
||||||
|
diff -durN syslinux-6.02.orig/efi/find-gnu-efi.sh syslinux-6.02/efi/find-gnu-efi.sh
|
||||||
|
--- syslinux-6.02.orig/efi/find-gnu-efi.sh 2013-10-13 19:59:03.000000000 +0200
|
||||||
|
+++ syslinux-6.02/efi/find-gnu-efi.sh 2014-04-22 00:19:23.638483887 +0200
|
||||||
|
@@ -9,7 +9,7 @@
|
||||||
|
find_include()
|
||||||
|
{
|
||||||
|
for d in $include_dirs; do
|
||||||
|
- found=`find $d -name efi -type d 2> /dev/null`
|
||||||
|
+ found=`find $SYSROOT$d -name efi -type d 2> /dev/null`
|
||||||
|
if [ "$found"x != "x" ] && [ -e $found/$ARCH/efibind.h ]; then
|
||||||
|
echo $found
|
||||||
|
break;
|
||||||
|
@@ -20,12 +20,12 @@
|
||||||
|
find_lib()
|
||||||
|
{
|
||||||
|
for d in $lib_dirs; do
|
||||||
|
- found=`find $d -name libgnuefi.a 2> /dev/null`
|
||||||
|
+ found=`find $SYSROOT$d -name libgnuefi.a 2> /dev/null`
|
||||||
|
if [ "$found"x != "x" ]; then
|
||||||
|
crt_name='crt0-efi-'$ARCH'.o'
|
||||||
|
- crt=`find $d -name $crt_name 2> /dev/null`
|
||||||
|
+ crt=`find $SYSROOT$d -name $crt_name 2> /dev/null`
|
||||||
|
if [ "$crt"x != "x" ]; then
|
||||||
|
- echo $d
|
||||||
|
+ echo $SYSROOT$d
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
fi
|
@ -15,6 +15,20 @@ SYSLINUX_INSTALL_IMAGES = YES
|
|||||||
|
|
||||||
SYSLINUX_DEPENDENCIES = host-nasm host-util-linux host-upx
|
SYSLINUX_DEPENDENCIES = host-nasm host-util-linux host-upx
|
||||||
|
|
||||||
|
ifeq ($(BR2_TARGET_SYSLINUX_LEGACY_BIOS),y)
|
||||||
|
SYSLINUX_TARGET = bios
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(BR2_TARGET_SYSLINUX_EFI),y)
|
||||||
|
ifeq ($(BR2_ARCH_IS_64),y)
|
||||||
|
SYSLINUX_EFI_BITS = efi64
|
||||||
|
else
|
||||||
|
SYSLINUX_EFI_BITS = efi32
|
||||||
|
endif # 64-bit
|
||||||
|
SYSLINUX_DEPENDENCIES += gnu-efi
|
||||||
|
SYSLINUX_TARGET = $(SYSLINUX_EFI_BITS)
|
||||||
|
endif # EFI
|
||||||
|
|
||||||
# The syslinux tarball comes with pre-compiled binaries.
|
# The syslinux tarball comes with pre-compiled binaries.
|
||||||
# Since timestamps might not be in the correct order, a rebuild is
|
# Since timestamps might not be in the correct order, a rebuild is
|
||||||
# not always triggered for all the different images.
|
# not always triggered for all the different images.
|
||||||
@ -30,7 +44,7 @@ SYSLINUX_POST_PATCH_HOOKS += SYSLINUX_CLEANUP
|
|||||||
# be used.
|
# be used.
|
||||||
define SYSLINUX_BUILD_CMDS
|
define SYSLINUX_BUILD_CMDS
|
||||||
$(TARGET_MAKE_ENV) $(MAKE1) CC="$(HOSTCC) -idirafter $(HOST_DIR)/usr/include $(HOST_LDFLAGS)" \
|
$(TARGET_MAKE_ENV) $(MAKE1) CC="$(HOSTCC) -idirafter $(HOST_DIR)/usr/include $(HOST_LDFLAGS)" \
|
||||||
AR="$(HOSTAR)" -C $(@D) bios
|
AR="$(HOSTAR)" SYSROOT=$(STAGING_DIR) -C $(@D) $(SYSLINUX_TARGET)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# While the actual bootloader is compiled for the target, several
|
# While the actual bootloader is compiled for the target, several
|
||||||
@ -40,12 +54,13 @@ endef
|
|||||||
# install time
|
# install time
|
||||||
define SYSLINUX_INSTALL_TARGET_CMDS
|
define SYSLINUX_INSTALL_TARGET_CMDS
|
||||||
$(TARGET_MAKE_ENV) $(MAKE1) CC="$(HOSTCC) -idirafter $(HOST_DIR)/usr/include $(HOST_LDFLAGS)" \
|
$(TARGET_MAKE_ENV) $(MAKE1) CC="$(HOSTCC) -idirafter $(HOST_DIR)/usr/include $(HOST_LDFLAGS)" \
|
||||||
AR="$(HOSTAR)" INSTALLROOT=$(HOST_DIR) \
|
AR="$(HOSTAR)" SYSROOT=$(STAGING_DIR) INSTALLROOT=$(HOST_DIR) \
|
||||||
-C $(@D) bios install
|
-C $(@D) $(SYSLINUX_TARGET) install
|
||||||
endef
|
endef
|
||||||
|
|
||||||
SYSLINUX_IMAGES-$(BR2_TARGET_SYSLINUX_ISOLINUX) += bios/core/isolinux.bin
|
SYSLINUX_IMAGES-$(BR2_TARGET_SYSLINUX_ISOLINUX) += bios/core/isolinux.bin
|
||||||
SYSLINUX_IMAGES-$(BR2_TARGET_SYSLINUX_PXELINUX) += bios/core/pxelinux.bin
|
SYSLINUX_IMAGES-$(BR2_TARGET_SYSLINUX_PXELINUX) += bios/core/pxelinux.bin
|
||||||
|
SYSLINUX_IMAGES-$(BR2_TARGET_SYSLINUX_EFI) += $(SYSLINUX_EFI_BITS)/efi/syslinux.efi
|
||||||
|
|
||||||
define SYSLINUX_INSTALL_IMAGES_CMDS
|
define SYSLINUX_INSTALL_IMAGES_CMDS
|
||||||
for i in $(SYSLINUX_IMAGES-y); do \
|
for i in $(SYSLINUX_IMAGES-y); do \
|
||||||
|
Loading…
Reference in New Issue
Block a user