public inbox for isar-users@googlegroups.com
 help / color / mirror / Atom feed
From: Gylstorff Quirin <quirin.gylstorff@siemens.com>
To: Henning Schild <henning.schild@siemens.com>
Cc: isar-users@googlegroups.com
Subject: Re: [PATCH v3 1/3] meta/support: Generate a custom initramfs
Date: Tue, 21 Apr 2020 16:30:41 +0200	[thread overview]
Message-ID: <032863d9-f9a8-9206-4d2d-db7f9aa939c9@siemens.com> (raw)
In-Reply-To: <20200420221400.5eb32b09@md1za8fc.ad001.siemens.net>



On 4/20/20 10:14 PM, Henning Schild wrote:
> Am Tue, 14 Apr 2020 14:24:47 +0200
> schrieb "[ext] Q. Gylstorff" <Quirin.Gylstorff@siemens.com>:
> 
>> From: Quirin Gylstorff <quirin.gylstorff@siemens.com>
>>
>> This package sets the Parameters for mkinitramfs/update-intramfs
>> before it regenerates the initrd.img of debian with a modified
>> version.
>>
>> Use cases are the remove unnecessary kernel modules to reduce the
>> size of the initrd by using the parameters:
>> ```
>> INITRAMFS_MODULES = "list"
>> INITRAMFS_MODULE_LIST += "ext4"
>> ```
>>
>> Set the boot root during the initrd generation by setting
>> `INITRAMFS_ROOT`.
>>
>> see also man pages of mkinitramfs and initramfs.conf.
>>
>> Signed-off-by: Quirin Gylstorff <quirin.gylstorff@siemens.com>
>> ---
>>   .../initramfs-config/files/control.tmpl       | 12 +++++++
>>   .../initramfs-config/files/postinst.tmpl      | 27 ++++++++++++++++
>>   .../initramfs-config/files/postrm.tmpl        | 19 +++++++++++
>>   .../initramfs-config/initramfs-config_0.1.bb  | 32
>> +++++++++++++++++++ 4 files changed, 90 insertions(+)
>>   create mode 100644
>> meta/recipes-support/initramfs-config/files/control.tmpl create mode
>> 100644 meta/recipes-support/initramfs-config/files/postinst.tmpl
>> create mode 100644
>> meta/recipes-support/initramfs-config/files/postrm.tmpl create mode
>> 100644 meta/recipes-support/initramfs-config/initramfs-config_0.1.bb
>>
>> diff --git a/meta/recipes-support/initramfs-config/files/control.tmpl
>> b/meta/recipes-support/initramfs-config/files/control.tmpl new file
>> mode 100644 index 0000000..8739b4a
>> --- /dev/null
>> +++ b/meta/recipes-support/initramfs-config/files/control.tmpl
>> @@ -0,0 +1,12 @@
>> +Source: initramfs-config
>> +Section: misc
>> +Priority: optional
>> +Standards-Version: 3.9.6
>> +Maintainer: isar-users <isar-users@googlegroups.com>
>> +Build-Depends: debhelper (>= 9)
>> +
>> +
>> +Package: initramfs-config
>> +Architecture: any
>> +Depends: ${shlibs:Depends}, ${misc:Depends}, initramfs-tools-core,
>> ${DEBIAN_DEPENDS} +Description: Configuration files for a custom
>> initramfs \ No newline at end of file
>> diff --git
>> a/meta/recipes-support/initramfs-config/files/postinst.tmpl
>> b/meta/recipes-support/initramfs-config/files/postinst.tmpl new file
>> mode 100644 index 0000000..ca8c9c6 --- /dev/null
>> +++ b/meta/recipes-support/initramfs-config/files/postinst.tmpl
>> @@ -0,0 +1,27 @@
>> +#!/bin/bash
> 
> can this be /bin/sh, and if not does that add a dep?

