<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>51479</bug_id>
          
          <creation_ts>2024-09-14 18:24:11 +0300</creation_ts>
          <short_desc>После загрузки live в режиме rw пропадает флаг boot с PMBR</short_desc>
          <delta_ts>2024-10-03 11:50:59 +0300</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>make-initrd-bootchain-liverw</component>
          <version>unstable</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>FIXED</resolution>
          
          <see_also>https://bugzilla.altlinux.org/show_bug.cgi?id=51485</see_also>
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P5</priority>
          <bug_severity>normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Антон Мидюков">antohami</reporter>
          <assigned_to name="Leonid Krivoshein">klark</assigned_to>
          <cc>antohami</cc>
    
    <cc>asy</cc>
    
    <cc>klark</cc>
    
    <cc>zerg</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>251606</commentid>
    <comment_count>0</comment_count>
    <who name="Антон Мидюков">antohami</who>
    <bug_when>2024-09-14 18:24:11 +0300</bug_when>
    <thetext>Имеем проблему у iso-образов с таблицей разделов GPT. После загрузки live в режиме rw пропадает флаг boot с PMBR. Из-за этого невозможно загрузиться на старых BIOS, так как они грузятся с тех MBR, на которых есть флаг boot.
Если смотреть fdisk&apos;ом, то выглядит это так:
Команда (m для справки): M

Ввод метки наследственного/гибридного MBR.

Команда (m для справки): p
Диск /dev/sda: 29,76 GiB, 31954556416 байт, 62411243 секторов
Единицы: секторов по 1 * 512 = 512 байт
Размер сектора (логический/физический): 512 байт / 512 байт
Размер I/O (минимальный/оптимальный): 512 байт / 512 байт
Тип метки диска: dos
Идентификатор диска: 0x00000000

Устр-во    Загрузочный начало    Конец  Секторы Размер Идентификатор Тип
/dev/sda1                   1 62411242 62411242  29,8G            ee GPT
/dev/sda2  *                0        0        1   512B             0 Пустой

