]> Gentwo Git Trees - linux/.git/commitdiff
vdpa/mlx5: Fix incorrect error code reporting in query_virtqueues
authorAlok Tiwari <alok.a.tiwari@oracle.com>
Mon, 29 Sep 2025 13:42:53 +0000 (06:42 -0700)
committerMichael S. Tsirkin <mst@redhat.com>
Thu, 27 Nov 2025 07:03:06 +0000 (02:03 -0500)
When query_virtqueues() fails, the error log prints the variable err
instead of cmd->err. Since err may still be zero at this point, the
log message can misleadingly report a success value 0 even though the
command actually failed.

Even worse, once err is set to the first failure, subsequent logs
print that same stale value. This makes the error reporting appear
one step behind the actual failing queue index, which is confusing
and misleading.

Fix the log to report cmd->err, which reflects the real failure code
returned by the firmware.

Fixes: 1fcdf43ea69e ("vdpa/mlx5: Use async API for vq query command")
Signed-off-by: Alok Tiwari <alok.a.tiwari@oracle.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Reviewed-by: Dragos Tatulea <dtatulea@nvidia.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Message-Id: <20250929134258.80956-1-alok.a.tiwari@oracle.com>

drivers/vdpa/mlx5/net/mlx5_vnet.c

index a7936bd1aabe17d6911f0ea2b22d727f5dd86dd4..ddaa1366704bb0026849e654347f5eff3d849580 100644 (file)
@@ -1256,7 +1256,7 @@ static int query_virtqueues(struct mlx5_vdpa_net *ndev,
                int vq_idx = start_vq + i;
 
                if (cmd->err) {
-                       mlx5_vdpa_err(mvdev, "query vq %d failed, err: %d\n", vq_idx, err);
+                       mlx5_vdpa_err(mvdev, "query vq %d failed, err: %d\n", vq_idx, cmd->err);
                        if (!err)
                                err = cmd->err;
                        continue;