SYNOPSIS
syslinux [OPTIONS] DEVICE extlinux [OPTIONS] PATH syslinux [-h | --help | -v | --version] extlinux [-h | --help | -v | --version]
DESCRIPTION
Install SYSLINUX to the DEVICE/PATH, altering the boot sector and installing the ldlinux.sys boot loader file. For the Linux installer extlinux, PATH is the desired path for the control files on a mounted, supported file system and sets the install-time working directory. For all others, DEVICE must specify a FAT12/FAT16/FAT32 file system. For the Linux installers syslinux and syslinux-mtools, DEVICE should be an unmounted file system. For the DOS/Win32/Win64 installers, DEVICE should be a drive like a: (case insensitive).
For versions ~4.00 and later, either -i/--install or -U/--update must be specified unless modifying the ADV of an existing install (options tagged with ADV) or requesting the help/usage or version info, .
If, during boot, the Shift or Alt keys are held down, or the Caps or Scroll locks are set, Syslinux will display a lilo(8) -style "boot:" prompt. The user can then type a kernel file name followed by any kernel parameters. The Syslinux bootloader does not need to know about the kernel or config files in advance.
Syslinux supports the loading of initial ramdisks (initrd) and the bzImage kernel format.
Please note, the ldlinux.sys boot loader file is flagged as immutable (where applicable) and is modified after copying in to help ensure boot-time integrity. File systems with a sufficiently large boot loader reserved area, like btrfs, will have ldlinux.sys installed there rather than as a normal file. Prior to version 4.00, extlinux would install a file extlinux.sys which versions 4.00 and later installers will replace with ldlinux.sys.
OPTIONS
Standalone options
- -i, --install
-
(~4.00+) Install SYSLINUX, regardless of an existing install.
- -U, --update
-
(~4.00+) Update an existing SYSLINUX/EXTLINUX install. If no Syslinux boot loader is present, return an error.
- -h, --help
-
Display help/usage information.
- -v, --version
-
Display version information and exit immediately.
Regular Options
- -a, --active
-
(DOS/Win32/Win64 ONLY) Mark the install target file system’s partition active.
- -d, --directory subdirectory
-
(Not necessary for extlinux as it is implied by PATH) Install the SYSLINUX control files in a subdirectory with the specified name (relative to the root directory on the device).
- --device DEVICE
-
(extlinux ONLY; 4.06+) Force use of a specific block device (experts only).
- -f, --force
-
Force install even if it appears unsafe. Before 4.00, -f was used for --offset in the Linux installers.
- -H, --heads head-count
-
Override the detected number of heads for the geometry. See also --sector.
-m, --mbr: (DOS/Win32/Win64 ONLY) Install the regular Syslinux MBR code to the MBR.
- -M, --menu-save
-
(4.00+; ADV) Set the label to select as default on the next boot.
- -o, --once command
-
(ADV) Declare a boot command to be tried on the first boot only. The use of -o for the Linux installers syslinux or syslinux-mtools has been deprecated as of ~4.00 and is no longer valid as of ~4.02.
- -O, --clear-once
-
Clear the boot-once command. See also --once.
- -r, --raid
-
(ADV) RAID mode. If boot fails, tell the BIOS to boot the next device in the boot sequence (usually the next hard disk) instead of stopping with an error message. This is useful for RAID-1 booting.
- --reset-adv
-
(ADV) Reset auxilliary data vector.
- -S, --sectors sector-count
-
Override the detected number of sectors for the geometry. See also --head.
- -s, --stupid
-
Install a "safe, slow and stupid" version of SYSLINUX. This version may work on some very buggy BIOSes on which SYSLINUX would otherwise fail. If you find a machine on which the -s option is required to make it boot reliably, please send as much info about your machine as you can, and include the failure mode.
- -t, --offset offset
-
(Linux syslinux/syslinux-mtools ONLY) Indicates that the filesystem is at an offset from the base of the device or file.
-z, --zipdrive Assume zipdrive geometry (--heads 64 --sectors 32). See also --head and --sector.
EXAMPLES
Booting DOS
For booting DOS and other similar operating systems, there is an easy and generally reliable solution to substitute in SYSLINUX as the primary boot loader.
-
Make a DOS-bootable disk; The following are possible commands:
format a: /s sys a:
-
Copy the DOS boot sector off using Linux or copybs.com:
dd if=/dev/fd0 of=dos.bss bs=512 count=1 copybs a: a:dos.bss
-
Install SYSLINUX using one of:
syslinux a: syslinux /dev/fd0 (before 4.00) syslinux -i /dev/fd0 (4.00+)
-
For Linux, mount the disk and copy the dos.bss to the disk:
mount -t msdos /dev/fd0 /mnt cp dos.bss /mnt
-
Copy a Linux kernel image and initrd payload files:
- Linux:
-
cp vmlinux /mnt cp initrd.gz /mnt
- DOS/Windows:
-
copy vmlinux a: copy initrd.gz a:
-
For Linux, umount the disk (if applicable):
umount /mnt
MBR
In order to boot from a hard disk (or hard disk-like device) in BIOS mode, an appropriate MBR boot block must also be installed in the MBR (first sector or 512 bytes of the disk), occupying at most 440 bytes.
- DOS/Windows:
-
If using FDISK, FDISK or a similar application must also be used to mark the partition as active.
fdisk /mbr OR syslinux -ma c:
- Linux:
-
dd bs=440 count=1 conv=notrunc if=mbr/mbr.bin of=/dev/sda
For altmbr.bin, an easy way to overwrite the MBR boot block and specify the partion number is:
printf '\1' | cat altmbr.bin - | dd bs=440 count=1 \ iflag=fullblock conv=notrunc of=/dev/sda
Note: using cat for writing the MBR can under some circumstances cause data loss or overwritting. For this reason, using dd is recommended for all situations.
SEE ALSO
syslinux.cfg(5), syslinux-cli(1), lilo(8), keytab-lilo.pl(8), fdisk(8), mkfs(8), superformat(1).
AUTHOR
This AsciiDoc derived document is a modified version of the original SYSLINUX documentation by H. Peter Anvin <hpa@zytor.com>. The conversion to a manpage was made by Arthur Korn <arthur@korn.ch>. The conversion to an AsciiDoc was made by Gene Cumm <gene.cumm@gmail.com>
COPYRIGHT
Copyright (C) 1994-2012 H. Peter Anvin. Free use of this software is granted under the terms of the GNU General Public License (GPL), version 2 (GPLv2) (or, at your option, any later version).