AlteratorLilo: различия между версиями

Материал из ALT Linux Wiki
Строка 48: Строка 48:
   
   
* Варианты установки загрузчика:
* Варианты установки загрузчика:
- без root on raid:
** все жесткие диски
    * все жесткие диски
** раздел, на котором находится /boot
    * раздел, на котором находится /boot
** (!) раздел на который ставится загрузчик в существующем lilo.conf (если отличается от предыдущих пунктов)
    * (!) раздел на который ставится загрузчик в существующем lilo.conf
      (если отличается от предыдущих пунктов)
- root on raid
    * (!?)в инсталяторе не показывать никакой вариант, кроме этого raid.
      (на все остальное lilo ругается из-за кривого состояния evms+dm+raid)
* Варианты загрузки -- неизменный список!
* Варианты загрузки -- неизменный список!
* combobox "Загружать по умолчанию"
* combobox "Загружать по умолчанию"
* combobox "Время ожидания"
* combobox "Время ожидания"
* кнопки "Применить" "Режим эксперта"
* кнопки "Применить" "Режим эксперта"
М.б пока не показывать никакие варианты кроме root on raid в инсталяторе?.. (на все остальное lilo ругается из-за кривого состояния evms+dm+raid)


===Политика работы с секциями===
===Политика работы с секциями===

Версия от 11:42, 30 октября 2008

Freesource-logo.png Blue Glass Arrow.svg MediaWiki logo.png
Эта страница была перемещена с freesource.info.
Эта страница наверняка требует чистки и улучшения — смело правьте разметку и ссылки.
Просьба по окончанию убрать этот шаблон со страницы.


Alterator-Lilo

В данный момент бэкенд alterator-lilo очень запутан и требует переделки. (Из-за существенной модификации интерфейса и довольно неаккуратной правки бэкенда, чтоб он этому интерфейсу соответствовал). Попробую cобрать здесь план нового бакенда...

(!) -- в существующем alterator-lilo пока нет


on_start()

  • собираем инфу по системе
 * варианты установки загрузчика
   * все диски, без raid и removable!
     * удобно получать у hal'a
   * раздел, на котором находится /boot
     * в т.ч. raid
     * грабли с raid под evms! Находится /dev/evms/md/md0, которого в системе не будет, непонятно как преобразовать его к /dev/md0 (который есть, но на которого нет ссылок из /dev/disk/* и про который не знает blkid и hal). Сейчас /evms/md просто отрезается...
 * рекомендуемое место для загрузчика
   * первый диск или raid, если на нем /boot
 * поиск других ОС
    - найти все разделы всех дисков
    - исключить свой раздел
    - поискать загрузчик, определить тип ОС
    - (!) здесь сделать только заготовки названий, а умное добавление уникальных чисел делать позже!.
  • читаем lilo.conf
 * если есть системый,
      берем его - нормализуем - чиним (применяем недостающие значения)
 * иначе - берем template - применяем рекомендуемые значение

on_read()

 * simple
 * expert
 * rawfile
   * генерим и отдаем форматированный lilo.conf

on_write()

 * simple
   * выставлять raid-extra-boot!.
 * expert
 * rawfile

on_list()

Простой интерфейс

  • Варианты установки загрузчика:
    • все жесткие диски
    • раздел, на котором находится /boot
    • (!) раздел на который ставится загрузчик в существующем lilo.conf (если отличается от предыдущих пунктов)
  • Варианты загрузки -- неизменный список!
  • combobox "Загружать по умолчанию"
  • combobox "Время ожидания"
  • кнопки "Применить" "Режим эксперта"

М.б пока не показывать никакие варианты кроме root on raid в инсталяторе?.. (на все остальное lilo ругается из-за кривого состояния evms+dm+raid)

Политика работы с секциями

В начале работы производится поиск других ОС. Кроме того, существует текущая конфигурация с какими-то своими секциями.

  • В экспертном интерфейсе показываются секции из конфигурационного файла, с возможностью добавлять и удалять вручную. Список найденных ОС никак не используется
  • В простом интерфейсе показывается список секций из конфигурационного файла + непересекающиеся с ним по именам устройств секции для найденных ОС. Checkbox'ами отмечено то, что включено в текущую конфигурацию. При генерации этого слитого списка происходит умная расстановка чисел в названия автоматически определенных секций (все имена должны быть уникальны).

Защита имен устройств

Что-то типа такого: /dev/sda <-> /dev/disk/by-id/scsi-SATA_ST3250820AS_5QE2FCJP

Видимо, надо выполнять преобразование при сборке/разборке lilo.conf. Чтоб в простом и экспертном интерфейсе мы оперировали с /dev/sda, а в lilo.conf (и в режиме редактирования lilo.conf) -- с disk by id... (При этом, разумеется, ничто не мешает читать из lilo.conf /dev/sda и др., или писать в экспертном интерфейсе disk by id)

Вопрос с root device. Надо ли, как это сейчас сделано, указывать его по uuid, или же для единообразия писать туда /dev/sda1 и, как и другие имена устройств, защищать с помощью /dev/disk/by-id (или /dev/disk/by-uuid)?

(сейчас все сделано немного не так...)

Расстановка bootable-флагов

  • Если загрузчик ставится на primary-раздел и на диске нет ни одного bootable-раздела -- ставлю флаг на этот раздел
  • Если загрузчик ставится на extended-раздел или в MBR и на диске нет ни одного bootable-раздела -- ставлю флаг на первый раздел диска
  • Если загрузчик ставится на raid -- произвожу эти действия для каждого из элементов raid'a.

Существующий код меня вполне устраивает.

странные грабли

  • Если у нас root на raid под evms, то lilo не хочет ставить загрузчик ни на что, кроме raid (кажется, evms делает какое-то полусломанное состояние dm-устройств). Видимо из-за этого же raid под evms не виден ни в hal ни в /dev/disk/*, blkid его как-то тоже странно понимает.
  • hal не может определить id и flags и для некоторых разделов