From: Kan Liang <kan.li...@intel.com>

Some drivers like i40e driver does not support separate tx and rx queues
as channels. Using rx queue to stand for the channels, if queue_pair is
set by driver.

Signed-off-by: Kan Liang <kan.li...@intel.com>
---
 drivers/net/ethernet/intel/i40e/i40e_main.c | 3 +++
 include/linux/netpolicy.h                   | 1 +
 net/core/netpolicy.c                        | 3 +++
 3 files changed, 7 insertions(+)

diff --git a/drivers/net/ethernet/intel/i40e/i40e_main.c 
b/drivers/net/ethernet/intel/i40e/i40e_main.c
index d3f087d..f03d9f6 100644
--- a/drivers/net/ethernet/intel/i40e/i40e_main.c
+++ b/drivers/net/ethernet/intel/i40e/i40e_main.c
@@ -9009,6 +9009,9 @@ static int i40e_ndo_netpolicy_init(struct net_device *dev,
        /* support MIX policy */
        info->has_mix_policy = true;
 
+       /* support queue pair */
+       info->queue_pair = true;
+
        return 0;
 }
 
diff --git a/include/linux/netpolicy.h b/include/linux/netpolicy.h
index fa740b5..2de59a6 100644
--- a/include/linux/netpolicy.h
+++ b/include/linux/netpolicy.h
@@ -75,6 +75,7 @@ struct netpolicy_info {
        enum netpolicy_name     cur_policy;
        unsigned long avail_policy[BITS_TO_LONGS(NET_POLICY_MAX)];
        bool    has_mix_policy;
+       bool    queue_pair;
        /* cpu and queue mapping information */
        struct netpolicy_sys_info       sys_info;
        /* List of policy objects 0 rx 1 tx */
diff --git a/net/core/netpolicy.c b/net/core/netpolicy.c
index a63ccd4..83242d3 100644
--- a/net/core/netpolicy.c
+++ b/net/core/netpolicy.c
@@ -398,6 +398,9 @@ int netpolicy_pick_queue(struct netpolicy_reg *reg, bool 
is_rx)
            (current->task_netpolicy.policy != reg->policy))
                return -EINVAL;
 
+       if (dev->netpolicy->queue_pair)
+               is_rx = true;
+
        /* fast path */
        read_lock(&np_sys_map_lock);
        if (netpolicy_sys_map_version == reg->sys_map_version) {
-- 
2.5.5

Reply via email to