Bug 24114 - Version upgrade problems on systems with non-embeded core.img
Summary: Version upgrade problems on systems with non-embeded core.img
Status: CLOSED FIXED
Alias: None
Product: Sisyphus
Classification: Development
Component: grub2 (show other bugs)
Version: unstable
Hardware: all Linux
: P3 normal
Assignee: Vitaly Kuznetsov
QA Contact: qa-sisyphus
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2010-09-19 22:17 MSD by Nikolay A. Fetisov
Modified: 2012-11-04 14:34 MSK (History)
3 users (show)

See Also:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
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 постарался хотя бы сделать несколько более заметным).