mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-06 14:31:46 +00:00
mlxsw: spectrum_acl: Set A-TCAM rules in Bloom filter
Add calls to eRP module for updating Bloom filter when a rule is added or removed from the A-TCAM. eRP module will update the Bloom filter only for cases in which the region has an active eRP table. Signed-off-by: Nir Dotan <nird@mellanox.com> Signed-off-by: Ido Schimmel <idosch@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f5a2852ed0
commit
8c81b7438b
1 changed files with 10 additions and 0 deletions
|
@ -508,6 +508,13 @@ __mlxsw_sp_acl_atcam_entry_add(struct mlxsw_sp *mlxsw_sp,
|
||||||
if (err)
|
if (err)
|
||||||
goto err_rhashtable_insert;
|
goto err_rhashtable_insert;
|
||||||
|
|
||||||
|
/* Bloom filter must be updated here, before inserting the rule into
|
||||||
|
* the A-TCAM.
|
||||||
|
*/
|
||||||
|
err = mlxsw_sp_acl_erp_bf_insert(mlxsw_sp, aregion, erp_mask, aentry);
|
||||||
|
if (err)
|
||||||
|
goto err_bf_insert;
|
||||||
|
|
||||||
err = mlxsw_sp_acl_atcam_region_entry_insert(mlxsw_sp, aregion, aentry,
|
err = mlxsw_sp_acl_atcam_region_entry_insert(mlxsw_sp, aregion, aentry,
|
||||||
rulei);
|
rulei);
|
||||||
if (err)
|
if (err)
|
||||||
|
@ -516,6 +523,8 @@ __mlxsw_sp_acl_atcam_entry_add(struct mlxsw_sp *mlxsw_sp,
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_rule_insert:
|
err_rule_insert:
|
||||||
|
mlxsw_sp_acl_erp_bf_remove(mlxsw_sp, aregion, erp_mask, aentry);
|
||||||
|
err_bf_insert:
|
||||||
rhashtable_remove_fast(&aregion->entries_ht, &aentry->ht_node,
|
rhashtable_remove_fast(&aregion->entries_ht, &aentry->ht_node,
|
||||||
mlxsw_sp_acl_atcam_entries_ht_params);
|
mlxsw_sp_acl_atcam_entries_ht_params);
|
||||||
err_rhashtable_insert:
|
err_rhashtable_insert:
|
||||||
|
@ -529,6 +538,7 @@ __mlxsw_sp_acl_atcam_entry_del(struct mlxsw_sp *mlxsw_sp,
|
||||||
struct mlxsw_sp_acl_atcam_entry *aentry)
|
struct mlxsw_sp_acl_atcam_entry *aentry)
|
||||||
{
|
{
|
||||||
mlxsw_sp_acl_atcam_region_entry_remove(mlxsw_sp, aregion, aentry);
|
mlxsw_sp_acl_atcam_region_entry_remove(mlxsw_sp, aregion, aentry);
|
||||||
|
mlxsw_sp_acl_erp_bf_remove(mlxsw_sp, aregion, aentry->erp_mask, aentry);
|
||||||
rhashtable_remove_fast(&aregion->entries_ht, &aentry->ht_node,
|
rhashtable_remove_fast(&aregion->entries_ht, &aentry->ht_node,
|
||||||
mlxsw_sp_acl_atcam_entries_ht_params);
|
mlxsw_sp_acl_atcam_entries_ht_params);
|
||||||
mlxsw_sp_acl_erp_mask_put(aregion, aentry->erp_mask);
|
mlxsw_sp_acl_erp_mask_put(aregion, aentry->erp_mask);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue