netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net-next v2 0/3] switchdev: add swdev ops
@ 2015-03-16  1:45 sfeldma
  2015-03-16  1:45 ` [PATCH net-next v2 1/3] " sfeldma
                   ` (3 more replies)
  0 siblings, 4 replies; 9+ messages in thread
From: sfeldma @ 2015-03-16  1:45 UTC (permalink / raw)
  To: netdev; +Cc: jiri, roopa, simon.horman

From: Scott Feldman <sfeldma@gmail.com>

v2:

 - Per Simon's review, squash some of the dependent commits into one to
   make series git bisect safe.

v1:

Per discussions at netconf, move switchdev ndo ops to a new swdev_ops to
keep ndo namespace clean and maintain switchdev-related ops into one place.

There are no functional changes here; just shuffling ops around for better
organization.

Scott Feldman (3):
  switchdev: add swdev ops
  switchdev: use new swdev ops
  netdev: remove ndo ops for switchdev

 drivers/net/ethernet/rocker/rocker.c |   64 +++++++++++++++++++---------------
 include/linux/netdevice.h            |   41 ++--------------------
 include/net/switchdev.h              |   38 ++++++++++++++++++++
 net/dsa/slave.c                      |    8 +++--
 net/switchdev/switchdev.c            |   42 +++++++++++-----------
 5 files changed, 104 insertions(+), 89 deletions(-)

-- 
1.7.10.4

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH net-next v2 1/3] switchdev: add swdev ops
  2015-03-16  1:45 [PATCH net-next v2 0/3] switchdev: add swdev ops sfeldma
@ 2015-03-16  1:45 ` sfeldma
  2015-03-20 23:00   ` Ben Hutchings
  2015-03-16  1:45 ` [PATCH net-next v2 2/3] switchdev: use new " sfeldma
                   ` (2 subsequent siblings)
  3 siblings, 1 reply; 9+ messages in thread
From: sfeldma @ 2015-03-16  1:45 UTC (permalink / raw)
  To: netdev; +Cc: jiri, roopa, simon.horman

From: Scott Feldman <sfeldma@gmail.com>

As discussed at netconf, introduce swdev_ops as first step to move switchdev
ops from ndo to swdev.  This will keep switchdev from cluttering up ndo ops
space.

Signed-off-by: Scott Feldman <sfeldma@gmail.com>
---
 include/linux/netdevice.h |    3 +++
 include/net/switchdev.h   |   38 ++++++++++++++++++++++++++++++++++++++
 2 files changed, 41 insertions(+)

diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index ddab1a2..9e8a2a9 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -1577,6 +1577,9 @@ struct net_device {
 	const struct net_device_ops *netdev_ops;
 	const struct ethtool_ops *ethtool_ops;
 	const struct forwarding_accel_ops *fwd_ops;
+#ifdef CONFIG_NET_SWITCHDEV
+	const struct swdev_ops *swdev_ops;
+#endif
 
 	const struct header_ops *header_ops;
 
diff --git a/include/net/switchdev.h b/include/net/switchdev.h
index 1a9382f..e5de53f 100644
--- a/include/net/switchdev.h
+++ b/include/net/switchdev.h
@@ -14,6 +14,44 @@
 #include <linux/netdevice.h>
 #include <linux/notifier.h>
 
+struct fib_info;
+
+/**
+ * struct switchdev_ops - switchdev operations
+ *
+ * int (*swdev_parent_id_get)(struct net_device *dev,
+ *			      struct netdev_phys_item_id *psid);
+ *	Called to get an ID of the switch chip this port is part of.
+ *	If driver implements this, it indicates that it represents a port
+ *	of a switch chip.
+ *
+ * int (*swdev_port_stp_update)(struct net_device *dev, u8 state);
+ *	Called to notify switch device port of bridge port STP
+ *	state change.
+ *
+ * int (*swdev_fib_ipv4_add)(struct net_device *dev, __be32 dst,
+ *			     int dst_len, struct fib_info *fi,
+ *			     u8 tos, u8 type, u32 nlflags, u32 tb_id);
+ *	Called to add/modify IPv4 route to switch device.
+ *
+ * int (*swdev_fib_ipv4_del)(struct net_device *dev, __be32 dst,
+ *			     int dst_len, struct fib_info *fi,
+ *			     u8 tos, u8 type, u32 tb_id);
+ *	Called to delete IPv4 route from switch device.
+ */
+struct swdev_ops {
+	int	(*swdev_parent_id_get)(struct net_device *dev,
+				       struct netdev_phys_item_id *psid);
+	int	(*swdev_port_stp_update)(struct net_device *dev, u8 state);
+	int	(*swdev_fib_ipv4_add)(struct net_device *dev, __be32 dst,
+				      int dst_len, struct fib_info *fi,
+				      u8 tos, u8 type, u32 nlflags,
+				      u32 tb_id);
+	int	(*swdev_fib_ipv4_del)(struct net_device *dev, __be32 dst,
+				      int dst_len, struct fib_info *fi,
+				      u8 tos, u8 type, u32 tb_id);
+};
+
 enum netdev_switch_notifier_type {
 	NETDEV_SWITCH_FDB_ADD = 1,
 	NETDEV_SWITCH_FDB_DEL,
-- 
1.7.10.4

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH net-next v2 2/3] switchdev: use new swdev ops
  2015-03-16  1:45 [PATCH net-next v2 0/3] switchdev: add swdev ops sfeldma
  2015-03-16  1:45 ` [PATCH net-next v2 1/3] " sfeldma
@ 2015-03-16  1:45 ` sfeldma
  2015-03-16  1:45 ` [PATCH net-next v2 3/3] netdev: remove ndo ops for switchdev sfeldma
  2015-03-16  1:51 ` [PATCH net-next v2 0/3] switchdev: add swdev ops David Miller
  3 siblings, 0 replies; 9+ messages in thread
From: sfeldma @ 2015-03-16  1:45 UTC (permalink / raw)
  To: netdev; +Cc: jiri, roopa, simon.horman

From: Scott Feldman <sfeldma@gmail.com>

Move swdev wrappers over to new swdev ops (from previous ndo ops).  No
functional changes to the implementation.

Signed-off-by: Scott Feldman <sfeldma@gmail.com>

rocker: move to new swdev ops

Signed-off-by: Scott Feldman <sfeldma@gmail.com>

dsa: move to new swdev ops

Signed-off-by: Scott Feldman <sfeldma@gmail.com>
---
 drivers/net/ethernet/rocker/rocker.c |   64 +++++++++++++++++++---------------
 net/dsa/slave.c                      |    8 +++--
 net/switchdev/switchdev.c            |   42 +++++++++++-----------
 3 files changed, 63 insertions(+), 51 deletions(-)

diff --git a/drivers/net/ethernet/rocker/rocker.c b/drivers/net/ethernet/rocker/rocker.c
index 223348d..bc5f27a 100644
--- a/drivers/net/ethernet/rocker/rocker.c
+++ b/drivers/net/ethernet/rocker/rocker.c
@@ -4131,8 +4131,26 @@ static int rocker_port_bridge_getlink(struct sk_buff *skb, u32 pid, u32 seq,
 				       rocker_port->brport_flags, mask);
 }
 
