]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
firmware: stratix10-svc: Return -EOPNOTSUPP when ATF async unsupported
authorMuhammad Amirul Asyraf Mohamad Jamian <muhammad.amirul.asyraf.mohamad.jamian@altera.com>
Thu, 16 Apr 2026 07:22:06 +0000 (00:22 -0700)
committerDinh Nguyen <dinguyen@kernel.org>
Thu, 28 May 2026 18:34:06 +0000 (13:34 -0500)
Add a 'supported' flag to struct stratix10_async_ctrl to indicate
whether the secure firmware supports SIP SVC v3 asynchronous
communication. When the ATF version check in stratix10_svc_async_init()
fails, set supported=false and return -EOPNOTSUPP instead of -EINVAL.

This allows callers to distinguish between "async not supported by this
ATF version" (-EOPNOTSUPP) and "programming error / bad argument"
(-EINVAL), and take appropriate action (e.g. fall back to synchronous
V1 SMC path) rather than treating both as fatal.

Also update stratix10_svc_add_async_client() to return -EOPNOTSUPP
immediately when async is not supported, rather than -EINVAL from the
!actrl->initialized check, so client drivers receive a consistent and
meaningful error code.

This patch is a prerequisite for the following fix and must be applied
together with it to correctly restore functionality on old ATF versions.

Fixes: bcb9f4f07061 ("firmware: stratix10-svc: Add support for async communication")
Cc: stable@vger.kernel.org
Suggested-by: Anders Hedlund <anders.hedlund@windriver.com>
Signed-off-by: Mahesh Rao <mahesh.rao@altera.com>
Signed-off-by: Muhammad Amirul Asyraf Mohamad Jamian <muhammad.amirul.asyraf.mohamad.jamian@altera.com>
Signed-off-by: Dinh Nguyen <dinguyen@kernel.org>
drivers/firmware/stratix10-svc.c

index e9e35d67ef966af101ee96bbdf60a14b0154b114..8a4f18602f36aa3ae32246825263a403dbac22c6 100644 (file)
@@ -212,6 +212,7 @@ struct stratix10_async_chan {
 /**
  * struct stratix10_async_ctrl - Control structure for Stratix10
  *                               asynchronous operations
+ * @supported: Flag indicating whether the system supports async operations
  * @initialized: Flag indicating whether the control structure has
  *               been initialized
  * @invoke_fn: Function pointer for invoking Stratix10 service calls
@@ -228,6 +229,7 @@ struct stratix10_async_chan {
  */
 
 struct stratix10_async_ctrl {
+       bool supported;
        bool initialized;
        void (*invoke_fn)(struct stratix10_async_ctrl *actrl,
                          const struct arm_smccc_1_2_regs *args,
@@ -1103,6 +1105,7 @@ EXPORT_SYMBOL_GPL(stratix10_svc_request_channel_byname);
  * Return: 0 on success, or a negative error code on failure:
  *         -EINVAL if the channel is NULL or the async controller is
  *         not initialized.
+ *         -EOPNOTSUPP if async operations are not supported.
  *         -EALREADY if the async channel is already allocated.
  *         -ENOMEM if memory allocation fails.
  *         Other negative values if ID allocation fails.
@@ -1121,6 +1124,9 @@ int stratix10_svc_add_async_client(struct stratix10_svc_chan *chan,
        ctrl = chan->ctrl;
        actrl = &ctrl->actrl;
 
+       if (!actrl->supported)
+               return -EOPNOTSUPP;
+
        if (!actrl->initialized) {
                dev_err(ctrl->dev, "Async controller not initialized\n");
                return -EINVAL;
@@ -1562,6 +1568,7 @@ static inline void stratix10_smc_1_2(struct stratix10_async_ctrl *actrl,
  *         initialized, -ENOMEM if memory allocation fails,
  *         -EADDRINUSE if the client ID is already reserved, or other
  *         negative error codes on failure.
+ *         -EOPNOTSUPP if system doesn't support async operations.
  */
 static int stratix10_svc_async_init(struct stratix10_svc_controller *controller)
 {
@@ -1585,10 +1592,12 @@ static int stratix10_svc_async_init(struct stratix10_svc_controller *controller)
            !(res.a1 > ASYNC_ATF_MINIMUM_MAJOR_VERSION ||
              (res.a1 == ASYNC_ATF_MINIMUM_MAJOR_VERSION &&
               res.a2 >= ASYNC_ATF_MINIMUM_MINOR_VERSION))) {
-               dev_err(dev,
-                       "Intel Service Layer Driver: ATF version is not compatible for async operation\n");
-               return -EINVAL;
+               dev_info(dev,
+                        "Intel Service Layer Driver: ATF version is not compatible for async operation\n");
+               actrl->supported = false;
+               return -EOPNOTSUPP;
        }
+       actrl->supported = true;
 
        actrl->invoke_fn = stratix10_smc_1_2;