[make-initrd] initramfs with libsystemd-shared.so

Alexey Gladkov legion at kernel.org
Thu Dec 5 17:57:36 MSK 2024


Привет!

Обратил внимание, что у меня создаётся образ через чур большого размера.
После некоторого расследования выяснил, что виноват b68f4cade4 ("dissect:
add --make-archive option to convert DDI to tarball") из репозитория
systemd. Он добавляет опциональную зависимость на libarchive, который в
свою очередь вытягивает libstdc++.so.6 и libxml2.so.2 и много чего ещё.

Поскольку initrd-put умеет и по умолчанию кладёт все зависимости, то в
образ приезжает libarchive. Обрабатывать такие зависимости необходимо
потому что среди них теперь libkmod.

Есть костыль, который позволит избавиться от такой зависимости.

$ diff -U0 /etc/initrd.mk.{before,after}
--- /etc/initrd.mk.before       2024-12-05 15:11:08.042256261 +0100
+++ /etc/initrd.mk.after        2024-12-05 15:12:07.735018593 +0100
@@ -11,0 +12,2 @@
+
+IGNORE_PUT_DLOPEN_FEATURE = archive

$ make-initrd -D -c /etc/initrd.mk.before 
...
[00:00:56] Unpacked size: 246M
[00:00:56] Image size: 75M
...

$ make-initrd -D -c /etc/initrd.mk.after
...
[00:00:45] Unpacked size: 194M
[00:00:45] Image size: 63M
...

К сожалению, эти переменные не учитывают имя бинарника, где требуется
выключить зависимость по имени или приоритету. Я пока не придумал как это
адекватно описывать. К счастью такие опциональные зависимости сейчас есть
только у одной библиотеки libsystemd-shared.so .

-- 
Rgrds, legion



More information about the Make-initrd mailing list