Print the syndrome of failure of FW command.

Signed-off-by: Erez Shitrit <ere...@nvidia.com>
Reviewed-by: Alex Vesker <va...@nvidia.com>
Acked-by: Matan Azrad <ma...@nvidia.com>
---
 drivers/net/mlx5/hws/mlx5dr_cmd.c | 48 ++++++++++++++++++++++---------
 1 file changed, 34 insertions(+), 14 deletions(-)

diff --git a/drivers/net/mlx5/hws/mlx5dr_cmd.c 
b/drivers/net/mlx5/hws/mlx5dr_cmd.c
index f9f220cc6a..7771aeb8cf 100644
--- a/drivers/net/mlx5/hws/mlx5dr_cmd.c
+++ b/drivers/net/mlx5/hws/mlx5dr_cmd.c
@@ -4,6 +4,12 @@
 
 #include "mlx5dr_internal.h"
 
+static uint32_t mlx5dr_cmd_get_syndrome(uint32_t *out)
+{
+       /* Assumption: syndrome is always the second u32 */
+       return be32toh(out[1]);
+}
+
 int mlx5dr_cmd_destroy_obj(struct mlx5dr_devx_obj *devx_obj)
 {
        int ret;
@@ -39,7 +45,8 @@ mlx5dr_cmd_flow_table_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create FT");
+               DR_LOG(ERR, "Failed to create FT (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -73,7 +80,8 @@ mlx5dr_cmd_flow_table_modify(struct mlx5dr_devx_obj *devx_obj,
 
        ret = mlx5_glue->devx_obj_modify(devx_obj->obj, in, sizeof(in), out, 
sizeof(out));
        if (ret) {
-               DR_LOG(ERR, "Failed to modify FT");
+               DR_LOG(ERR, "Failed to modify FT (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
        }
 
@@ -96,7 +104,8 @@ mlx5dr_cmd_flow_table_query(struct mlx5dr_devx_obj *devx_obj,
 
        ret = mlx5_glue->devx_obj_query(devx_obj->obj, in, sizeof(in), out, 
sizeof(out));
        if (ret) {
-               DR_LOG(ERR, "Failed to query FT");
+               DR_LOG(ERR, "Failed to query FT (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
                return ret;
        }
@@ -129,7 +138,8 @@ mlx5dr_cmd_flow_group_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create Flow group");
+               DR_LOG(ERR, "Failed to create Flow group(syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -182,7 +192,8 @@ mlx5dr_cmd_set_fte(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create FTE");
+               DR_LOG(ERR, "Failed to create FTE (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
                goto free_devx;
        }
@@ -325,7 +336,8 @@ mlx5dr_cmd_rtc_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create RTC");
+               DR_LOG(ERR, "Failed to create RTC (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -365,7 +377,8 @@ mlx5dr_cmd_stc_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create STC");
+               DR_LOG(ERR, "Failed to create STC (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -505,7 +518,8 @@ mlx5dr_cmd_stc_modify(struct mlx5dr_devx_obj *devx_obj,
 
        ret = mlx5_glue->devx_obj_modify(devx_obj->obj, in, sizeof(in), out, 
sizeof(out));
        if (ret) {
-               DR_LOG(ERR, "Failed to modify STC FW action_type %d", 
stc_attr->action_type);
+               DR_LOG(ERR, "Failed to modify STC FW action_type %d (syndrome: 
%#x)",
+                      stc_attr->action_type, mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
        }
 
@@ -542,7 +556,8 @@ mlx5dr_cmd_arg_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create ARG");
+               DR_LOG(ERR, "Failed to create ARG (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -606,7 +621,8 @@ mlx5dr_cmd_header_modify_pattern_create(struct ibv_context 
*ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create header_modify_pattern");
+               DR_LOG(ERR, "Failed to create header_modify_pattern (syndrome: 
%#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
                goto free_obj;
        }
@@ -649,7 +665,8 @@ mlx5dr_cmd_ste_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create STE");
+               DR_LOG(ERR, "Failed to create STE (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -708,7 +725,8 @@ mlx5dr_cmd_definer_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create Definer");
+               DR_LOG(ERR, "Failed to create Definer (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
@@ -775,7 +793,8 @@ int mlx5dr_cmd_sq_modify_rdy(struct mlx5dr_devx_obj 
*devx_obj)
 
        ret = mlx5_glue->devx_obj_modify(devx_obj->obj, in, sizeof(in), out, 
sizeof(out));
        if (ret) {
-               DR_LOG(ERR, "Failed to modify SQ");
+               DR_LOG(ERR, "Failed to modify SQ (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                rte_errno = errno;
        }
 
@@ -843,7 +862,8 @@ mlx5dr_cmd_alias_obj_create(struct ibv_context *ctx,
 
        devx_obj->obj = mlx5_glue->devx_obj_create(ctx, in, sizeof(in), out, 
sizeof(out));
        if (!devx_obj->obj) {
-               DR_LOG(ERR, "Failed to create ALIAS OBJ");
+               DR_LOG(ERR, "Failed to create ALIAS OBJ (syndrome: %#x)",
+                      mlx5dr_cmd_get_syndrome(out));
                simple_free(devx_obj);
                rte_errno = errno;
                return NULL;
-- 
2.18.2

Reply via email to