Linux-ARM-Kernel Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Nirmoy Das <nirmoyd@nvidia.com>
To: Andre Przywara <andre.przywara@arm.com>,
	Mark Rutland <mark.rutland@arm.com>,
	Lorenzo Pieralisi <lpieralisi@kernel.org>,
	"Sudeep Holla" <sudeep.holla@kernel.org>
Cc: vsethi@nvidia.com, Salman Nabi <salman.nabi@arm.com>,
	linux-kernel@vger.kernel.org, vwadekar@nvidia.com,
	Trilok Soni <trilokkumar.soni@oss.qualcomm.com>,
	linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH v2 6/8] firmware: smccc: lfa: Add auto_activate sysfs file
Date: Wed, 24 Jun 2026 21:45:54 +0200	[thread overview]
Message-ID: <483b7983-44c8-4a17-9db5-61b950a41ffa@nvidia.com> (raw)
In-Reply-To: <20260317103336.1273582-7-andre.przywara@arm.com>

Hi Andre,

On 17.03.26 12:33, Andre Przywara wrote:
> The Arm LFA spec places control over the actual activation process in
> the hands of the non-secure host OS. An platform initiated interrupt or
> notification signals the availability of an updateable firmware image,
> but does not necessarily need to trigger it automatically.
>
> Add a sysfs control file that guards such automatic activation. If an
> administrator wants to allow automatic platform initiated updates, they
> can activate that by echoing a "1" into the auto_activate file in the
> respective sysfs directory. Any incoming notification would then result
> in the activation triggered.
>
> Signed-off-by: Andre Przywara <andre.przywara@arm.com>
> ---
>   drivers/firmware/smccc/lfa_fw.c | 34 ++++++++++++++++++++++++++++++---
>   1 file changed, 31 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/firmware/smccc/lfa_fw.c b/drivers/firmware/smccc/lfa_fw.c
> index f20ea45cdbd9..5dc531e462eb 100644
> --- a/drivers/firmware/smccc/lfa_fw.c
> +++ b/drivers/firmware/smccc/lfa_fw.c
> @@ -101,6 +101,7 @@ enum image_attr_names {
>   	LFA_ATTR_FORCE_CPU_RENDEZVOUS,
>   	LFA_ATTR_ACTIVATE,
>   	LFA_ATTR_CANCEL,
> +	LFA_ATTR_AUTO_ACTIVATE,
>   	LFA_ATTR_NR_IMAGES
>   };
>   
> @@ -115,6 +116,7 @@ struct fw_image {
>   	bool may_reset_cpu;
>   	bool cpu_rendezvous;
>   	bool cpu_rendezvous_forced;
> +	bool auto_activate;
>   	struct kobj_attribute image_attrs[LFA_ATTR_NR_IMAGES];
>   };
>   
> @@ -561,6 +563,28 @@ static ssize_t cancel_store(struct kobject *kobj, struct kobj_attribute *attr,
>   	return count;
>   }
>   
> +static ssize_t auto_activate_store(struct kobject *kobj,
> +				   struct kobj_attribute *attr,
> +				   const char *buf, size_t count)
> +{
> +	struct fw_image *image = kobj_to_fw_image(kobj);
> +	int ret;
> +
> +	ret = kstrtobool(buf, &image->auto_activate);
> +	if (ret)
> +		return ret;
> +
> +	return count;
> +}
> +
> +static ssize_t auto_activate_show(struct kobject *kobj,
> +				  struct kobj_attribute *attr, char *buf)
> +{
> +	struct fw_image *image = kobj_to_fw_image(kobj);
> +
> +	return sysfs_emit(buf, "%d\n", image->auto_activate);
> +}
> +
>   static struct kobj_attribute image_attrs_group[LFA_ATTR_NR_IMAGES] = {
>   	[LFA_ATTR_NAME]			= __ATTR_RO(name),
>   	[LFA_ATTR_CURRENT_VERSION]	= __ATTR_RO(current_version),
> @@ -571,7 +595,8 @@ static struct kobj_attribute image_attrs_group[LFA_ATTR_NR_IMAGES] = {
>   	[LFA_ATTR_CPU_RENDEZVOUS]	= __ATTR_RO(cpu_rendezvous),
>   	[LFA_ATTR_FORCE_CPU_RENDEZVOUS]	= __ATTR_RW(force_cpu_rendezvous),
>   	[LFA_ATTR_ACTIVATE]		= __ATTR_WO(activate),
> -	[LFA_ATTR_CANCEL]		= __ATTR_WO(cancel)
> +	[LFA_ATTR_CANCEL]		= __ATTR_WO(cancel),
> +	[LFA_ATTR_AUTO_ACTIVATE]	= __ATTR_RW(auto_activate),
>   };
>   
>   static void init_image_default_attrs(void)
> @@ -640,6 +665,7 @@ static int update_fw_image_node(char *fw_uuid, int seq_id,
>   	image->kobj.kset = lfa_kset;
>   	image->image_name = image_name;
>   	image->cpu_rendezvous_forced = true;
> +	image->auto_activate = false;


I think sysadmins should be able to automate setting this at boot and
after firmware inventory changes.

A udev rule matching /sys/firmware/lfa/<uuid>/auto_activate did not work
when I tried it, since those entries are plain kobjects under
/sys/firmware. The arm-lfa faux device worked better as the event anchor,
with something like:

   if (lfa_dev)
           kobject_uevent(&lfa_dev->dev.kobj, KOBJ_CHANGE);

Then userspace can use:

   ACTION=="add|change", SUBSYSTEM=="faux", KERNEL=="arm-lfa", \
           RUN+="/usr/sbin/lfa-auto-activate"

What do you think about adding such a notification in v3?

Regards,
Nirmoy


>   	set_image_flags(image, seq_id, image_flags, reg_current_ver,
>   			reg_pending_ver);
>   	if (kobject_init_and_add(&image->kobj, &image_ktype, NULL,
> @@ -709,7 +735,8 @@ static int update_fw_images_tree(void)
>   
>   /*
>    * Go through all FW images in a loop and trigger activation
> - * of all activatible and pending images.
> + * of all activatible and pending images, but only if automatic
> + * activation for that image is allowed.
>    * We have to restart enumeration after every triggered activation,
>    * since the firmware images might have changed during the activation.
>    */
> @@ -728,7 +755,8 @@ static int activate_pending_image(void)
>   			continue; /* Invalid FW component */
>   
>   		update_fw_image_pending(image);
> -		if (image->activation_capable && image->activation_pending) {
> +		if (image->activation_capable && image->activation_pending &&
> +		    image->auto_activate) {
>   			found_pending = true;
>   			break;
>   		}


  parent reply	other threads:[~2026-06-24 19:46 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-03-17 10:33 [PATCH v2 0/8] Arm Live Firmware Activation (LFA) support Andre Przywara
2026-03-17 10:33 ` [PATCH v2 1/8] dt-bindings: arm: Add Live Firmware Activation binding Andre Przywara
2026-03-18  8:04   ` Krzysztof Kozlowski
2026-03-18 16:00     ` Andre Przywara
2026-03-17 10:33 ` [PATCH v2 2/8] firmware: smccc: Add support for Live Firmware Activation (LFA) Andre Przywara
2026-03-18  8:09   ` Krzysztof Kozlowski
2026-03-18  8:12     ` Krzysztof Kozlowski
2026-03-18 15:39       ` Andre Przywara
2026-03-17 10:33 ` [PATCH v2 3/8] firmware: smccc: lfa: Move image rescanning Andre Przywara
2026-03-17 10:33 ` [PATCH v2 4/8] firmware: smccc: lfa: Add timeout and trigger watchdog Andre Przywara
2026-06-24 20:46   ` Nirmoy Das
2026-03-17 10:33 ` [PATCH v2 5/8] firmware: smccc: lfa: Register ACPI notification Andre Przywara
2026-03-17 10:33 ` [PATCH v2 6/8] firmware: smccc: lfa: Add auto_activate sysfs file Andre Przywara
2026-03-18  8:05   ` Krzysztof Kozlowski
2026-06-24 19:45   ` Nirmoy Das [this message]
2026-03-17 10:33 ` [PATCH v2 7/8] firmware: smccc: lfa: Register DT interrupt Andre Przywara
2026-03-18  8:14   ` Krzysztof Kozlowski
2026-03-18 11:35   ` kernel test robot
2026-03-18 14:21   ` kernel test robot
2026-03-18 14:21   ` kernel test robot
2026-03-19 12:52     ` Andre Przywara
2026-03-17 10:33 ` [PATCH v2 8/8] firmware: smccc: lfa: introduce SMC access lock Andre Przywara
2026-03-18  8:00 ` [PATCH v2 0/8] Arm Live Firmware Activation (LFA) support Krzysztof Kozlowski

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=483b7983-44c8-4a17-9db5-61b950a41ffa@nvidia.com \
    --to=nirmoyd@nvidia.com \
    --cc=andre.przywara@arm.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=lpieralisi@kernel.org \
    --cc=mark.rutland@arm.com \
    --cc=salman.nabi@arm.com \
    --cc=sudeep.holla@kernel.org \
    --cc=trilokkumar.soni@oss.qualcomm.com \
    --cc=vsethi@nvidia.com \
    --cc=vwadekar@nvidia.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