Make-initrd development discussion
 help / color / mirror / Atom feed
From: Alexey Gladkov <legion@kernel.org>
To: make-initrd@lists.altlinux.org
Subject: Re: [make-initrd] Possible missing firmware
Date: Sat, 5 Jul 2025 17:00:23 +0200
Message-ID: <aGk-B9mghig2sQqw@example.org> (raw)
In-Reply-To: <73b7d08b-5a20-4dfb-86df-0471151708c6@gmail.com>

On Sat, Jul 05, 2025 at 04:04:05PM +0300, Leonid Krivoshein wrote:
> > Прошу, потому что из тех сообщений об ошибках я себе нафантазировал одно,
> > а ты и Антон думаете скорее всего про другое.
> 
> Пакеты с firmware и пакеты с ядрами сопровождаются разными людьми, они 
> обновляются не синхронно, не согласованно.

Ну то есть проблема всё-таки организационная. Из-за несогласованности
мантейнеров пакетов страдают пользователи.

> О проблемах разъезда путей в ядре и соответствующей firmware мы всегда
> узнаём постфактум по соответствующим багам,

Что ты имеешь в виду под разъездом путей ?

/lib/firmware/nvidia/470.256.02/gsp.bin
/lib/firmware/nvidia/570.169/gsp_ga10x.bin
/lib/firmware/nvidia/570.169/gsp_tu10x.bin

Ты про вот такие пути, где есть версия ? Это единственный пример с
проблемными путями, который я смог придумать.

> когда новое initrd уже сгенерировано и не получилось загрузиться или
> получилось, но эта новая связка создала проблемы при дальнейшей работе.
> Мы могли бы выявлять потенциальные проблемы уже на этапе создания
> initrd. А без реализации предлагаемого мы не сможем даже примерно
> оценить масштаб этой проблемы для будущих обновлений. Поэтому я считаю,
> что такой инструмент был бы полезным. Хотя бы подсчитывать число
> предупреждений без вывода их в stderr, если не указан "-v".

Я считаю, что никто из пользователей не будет смотреть на эти
предупреждения об отсутствующих firmware.

Пользователю не ясно какие firmware необходимы, а какие нет. Список в
десяток или сотни строк про отсутствующие чего-то-там никак пониманию не
помогут. Непонятно, что делать пользователю, если он такое видит. Если это
ошибка, то это должно быть ошибкой.

Я уже не говорю, про обновления через gui всякие, где выхлопа от генерации
initrd вообще не видно. Например на моей системе это вообще происходит в
бэкграунде, не смотря что обновление не через gui происходит.

Вот варианты решения проблемы в порядке трудозатратности.

1. Добавить в depinfo режим отображения отсутствующих firmware и
использовать эту утилиту для проверки при сборки пакетов с
модулями/firmware. Так как именно при сборке пакета ломается загрузка.

module /lib/modules/6.15.4-gentoo-dist/kernel/drivers/net/wireless/realtek/rtlwifi/rtlwifi.ko
   \_ module /lib/modules/6.15.4-gentoo-dist/kernel/net/wireless/cfg80211.ko
      \_ missing-firmware regulatory.db
      \_ missing-firmware regulatory.db.p7s
      \_ module /lib/modules/6.15.4-gentoo-dist/kernel/net/rfkill/rfkill.ko
   \_ module /lib/modules/6.15.4-gentoo-dist/kernel/net/mac80211/mac80211.ko
      \_ module /lib/modules/6.15.4-gentoo-dist/kernel/lib/crypto/libarc4.ko

2. Поскольку не существует хорошего способа определить необходимые
firmware, то можно сделать режим, в котором будут требоваться _все_
firmware для пакуемых модулей.

3. Можно сделать фичу по определению firmware требовавшихся для загрузки
текущего ядра и пробовать использовать эту информацию. В этом случае можно
будет по аналогии с MODULES_ADD добавить контроль за необходимыми
firmware.
Из минусов, что это всё ещё хак по определению требуемых firmware и всё
равно нужно будет решать задачу с путями.

-- 
Rgrds, legion



  reply	other threads:[~2025-07-05 15:00 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-07-02 23:37 Leonid Krivoshein
2025-07-04 10:42 ` Alexey Gladkov
2025-07-04 10:43   ` Anton Midyukov
2025-07-04 11:38     ` Alexey Gladkov
2025-07-04 13:20       ` Alexey Gladkov
2025-07-04 15:03         ` Alexey Gladkov
2025-07-04 15:23           ` Leonid Krivoshein
2025-07-04 18:23             ` Alexey Gladkov
2025-07-05  0:47               ` Leonid Krivoshein
2025-07-05  8:36                 ` Alexey Gladkov
2025-07-05 13:04                   ` Leonid Krivoshein
2025-07-05 15:00                     ` Alexey Gladkov [this message]
2025-07-05 22:40                       ` Leonid Krivoshein
2025-07-05 23:57                         ` Alexey Gladkov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=aGk-B9mghig2sQqw@example.org \
    --to=legion@kernel.org \
    --cc=make-initrd@lists.altlinux.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

Make-initrd development discussion

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/make-initrd/0 make-initrd/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 make-initrd make-initrd/ http://lore.altlinux.org/make-initrd \
		make-initrd@lists.altlinux.org make-initrd@lists.altlinux.ru make-initrd@lists.altlinux.com
	public-inbox-index make-initrd

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.make-initrd


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git