Bug 24114

Summary: Version upgrade problems on systems with non-embeded core.img
Product: Sisyphus Reporter: Nikolay A. Fetisov <naf>
Component: grub2Assignee: Vitaly Kuznetsov <vitty>
Status: CLOSED FIXED QA Contact: qa-sisyphus
Severity: normal    
Priority: P3 CC: boyarsh, evg, mike
Version: unstable   
Hardware: all   
OS: Linux   

Description Nikolay A. Fetisov 2010-09-19 22:17:03 MSD
На системах с нестандартным числом секторов на дорожке, в частности, с контроллерами HP Smart Array (с геометрией дисков 255 heads, 32 sectors/track), невозможно разместить core.img в свободных секторах после MBR - см. http://lists.altlinux.org/pipermail/sisyphus/2010-April/346722.html и #23308

Установка Grub2 на таких системах проводится с использованием blocklists, через 
grub-install --force '(hd0)'

Обновление пакета с предыдущих версий до текущей 1.98-alt16.20100804 меняет расположение core.img. Как следствие, при следующей перезагрузке системы Grub не может загрузить core.img и выходит в rescue mode.

Для корректного обновления Grub2 при использовании blocklists требуется повторная установка загрузчика через grub-install, без этого обновление пакета приводит к невозможности последующей загрузки системы без доступа к консоли.
Comment 1 Vitaly Kuznetsov 2010-09-20 17:32:47 MSD
А видится ли какое-то решение данной проблемы? В момент обновления пакета достаточно сложно определить куда и каким образом был установлен grub.
Comment 2 Nikolay A. Fetisov 2010-09-29 12:04:58 MSD
У меня красивых идей пока нет.

С другой стороны, рано или поздно выйдет новая версия Grub - и тогда вопрос определения, куда установлен загрузчик, станет очень актуальным. Сейчас, из rescue mode, ещё можно найти диск с /boot/grub, подгрузить модули и загрузить ядро. При несовпадении версий загрузчика в нулевом цилиндре и обновлённых модулей к нему в системе, думаю, такое уже не получится.

Из некрасивых идей: вносить grub2 в Allow-Duplicated, класть для каждого релиза пакета модули и прочее в отдельные каталоги в /boot, типа 
/boot/grub-1.98-alt16.20100804/, и отдавать переустановку загрузчика полностью на откуп пользователям.
Comment 3 Evgenii Terechkov 2010-09-29 15:05:54 MSD
А в других дистрибутивах что, не заморачивались с таким?
Comment 4 Repository Robot 2010-10-05 00:41:12 MSD
grub2-1.98-alt18.20100804 -> sisyphus:

* Mon Oct 04 2010 Vitaly Kuznetsov <vitty@altlinux> 1.98-alt18.20100804
- add GRUB_AUTOUPDATE_DEVICE and GRUB_AUTOUPDATE_FORCE options for
  automatic grub update (ALT #24114)
Comment 5 Vitaly Kuznetsov 2010-10-05 08:43:34 MSD
Поясню по исправлению: теперь в /etc/sysconfig/grub2 можно задать опции GRUB_AUTOUPDATE_DEVICE и GRUB_AUTOUPDATE_FORCE для автообновления grub. Более того, alterator-grub обучен это делать.
Comment 6 Nikolay A. Fetisov 2010-10-06 15:55:44 MSD
Проверил - похоже, обновилось нормально.
Спасибо.
Comment 7 Michael Shigorin 2012-11-04 14:34:17 MSK
(In reply to comment #2)
> С другой стороны, рано или поздно выйдет новая версия Grub
Предлагаю заинтересованным обратить внимание на bug #27916.

Пока из мыслей -- в posttrans trigger делать дополнительную проверку на наличие ^GRUB_AUTOUPDATE_DEVICE в /etc/sysconfig/grub2; если не нашлось, выдавать рекомендации для copy-paste после обдумывания (т.к. вывод grub-autoupdate в %post при dist-upgrade может уехать незамеченным с учётом его скромности -- в 2.00-alt2 постарался хотя бы сделать несколько более заметным).