Syslinux (Русский)
Syslinux — это набор загрузчиков, способных загружать образы с жестких дисков, компакт-дисков, а также через сеть с использованием PXE. Он поддерживает файловые системы FAT, ext2, ext3, ext4 и Btrfs.
Системы с BIOS
Обзор процесса загрузки
- Этап 1 : Часть 1 - Загрузка MBR - При запуске BIOS загружает 440 байт загрузочного кода MBR, расположенного в начале диска (
/usr/lib/syslinux/bios/mbr.bin
или/usr/lib/syslinux/bios/gptmbr.bin
) - Этап 1 : Часть 2 - Поиск активного раздела. На первом этапе загрузки MBR ищет раздел, помеченный, как активный (с установленным boot-флагом). Предположим, это раздел
/boot
- Этап 2 : Часть 1 - Выполнение загрузочной записи тома - Первый этап загрузочной записи MBR начинает выполнение Загрузочной Записи Тома (VBR) с раздела
/boot
. При использовании syslinux загрузочный код VBR находится в стартовом секторе/boot/syslinux/ldlinux.sys
, который был создан командойextlinux --install
. Обратите внимание, что — не то же самое, что - Этап 2 : Часть 2 - Выполнение
/boot/syslinux/ldlinux.sys
- VBR загрузит остальную часть/boot/syslinux/ldlinux.sys
. Расположение сектора/boot/syslinux/ldlinux.sys
не должно измениться, иначе syslinux не выполнит загрузку - Этап 3 - Загрузка -
/boot/syslinux/ldlinux.sys
загрузит (основной модуль), который содержит остаток основной части syslinux, не умещающейся в (из-за ограничений на размер файла). должен присутствовать в каждой установке syslinux/extlinux и соответствовать версии , установленной на раздел. В противном случае, syslinux не выполнит загрузку. Смотрите http://bugzilla.syslinux.org/show_bug.cgi?id=7 для получения дополнительной информации - Этап 4 - Поиск и загрузка файла конфигурации - После того, как Syslinux загрузится полностью, он ищет файл
/boot/syslinux/syslinux.cfg
(или/boot/syslinux/extlinux.conf
в некоторых случаях) и загружает его, если он найден. Если нет, появится приглашение командной строки . Этот шаг и остаток неосновной части syslinux (модули , за исключением и ) требуют наличия модулей (библиотек) (https://wiki.syslinux.org/wiki/index.php/Common_Problems#ELF). Модули библиотек и неосновные модули должны соответствовать версии , установленной на раздел
Установка
Установите пакет из официальных репозиториев.
Автоматическая установка
Скрипт установит Syslinux, скопирует модули в /boot/syslinux
, установит boot-флаг и загрузочный код в MBR. Он может работать с дисками MBR и GPT с программным RAID:
- Если вы используете отдельный раздел /boot, удостоверьтесь, что он примонтирован. Используйте для этого команду ; если вы не видите точку монтирования
/boot
, примонтируйте раздел до того, как вы приступите к следующему шагу - Запустите с опциями (установить файлы), (пометить раздел, как активный, при помощи boot-флага) и (установить загрузочный код MBR): Если эта команда выдает ошибку Установка Syslinux BIOS не удалась (Syslinux BIOS install failed), вероятно, проблема в том, что исполняемый файл не может найти раздел, содержащий
/boot
: Это может случиться, например, при обновлении с LILO, который при загрузке текущего пользовательского (custom) ядра изменил параметр ядра в командной строке с, допустим, на его числовой эквивалентroot=801
, о чем свидетельствуют/proc/cmdline
и вывод команды . Исправьте ситуацию либо используя ручную установку, как описано ниже, с указанием для , либо просто перезагрузившись на обычное ядро Arch Linux, поскольку оно использует initramfs, благодаря чему проблема исчезнет. - Создайте или отредактируйте файл
/boot/syslinux/syslinux.cfg
, следуя указаниям из раздела #Настройка.
Ручная установка
Загрузочный раздел, на который вы планируете установить Syslinux, должен содержать файловую систему FAT, ext2, ext3, ext4 или Btrfs. Вы должны устанавливать его по пути точки монтирования, а не на устройство . Вы не должны устанавливать его в корневой каталог файловой системы, например, устройства , примонтированного в /boot
. Вы можете установить Syslinux в каталог :
# mkdir /boot/syslinux # cp -r /usr/lib/syslinux/bios/*.c32 /boot/syslinux/ ## скопируйте ВСЕ файлы *.c32 из /usr/lib/syslinux/bios/, А НЕ СОЗДАВАЙТЕ СИМВОЛЬНЫЕ ССЫЛКИ # extlinux --install /boot/syslinux
После этого установите загрузочный код Syslinux (mbr.bin
или ) в 440-байтную область загрузочного кода MBR (не путать с MBR как таблицей разделов msdos) диска, как описано в следующем разделе.
Таблица разделов MBR
Загляните в основную статью: Master Boot Record (Русский).
Теперь вам необходимо пометить ваш загрузочный раздел как активный в вашей таблице разделов. Вот несколько приложений, способных это сделать: fdisk
, , , ("boot-флаг"). Должно получиться примерно следующее:
Установите MBR:
# dd bs=440 count=1 conv=notrunc if=/usr/lib/syslinux/bios/mbr.bin of=/dev/sda
Альтернативная MBR, которую предоставляет Syslinux: . Эта MBR не сканирует диск на наличие загрузочного раздела; вместо этого, последнему байту MBR присваивается значение, отображающее то, с какого раздела необходимо выполнять загрузку. Вот пример того, как может быть скопирован:
# printf '\x5' | cat /usr/lib/syslinux/bios/altmbr.bin - | \ dd bs=440 count=1 iflag=fullblock conv=notrunc of=/dev/sda
В этом случае один байт со значением 5 добавляется к содержимому и итоговые 440 байт пишутся в MBR устройства . Syslinux был установлен на первый логический раздел () диска.
Таблица разделов GUID (GPT)
Загляните в основную статью: GUID Partition Table.
Второй бит атрибутов (атрибут "legacy_boot") должен быть установлен для раздела /boot
:.
# sgdisk /dev/sda --attributes=1:set:2
Это переключит атрибут legacy BIOS bootable на разделе 1. Для проверки:
# sgdisk /dev/sda --attributes=1:show
1:2:1 (legacy BIOS bootable)
Установите MBR:
# dd bs=440 conv=notrunc count=1 if=/usr/lib/syslinux/bios/gptmbr.bin of=/dev/sda
Если это не сработает, вы также можете попробовать:
# syslinux-install_update -i -m
Системы с UEFI
Недостатки UEFI Syslinux
- UEFI Syslinux не может быть подписан (из sbsigntool) для UEFI Secure Boot. Багрепорт: http://bugzilla.syslinux.org/show_bug.cgi?id=8
- Использование TAB при редактировании параметров ядра в меню UEFI Syslinux ведет к "нечитаемому тексту" (строки текста накладываются друг на друга). Багрепорт: http://bugzilla.syslinux.org/show_bug.cgi?id=9
- UEFI Syslinux не поддерживает chainloading других приложений EFI, таких как или
Windows Boot Manager
. Багрепорт: http://bugzilla.syslinux.org/show_bug.cgi?id=17
- UEFI Syslinux может не загружаться в некоторых виртуальных машинах вроде QEMU/OVMF или VirtualBox, в продуктах/версиях VMware, а также в некоторых эмуляторах окружения UEFI, таких как DUET. Участник проекта Syslinux не подтвердил наличие этой проблемы при использовании VMware Workstation 10.0.2 и Syslinux-6.02. Отчеты об ошибках: http://bugzilla.syslinux.org/show_bug.cgi?id=21 и http://bugzilla.syslinux.org/show_bug.cgi?id=23
- Memdisk недоступен для UEFI. Багрепорт: http://bugzilla.syslinux.org/show_bug.cgi?id=30
Установка
- Установите пакеты и из официальных репозиториев. Затем настройте syslinux в Системном Разделе EFI (ESP), как показано ниже
- Скопируйте файлы syslinux в ESP (замените на точку монтирования ESP, обычно это
/boot
):
# mkdir -p $esp/EFI/syslinux # cp -r /usr/lib/syslinux/efi64/* $esp/EFI/syslinux
- Настройте загрузочную запись для Syslinux, используя efibootmgr:
# efibootmgr -c -d /dev/sdX -p 1 -l /EFI/syslinux/syslinux.efi -L "Syslinux"
- Создайте или отредактируйте файл , следуя указаниям из раздела #Настройка
Настройка
Конфигурационный файл Syslinux, syslinux.cfg
, должен быть создан в том же каталоге, в котором установлен Syslinux. В нашем случае это для систем с BIOS и для систем с UEFI.
Загрузчик будет искать как syslinux.cfg
(предпочтительно), так и
Примеры
Приглашение командной строки
Это простой конфигурационный файл, который отобразит приглашение командной строки и выполнит автоматическую загрузку через 5 секунд. Если вы хотите, чтобы загрузка начиналась сразу же, без вывода приглашения, установите параметр в значение .
Конфигурация:
Текстовое меню загрузки
Syslinux также позволяет вам использовать меню загрузки. Для этого скопируйте модуль в ваш каталог Syslinux:
# cp /usr/lib/syslinux/bios/menu.c32 /boot/syslinux/
Конфигурация:
Для получения дополнительных подробностей смотрите документацию по Syslinux или Syslinux wiki.
Графическое меню загрузки
Syslinux также позволяет вам использовать графическое меню загрузки. Для этого скопируйте COM32 модуль vesamenu
в ваш каталог Syslinux:
# cp /usr/lib/syslinux/bios/vesamenu.c32 /boot/syslinux/
В этой конфигурации используется такой же дизайн меню, как и на установочном образе Arch. Ее можно найти по адресу gitlab.archlinux.org. Фоновое изображение Arch Linux можно скачать там же. Скопируйте его в .
Конфигурация:
С версии Syslinux 3.84, поддерживает указание необходимого разрешения через параметр . Для этого вставьте строку в ваш файл конфигурации (в данном примере используется разрешение 1440x900). Фоновое изображение должно иметь такое же разрешение, в противном случае Syslinux откажется загружать меню.
Параметры ядра
Параметры ядра устанавливаются при помощи строки файла syslinux.cfg
. Рекомендуется внести эти изменения, в том числе, и для режима fallback.
В самых простых случаях должно быть изменено лишь имя раздела в параметре root
. Измените на то, что необходимо для указания на верный корневой раздел.
APPEND root=/dev/sda2
Если вы хотите использовать UUID для постоянного именования устройств, а не их номера, измените значение строки , как показано ниже, заменив 1234
на вашего корневого раздела:
APPEND root=UUID=1234 rw
Если вы используете шифрование LUKS, измените строку для использования вашего шифрованного тома:
APPEND root=/dev/mapper/group-name cryptdevice=/dev/sda2:name rw
Если вы используете программный RAID с mdadm, измените строку для указания вашего RAID-массива. В приведенном ниже примере указывается три массива RAID 1, и один из них устанавливается в качестве корневого:
APPEND root=/dev/md1 rw md=0,/dev/sda2,/dev/sdb2 md=1,/dev/sda3,/dev/sdb3 md=2,/dev/sda4,/dev/sdb4
Если загрузка с раздела raid проваливается с использованием kernel device node method, более надежным способом является использование меток разделов:
APPEND root=МЕТКА=МЕТКА_КОРНЕВОГО_РАЗДЕЛА rw
Автозагрузка
Если вы не хотите, чтобы выводилось меню Syslinux, используйте #Приглашение командной строки, при этом установив параметр в значение . Убедитесь, что в вашем syslinux.cfg
указана опция .
Безопасность
Syslinux имеет два уровня безопасности загрузчика: мастер-пароль для всего меню и отдельные пароли для пунктов. В файле syslinux.cfg
используйте
чтобы установить мастер-пароль загрузчика, и
внутри блока , чтобы установить пароль на отдельные пункты загрузки.
Передача управления другому загрузчику (chainloading)
Если вам необходимо передать управление другому загрузчику (например, для загрузки Windows), скопируйте модуль в ваш каталог Syslinux (для получения подробностей прочитайте инструкции из предыдущих разделов). Затем создайте секцию в конфигурационном файле:
hd0 3
— это третий раздел на первом устройстве BIOS. Счет устройств ведется с нуля, а счет разделов на устройствах — с единицы.
Если вы не уверены в том, какое устройство в BIOS считается "первым", вы можете использовать идентификатор MBR, или же, если вы используете GPT, метки файловой системы. Чтобы использовать идентификатор MBR, выполните команду
# fdisk -l /dev/sdb
Disk /dev/sdb: 128.0 GB, 128035676160 bytes 255 heads, 63 sectors/track, 15566 cylinders, total 250069680 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk identifier: 0xf00f1fd3 Device Boot Start End Blocks Id System /dev/sdb1 2048 4196351 2097152 7 HPFS/NTFS/exFAT /dev/sdb2 4196352 250066943 122935296 7 HPFS/NTFS/exFAT
заменив на то устройство, которое вам необходимо. Использование шестнадцатеричного идентификатора диска (Disk identifier) в этом случае в файле syslinux.cfg
будет выглядеть так:
Для получения дополнительных подробностей про chainloading смотрите Syslinux wiki.
Если на том же разделе у вас установлен GRUB, вы можете передать ему управление, используя:
Это может быть необходимо для загрузки из образов ISO.
Chainloading для других систем Linux
Передача управления другому загрузчику, такому, как в Windows, является достаточно тривиальной задачей. Но в Syslinux возможна только загрузка файлов, находящихся на том же разделе, что и конфигурационный файл. Таким образом, если у вас установлена другая система Linux на другом разделе без отдельного /boot
, появляется необходимость в применении Extlinux. По существу, Extlinux может быть установлен в "суперблок" раздела и обозначен, как отдельный загрузчик. Extlinux является частью проекта Syslinux и включен в пакет .
Следующие инструкции подразумевают, что Syslinux у вас уже установлен. Также они подразумевают, что используется типичный путь к конфигурации Arch Linux /boot/syslinux
и разделом для передачи управления является раздел .
Загрузитесь в имеющийся Linux (вероятно, на разделе, который указан в Syslinux для загрузки), примонтируйте другой корневой раздел в желаемую точку монтирования. В данном примере будет использоваться . Также, если вы используете отдельный раздел /boot
во второй операционной системе, он также должен быть примонтирован. В приведенном примере предполагается, что это .
# mount /dev/sda3 /mnt # mount /dev/sda2 /mnt/boot (необходимо только в случае отдельного /boot)
Установите Extlinux и скопируйте необходимые файлы :
# extlinux -i /mnt/boot/syslinux # cp /usr/lib/syslinux/bios/*.c32 /mnt/boot/syslinux
Создайте файл /mnt/boot/syslinux/syslinux.cfg
. Вот пример файла конфигурации:
Взято со страницы пользователя Djgera.
Использование memtest
Установите пакет memtest86+ из официальных репозиториев.
Используйте такую секцию для запуска memtest:
HDT
HDT (Hardware Detection Tool) отображает информацию об аппаратном обеспечении. Как и раньше, файл должен быть скопирован из каталога . Для информации PCI скопируйте файл в и добавьте следующее в ваш конфигурационный файл:
Перезагрузка и выключение
Используйте следующие секции для возможности перезагрузки или выключения вашей машины:
/boot/syslinux/syslinux.cfg
LABEL reboot MENU LABEL Reboot COM32 reboot.c32 LABEL poweroff MENU LABEL Power Off COM32 poweroff.c32
Очистка экрана
Для очистки экрана при выходе из меню добавьте следующую строку:
Раскладка клавиатуры
Если вам часто приходится редактировать параметры загрузки, вы можете захотеть изменить раскладку клавиатуры. Это позволит вам проще вводить "=", "/" и другие символы.
Сначала вы должны создать совместимую раскладку (в данном примере — немецкая):
us.kmap
, иначе эти действия ничего не дадут$ cp /usr/share/kbd/keymaps/i386/qwertz/de.map.gz . $ cp /usr/share/kbd/keymaps/i386/qwerty/us.map.gz . $ gunzip de.map.gz $ gunzip us.map.gz $ mv de.map de.kmap $ mv us.map us.kmap # keytab-lilo de > de.ktl
Скопируйте файл от имени суперпользователя в каталог и назначьте root'a владельцем:
# chown root:root /boot/syslinux/de.ktl
Теперь отредактируйте , добавив:
Скрытие меню
Используйте опцию: чтобы скрыть меню и отображать только таймер. Нажмите любую клавишу в это время, и меню появится на экране.
PXELINUX
PXELINUX предоставляется пакетом .
Скопируйте загрузчик (предоставляемый пакетом syslinux) в boot-каталог клиента. При использовании версии 5.00 (и более новых) также скопируйте ldlinux.c32
из того же пакета:
# cp /usr/lib/syslinux/bios/pxelinux.0 "$root/boot" # cp /usr/lib/syslinux/bios/ldlinux.c32 "$root/boot" # mkdir "$root/boot/pxelinux.cfg"
Мы также создали каталог , в котором PXELINUX по умолчанию ищет конфигурационные файлы. Поскольку мы не хотим иметь различий между разными MAC хоста, мы создаем конфигурацию :
# vim "$root/boot/pxelinux.cfg/default"
default linux label linux kernel vmlinuz-linux append initrd=initramfs-linux.img quiet ip=:::::eth0:dhcp nfsroot=10.0.0.1:/arch
Или, если вы используете NBD, пропишите следующую строку:
PXELINUX использует тот же синтаксис конфигурации, что и SYSLINUX; обратитесь к upstream-документации для получения дополнительной информации.
Ядро и initramfs будут переданы через TFTP, так что пути к ним должны быть прописаны относительно корня TFTP.
Для загрузки pxelinux замените в на
Загрузка файлов образа ISO9660 при помощи memdisk
Syslinux поддерживает прямую загрузку из ISO-образов при помощи модуля memdisk. Для просмотра примеров обратитесь к разделу Использование Syslinux и memdisk.
Решение проблем
Использование приглашения Syslinux
Вы можете ввести имя блока записи, которую вы хотите загрузить (из тех, что указаны в файле syslinux.cfg
). Если вы использовали конфигурации из приведенных примеров, просто напишите:
boot: arch
Если вы получите ошибку о том, что конфигурационный файл не может быть загружен (configuration file could not be loaded), вы можете передать необходимые параметры загрузки, например:
boot: ../vmlinuz-linux root=/dev/sda2 rw initrd=../initramfs-linux.img
Если у вас нет доступа к в ramfs, и, следовательно, временно не можете загрузить ядро:
- 1. Создайте временный каталог, чтобы примонтировать ваш корневой раздел (если он еще не существует):
# mkdir -p /new_root
- 2. Примонтируйте в
/new_root
(в случае, если находится на том же разделе; иначе вам придется монтировать и то, и другое):
# mount /dev/sd[a-z][1-9] /new_root
- 3. Используя , отредактируйте
syslinux.cfg
опять, чтобы он удовлетворял вашим потребностям, и сохраните файл - 4. Выполните перезагрузку
Fsck не работает на корневом разделе
Если журнал корневой файловой системы поврежден, в ramfs emergency shell примонтируйте корневую файловую систему:
# mount /dev/корневой раздел /new_root
И возьмите оттуда двоичный файл tune2fs (он не включен в состав Syslinux):
# cp /new_root/sbin/tune2fs /sbin/
Следуйте инструкциям в fsck#ext2fs: no external journal для создания нового журнала корневого раздела.
No Default or UI found on some computers
Некоторые производители материнских плат предоставляют меньшую совместимость загрузки с устройств USB, чем другие. В то время, как устройства USB, отформатированные в ext4, могут загружаться на более свежих компьютерах, некоторые машины могут зависнуть, если загрузочный раздел, содержащий ядро и initrd, не является разделом FAT16. Для предотвращения загрузки на более старых машинах и провала чтения syslinux.cfg
, используйте , чтобы создать раздел FAT16 (<=2GB), и отформатируйте его при помощи пакета :
# mkfs.msdos -F 16 /dev/sda1
Затем установите и настройте Syslinux.
Missing operating system
Если вы видите это сообщение, удостоверьтесь, что разделу, содержащему /boot
, присвоен boot-флаг. Если флаг включен, возможно, раздел начинается с сектора 1, а не с 63 или 2048. Проверьте это с помощью fdisk -l
. Если предположение верно, вы можете передвинуть раздел(ы) при помощи с диска восстановления. Или же, если у вас отдельный загрузочный раздел, вы можете создать резервную копию /boot
при помощи
# cp -a /boot /boot.bak
а затем загрузиться с установочного образа Arch. Далее используйте , чтобы удалить раздел /boot
и создать его заново. Теперь он должен начинаться с правильного сектора, 63. Примонтируйте ваши разделы и выполните chroot. Восстановите /boot
следующей командой:
# cp -a /boot.bak/* /boot
Проверьте правильность файла , выполните:
# syslinux-install_update -iam
и перезагрузитесь.
Вы также получите это сообщение об ошибке, если пытаетесь загрузиться с массива RAID 1 и создали массив с слишком новой версией метаданных, которую Syslinux не понимает. По состоянию на август 2013 года по умолчанию mdadm создаст массив с версией 1.2 метаданных, но Syslinux не понимает версии, новее 1.0. В этом случае вам необходимо пересоздать массив RAID, используя флаг в mdadm.
Windows загружается, игнорируя Syslinux
Решение: Убедитесь, что разделу, содержащему /boot
, присвоен boot-флаг. Также убедитесь, что этот флаг не включен на разделе с Windows. Смотрите раздел установки выше.
MBR, идущий в Syslinux, ищет первый активный раздел, имеющий boot-флаг. Раздел с Windows, вероятно, был найден первым и имел этот флаг.
После выбора пункта меню ничего не происходит
Вы выбираете пункт меню, и ничего не происходит, экран только "обновляется". Обычно это означает, что в файле syslinux.cfg
имеется ошибка. Нажмите для редактирования параметров загрузки. В качестве альтернативы, вы можете нажать Esc
и прописать имя блока вашей загрузочной записи (например, arch). Другой причиной может быть то, что у вас не установлено ядро. Найдите способ получить доступ к вашей файловой системе (например, используя live CD), удостоверьтесь, что файл существует и имеет ненулевой размер. Если это не так, переустановите ядро.
Невозможно удалить ldlinux.sys
Файл имеет защитный атрибут, предотвращающий его удаление или перезапись. Это сделано потому, что расположение файла не должно меняться, иначе Syslinux должен быть переустановлен. Чтобы удалить его, выполните:
# chattr -i /boot/syslinux/ldlinux.sys # rm /boot/syslinux/ldlinux.sys
Белый блок в верхнем левом углу при использовании vesamenu
Проблема: По состоянию на linux-3.0, драйвер modesetting пытается сохранять текущее содержимое экрана после смены разрешения (по крайней мере, это происходит с моим Intel, когда Syslinux работает в текстовом режиме). Возникает ошибка с комбинированием модуля vesamenu в Syslinux (белый блок — попытка сохранить меню Syslinux, но драйвер не может "ухватить" картинку из графического режима vesa).
Если у вас прописано свое разрешение и vesamenu
с ранним modesetting, попробуйте проделать следующее с вашим syslinux.cfg
для удаления белого блока и продолжения вывода графического режима:
APPEND root=/dev/sda6 rw 5 vga=current quiet splash
Chainloading Windows не работает, когда она установлена на другом диске
Если Windows установлена не на том диске, на котором установлен Arch, и у вас возникает проблема с передачей управления другому загрузчику, попробуйте следующую конфигурацию:
LABEL Windows MENU LABEL Windows COM32 chain.c32 APPEND mbr:0xdfc1ba9e swap
Замените код mbr тем, что есть на диске с windows (детали выше), и добавьте в опции.
Чтение логов загрузчика
В некоторых случаях, например, когда загрузчику не удается загрузить ядро, крайне желательно узнать дополнительную информацию о процессе загрузки. Syslinux отображает сообщения об ошибках на экране, но появляющееся меню быстро их скрывает. Чтобы избежать этого, необходимо отключить в syslinux.cfg
и использовать приглашение по умолчанию — "command-line". Это означает:
- Отменить указание UI
- Отменить ONTIMEOUT
- Отменить ONERROR
- Отменить MENU CLEAR
- Использовать больший TIMEOUT
- Использовать PROMPT 1
- Использовать DEFAULT <problematic_label>
Для получения более информативных отладочных сообщений необходимо перекомпилировать пакет с дополнительными CFLAGS:
-DDEBUG_STDIO=1 -DCORE_DEBUG=1