После загрузки в режиме rw (режим сохранения сеанса), запись /dev/sda2 из MBR пропадает.
Это не регрессия относительно propagator, там происходит ровно тоже.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251609</commentid>
    <comment_count>1</comment_count>
    <who name="Sergey Y. Afonin">asy</who>
    <bug_when>2024-09-14 20:46:34 +0300</bug_when>
    <thetext>Когда-то, дежавю подсказывает, что во времена 4-го бранча примерно, такая проблема появилась в BIOS Intel. То есть без такого флага на любом разделе BIOS даже не пытаестя грузить MBR с hdd. На не Intel всё грузилось. Вроде бы даже баг был, но что-то не найду, а может и в раасылке обсуждали без бага.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251637</commentid>
    <comment_count>2</comment_count>
    <who name="Leonid Krivoshein">klark</who>
    <bug_when>2024-09-15 16:40:01 +0300</bug_when>
    <thetext>(In reply to Антон Мидюков from comment #0)
&gt; запись /dev/sda2 из MBR пропадает.
Из защитного MBR с гибридной GUID/GPT-разметкой. И это не влияет на загрузку в режиме Legacy и UEFI, я проверил на виртуалке. По стандарту и не должно влиять.

Но оказалось, что некоторые старые BIOS (до 2010 года) пытаются проанализировать загрузочный сектор и отказываются загружать его, если он не содержит загрузочного раздела MBR. Хотя это проблема BIOS, исправление понятно, как реализовать: https://wiki.archlinux.org/title/Partitioning#Tricking_old_BIOS_into_booting_from_GPT -- проверил, и это работает. Теперь нужно лишь определить, в каких случаях следует применять данный хак.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251638</commentid>
    <comment_count>3</comment_count>
    <who name="Антон Мидюков">antohami</who>
    <bug_when>2024-09-15 18:34:41 +0300</bug_when>
    <thetext>(Ответ для Leonid Krivoshein на комментарий #2)
&gt; (In reply to Антон Мидюков from comment #0)
&gt; &gt; запись /dev/sda2 из MBR пропадает.
&gt; Из защитного MBR с гибридной GUID/GPT-разметкой. И это не влияет на загрузку
&gt; в режиме Legacy и UEFI, я проверил на виртуалке. По стандарту и не должно
&gt; влиять.
&gt; 
&gt; Но оказалось, что некоторые старые BIOS (до 2010 года) пытаются
&gt; проанализировать загрузочный сектор и отказываются загружать его, если он не
&gt; содержит загрузочного раздела MBR. Хотя это проблема BIOS, исправление
&gt; понятно, как реализовать:
&gt; https://wiki.archlinux.org/title/
&gt; Partitioning#Tricking_old_BIOS_into_booting_from_GPT -- проверил, и это
&gt; работает. Теперь нужно лишь определить, в каких случаях следует применять
&gt; данный хак.

После создания раздела создавать, если таблица разделов gpt.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251640</commentid>
    <comment_count>4</comment_count>
    <who name="Sergey Y. Afonin">asy</who>
    <bug_when>2024-09-15 19:57:16 +0300</bug_when>
    <thetext>(In reply to Leonid Krivoshein from comment #2)

&gt; Но оказалось, что некоторые старые BIOS (до 2010 года) пытаются
&gt; проанализировать загрузочный сектор и отказываются загружать его, если он не
&gt; содержит загрузочного раздела

Если бы некоторные, а то поголовно весь Intel. И я не уверен, что &quot;до 2010&quot;. Это что касается hdd. С флешкой вот только сейчас нарвался, но очень похоже на то же самое.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251641</commentid>
    <comment_count>5</comment_count>
    <who name="Leonid Krivoshein">klark</who>
    <bug_when>2024-09-15 20:39:33 +0300</bug_when>
    <thetext>(In reply to Антон Мидюков from comment #3)
&gt; (Ответ для Leonid Krivoshein на комментарий #2)
&gt; &gt; нужно лишь определить, в каких случаях следует применять данный хак.
&gt; После создания раздела создавать, если таблица разделов gpt.
Поскольку в данном случае затирается вторая запись таблицы MBR, очевидно, это не стоит делать во всех случаях. Видимо нужно дважды проверить. Первый раз -- до внесения изменений и второй раз -- после. И только если такая запись была и исчезла, тогда уже её создавать. Разумеется, при наличии сигнатуры GUID/GPT.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251645</commentid>
    <comment_count>6</comment_count>
    <who name="Leonid Krivoshein">klark</who>
    <bug_when>2024-09-16 01:09:31 +0300</bug_when>
    <thetext>Собрал task #357588 с попыткой пофиксить. Одной проверки оказалось достаточно, т.к. если всё было правильно, понятно, что команды удалят второй раздел.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251646</commentid>
    <comment_count>7</comment_count>
    <who name="Антон Мидюков">antohami</who>
    <bug_when>2024-09-16 03:15:26 +0300</bug_when>
    <thetext>(Ответ для Leonid Krivoshein на комментарий #6)
&gt; Собрал task #357588 с попыткой пофиксить. Одной проверки оказалось
&gt; достаточно, т.к. если всё было правильно, понятно, что команды удалят второй
&gt; раздел.

Работает. Проверял iso-шку.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251654</commentid>
    <comment_count>8</comment_count>
    <who name="Sergey Y. Afonin">asy</who>
    <bug_when>2024-09-16 10:35:18 +0300</bug_when>
    <thetext>(In reply to Антон Мидюков from comment #7)

&gt; &gt; Собрал task #357588 с попыткой пофиксить. Одной проверки оказалось
&gt; &gt; достаточно, т.к. если всё было правильно, понятно, что команды удалят второй
&gt; &gt; раздел.
&gt; 
&gt; Работает. Проверял iso-шку.

На том компьютере, где раньше не грузилось? Если нет, то в https://nightly.altlinux.org/p11/beta/ можно положить?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251660</commentid>
    <comment_count>9</comment_count>
    <who name="Антон Мидюков">antohami</who>
    <bug_when>2024-09-16 11:15:23 +0300</bug_when>
    <thetext>(Ответ для Sergey Y. Afonin на комментарий #8)
&gt; (In reply to Антон Мидюков from comment #7)
&gt; 
&gt; &gt; &gt; Собрал task #357588 с попыткой пофиксить. Одной проверки оказалось
&gt; &gt; &gt; достаточно, т.к. если всё было правильно, понятно, что команды удалят второй
&gt; &gt; &gt; раздел.
&gt; &gt; 
&gt; &gt; Работает. Проверял iso-шку.
&gt; 
&gt; На том компьютере, где раньше не грузилось? Если нет, то в
&gt; https://nightly.altlinux.org/p11/beta/ можно положить?

https://nightly.altlinux.org/sisyphus/archive/regular-lxqt-20240916-x86_64.iso</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251661</commentid>
    <comment_count>10</comment_count>
    <who name="Sergey Y. Afonin">asy</who>
    <bug_when>2024-09-16 11:44:26 +0300</bug_when>
    <thetext>(In reply to Антон Мидюков from comment #9)

&gt; &gt; На том компьютере, где раньше не грузилось? Если нет, то в
&gt; &gt; https://nightly.altlinux.org/p11/beta/ можно положить?
&gt; 
&gt; https://nightly.altlinux.org/sisyphus/archive/regular-lxqt-20240916-x86_64.iso

Да, грузится теперь.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>251668</commentid>
    <comment_count>11</comment_count>
    <who name="Repository Robot">repository-robot</who>
    <bug_when>2024-09-16 16:33:57 +0300</bug_when>
    <thetext>make-initrd-bootchain-0.1.5-alt25 -&gt; sisyphus:

 Mon Sep 16 2024 Leonid Krivoshein &lt;klark@altlinux&gt; 0.1.5-alt25
 - tricking old BIOS into booting from GPT (ALT #51479)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>252493</commentid>
    <comment_count>12</comment_count>
    <who name="Sergey Y. Afonin">asy</who>
    <bug_when>2024-10-03 11:50:59 +0300</bug_when>
    <thetext>[cyber] I: p11/branch packages: +4 (19461)
Date: 03/10/24 04:16

make-initrd-bootchain - bootchain modules set for make-initrd
* Mon Sep 16 2024 Leonid Krivoshein &lt;klark@altlinux&gt; 0.1.5-alt25
- tricking old BIOS into booting from GPT (ALT #51479)
* Sun Sep 01 2024 Leonid Krivoshein &lt;klark@altlinux&gt; 0.1.5-alt24
- added asciidoc sources of the reference guide
* Thu Mar 07 2024 Leonid Krivoshein &lt;klark@altlinux&gt; 0.1.5-alt23

Может стартеркиты p11 пересоздать, не дожидаясь зимы?</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>