Yes it can.
Quirin
> 
> Henning
> 
>> +INITRAMFS_CONF=/etc/initramfs-tools/initramfs.conf
>> +if [ -f ${INITRAMFS_CONF} ]; then
>> +    sed -i -E 's/(^MODULES=).*/\1${INITRAMFS_MODULES}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^BUSYBOX=).*/\1${INITRAMFS_BUSYBOX}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^COMPRESS=).*/\1${INITRAMFS_COMPRESS}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^KEYMAP=).*/\1${INITRAMFS_KEYMAP}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^DEVICE=).*/\1${INITRAMFS_NET_DEVICE}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^NFSROOT=).*/\1${INITRAMFS_NFSROOT}/'
>> ${INITRAMFS_CONF}
>> +    sed -i -E 's/(^RUNSIZE=).*/\1${INITRAMFS_RUNSIZE}/'
>> ${INITRAMFS_CONF}
>> +    if grep -Fxq "ROOT=" "${INITRAMFS_CONF}"; then
>> +        sed -i -E 's/(^ROOT=).*/\1${INITRAMFS_ROOT}/'
>> ${INITRAMFS_CONF}
>> +    else
>> +        sed -i -E "\$aROOT=${INITRAMFS_ROOT}" ${INITRAMFS_CONF}
>> +    fi
>> +fi
>> +
>> +MODULES_LIST_FILE=/etc/initramfs-tools/modules
>> +if [ -f ${MODULES_LIST_FILE} ]; then
>> +    for modname in ${INITRAMFS_MODULE_LIST}; do
>> +        if ! grep -Fxq "$modname" "${MODULES_LIST_FILE}"; then
>> +            echo "$modname" >> "${MODULES_LIST_FILE}"
>> +        fi
>> +    done
>> +fi
>> +
>> +update-initramfs -v -u
>> diff --git a/meta/recipes-support/initramfs-config/files/postrm.tmpl
>> b/meta/recipes-support/initramfs-config/files/postrm.tmpl new file
>> mode 100644 index 0000000..55399d5
>> --- /dev/null
>> +++ b/meta/recipes-support/initramfs-config/files/postrm.tmpl
>> @@ -0,0 +1,19 @@
>> +#!/bin/bash
>> +# back to the debian defaults
>> +INITRAMFS_CONF=/etc/initramfs-tools/initramfs.conf
>> +sed -i -E 's/(^MODULES=).*/\1most/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^BUSYBOX=).*/\1auto/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^COMPRESS=).*/\1gzip/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^KEYMAP=).*/\1n/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^DEVICE=).*/\1/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^NFSROOT=).*/\1auto/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^RUNSIZE=).*/\110%/' ${INITRAMFS_CONF}
>> +sed -i -E 's/(^ROOT=).*//' ${INITRAMFS_CONF}
>> +
>> +# remove the added modules
>> +MODULES_LIST_FILE=/etc/initramfs-tools/modules
>> +for modname in ${INITRAMFS_MODULE_LIST}; do
>> +    sed -i -E 's/$modname//'
>> +done
>> +
>> +update-initramfs -v -u
>> diff --git
>> a/meta/recipes-support/initramfs-config/initramfs-config_0.1.bb
>> b/meta/recipes-support/initramfs-config/initramfs-config_0.1.bb new
>> file mode 100644 index 0000000..34bb25b --- /dev/null
>> +++ b/meta/recipes-support/initramfs-config/initramfs-config_0.1.bb
>> @@ -0,0 +1,32 @@
>> +# This software is a part of ISAR.
>> +# Copyright (C) 2020 Siemens AG
>> +#
>> +# SPDX-License-Identifier: MIT
>> +inherit dpkg-raw
>> +inherit template
>> +DESCRIPTION = "Recipe to set the initramfs configuration and
>> generate a new ramfs" +
>> +
>> +SRC_URI = "file://postinst.tmpl \
>> +           file://postrm.tmpl \
>> +           file://control.tmpl \
>> +          "
>> +
>> +INITRAMFS_MODULES ?= "most"
>> +INITRAMFS_BUSYBOX ?= "auto"
>> +INITRAMFS_COMPRESS ?= "gzip"
>> +INITRAMFS_KEYMAP ?= "n"
>> +INITRAMFS_NET_DEVICE ?= ""
>> +INITRAMFS_NFSROOT ?= "auto"
>> +INITRAMFS_RUNSIZE ?= "10%"
>> +INITRAMFS_ROOT ?= ""
>> +INITRAMFS_MODULE_LIST ?= ""
>> +CREATE_NEW_INITRAMFS ?= "n"
>> +KERNEL_PACKAGE = "${@ ("linux-image-" + d.getVar("KERNEL_NAME",
>> True)) if d.getVar("KERNEL_NAME", True) else ""}" +DEBIAN_DEPENDS +=
>> ", ${KERNEL_PACKAGE}" +TEMPLATE_FILES = "postinst.tmpl control.tmpl
>> postrm.tmpl" +TEMPLATE_VARS += "INITRAMFS_MODULES INITRAMFS_BUSYBOX
>> INITRAMFS_COMPRESS \
>> +                  INITRAMFS_KEYMAP INITRAMFS_NET_DEVICE
>> INITRAMFS_NFSROOT \
>> +                  INITRAMFS_RUNSIZE INITRAMFS_ROOT
>> INITRAMFS_MODULE_LIST CREATE_NEW_INITRAMFS DEBIAN_DEPENDS" +
>> +
> 

