From 32b45dbc48ae8133ef1686be660e70cc9f45d51e Mon Sep 17 00:00:00 2001
From: lxl_snow
Date: Tue, 14 Mar 2023 11:38:01 +0800
Subject: [PATCH] net/mlx5: Geneve, Fix handling of Geneve object id as error
code
ANBZ:#4504
commit d28a06d7dbedc598a06bd1e53a28125f87ca5d0c upstream
On success, mlx5_geneve_tlv_option_create returns non negative
Geneve object id. In case the object id is positive value the
caller functions will handle it as an error (non zero) and
will fail to offload the Geneve rule.
Fix this by changing caller function ,mlx5_geneve_tlv_option_add,
to return 0 in case valid non negative object id was provided.
Fixes: 0ccc171ea6a2 ("net/mlx5: Geneve, Manage Geneve TLV options")
Signed-off-by: Maor Dickman
Reviewed-by: Raed Salem
Signed-off-by: Saeed Mahameed
Signed-off-by: lxl_snow
---
drivers/net/ethernet/mellanox/mlx5/core/lib/geneve.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/drivers/net/ethernet/mellanox/mlx5/core/lib/geneve.c b/drivers/net/ethernet/mellanox/mlx5/core/lib/geneve.c
index 23361a9ae4fa..6dc83e871cd7 100644
--- a/drivers/net/ethernet/mellanox/mlx5/core/lib/geneve.c
+++ b/drivers/net/ethernet/mellanox/mlx5/core/lib/geneve.c
@@ -105,6 +105,7 @@ int mlx5_geneve_tlv_option_add(struct mlx5_geneve *geneve, struct geneve_opt *op
geneve->opt_type = opt->type;
geneve->obj_id = res;
geneve->refcount++;
+ res = 0;
}
unlock:
--
Gitee