Make-initrd development discussion
 help / color / mirror / Atom feed
* [make-initrd] [PATCH v6 15/22] bootchain-core: introduces the built-in "noop" pseudo-step
@ 2021-10-24 17:22 Leonid Krivoshein
  0 siblings, 0 replies; only message in thread
From: Leonid Krivoshein @ 2021-10-24 17:22 UTC (permalink / raw)
  To: make-initrd

Usually the <OUT> of a step automatically matches the <IN> of the next step.
The "noop" step does nothing and is intended to separate the <OUT> of the
previous step from the <IN> of the next step.

Signed-off-by: Leonid Krivoshein <>
 features/bootchain-core/        | 17 +++++++++++++++++
 features/bootchain-core/data/sbin/chaind |  8 +++++++-
 2 files changed, 24 insertions(+), 1 deletion(-)

diff --git a/features/bootchain-core/ b/features/bootchain-core/
index ffed599..db73c0a 100644
--- a/features/bootchain-core/
+++ b/features/bootchain-core/
@@ -49,6 +49,11 @@ us to optimize fill in `initramfs` only which we are need.
 - Modularity: loading methods are initially separated from the common
   code and daemon.
+- Some steps (actions) are built directly into the code of the main loop
+  of the `chaind` daemon, external scripts are not called to execute them.
+  Such pseudo-steps allow you to control, basically, the internal state of the
+  daemon and should not be taken into account in the boot chain, as if they are
+  hidden.
 - `bootchain-sh-functions` extends the API of the original `pipeline-sh-functions`,
   see the details in the corresponding section.
 - Via resolve_target() supports not only forward, but also reverse addressing,
@@ -93,6 +98,18 @@ parameters:
 Other `bootchain-*` modules can also use this configuration file for their
 own needs.
+## In-app pseudo-steps
+All the steps listed below are an extension of the `pipeline`. They are
+embedded in the code of the main loop of the `boot chain-loop` daemon, do
+not need additional parameters and should not be taken into account when
+addressing, as if they are hidden.
+- `noop` - does not perform any actions and is designed to pull off the results
+  on the <OUT> of the previous step from the <IN> of the next step, which can
+  be useful, for example, when we don`t want the results of the `waitdev` step
+  to be used in the next step, `localdev`, which primarily looks at them.
 ## External elements of the bootchain (steps-scripts)
 - `mountfs` - mounts a file or device from the result of the previous or other
diff --git a/features/bootchain-core/data/sbin/chaind b/features/bootchain-core/data/sbin/chaind
index 9224c40..5623a37 100755
--- a/features/bootchain-core/data/sbin/chaind
+++ b/features/bootchain-core/data/sbin/chaind
@@ -48,7 +48,13 @@ while [ -n "$chainsteps" ]; do
-	if [ -x "$exe" ]; then
+	if [ "$name" = noop ]; then
+		chainsteps="${chainsteps#$name}"
+		chainsteps="${chainsteps#,}"
+		prevdir=
+		message "[0] Step '$name' has been passed"
+	elif [ -x "$exe" ]; then
 		assign "callnum" "\${callnum_$name:-0}"

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2021-10-24 17:22 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-10-24 17:22 [make-initrd] [PATCH v6 15/22] bootchain-core: introduces the built-in "noop" pseudo-step Leonid Krivoshein

Make-initrd development discussion

This inbox may be cloned and mirrored by anyone:

	git clone --mirror 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/ \
	public-inbox-index make-initrd

Example config snippet for mirrors.
Newsgroup available over NNTP:

AGPL code for this site: git clone