提交 0c921a89 编写于 作者: J Jiri Pirko 提交者: David S. Miller

mlxsw: acl: Use PBS type for forward action

Current behaviour of "mirred redirect" action (forward) offload is a bit
odd. For matched packets the action forwards them to the desired
destination, but it also lets the packet duplicates to go the original
way down (bridge, router, etc). That is more like "mirred mirror".
Fix this by using PBS type which behaves exactly like "mirred redirect".
Note that PBS does not support loopback mode.

Fixes: 4cda7d8d ("mlxsw: core: Introduce flexible actions support")
Signed-off-by: NJiri Pirko <jiri@mellanox.com>
Reviewed-by: NIdo Schimmel <idosch@mellanox.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 6a553b48
...@@ -651,17 +651,16 @@ int mlxsw_afa_block_append_fwd(struct mlxsw_afa_block *block, ...@@ -651,17 +651,16 @@ int mlxsw_afa_block_append_fwd(struct mlxsw_afa_block *block,
u8 local_port, bool in_port) u8 local_port, bool in_port)
{ {
struct mlxsw_afa_fwd_entry_ref *fwd_entry_ref; struct mlxsw_afa_fwd_entry_ref *fwd_entry_ref;
u32 kvdl_index = 0; u32 kvdl_index;
char *act; char *act;
int err; int err;
if (!in_port) { if (in_port)
fwd_entry_ref = mlxsw_afa_fwd_entry_ref_create(block, return -EOPNOTSUPP;
local_port); fwd_entry_ref = mlxsw_afa_fwd_entry_ref_create(block, local_port);
if (IS_ERR(fwd_entry_ref)) if (IS_ERR(fwd_entry_ref))
return PTR_ERR(fwd_entry_ref); return PTR_ERR(fwd_entry_ref);
kvdl_index = fwd_entry_ref->fwd_entry->kvdl_index; kvdl_index = fwd_entry_ref->fwd_entry->kvdl_index;
}
act = mlxsw_afa_block_append_action(block, MLXSW_AFA_FORWARD_CODE, act = mlxsw_afa_block_append_action(block, MLXSW_AFA_FORWARD_CODE,
MLXSW_AFA_FORWARD_SIZE); MLXSW_AFA_FORWARD_SIZE);
...@@ -669,13 +668,12 @@ int mlxsw_afa_block_append_fwd(struct mlxsw_afa_block *block, ...@@ -669,13 +668,12 @@ int mlxsw_afa_block_append_fwd(struct mlxsw_afa_block *block,
err = -ENOBUFS; err = -ENOBUFS;
goto err_append_action; goto err_append_action;
} }
mlxsw_afa_forward_pack(act, MLXSW_AFA_FORWARD_TYPE_OUTPUT, mlxsw_afa_forward_pack(act, MLXSW_AFA_FORWARD_TYPE_PBS,
kvdl_index, in_port); kvdl_index, in_port);
return 0; return 0;
err_append_action: err_append_action:
if (!in_port) mlxsw_afa_fwd_entry_ref_destroy(block, fwd_entry_ref);
mlxsw_afa_fwd_entry_ref_destroy(block, fwd_entry_ref);
return err; return err;
} }
EXPORT_SYMBOL(mlxsw_afa_block_append_fwd); EXPORT_SYMBOL(mlxsw_afa_block_append_fwd);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册