* [ptxdist] [PATCH 2/3] templates: add template for custom FIT images
2023-08-22 12:12 [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees Roland Hieber
@ 2023-08-22 12:12 ` Roland Hieber
2023-08-22 12:12 ` [ptxdist] [PATCH 3/3] doc: ref_make_macros: document world/image-fit macro Roland Hieber
2023-08-31 7:36 ` [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees Michael Olbrich
2 siblings, 0 replies; 4+ messages in thread
From: Roland Hieber @ 2023-08-22 12:12 UTC (permalink / raw)
To: ptxdist; +Cc: Roland Hieber
Signed-off-by: Roland Hieber <rhi@pengutronix.de>
---
rules/templates/template-image-fit-in | 8 ++++++
rules/templates/template-image-fit-make | 34 +++++++++++++++++++++++++
scripts/lib/ptxd_lib_template.sh | 25 ++++++++++++++++++
3 files changed, 67 insertions(+)
create mode 100644 rules/templates/template-image-fit-in
create mode 100644 rules/templates/template-image-fit-make
diff --git a/rules/templates/template-image-fit-in b/rules/templates/template-image-fit-in
new file mode 100644
index 000000000000..ac5606dd0d89
--- /dev/null
+++ b/rules/templates/template-image-fit-in
@@ -0,0 +1,8 @@
+## SECTION=image
+
+config IMAGE_@PACKAGE@
+ tristate
+ @select_CODE_SIGNING@# TODO: select kernel and initrd image
+ prompt "Generate images/@package@.fit"
+ help
+ FIXME
diff --git a/rules/templates/template-image-fit-make b/rules/templates/template-image-fit-make
new file mode 100644
index 000000000000..265b7e6350c7
--- /dev/null
+++ b/rules/templates/template-image-fit-make
@@ -0,0 +1,34 @@
+# -*-makefile-*-
+#
+# Copyright (C) @YEAR@ by @AUTHOR@
+#
+# For further information about the PTXdist project and license conditions
+# see the README file.
+#
+
+#
+# We provide this package
+#
+IMAGE_PACKAGES-$(PTXCONF_IMAGE_@PACKAGE@) += image-@package@
+
+#
+# Paths and names
+#
+IMAGE_@PACKAGE@ := image-@package@
+IMAGE_@PACKAGE@_DIR := $(BUILDDIR)/$(IMAGE_@PACKAGE@)
+IMAGE_@PACKAGE@_IMAGE := $(IMAGEDIR)/@package@.fit
+IMAGE_@PACKAGE@_VERSION :=
+IMAGE_@PACKAGE@_KERNEL = # TODO: $(IMAGEDIR)/linuximage
+IMAGE_@PACKAGE@_DTB = # TODO: $(IMAGEDIR)/your-board.dtb
+IMAGE_@PACKAGE@_INITRAMFS = # optional: $(IMAGEDIR)/your-initramfs
+@CODE_SIGNING_VARS@
+# ----------------------------------------------------------------------------
+# Image
+# ----------------------------------------------------------------------------
+
+$(IMAGE_@PACKAGE@_IMAGE): $(IMAGE_@PACKAGE@_KERNEL) $(IMAGE_@PACKAGE@_INITRAMFS) $(IMAGE_@PACKAGE@_DTB)
+ @$(call targetinfo)
+ @$(call world/image-fit, IMAGE_@PACKAGE@)
+ @$(call finish)
+
+# vim: syntax=make
diff --git a/scripts/lib/ptxd_lib_template.sh b/scripts/lib/ptxd_lib_template.sh
index 30cc48d6c9b0..f8f188e148ac 100644
--- a/scripts/lib/ptxd_lib_template.sh
+++ b/scripts/lib/ptxd_lib_template.sh
@@ -598,6 +598,31 @@ export -f ptxd_template_new_image_tgz
ptxd_template_help_list[${#ptxd_template_help_list[@]}]="image-tgz"
ptxd_template_help_list[${#ptxd_template_help_list[@]}]="create package for a tgz image"
+ptxd_template_new_image_fit() {
+ export class="image-"
+ ptxd_template_read_name &&
+ ptxd_template_read_author &&
+ ptxd_template_read "sign FIT image? (y/N)" SIGN
+ case "$SIGN" in
+ y*|Y*)
+ export select_CODE_SIGNING="select CODE_SIGNING
+ "
+ export CODE_SIGNING_VARS="
+IMAGE_@PACKAGE@_SIGN_ROLE := # TODO: role name of the code signing provider, passed to cs_get_uri
+IMAGE_@PACKAGE@_KEY_NAME_HINT := # TODO: key-name-hint property in the signature node of the FIT image
+"
+ ;;
+ *)
+ export select_CODE_SIGNING=""
+ export CODE_SIGNING_VARS=""
+ ;;
+ esac
+ ptxd_template_write_platform_rules
+}
+export -f ptxd_template_new_image_fit
+ptxd_template_help_list[${#ptxd_template_help_list[@]}]="image-fit"
+ptxd_template_help_list[${#ptxd_template_help_list[@]}]="create package for a FIT image"
+
ptxd_template_new_image_genimage() {
export class="image-"
ptxd_template_read_name &&
--
2.39.2
^ permalink raw reply [flat|nested] 4+ messages in thread
* [ptxdist] [PATCH 3/3] doc: ref_make_macros: document world/image-fit macro
2023-08-22 12:12 [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees Roland Hieber
2023-08-22 12:12 ` [ptxdist] [PATCH 2/3] templates: add template for custom FIT images Roland Hieber
@ 2023-08-22 12:12 ` Roland Hieber
2023-08-31 7:36 ` [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees Michael Olbrich
2 siblings, 0 replies; 4+ messages in thread
From: Roland Hieber @ 2023-08-22 12:12 UTC (permalink / raw)
To: ptxdist; +Cc: Roland Hieber
Signed-off-by: Roland Hieber <rhi@pengutronix.de>
---
doc/ref_make_macros.rst | 38 ++++++++++++++++++++++++++++++++++++++
1 file changed, 38 insertions(+)
diff --git a/doc/ref_make_macros.rst b/doc/ref_make_macros.rst
index b8cfe9eff644..fe300c45757a 100644
--- a/doc/ref_make_macros.rst
+++ b/doc/ref_make_macros.rst
@@ -175,6 +175,44 @@ omitted.
``ptx/image-install-link`` creates a symlink in the image directory.
+.. _world_image_fit:
+
+world/image-fit
+~~~~~~~~~~~~~~~
+
+.. code-block:: none
+
+ @$(call world/image-fit, <PKG>)
+
+Build a FIT image containing a kernel, optionally an initial ramdisk, and one or
+multiple device trees. For each device tree, a configuration node is generated.
+
+.. note:: You can generate a template for a new FIT image recipe by
+ calling ``ptxdist newpackage image-fit``.
+
+The following variables are respected:
+
+``<PKG>_IMAGE``
+ The output file, usually something like ``$(IMAGEDIR)/pkg.fit``.
+
+``<PKG>_KERNEL``
+ The kernel image to package into the FIT image.
+
+``<PKG>_DTB``
+ One or more device trees that should be included in the FIT image.
+
+``<PKG>_INITRAMFS``
+ If the FIT image should contain an initial ramdisk, this variable determines
+ the initrd file name that is included. Otherwise it can be left empty.
+
+``<PKG>_SIGN_ROLE``
+ If the FIT image should be signed, this variable determines the role name
+ used for the signature. It is passed to :ref:`cs_get_uri`.
+
+``<PKG>_KEY_NAME_HINT``
+ If the FIT image should be signed, this variable determines the
+ *key-name-hint* property of the signature node.
+
.. _install_copy:
install_copy
--
2.39.2
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees
2023-08-22 12:12 [ptxdist] [PATCH 1/3] kernel: add make target for the installed device trees Roland Hieber
2023-08-22 12:12 ` [ptxdist] [PATCH 2/3] templates: add template for custom FIT images Roland Hieber
2023-08-22 12:12 ` [ptxdist] [PATCH 3/3] doc: ref_make_macros: document world/image-fit macro Roland Hieber
@ 2023-08-31 7:36 ` Michael Olbrich
2 siblings, 0 replies; 4+ messages in thread
From: Michael Olbrich @ 2023-08-31 7:36 UTC (permalink / raw)
To: Roland Hieber, ptxdist
On Tue, Aug 22, 2023 at 02:12:32PM +0200, Roland Hieber wrote:
> This makes it easy to depend on the kernel.targetinstall stage by
> depending on one of the .dtb's that it installs into the image dir, e.g.
> when building a custom recipe for a FIT image. As a nice side-effect,
> you can simply call "ptxdist image <board.dtb>" to build the device
> tree.
>
> Signed-off-by: Roland Hieber <rhi@pengutronix.de>
> ---
> rules/kernel.make | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/rules/kernel.make b/rules/kernel.make
> index e70af54e6137..5c1817efe7c7 100644
> --- a/rules/kernel.make
> +++ b/rules/kernel.make
> @@ -281,6 +281,10 @@ endif
> # Target-Install
> # ----------------------------------------------------------------------------
>
> +ifneq "$(KERNEL_DTB_FILES)" ""
I didn't know that syntax existed, but we use () in ptxdist, so lets keep
it consistent:
ifneq ($(KERNEL_DTB_FILES),)
Michael
> +$(addprefix $(IMAGEDIR)/,$(KERNEL_DTB_FILES)): $(STATEDIR)/kernel.targetinstall
> +endif
> +
> $(STATEDIR)/kernel.targetinstall:
> @$(call targetinfo)
>
> --
> 2.39.2
>
>
>
--
Pengutronix e.K. | |
Steuerwalder Str. 21 | http://www.pengutronix.de/ |
31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
^ permalink raw reply [flat|nested] 4+ messages in thread