accel/habanalabs: call to HW/FW err returns 0 when no events exist
authorMoti Haimovski <mhaimovski@habana.ai>
Thu, 13 Apr 2023 10:54:40 +0000 (13:54 +0300)
committerOded Gabbay <ogabbay@kernel.org>
Mon, 5 Jun 2023 12:31:34 +0000 (15:31 +0300)
This commit modifies the call to retrieve HW or FW error events to
return success when no events are pending, as done in the calls to
other events.

Signed-off-by: Moti Haimovski <mhaimovski@habana.ai>
Reviewed-by: Oded Gabbay <ogabbay@kernel.org>
Signed-off-by: Oded Gabbay <ogabbay@kernel.org>
drivers/accel/habanalabs/common/habanalabs_ioctl.c

index 203ee857810c7bd9c539041e309eb5e705fbe327..4368e6c9a23afbfcf4d8abaf62e6a6ce83d8e445 100644 (file)
@@ -842,15 +842,15 @@ static int hw_err_info(struct hl_fpriv *hpriv, struct hl_info_args *args)
        struct hw_err_info *info;
        int rc;
 
-       if ((!user_buf_size) || (!user_buf))
+       if (!user_buf)
                return -EINVAL;
 
-       if (user_buf_size < sizeof(struct hl_info_hw_err_event))
-               return -ENOMEM;
-
        info = &hdev->captured_err_info.hw_err;
        if (!info->event_info_available)
-               return -ENOENT;
+               return 0;
+
+       if (user_buf_size < sizeof(struct hl_info_hw_err_event))
+               return -ENOMEM;
 
        rc = copy_to_user(user_buf, &info->event, sizeof(struct hl_info_hw_err_event));
        return rc ? -EFAULT : 0;
@@ -864,15 +864,15 @@ static int fw_err_info(struct hl_fpriv *hpriv, struct hl_info_args *args)
        struct fw_err_info *info;
        int rc;
 
-       if ((!user_buf_size) || (!user_buf))
+       if (!user_buf)
                return -EINVAL;
 
-       if (user_buf_size < sizeof(struct hl_info_fw_err_event))
-               return -ENOMEM;
-
        info = &hdev->captured_err_info.fw_err;
        if (!info->event_info_available)
-               return -ENOENT;
+               return 0;
+
+       if (user_buf_size < sizeof(struct hl_info_fw_err_event))
+               return -ENOMEM;
 
        rc = copy_to_user(user_buf, &info->event, sizeof(struct hl_info_fw_err_event));
        return rc ? -EFAULT : 0;