-static int rocker_port_switch_parent_id_get(struct net_device *dev,
-					    struct netdev_phys_item_id *psid)
+static const struct net_device_ops rocker_port_netdev_ops = {
+	.ndo_open			= rocker_port_open,
+	.ndo_stop			= rocker_port_stop,
+	.ndo_start_xmit			= rocker_port_xmit,
+	.ndo_set_mac_address		= rocker_port_set_mac_address,
+	.ndo_vlan_rx_add_vid		= rocker_port_vlan_rx_add_vid,
+	.ndo_vlan_rx_kill_vid		= rocker_port_vlan_rx_kill_vid,
+	.ndo_fdb_add			= rocker_port_fdb_add,
+	.ndo_fdb_del			= rocker_port_fdb_del,
+	.ndo_fdb_dump			= rocker_port_fdb_dump,
+	.ndo_bridge_setlink		= rocker_port_bridge_setlink,
+	.ndo_bridge_getlink		= rocker_port_bridge_getlink,
+};
+
+/********************
+ * swdev interface
+ ********************/
+
+static int rocker_port_swdev_parent_id_get(struct net_device *dev,
+					   struct netdev_phys_item_id *psid)
 {
 	struct rocker_port *rocker_port = netdev_priv(dev);
 	struct rocker *rocker = rocker_port->rocker;
@@ -4142,18 +4160,18 @@ static int rocker_port_switch_parent_id_get(struct net_device *dev,
 	return 0;
 }
 
-static int rocker_port_switch_port_stp_update(struct net_device *dev, u8 state)
+static int rocker_port_swdev_port_stp_update(struct net_device *dev, u8 state)
 {
 	struct rocker_port *rocker_port = netdev_priv(dev);
 
 	return rocker_port_stp_update(rocker_port, state);
 }
 
-static int rocker_port_switch_fib_ipv4_add(struct net_device *dev,
-					   __be32 dst, int dst_len,
-					   struct fib_info *fi,
-					   u8 tos, u8 type,
-					   u32 nlflags, u32 tb_id)
+static int rocker_port_swdev_fib_ipv4_add(struct net_device *dev,
+					  __be32 dst, int dst_len,
+					  struct fib_info *fi,
+					  u8 tos, u8 type,
+					  u32 nlflags, u32 tb_id)
 {
 	struct rocker_port *rocker_port = netdev_priv(dev);
 	int flags = 0;
@@ -4162,10 +4180,10 @@ static int rocker_port_switch_fib_ipv4_add(struct net_device *dev,
 				    fi, tb_id, flags);
 }
 
-static int rocker_port_switch_fib_ipv4_del(struct net_device *dev,
-					   __be32 dst, int dst_len,
-					   struct fib_info *fi,
-					   u8 tos, u8 type, u32 tb_id)
+static int rocker_port_swdev_fib_ipv4_del(struct net_device *dev,
+					  __be32 dst, int dst_len,
+					  struct fib_info *fi,
+					  u8 tos, u8 type, u32 tb_id)
 {
 	struct rocker_port *rocker_port = netdev_priv(dev);
 	int flags = ROCKER_OP_FLAG_REMOVE;
@@ -4174,22 +4192,11 @@ static int rocker_port_switch_fib_ipv4_del(struct net_device *dev,
 				    fi, tb_id, flags);
 }
 
-static const struct net_device_ops rocker_port_netdev_ops = {
-	.ndo_open			= rocker_port_open,
-	.ndo_stop			= rocker_port_stop,
-	.ndo_start_xmit			= rocker_port_xmit,
-	.ndo_set_mac_address		= rocker_port_set_mac_address,
-	.ndo_vlan_rx_add_vid		= rocker_port_vlan_rx_add_vid,
-	.ndo_vlan_rx_kill_vid		= rocker_port_vlan_rx_kill_vid,
-	.ndo_fdb_add			= rocker_port_fdb_add,
-	.ndo_fdb_del			= rocker_port_fdb_del,
-	.ndo_fdb_dump			= rocker_port_fdb_dump,
-	.ndo_bridge_setlink		= rocker_port_bridge_setlink,
-	.ndo_bridge_getlink		= rocker_port_bridge_getlink,
-	.ndo_switch_parent_id_get	= rocker_port_switch_parent_id_get,
-	.ndo_switch_port_stp_update	= rocker_port_switch_port_stp_update,
-	.ndo_switch_fib_ipv4_add	= rocker_port_switch_fib_ipv4_add,
-	.ndo_switch_fib_ipv4_del	= rocker_port_switch_fib_ipv4_del,
+static const struct swdev_ops rocker_port_swdev_ops = {
+	.swdev_parent_id_get		= rocker_port_swdev_parent_id_get,
+	.swdev_port_stp_update		= rocker_port_swdev_port_stp_update,
+	.swdev_fib_ipv4_add		= rocker_port_swdev_fib_ipv4_add,
+	.swdev_fib_ipv4_del		= rocker_port_swdev_fib_ipv4_del,
 };
 
 /********************
@@ -4544,6 +4551,7 @@ static int rocker_probe_port(struct rocker *rocker, unsigned int port_number)
 	rocker_port_dev_addr_init(rocker, rocker_port);
 	dev->netdev_ops = &rocker_port_netdev_ops;
 	dev->ethtool_ops = &rocker_port_ethtool_ops;
+	dev->swdev_ops = &rocker_port_swdev_ops;
 	netif_napi_add(dev, &rocker_port->napi_tx, rocker_port_poll_tx,
 		       NAPI_POLL_WEIGHT);
 	netif_napi_add(dev, &rocker_port->napi_rx, rocker_port_poll_rx,
diff --git a/net/dsa/slave.c b/net/dsa/slave.c
index 6511552..2138d99 100644
--- a/net/dsa/slave.c
+++ b/net/dsa/slave.c
@@ -572,8 +572,11 @@ static const struct net_device_ops dsa_slave_netdev_ops = {
 	.ndo_set_rx_mode	= dsa_slave_set_rx_mode,
 	.ndo_set_mac_address	= dsa_slave_set_mac_address,
 	.ndo_do_ioctl		= dsa_slave_ioctl,
-	.ndo_switch_parent_id_get = dsa_slave_parent_id_get,
-	.ndo_switch_port_stp_update = dsa_slave_stp_update,
+};
+
+static const struct swdev_ops dsa_slave_swdev_ops = {
+	.swdev_parent_id_get = dsa_slave_parent_id_get,
+	.swdev_port_stp_update = dsa_slave_stp_update,
 };
 
 static void dsa_slave_adjust_link(struct net_device *dev)
@@ -755,6 +758,7 @@ int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
 	eth_hw_addr_inherit(slave_dev, master);
 	slave_dev->tx_queue_len = 0;
 	slave_dev->netdev_ops = &dsa_slave_netdev_ops;
+	slave_dev->swdev_ops = &dsa_slave_swdev_ops;
 
 	SET_NETDEV_DEV(slave_dev, parent);
 	slave_dev->dev.of_node = ds->pd->port_dn[port];
diff --git a/net/switchdev/switchdev.c b/net/switchdev/switchdev.c
index b7a2313..c9bfa00 100644
--- a/net/switchdev/switchdev.c
+++ b/net/switchdev/switchdev.c
@@ -28,11 +28,11 @@
 int netdev_switch_parent_id_get(struct net_device *dev,
 				struct netdev_phys_item_id *psid)
 {
-	const struct net_device_ops *ops = dev->netdev_ops;
+	const struct swdev_ops *ops = dev->swdev_ops;
 
-	if (!ops->ndo_switch_parent_id_get)
+	if (!ops || !ops->swdev_parent_id_get)
 		return -EOPNOTSUPP;
-	return ops->ndo_switch_parent_id_get(dev, psid);
+	return ops->swdev_parent_id_get(dev, psid);
 }
 EXPORT_SYMBOL_GPL(netdev_switch_parent_id_get);
 
@@ -46,12 +46,12 @@ EXPORT_SYMBOL_GPL(netdev_switch_parent_id_get);
  */
 int netdev_switch_port_stp_update(struct net_device *dev, u8 state)
 {
-	const struct net_device_ops *ops = dev->netdev_ops;
+	const struct swdev_ops *ops = dev->swdev_ops;
 
-	if (!ops->ndo_switch_port_stp_update)
+	if (!ops || !ops->swdev_port_stp_update)
 		return -EOPNOTSUPP;
-	WARN_ON(!ops->ndo_switch_parent_id_get);
-	return ops->ndo_switch_port_stp_update(dev, state);
+	WARN_ON(!ops->swdev_parent_id_get);
+	return ops->swdev_port_stp_update(dev, state);
 }
 EXPORT_SYMBOL_GPL(netdev_switch_port_stp_update);
 
@@ -230,17 +230,17 @@ EXPORT_SYMBOL_GPL(ndo_dflt_netdev_switch_port_bridge_dellink);
 
 static struct net_device *netdev_switch_get_lowest_dev(struct net_device *dev)
 {
-	const struct net_device_ops *ops = dev->netdev_ops;
+	const struct swdev_ops *ops = dev->swdev_ops;
 	struct net_device *lower_dev;
 	struct net_device *port_dev;
 	struct list_head *iter;
 
 	/* Recusively search down until we find a sw port dev.
-	 * (A sw port dev supports ndo_switch_parent_id_get).
+	 * (A sw port dev supports swdev_parent_id_get).
 	 */
 
 	if (dev->features & NETIF_F_HW_SWITCH_OFFLOAD &&
-	    ops->ndo_switch_parent_id_get)
+	    ops && ops->swdev_parent_id_get)
 		return dev;
 
 	netdev_for_each_lower_dev(dev, lower_dev, iter) {
@@ -304,7 +304,7 @@ int netdev_switch_fib_ipv4_add(u32 dst, int dst_len, struct fib_info *fi,
 			       u8 tos, u8 type, u32 nlflags, u32 tb_id)
 {
 	struct net_device *dev;
-	const struct net_device_ops *ops;
+	const struct swdev_ops *ops;
 	int err = 0;
 
 	/* Don't offload route if using custom ip rules or if
@@ -322,12 +322,12 @@ int netdev_switch_fib_ipv4_add(u32 dst, int dst_len, struct fib_info *fi,
 	dev = netdev_switch_get_dev_by_nhs(fi);
 	if (!dev)
 		return 0;
-	ops = dev->netdev_ops;
+	ops = dev->swdev_ops;
 
-	if (ops->ndo_switch_fib_ipv4_add) {
-		err = ops->ndo_switch_fib_ipv4_add(dev, htonl(dst), dst_len,
-						   fi, tos, type, nlflags,
-						   tb_id);
+	if (ops->swdev_fib_ipv4_add) {
+		err = ops->swdev_fib_ipv4_add(dev, htonl(dst), dst_len,
+					      fi, tos, type, nlflags,
+					      tb_id);
 		if (!err)
 			fi->fib_flags |= RTNH_F_EXTERNAL;
 	}
@@ -352,7 +352,7 @@ int netdev_switch_fib_ipv4_del(u32 dst, int dst_len, struct fib_info *fi,
 			       u8 tos, u8 type, u32 tb_id)
 {
 	struct net_device *dev;
-	const struct net_device_ops *ops;
+	const struct swdev_ops *ops;
 	int err = 0;
 
 	if (!(fi->fib_flags & RTNH_F_EXTERNAL))
@@ -361,11 +361,11 @@ int netdev_switch_fib_ipv4_del(u32 dst, int dst_len, struct fib_info *fi,
 	dev = netdev_switch_get_dev_by_nhs(fi);
 	if (!dev)
 		return 0;
-	ops = dev->netdev_ops;
+	ops = dev->swdev_ops;
 
-	if (ops->ndo_switch_fib_ipv4_del) {
-		err = ops->ndo_switch_fib_ipv4_del(dev, htonl(dst), dst_len,
-						   fi, tos, type, tb_id);
+	if (ops->swdev_fib_ipv4_del) {
+		err = ops->swdev_fib_ipv4_del(dev, htonl(dst), dst_len,
+					      fi, tos, type, tb_id);
 		if (!err)
 			fi->fib_flags &= ~RTNH_F_EXTERNAL;
 	}
-- 
1.7.10.4

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH net-next v2 3/3] netdev: remove ndo ops for switchdev
  2015-03-16  1:45 [PATCH net-next v2 0/3] switchdev: add swdev ops sfeldma
  2015-03-16  1:45 ` [PATCH net-next v2 1/3] " sfeldma
  2015-03-16  1:45 ` [PATCH net-next v2 2/3] switchdev: use new " sfeldma
@ 2015-03-16  1:45 ` sfeldma
  2015-03-16  1:51 ` [PATCH net-next v2 0/3] switchdev: add swdev ops David Miller
  3 siblings, 0 replies; 9+ messages in thread
From: sfeldma @ 2015-03-16  1:45 UTC (permalink / raw)
  To: netdev; +Cc: jiri, roopa, simon.horman

From: Scott Feldman <sfeldma@gmail.com>

Signed-off-by: Scott Feldman <sfeldma@gmail.com>
---
 include/linux/netdevice.h |   38 --------------------------------------
 1 file changed, 38 deletions(-)

diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index 9e8a2a9..dd1d069 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -768,8 +768,6 @@ struct netdev_phys_item_id {
 typedef u16 (*select_queue_fallback_t)(struct net_device *dev,
 				       struct sk_buff *skb);
 
-struct fib_info;
-
 /*
  * This structure defines the management hooks for network devices.
  * The following hooks can be defined; unless noted otherwise, they are
@@ -1024,23 +1022,6 @@ struct fib_info;
  *	be otherwise expressed by feature flags. The check is called with
  *	the set of features that the stack has calculated and it returns
  *	those the driver believes to be appropriate.
- *
- * int (*ndo_switch_parent_id_get)(struct net_device *dev,
- *				   struct netdev_phys_item_id *psid);
- *	Called to get an ID of the switch chip this port is part of.
- *	If driver implements this, it indicates that it represents a port
- *	of a switch chip.
- * int (*ndo_switch_port_stp_update)(struct net_device *dev, u8 state);
- *	Called to notify switch device port of bridge port STP
- *	state change.
- * int (*ndo_sw_parent_fib_ipv4_add)(struct net_device *dev, __be32 dst,
- *				     int dst_len, struct fib_info *fi,
- *				     u8 tos, u8 type, u32 nlflags, u32 tb_id);
- *	Called to add/modify IPv4 route to switch device.
- * int (*ndo_sw_parent_fib_ipv4_del)(struct net_device *dev, __be32 dst,
- *				     int dst_len, struct fib_info *fi,
- *				     u8 tos, u8 type, u32 tb_id);
- *	Called to delete IPv4 route from switch device.
  */
 struct net_device_ops {
 	int			(*ndo_init)(struct net_device *dev);
@@ -1197,25 +1178,6 @@ struct net_device_ops {
 	netdev_features_t	(*ndo_features_check) (struct sk_buff *skb,
 						       struct net_device *dev,
 						       netdev_features_t features);
-#ifdef CONFIG_NET_SWITCHDEV
-	int			(*ndo_switch_parent_id_get)(struct net_device *dev,
-							    struct netdev_phys_item_id *psid);
-	int			(*ndo_switch_port_stp_update)(struct net_device *dev,
-							      u8 state);
-	int			(*ndo_switch_fib_ipv4_add)(struct net_device *dev,
-							   __be32 dst,
-							   int dst_len,
-							   struct fib_info *fi,
-							   u8 tos, u8 type,
-							   u32 nlflags,
-							   u32 tb_id);
-	int			(*ndo_switch_fib_ipv4_del)(struct net_device *dev,
-							   __be32 dst,
-							   int dst_len,
-							   struct fib_info *fi,
-							   u8 tos, u8 type,
-							   u32 tb_id);
-#endif
 };
 
 /**
-- 
1.7.10.4

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH net-next v2 0/3] switchdev: add swdev ops
  2015-03-16  1:45 [PATCH net-next v2 0/3] switchdev: add swdev ops sfeldma
                   ` (2 preceding siblings ...)
  2015-03-16  1:45 ` [PATCH net-next v2 3/3] netdev: remove ndo ops for switchdev sfeldma
@ 2015-03-16  1:51 ` David Miller
  2015-03-16  1:55   ` David Miller
  3 siblings, 1 reply; 9+ messages in thread
From: David Miller @ 2015-03-16  1:51 UTC (permalink / raw)
  To: sfeldma; +Cc: netdev, jiri, roopa, simon.horman

From: sfeldma@gmail.com
Date: Sun, 15 Mar 2015 18:45:18 -0700

> v2:
> 
>  - Per Simon's review, squash some of the dependent commits into one to
>    make series git bisect safe.
> 
> v1:
> 
> Per discussions at netconf, move switchdev ndo ops to a new swdev_ops to
> keep ndo namespace clean and maintain switchdev-related ops into one place.
> 
> There are no functional changes here; just shuffling ops around for better
> organization.

This looks a lot better, series applied.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH net-next v2 0/3] switchdev: add swdev ops
  2015-03-16  1:51 ` [PATCH net-next v2 0/3] switchdev: add swdev ops David Miller
@ 2015-03-16  1:55   ` David Miller
  0 siblings, 0 replies; 9+ messages in thread
From: David Miller @ 2015-03-16  1:55 UTC (permalink / raw)
  To: sfeldma; +Cc: netdev, jiri, roopa, simon.horman

From: David Miller <davem@davemloft.net>
Date: Sun, 15 Mar 2015 21:51:31 -0400 (EDT)

> From: sfeldma@gmail.com
> Date: Sun, 15 Mar 2015 18:45:18 -0700
> 
>> v2:
>> 
>>  - Per Simon's review, squash some of the dependent commits into one to
>>    make series git bisect safe.
>> 
>> v1:
>> 
>> Per discussions at netconf, move switchdev ndo ops to a new swdev_ops to
>> keep ndo namespace clean and maintain switchdev-related ops into one place.
>> 
>> There are no functional changes here; just shuffling ops around for better
>> organization.
> 
> This looks a lot better, series applied.

Actually, reverted.

DSA doesn't build, I think you need to add a missing include
or something.

net/dsa/slave.c:577:21: error: variable ‘dsa_slave_swdev_ops’ has initializer but incomplete type
 static const struct swdev_ops dsa_slave_swdev_ops = {
                     ^
net/dsa/slave.c:578:2: error: unknown field ‘swdev_parent_id_get’ specified in initializer
  .swdev_parent_id_get = dsa_slave_parent_id_get,
  ^

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH net-next v2 1/3] switchdev: add swdev ops
  2015-03-16  1:45 ` [PATCH net-next v2 1/3] " sfeldma
@ 2015-03-20 23:00   ` Ben Hutchings
  2015-03-20 23:58     ` Scott Feldman
  0 siblings, 1 reply; 9+ messages in thread
From: Ben Hutchings @ 2015-03-20 23:00 UTC (permalink / raw)
  To: sfeldma; +Cc: netdev, jiri, roopa, simon.horman

[-- Attachment #1: Type: text/plain, Size: 1152 bytes --]

On Sun, 2015-03-15 at 18:45 -0700, sfeldma@gmail.com wrote:
[...]
> +/**
> + * struct switchdev_ops - switchdev operations
> + *
> + * int (*swdev_parent_id_get)(struct net_device *dev,
> + *			      struct netdev_phys_item_id *psid);
> + *	Called to get an ID of the switch chip this port is part of.
> + *	If driver implements this, it indicates that it represents a port
> + *	of a switch chip.
> + *
> + * int (*swdev_port_stp_update)(struct net_device *dev, u8 state);
> + *	Called to notify switch device port of bridge port STP
> + *	state change.
> + *
> + * int (*swdev_fib_ipv4_add)(struct net_device *dev, __be32 dst,
> + *			     int dst_len, struct fib_info *fi,
> + *			     u8 tos, u8 type, u32 nlflags, u32 tb_id);
> + *	Called to add/modify IPv4 route to switch device.
> + *
> + * int (*swdev_fib_ipv4_del)(struct net_device *dev, __be32 dst,
> + *			     int dst_len, struct fib_info *fi,
> + *			     u8 tos, u8 type, u32 tb_id);
> + *	Called to delete IPv4 route from switch device.
[...]

This isn't correct kernel-doc syntax.

Ben.

-- 
Ben Hutchings
All extremists should be taken out and shot.

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 811 bytes --]

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH net-next v2 1/3] switchdev: add swdev ops
  2015-03-20 23:00   ` Ben Hutchings
@ 2015-03-20 23:58     ` Scott Feldman
  2015-03-21  0:04       ` Ben Hutchings
  0 siblings, 1 reply; 9+ messages in thread
From: Scott Feldman @ 2015-03-20 23:58 UTC (permalink / raw)
  To: Ben Hutchings
  Cc: Netdev, Jiří Pírko, Roopa Prabhu,
	simon.horman@netronome.com

On Fri, Mar 20, 2015 at 4:00 PM, Ben Hutchings <ben@decadent.org.uk> wrote:
> On Sun, 2015-03-15 at 18:45 -0700, sfeldma@gmail.com wrote:
> [...]
>> +/**
>> + * struct switchdev_ops - switchdev operations
>> + *
>> + * int (*swdev_parent_id_get)(struct net_device *dev,
>> + *                         struct netdev_phys_item_id *psid);
>> + *   Called to get an ID of the switch chip this port is part of.
>> + *   If driver implements this, it indicates that it represents a port
>> + *   of a switch chip.
>> + *
>> + * int (*swdev_port_stp_update)(struct net_device *dev, u8 state);
>> + *   Called to notify switch device port of bridge port STP
>> + *   state change.
>> + *
>> + * int (*swdev_fib_ipv4_add)(struct net_device *dev, __be32 dst,
>> + *                        int dst_len, struct fib_info *fi,
>> + *                        u8 tos, u8 type, u32 nlflags, u32 tb_id);
>> + *   Called to add/modify IPv4 route to switch device.
>> + *
>> + * int (*swdev_fib_ipv4_del)(struct net_device *dev, __be32 dst,
>> + *                        int dst_len, struct fib_info *fi,
>> + *                        u8 tos, u8 type, u32 tb_id);
>> + *   Called to delete IPv4 route from switch device.
> [...]
>
> This isn't correct kernel-doc syntax.

It was a cut-and-paste from netdevice.h.  Give me an example of
correct syntax, and I'll fix these.

-scott

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH net-next v2 1/3] switchdev: add swdev ops
  2015-03-20 23:58     ` Scott Feldman
@ 2015-03-21  0:04       ` Ben Hutchings
  0 siblings, 0 replies; 9+ messages in thread
From: Ben Hutchings @ 2015-03-21  0:04 UTC (permalink / raw)
  To: Scott Feldman
  Cc: Netdev, Jiří Pírko, Roopa Prabhu,
	simon.horman@netronome.com

[-- Attachment #1: Type: text/plain, Size: 1848 bytes --]

On Fri, 2015-03-20 at 16:58 -0700, Scott Feldman wrote:
> On Fri, Mar 20, 2015 at 4:00 PM, Ben Hutchings <ben@decadent.org.uk> wrote:
> > On Sun, 2015-03-15 at 18:45 -0700, sfeldma@gmail.com wrote:
> > [...]
> >> +/**
> >> + * struct switchdev_ops - switchdev operations
> >> + *
> >> + * int (*swdev_parent_id_get)(struct net_device *dev,
> >> + *                         struct netdev_phys_item_id *psid);
> >> + *   Called to get an ID of the switch chip this port is part of.
> >> + *   If driver implements this, it indicates that it represents a port
> >> + *   of a switch chip.
> >> + *
> >> + * int (*swdev_port_stp_update)(struct net_device *dev, u8 state);
> >> + *   Called to notify switch device port of bridge port STP
> >> + *   state change.
> >> + *
> >> + * int (*swdev_fib_ipv4_add)(struct net_device *dev, __be32 dst,
> >> + *                        int dst_len, struct fib_info *fi,
> >> + *                        u8 tos, u8 type, u32 nlflags, u32 tb_id);
> >> + *   Called to add/modify IPv4 route to switch device.
> >> + *
> >> + * int (*swdev_fib_ipv4_del)(struct net_device *dev, __be32 dst,
> >> + *                        int dst_len, struct fib_info *fi,
> >> + *                        u8 tos, u8 type, u32 tb_id);
> >> + *   Called to delete IPv4 route from switch device.
> > [...]
> >
> > This isn't correct kernel-doc syntax.
> 
> It was a cut-and-paste from netdevice.h.  Give me an example of
> correct syntax, and I'll fix these.

/**
 * struct switchdev_ops - switchdev operations
 * @swdev_parent_id_get: Called to get an ID of the switch chip this
 *	port is part of.  If driver implements this, it indicates that
 *	it represents a port of a switch chip.
 * ...
 */

Ben.

-- 
Ben Hutchings
If you seem to know what you are doing, you'll be given more to do.

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 811 bytes --]

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2015-03-21  0:04 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-03-16  1:45 [PATCH net-next v2 0/3] switchdev: add swdev ops sfeldma
2015-03-16  1:45 ` [PATCH net-next v2 1/3] " sfeldma
2015-03-20 23:00   ` Ben Hutchings
2015-03-20 23:58     ` Scott Feldman
2015-03-21  0:04       ` Ben Hutchings
2015-03-16  1:45 ` [PATCH net-next v2 2/3] switchdev: use new " sfeldma
2015-03-16  1:45 ` [PATCH net-next v2 3/3] netdev: remove ndo ops for switchdev sfeldma
2015-03-16  1:51 ` [PATCH net-next v2 0/3] switchdev: add swdev ops David Miller
2015-03-16  1:55   ` David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).