aboutsummaryrefslogtreecommitdiffstats
path: root/net/core
diff options
context:
space:
mode:
authorJiri Pirko <jiri@mellanox.com>2016-07-04 02:23:12 -0400
committerDavid S. Miller <davem@davemloft.net>2016-07-04 21:25:15 -0400
commit7ce856aaaf13a5dc969ac5f998e5daaf1abe4cd2 (patch)
tree0f35230adc52699ef4949d4515e6ffc01422f916 /net/core
parent61c503f976b5449e6d7d31f74adbc29d6ce06125 (diff)
mlxsw: spectrum: Add couple of lower device helper functions
Add functions that iterate over lower devices and find port device. As a dependency add netdev_for_each_all_lower_dev and netdev_for_each_all_lower_dev_rcu macro with netdev_all_lower_get_next and netdev_all_lower_get_next_rcu shelpers. Also, add functions to return mlxsw struct according to lower device found and mlxsw_port struct with a reference to lower device. Signed-off-by: Jiri Pirko <jiri@mellanox.com> Reviewed-by: Ido Schimmel <idosch@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core')
-rw-r--r--net/core/dev.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/net/core/dev.c b/net/core/dev.c
index aba10d2a8bc3..a4f3b0a9aeaf 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -5445,6 +5445,52 @@ void *netdev_lower_get_next(struct net_device *dev, struct list_head **iter)
5445EXPORT_SYMBOL(netdev_lower_get_next); 5445EXPORT_SYMBOL(netdev_lower_get_next);
5446 5446
5447/** 5447/**
5448 * netdev_all_lower_get_next - Get the next device from all lower neighbour list
5449 * @dev: device
5450 * @iter: list_head ** of the current position
5451 *
5452 * Gets the next netdev_adjacent from the dev's all lower neighbour
5453 * list, starting from iter position. The caller must hold RTNL lock or
5454 * its own locking that guarantees that the neighbour all lower
5455 * list will remain unchanged.
5456 */
5457struct net_device *netdev_all_lower_get_next(struct net_device *dev, struct list_head **iter)
5458{
5459 struct netdev_adjacent *lower;
5460
5461 lower = list_entry(*iter, struct netdev_adjacent, list);
5462
5463 if (&lower->list == &dev->all_adj_list.lower)
5464 return NULL;
5465
5466 *iter = lower->list.next;
5467
5468 return lower->dev;
5469}
5470EXPORT_SYMBOL(netdev_all_lower_get_next);
5471
5472/**
5473 * netdev_all_lower_get_next_rcu - Get the next device from all
5474 * lower neighbour list, RCU variant
5475 * @dev: device
5476 * @iter: list_head ** of the current position
5477 *
5478 * Gets the next netdev_adjacent from the dev's all lower neighbour
5479 * list, starting from iter position. The caller must hold RCU read lock.
5480 */
5481struct net_device *netdev_all_lower_get_next_rcu(struct net_device *dev,
5482 struct list_head **iter)
5483{
5484 struct netdev_adjacent *lower;
5485
5486 lower = list_first_or_null_rcu(&dev->all_adj_list.lower,
5487 struct netdev_adjacent, list);
5488
5489 return lower ? lower->dev : NULL;
5490}
5491EXPORT_SYMBOL(netdev_all_lower_get_next_rcu);
5492
5493/**
5448 * netdev_lower_get_first_private_rcu - Get the first ->private from the 5494 * netdev_lower_get_first_private_rcu - Get the first ->private from the
5449 * lower neighbour list, RCU 5495 * lower neighbour list, RCU
5450 * variant 5496 * variant