-- 
Quirin Gylstorff

Siemens AG
Corporate Technology
Research in Digitalization and Automation
Smart Embedded Systems
CT RDA IOT SES-DE
Otto-Hahn-Ring 6
81739 Muenchen, Germany
Mobile: +49 173 3746683
mailto:quirin.gylstorff@siemens.com
www.siemens.com/ingenuityforlife

Siemens Aktiengesellschaft: Chairman of the Supervisory Board: Jim 
Hagemann Snabe; Managing Board: Joe Kaeser, Chairman, President and 
Chief Executive Officer; Roland Busch, Lisa Davis, Klaus Helmrich, 
Cedrik Neike, Michael Sen, Ralf P. Thomas; Registered offices: Berlin 
and Munich, Germany; Commercial registries: Berlin Charlottenburg, HRB 
12300, Munich, HRB 6684; WEEE-Reg.-No. DE 23691322

Important notice: This e-mail and any attachment thereof contain 
corporate proprietary information. If you have received it by mistake, 
please notify us immediately by reply e-mail and delete this e-mail and 
its attachments from your system. Thank you.

  reply	other threads:[~2020-04-21 14:30 UTC|newest]

Thread overview: 58+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-03-27 13:27 [PATCH 0/3] some image classes Q. Gylstorff
2020-03-27 13:27 ` [PATCH 1/3] meta/classes: Generate a custom initramfs Q. Gylstorff
2020-03-30  7:25   ` Gylstorff Quirin
2020-03-30  8:08     ` Henning Schild
2020-03-27 13:28 ` [PATCH 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-03-27 18:50   ` Henning Schild
2020-03-30  7:27     ` Gylstorff Quirin
2020-03-27 13:28 ` [PATCH 3/3] meta/classes: add cpiogz-img Q. Gylstorff
2020-03-27 19:01   ` Henning Schild
2020-03-30  7:29     ` Gylstorff Quirin
2020-03-27 14:51 ` [PATCH] Add ova configuration for testing Q. Gylstorff
2020-03-27 18:46   ` Henning Schild
2020-03-27 14:52 ` [PATCH] conf: Add multiconfig for cpiogz Q. Gylstorff
2020-04-03 14:55 ` [PATCH v2 0/3] some images classes Q. Gylstorff
2020-04-03 14:55   ` [PATCH v2 1/3] meta/support: Generate a custom initramfs Q. Gylstorff
2020-04-09  6:39     ` Henning Schild
2020-04-09 13:59       ` Gylstorff Quirin
2020-04-09 17:18         ` Henning Schild
2020-04-03 14:55   ` [PATCH v2 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-04-09  6:48     ` Henning Schild
2020-04-09 14:28       ` Gylstorff Quirin
2020-04-03 14:55   ` [PATCH v2 3/3] meta/classes: add cpiogz-img Q. Gylstorff
2020-04-09  6:54   ` [PATCH v2 0/3] some images classes Henning Schild
2020-04-14 12:24     ` [PATCH v3 " Q. Gylstorff
2020-04-14 12:24       ` [PATCH v3 1/3] meta/support: Generate a custom initramfs Q. Gylstorff
2020-04-20 20:14         ` Henning Schild
2020-04-21 14:30           ` Gylstorff Quirin [this message]
2020-04-14 12:24       ` [PATCH v3 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-04-14 12:24       ` [PATCH v3 3/3] meta/classes: add cpiogz-img Q. Gylstorff
2020-04-20 20:14       ` [PATCH v3 0/3] some images classes Henning Schild
2020-04-21 14:57         ` [PATCH v4 0/3] some images Q. Gylstorff
2020-04-21 14:57           ` [PATCH v4 1/3] meta/support: Generate a custom initramfs Q. Gylstorff
2020-04-21 14:57           ` [PATCH v4 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-04-21 15:17             ` Jan Kiszka
2020-04-23  9:46               ` [PATCH v5 0/3] some images Q. Gylstorff
2020-04-23  9:46                 ` [PATCH v5 1/3] meta/support: Generate a custom initramfs Q. Gylstorff
2020-06-18 15:54                   ` Harald Seiler
2020-06-22 13:44                     ` Gylstorff Quirin
2020-06-25 12:56                     ` [PATCH v6 0/3] some images Q. Gylstorff
2020-06-25 12:56                       ` [PATCH v6 1/3] meta/support: Generate a custom initramfs Q. Gylstorff
2020-09-16 12:24                         ` Harald Seiler
2020-06-25 12:56                       ` [PATCH v6 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-06-25 12:56                       ` [PATCH v6 3/3] meta/classes: add cpiogz-img Q. Gylstorff
2020-10-13 10:22                       ` [PATCH v6 0/3] some images Jan Kiszka
2021-02-05 10:07                         ` Gylstorff Quirin
2021-02-05 10:52                   ` [PATCH v7 0/2] CPIO & OVA Images Q. Gylstorff
2021-02-05 10:52                     ` [PATCH v7 1/2] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2021-02-05 11:16                       ` Jan Kiszka
2021-02-05 10:52                     ` [PATCH v7 2/2] meta/classes: add cpiogz-img Q. Gylstorff
2021-02-05 11:09                       ` Jan Kiszka
2021-02-05 15:57                     ` [PATCH v8 0/2] CPIO & OVA Images Q. Gylstorff
2021-02-05 15:57                       ` [PATCH v8 1/2] meta/classes: Generate ova image for VMWare or Virtualbox Q. Gylstorff
2021-03-26 11:47                         ` Anton Mikanovich
2021-02-05 15:57                       ` [PATCH v8 2/2] meta/classes: add cpiogz-img Q. Gylstorff
2021-03-26 11:51                         ` Anton Mikanovich
2020-04-23  9:46                 ` [PATCH v5 2/3] meta/classes: Generate ova image for vmware or virtualbox Q. Gylstorff
2020-04-23  9:46                 ` [PATCH v5 3/3] meta/classes: add cpiogz-img Q. Gylstorff
2020-04-21 14:57           ` [PATCH v4 " Q. Gylstorff

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=032863d9-f9a8-9206-4d2d-db7f9aa939c9@siemens.com \
    --to=quirin.gylstorff@siemens.com \
    --cc=henning.schild@siemens.com \
    --cc=isar-users@googlegroups.com \
    /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
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox