net: netdevice: Add operation ndo_sk_get_lower_dev
authorTariq Toukan <tariqt@nvidia.com>
Sun, 17 Jan 2021 14:59:42 +0000 (16:59 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 19 Jan 2021 04:48:39 +0000 (20:48 -0800)
ndo_sk_get_lower_dev returns the lower netdev that corresponds to
a given socket.
Additionally, we implement a helper netdev_sk_get_lowest_dev() to get
the lowest one in chain.

Signed-off-by: Tariq Toukan <tariqt@nvidia.com>
Reviewed-by: Boris Pismenny <borisp@nvidia.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/linux/netdevice.h
net/core/dev.c

index 5b949076ed2319fc676a7172350480efea5807d9..02dcef4d66e2e6faf081952e687e6f12d3d5980c 100644 (file)
@@ -1398,6 +1398,8 @@ struct net_device_ops {
        struct net_device*      (*ndo_get_xmit_slave)(struct net_device *dev,
                                                      struct sk_buff *skb,
                                                      bool all_slaves);
+       struct net_device*      (*ndo_sk_get_lower_dev)(struct net_device *dev,
+                                                       struct sock *sk);
        netdev_features_t       (*ndo_fix_features)(struct net_device *dev,
                                                    netdev_features_t features);
        int                     (*ndo_set_features)(struct net_device *dev,
@@ -2858,6 +2860,8 @@ int init_dummy_netdev(struct net_device *dev);
 struct net_device *netdev_get_xmit_slave(struct net_device *dev,
                                         struct sk_buff *skb,
                                         bool all_slaves);
+struct net_device *netdev_sk_get_lowest_dev(struct net_device *dev,
+                                           struct sock *sk);
 struct net_device *dev_get_by_index(struct net *net, int ifindex);
 struct net_device *__dev_get_by_index(struct net *net, int ifindex);
 struct net_device *dev_get_by_index_rcu(struct net *net, int ifindex);
index bae35c1ae192897d8fc5d514a9b701bd6cee988c..6b90520a01b197ece227e564e358044952e80d4c 100644 (file)
@@ -8105,6 +8105,39 @@ struct net_device *netdev_get_xmit_slave(struct net_device *dev,
 }
 EXPORT_SYMBOL(netdev_get_xmit_slave);
 
+static struct net_device *netdev_sk_get_lower_dev(struct net_device *dev,
+                                                 struct sock *sk)
+{
+       const struct net_device_ops *ops = dev->netdev_ops;
+
+       if (!ops->ndo_sk_get_lower_dev)
+               return NULL;
+       return ops->ndo_sk_get_lower_dev(dev, sk);
+}
+
+/**
+ * netdev_sk_get_lowest_dev - Get the lowest device in chain given device and socket
+ * @dev: device
+ * @sk: the socket
+ *
+ * %NULL is returned if no lower device is found.
+ */
+
+struct net_device *netdev_sk_get_lowest_dev(struct net_device *dev,
+                                           struct sock *sk)
+{
+       struct net_device *lower;
+
+       lower = netdev_sk_get_lower_dev(dev, sk);
+       while (lower) {
+               dev = lower;
+               lower = netdev_sk_get_lower_dev(dev, sk);
+       }
+
+       return dev;
+}
+EXPORT_SYMBOL(netdev_sk_get_lowest_dev);
+
 static void netdev_adjacent_add_links(struct net_device *dev)
 {
        struct netdev_adjacent *iter;