vfio/mlx5: Handle the EREMOTEIO error upon the SAVE command
authorYishai Hadas <yishaih@nvidia.com>
Mon, 5 Feb 2024 12:48:26 +0000 (14:48 +0200)
committerAlex Williamson <alex.williamson@redhat.com>
Thu, 22 Feb 2024 19:17:32 +0000 (12:17 -0700)
The SAVE command uses the async command interface over the PF.

Upon a failure in the firmware -EREMOTEIO is returned.

In that case call mlx5_cmd_out_err() to let it print the command failure
details including the firmware syndrome.

Note:
The other commands in the driver use the sync command interface in a way
that a firmware syndrome is printed upon an error inside mlx5_core.

Signed-off-by: Yishai Hadas <yishaih@nvidia.com>
Reviewed-by: Kevin Tian <kevin.tian@intel.com>
Acked-by: Leon Romanovsky <leon@kernel.org>
Link: https://lore.kernel.org/r/20240205124828.232701-4-yishaih@nvidia.com
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
drivers/vfio/pci/mlx5/cmd.c

index 8a39ff19da280487b5975499103c8a2118175722..6b45bd7d89ad57159d67fa79d7974546607639b4 100644 (file)
@@ -614,8 +614,13 @@ static void mlx5vf_save_callback(int status, struct mlx5_async_work *context)
 
 err:
        /* The error flow can't run from an interrupt context */
-       if (status == -EREMOTEIO)
+       if (status == -EREMOTEIO) {
                status = MLX5_GET(save_vhca_state_out, async_data->out, status);
+               /* Failed in FW, print cmd out failure details */
+               mlx5_cmd_out_err(migf->mvdev->mdev, MLX5_CMD_OP_SAVE_VHCA_STATE, 0,
+                                async_data->out);
+       }
+
        async_data->status = status;
        queue_work(migf->mvdev->cb_wq, &async_data->work);
 }