From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on sa.local.altlinux.org X-Spam-Level: X-Spam-Status: No, score=-3.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,RP_MATCHES_RCVD autolearn=ham autolearn_force=no version=3.4.1 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=basealt.ru; s=dkim; t=1732444488; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=XDjqmmPE+LZcHGq9FCbx9No3chuZulh3WMkvuZh8NnU=; b=srEnlMJT7QoTLLXIoTj3gXcBTcTrKvfaThXq25yEQXhdw82rz6pj/bT/OrJmwgrZttpG5F y4R0/Efe039H5rBT3/NTEThHZtvOOpGTAj0nFktdHszapXMXlz43Ti6Fe5dZjxeEWPNsHu s6YWAB+N66jP63wU/NMfcTnvx/PD8C2NuCyMoKJNbyTQ54rfrWiXtSGE1HtD+DOm4cIffr Jz7yqcWxd7eqVDpFSKSBjByD3usVl5GfTd3rjlbe1vgwB6S4AHkEC2ne/Suu5GJhwpaL/A gZPLijQTgf2/OljnvAvEipDdDHeadNNpI4HVZHt9A4rj0nrB6CjIuVK6elDqqw== Message-ID: <27e1acdc-8776-4089-831d-693dedc642cd@basealt.ru> Date: Sun, 24 Nov 2024 13:34:46 +0300 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird To: make-initrd@lists.altlinux.org References: <20241116122309.df5fdad73578af49341206ad@basealt.ru> <8a849bcc-e792-40e5-a558-6c8693935278@basealt.ru> Content-Language: ru From: =?UTF-8?B?0JDQvdGC0L7QvSDQnNC40LTRjtC60L7Qsg==?= In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Subject: Re: [make-initrd] =?utf-8?b?0KDQsNGB0YjQuNGA0LXQvdC40LUg0YDQsNC30LQ=?= =?utf-8?b?0LXQu9CwINGBINC60L7RgNC90LXQvA==?= X-BeenThere: make-initrd@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: make-initrd@lists.altlinux.org List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 24 Nov 2024 10:34:51 -0000 Archived-At: List-Archive: 23.11.2024 20:59, Alexey Gladkov пишет: > On Sat, Nov 23, 2024 at 05:18:28PM +0300, Антон Мидюков wrote: >> 16.11.2024 16:28, Alexey Gladkov пишет: >>> On Sat, Nov 16, 2024 at 12:23:09PM +0700, Egor Shestakov wrote: >>>> Всем привет! >>>> >>>> Есть ли у initrd возможность штатными средствами расширить раздел >>>> с корнем на всё свободное место? Это необходимо после установки образа >>>> системы на sd-карточку. Фича kickstart вроде умеет создавать разделы, но >>>> как с ним работать не понятно, и можно ли её использовать на уже >>>> установленной системе? >>> >>> Это можно сделать через kickstart. У команды partition есть опция --grow [1]. >>> Вот тут [2] есть пример использования. Чтобы расширить существующий раздел >>> нужно использовать опцию --resize. >>> >>> [1] https://github.com/osboot/make-initrd/wiki/feature-kickstart#part-or-partition >>> [2] https://github.com/osboot/make-initrd/blob/master/testing/test-root-efi-partition.cfg >>> >> >> Я попробовал. Столкнулся с проблемами. >> >> 1. Какой-то не такой readlink используется в initrd, который не знает опцию -e. >> Обошёл так: >> diff --git a/make-initrd/features/kickstart/data/bin/kickstart-sh-storage b/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> index 2cd7b12c..de9b9c1a 100644 >> --- a/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> +++ b/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> @@ -820,7 +825,7 @@ part() >> local partnum >> read -r partnum < "/sys/class/block/$partdev/partition" >> >> - dev="$(readlink -ev "/sys/class/block/$partdev")" >> + dev="$(readlink -v "/sys/class/block/$partdev")" >> dev="${dev%/*}" >> dev="${dev##*/}" > > Да, я с этим уже сталкивался. У меня даже есть враппер для этого: > > https://github.com/osboot/make-initrd/blob/master/runtime/data/bin/readlink-e > > В busybox readlink немного не совместимый с coreutils. > То есть нужно заменить 'readlink -ev' на 'readlink-e -v'? Прислать патч? >> >> 2. Есть потребность считать корневым разделом тот, что скрывается за >> переменной ROOT, чтобы не нужно было привязываться к конкретному UUID >> или LABEL и соответственно в случае их изменения пересобирать initrd. >> Поэтому сделал такой патчик: >> >> diff --git a/make-initrd/features/kickstart/data/bin/kickstart-sh-storage b/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> index 2cd7b12c..de9b9c1a 100644 >> --- a/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> +++ b/make-initrd/features/kickstart/data/bin/kickstart-sh-storage >> @@ -12,6 +12,11 @@ ks_devname() >> { >> local devname='' >> case "$1" in >> + root) >> + [ -n "$ROOT" ] || fatal "root is not specified" >> + ks_devname "$ROOT" >> + return >> + ;; >> LABEL=*) >> devname="$(blkid -o device -L "${1#LABEL=}")" >> ;; > > Ок. Можно такой алиас сделать. > Замечаний к коду нет? Тогда пришлю патч? >> kickstart файл у меня получился такой: >> part --onpart=root --resize --grow --useexisting >> >> 3. Раздел увеличивается, но файловая система нет. Так и должно быть? Или >> я что-то делаю не так. Сразу не заметил, так как в /etc/fstab был >> указан параметр монтирования x-systemd.growfs, благодаря чему файловая >> система расширялась systemd. > > Я это не реализовал так как в тот момент мне это не было нужно. Но считаю, > что раз возникла потребность, то это стоит сделать. Правда пока не не знаю > несколько это будет хлопотно. > В принципе, пока можно и с x-systemd.growfs жить. Но он привязан к systemd и не поддерживает, к примеру, f2fs, которая хорошо подходит для флешек (что акутально для планшетов, смартфонов, одноплатников). -- С уважением, Антон Мидюков