The pf has enabled the ACL filter, so uninit is no longer limited
to the DCF.

Fixes: a9d612291c2d ("net/ice: support IPv4 fragments in ACL filters")

Signed-off-by: Mingjin Ye <mingjinx...@intel.com>
---
 drivers/net/intel/ice/ice_acl_filter.c | 48 +++++++++++++-------------
 1 file changed, 24 insertions(+), 24 deletions(-)

diff --git a/drivers/net/intel/ice/ice_acl_filter.c 
b/drivers/net/intel/ice/ice_acl_filter.c
index 04c17a98ed..83cb3e36f9 100644
--- a/drivers/net/intel/ice/ice_acl_filter.c
+++ b/drivers/net/intel/ice/ice_acl_filter.c
@@ -278,26 +278,28 @@ ice_acl_prof_init(struct ice_pf *pf)
        if (ret)
                goto err_add_prof_ipv4_sctp;
 
-       for (i = 0; i < pf->main_vsi->idx; i++) {
-               ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4, i);
-               if (ret)
-                       goto err_assoc_prof;
-
-               ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4_frag, i);
-               if (ret)
-                       goto err_assoc_prof;
-
-               ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4_udp, i);
-               if (ret)
-                       goto err_assoc_prof;
-
-               ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4_tcp, i);
-               if (ret)
-                       goto err_assoc_prof;
-
-               ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4_sctp, i);
-               if (ret)
-                       goto err_assoc_prof;
+       if (hw->dcf_enabled) {
+               for (i = 0; i < pf->main_vsi->idx; i++) {
+                       ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, prof_ipv4, 
i);
+                       if (ret)
+                               goto err_assoc_prof;
+
+                       ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, 
prof_ipv4_frag, i);
+                       if (ret)
+                               goto err_assoc_prof;
+
+                       ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, 
prof_ipv4_udp, i);
+                       if (ret)
+                               goto err_assoc_prof;
+
+                       ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, 
prof_ipv4_tcp, i);
+                       if (ret)
+                               goto err_assoc_prof;
+
+                       ret = ice_flow_assoc_prof(hw, ICE_BLK_ACL, 
prof_ipv4_sctp, i);
+                       if (ret)
+                               goto err_assoc_prof;
+               }
        }
        return 0;
 
@@ -1082,10 +1084,8 @@ ice_acl_uninit(struct ice_adapter *ad)
        struct ice_pf *pf = &ad->pf;
        struct ice_hw *hw = ICE_PF_TO_HW(pf);
 
-       if (ad->hw.dcf_enabled) {
-               ice_deinit_acl(pf);
-               ice_acl_prof_free(hw);
-       }
+       ice_deinit_acl(pf);
+       ice_acl_prof_free(hw);
 }
 
 static struct
-- 
2.25.1

Reply via email to