I recognize hardware with Lua and execute the ESXi installer with configuration files for that hardware. This works fine with normal Syslinux boot, but I want to get it working for UEFI boot as well. I found?efi64/efi/syslinux.efi and efi32/efi/syslinux.efi in the installer source, copied them and named them respectively?BOOTX64.EFI and?BOOTIA32.EFI in USBDISK:\EFI\BOOT. These were also the original names that the ESXi installer uses for it's UEFI boot files. However when using the efi files that the ESXi installers ships with, it skips syslinux.cfg and runs directly to boot.cfg (vmware specific file). In my setup of the regular bios boot usb installer that I want working with UEFI, syslinux reads syslinux.cfg, that presents a menu where I can select what boot.cfg I want to use with the ESXi installer. If I select nothing, a lua script starts that discovers the hardware and executes the correct the esxi installer with the correct boot.cfg. So that is what I want syslinux uefi to do, and just copying in the files like described above with syslinux.cfg and the rest didn't do the trick. So the question really is, how do I get syslinux UEFI to read syslinux.cfg and continue from there? Den 19. april 2016 kl. 12.37.05 +02.00 skrev Gene Cumm <gene.cumm at gmail.com>:> On Mon, Apr 18, 2016 at 5:40 AM, Atle Holm via Syslinux > <<syslinux at zytor.com>> wrote: > > > I am looking for guides on how to create syslinux uefi bootable usb. > > A syslinux bootable usb is created already with vesamenu and luascripting. > > Want to set up the same thing to be UEFI compatible. > > > What are you doing with Lua? Offering multiple boot selections > including ESXI's installer? Or customizing the boot parameters for > ESXi's installer? > > > In this case I am booting an vmware esxi installer. /EFI/boot on the vmware ISO has the files BOOTX64.EFI and BOOTIA32.EFI that can be used on the usb. But these always go directly to boot.cfg, syslinux.cfg is never read and thus my boot menu is never shown, an I never get to use the lua scripting. > > > These binaries are not Syslinux. They identify themselves as > "mboot_em64t.efi". Syslinux EFI binaries will have "Syslinux" in > plain text in the binary. > > Also, mboot.c32 contains closed source enhancements not available in > Syslinux to read the very same file. If VMware is willing, I'd love > to review and merge these enhancements. > > > I guess syslinux has these efi files somewhere, but on Centos7 I have not found them even when I did install the syslinux package. > > > The EFI binaries were introduced with 6.00. > <http://mirror.centos.org/centos/7/os/x86_64/Packages/> seems to > indicate version 4.05. I don't know where CentOS or RHEL may place > them, if at all, but in the binary/source archive, they're at > efi64/efi/syslinux.efi and efi32/efi/syslinux.efi. > > > > The general recipe that I have found is the following: > > - A "EFI/boot" folder for EFI boot, installed manually: > > - Copy all *.c32 objects from "/usr/lib/syslinux/efi64/" > > - Copy "syslinux.efi" to "bootx64.efi" in same folder as above > > - Edit "syslinux.cfg" in "EFI/boot" > > > > > > But as stated, can't find syslinux.efi > > Best regards > > > I'm pretty sure your packages are of a version that's too old. > > The steps necessary for a USB boot that can chainload VMware ESXi's > mboot loader may be possible but only with the latest git commits > however I don't know if they'll be of any use. > > -- > -Gene >
On Wed, Apr 20, 2016 at 5:03 AM, Atle Holm <atle at team-holm.net> wrote:> I recognize hardware with Lua and execute the ESXi installer with > configuration files for that hardware. > This works fine with normal Syslinux boot, but I want to get it working for > UEFI boot as well. > > I found efi64/efi/syslinux.efi and efi32/efi/syslinux.efi in the installer > source, copied them and named them respectively BOOTX64.EFI and BOOTIA32.EFI > in USBDISK:\EFI\BOOT. > These were also the original names that the ESXi installer uses for it's > UEFI boot files.These are generic names in the UEFI standard.> However when using the efi files that the ESXi installers ships with, it > skips syslinux.cfg and runs directly to boot.cfg (vmware specific file).Correct. For your case, you have to ignore the VMware provided EFI boot loader.> In my setup of the regular bios boot usb installer that I want working with > UEFI, syslinux reads syslinux.cfg, that presents a menu where I can select > what boot.cfg I want to use with the ESXi installer. If I select nothing, a > lua script starts that discovers the hardware and executes the correct the > esxi installer with the correct boot.cfg. > > So that is what I want syslinux uefi to do, and just copying in the files > like described above with syslinux.cfg and the rest didn't do the trick. > > So the question really is, how do I get syslinux UEFI to read syslinux.cfg > and continue from there?So you either skipped copying the EFI boot loaders or deleted them then copied the initial Syslinux boot loader and a config. If instead you happened to rename them and then it seems to boot them still, move them to a new directory or delete them as they still exist as the old name (FAT has two ways to store the name). Did you also copy ldlinux.c32 and all other necessary files? Where did you put syslinux.cfg? Searching the root directory of the USB disk is the last attempt to find a config then it warns that no config was found. Bear in mind that BIOS COM32 files are not compatible with EFI ia32 or ia32-64 environments. -- -Gene> Den 19. april 2016 kl. 12.37.05 +02.00 skrev Gene Cumm > <gene.cumm at gmail.com>: > > On Mon, Apr 18, 2016 at 5:40 AM, Atle Holm via Syslinux > <syslinux at zytor.com> wrote: > > I am looking for guides on how to create syslinux uefi bootable usb. > A syslinux bootable usb is created already with vesamenu and luascripting. > Want to set up the same thing to be UEFI compatible. > > > What are you doing with Lua? Offering multiple boot selections > including ESXI's installer? Or customizing the boot parameters for > ESXi's installer? > > In this case I am booting an vmware esxi installer. /EFI/boot on the vmware > ISO has the files BOOTX64.EFI and BOOTIA32.EFI that can be used on the usb. > But these always go directly to boot.cfg, syslinux.cfg is never read and > thus my boot menu is never shown, an I never get to use the lua scripting. > > > These binaries are not Syslinux. They identify themselves as > "mboot_em64t.efi". Syslinux EFI binaries will have "Syslinux" in > plain text in the binary. > > Also, mboot.c32 contains closed source enhancements not available in > Syslinux to read the very same file. If VMware is willing, I'd love > to review and merge these enhancements. > > I guess syslinux has these efi files somewhere, but on Centos7 I have not > found them even when I did install the syslinux package. > > > The EFI binaries were introduced with 6.00. > http://mirror.centos.org/centos/7/os/x86_64/Packages/ seems to > indicate version 4.05. I don't know where CentOS or RHEL may place > them, if at all, but in the binary/source archive, they're at > efi64/efi/syslinux.efi and efi32/efi/syslinux.efi. > > The general recipe that I have found is the following: > - A "EFI/boot" folder for EFI boot, installed manually: > - Copy all *.c32 objects from "/usr/lib/syslinux/efi64/" > - Copy "syslinux.efi" to "bootx64.efi" in same folder as above > - Edit "syslinux.cfg" in "EFI/boot" > > > But as stated, can't find syslinux.efi > Best regards > > > I'm pretty sure your packages are of a version that's too old. > > The steps necessary for a USB boot that can chainload VMware ESXi's > mboot loader may be possible but only with the latest git commits > however I don't know if they'll be of any use. > > -- > -Gene
Under EFI/BOOT are the following files: BOOTIA32.EFI (from efi32/efi/syslinux.efi) BOOTX64.EFI (from efi64/efi/syslinux.efi) ldlinux.sys (copied from root of partition) lua.c32 mboot.c32 menu.c32 syslinux.cfg vesamenu.c32 KS.CFG (vmware specific) BOOT.CFG (vmware specific) autoselect.lua These files are also all under the root of the partition (except BOOTIA32.EFI and BOOTX64.EFI) and work fine there if I use a normal bios boot. When using UEFI boot, things don't work. If the .c32 files here are incorrect for UEFI boot, where do I get the correct files? I haven't been able to find a description/recipe on how to set up UEFI boot with Syslinux. Why is there none, or where is it? That would probably be easier. Den 20. april 2016 kl. 12.08.26 +02.00 skrev Gene Cumm <gene.cumm at gmail.com>:> On Wed, Apr 20, 2016 at 5:03 AM, Atle Holm <<atle at team-holm.net>> wrote: > > > I recognize hardware with Lua and execute the ESXi installer with > > configuration files for that hardware. > > This works fine with normal Syslinux boot, but I want to get it working for > > UEFI boot as well. > > > > I found efi64/efi/syslinux.efi and efi32/efi/syslinux.efi in the installer > > source, copied them and named them respectively BOOTX64.EFI and BOOTIA32.EFI > > in USBDISK:\EFI\BOOT. > > These were also the original names that the ESXi installer uses for it's > > UEFI boot files. > > > These are generic names in the UEFI standard. > > > > However when using the efi files that the ESXi installers ships with, it > > skips syslinux.cfg and runs directly to boot.cfg (vmware specific file). > > > Correct. For your case, you have to ignore the VMware provided EFI boot loader. > > > > In my setup of the regular bios boot usb installer that I want working with > > UEFI, syslinux reads syslinux.cfg, that presents a menu where I can select > > what boot.cfg I want to use with the ESXi installer. If I select nothing, a > > lua script starts that discovers the hardware and executes the correct the > > esxi installer with the correct boot.cfg. > > > > So that is what I want syslinux uefi to do, and just copying in the files > > like described above with syslinux.cfg and the rest didn't do the trick. > > > > So the question really is, how do I get syslinux UEFI to read syslinux.cfg > > and continue from there? > > > So you either skipped copying the EFI boot loaders or deleted them > then copied the initial Syslinux boot loader and a config. If instead > you happened to rename them and then it seems to boot them still, move > them to a new directory or delete them as they still exist as the old > name (FAT has two ways to store the name). > > Did you also copy ldlinux.c32 and all other necessary files? Where > did you put syslinux.cfg? Searching the root directory of the USB > disk is the last attempt to find a config then it warns that no config > was found. Bear in mind that BIOS COM32 files are not compatible with > EFI ia32 or ia32-64 environments. > > -- > -Gene > > > > > Den 19. april 2016 kl. 12.37.05 +02.00 skrev Gene Cumm > > <<gene.cumm at gmail.com>>: > > > > On Mon, Apr 18, 2016 at 5:40 AM, Atle Holm via Syslinux > > <<syslinux at zytor.com>> wrote: > > > > I am looking for guides on how to create syslinux uefi bootable usb. > > A syslinux bootable usb is created already with vesamenu and luascripting. > > Want to set up the same thing to be UEFI compatible. > > > > > > What are you doing with Lua? Offering multiple boot selections > > including ESXI's installer? Or customizing the boot parameters for > > ESXi's installer? > > > > In this case I am booting an vmware esxi installer. /EFI/boot on the vmware > > ISO has the files BOOTX64.EFI and BOOTIA32.EFI that can be used on the usb. > > But these always go directly to boot.cfg, syslinux.cfg is never read and > > thus my boot menu is never shown, an I never get to use the lua scripting. > > > > > > These binaries are not Syslinux. They identify themselves as > > "mboot_em64t.efi". Syslinux EFI binaries will have "Syslinux" in > > plain text in the binary. > > > > Also, mboot.c32 contains closed source enhancements not available in > > Syslinux to read the very same file. If VMware is willing, I'd love > > to review and merge these enhancements. > > > > I guess syslinux has these efi files somewhere, but on Centos7 I have not > > found them even when I did install the syslinux package. > > > > > > The EFI binaries were introduced with 6.00. > > <http://mirror.centos.org/centos/7/os/x86_64/Packages/> seems to > > indicate version 4.05. I don't know where CentOS or RHEL may place > > them, if at all, but in the binary/source archive, they're at > > efi64/efi/syslinux.efi and efi32/efi/syslinux.efi. > > > > The general recipe that I have found is the following: > > - A "EFI/boot" folder for EFI boot, installed manually: > > - Copy all *.c32 objects from "/usr/lib/syslinux/efi64/" > > - Copy "syslinux.efi" to "bootx64.efi" in same folder as above > > - Edit "syslinux.cfg" in "EFI/boot" > > > > > > But as stated, can't find syslinux.efi > > Best regards > > > > > > I'm pretty sure your packages are of a version that's too old. > > > > The steps necessary for a USB boot that can chainload VMware ESXi's > > mboot loader may be possible but only with the latest git commits > > however I don't know if they'll be of any use. > > > > -- > > -Gene > >