When loading the OS default package and the pipeline mode is enabled
by the "pipeline-mode-support=1" operation. In this case, the wrong
parser is selected for processing and it will cause the unsupported
patterns(pppoes/pfcp/l2tpv3/esp/ah) to be validated successfully.
This patch corrects the parser selection issue.

Fixes: 47d460d63233 ("net/ice: rework switch filter")
Cc: sta...@dpdk.org

Signed-off-by: Guinan Sun <guinanx....@intel.com>
---
 drivers/net/ice/ice_switch_filter.c | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ice/ice_switch_filter.c 
b/drivers/net/ice/ice_switch_filter.c
index c4b00b6a2..884fbaae2 100644
--- a/drivers/net/ice/ice_switch_filter.c
+++ b/drivers/net/ice/ice_switch_filter.c
@@ -1806,7 +1806,8 @@ ice_switch_init(struct ice_adapter *ad)
        else
                return -EINVAL;
 
-       if (ad->devargs.pipe_mode_support)
+       if (ad->devargs.pipe_mode_support &&
+           ad->active_pkg_type != ICE_PKG_TYPE_OS_DEFAULT)
                ret = ice_register_parser(perm_parser, ad);
        else
                ret = ice_register_parser(dist_parser, ad);
@@ -1824,7 +1825,8 @@ ice_switch_uninit(struct ice_adapter *ad)
        else
                dist_parser = &ice_switch_dist_parser_os;
 
-       if (ad->devargs.pipe_mode_support)
+       if (ad->devargs.pipe_mode_support &&
+           ad->active_pkg_type != ICE_PKG_TYPE_OS_DEFAULT)
                ice_unregister_parser(perm_parser, ad);
        else
                ice_unregister_parser(dist_parser, ad);
-- 
2.17.1

Reply via email to