123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- From 21bd64bd717dedac96f53b668144cbe37d3c12d4 Mon Sep 17 00:00:00 2001
- From: "Russell King (Oracle)" <[email protected]>
- Date: Tue, 30 Nov 2021 13:09:55 +0000
- Subject: [PATCH] net: dsa: consolidate phylink creation
- MIME-Version: 1.0
- Content-Type: text/plain; charset=UTF-8
- Content-Transfer-Encoding: 8bit
- The code in port.c and slave.c creating the phylink instance is very
- similar - let's consolidate this into a single function.
- Signed-off-by: Russell King (Oracle) <[email protected]>
- Reviewed-by: Marek Behún <[email protected]>
- Reviewed-by: Andrew Lunn <[email protected]>
- Signed-off-by: Jakub Kicinski <[email protected]>
- ---
- net/dsa/dsa_priv.h | 2 +-
- net/dsa/port.c | 44 ++++++++++++++++++++++++++++----------------
- net/dsa/slave.c | 19 +++----------------
- 3 files changed, 32 insertions(+), 33 deletions(-)
- --- a/net/dsa/dsa_priv.h
- +++ b/net/dsa/dsa_priv.h
- @@ -260,13 +260,13 @@ int dsa_port_mrp_add_ring_role(const str
- const struct switchdev_obj_ring_role_mrp *mrp);
- int dsa_port_mrp_del_ring_role(const struct dsa_port *dp,
- const struct switchdev_obj_ring_role_mrp *mrp);
- +int dsa_port_phylink_create(struct dsa_port *dp);
- int dsa_port_link_register_of(struct dsa_port *dp);
- void dsa_port_link_unregister_of(struct dsa_port *dp);
- int dsa_port_hsr_join(struct dsa_port *dp, struct net_device *hsr);
- void dsa_port_hsr_leave(struct dsa_port *dp, struct net_device *hsr);
- int dsa_port_tag_8021q_vlan_add(struct dsa_port *dp, u16 vid, bool broadcast);
- void dsa_port_tag_8021q_vlan_del(struct dsa_port *dp, u16 vid, bool broadcast);
- -extern const struct phylink_mac_ops dsa_port_phylink_mac_ops;
-
- static inline bool dsa_port_offloads_bridge_port(struct dsa_port *dp,
- const struct net_device *dev)
- --- a/net/dsa/port.c
- +++ b/net/dsa/port.c
- @@ -1076,7 +1076,7 @@ static void dsa_port_phylink_mac_link_up
- speed, duplex, tx_pause, rx_pause);
- }
-
- -const struct phylink_mac_ops dsa_port_phylink_mac_ops = {
- +static const struct phylink_mac_ops dsa_port_phylink_mac_ops = {
- .validate = dsa_port_phylink_validate,
- .mac_pcs_get_state = dsa_port_phylink_mac_pcs_get_state,
- .mac_config = dsa_port_phylink_mac_config,
- @@ -1085,6 +1085,30 @@ const struct phylink_mac_ops dsa_port_ph
- .mac_link_up = dsa_port_phylink_mac_link_up,
- };
-
- +int dsa_port_phylink_create(struct dsa_port *dp)
- +{
- + struct dsa_switch *ds = dp->ds;
- + phy_interface_t mode;
- + int err;
- +
- + err = of_get_phy_mode(dp->dn, &mode);
- + if (err)
- + mode = PHY_INTERFACE_MODE_NA;
- +
- + if (ds->ops->phylink_get_interfaces)
- + ds->ops->phylink_get_interfaces(ds, dp->index,
- + dp->pl_config.supported_interfaces);
- +
- + dp->pl = phylink_create(&dp->pl_config, of_fwnode_handle(dp->dn),
- + mode, &dsa_port_phylink_mac_ops);
- + if (IS_ERR(dp->pl)) {
- + pr_err("error creating PHYLINK: %ld\n", PTR_ERR(dp->pl));
- + return PTR_ERR(dp->pl);
- + }
- +
- + return 0;
- +}
- +
- static int dsa_port_setup_phy_of(struct dsa_port *dp, bool enable)
- {
- struct dsa_switch *ds = dp->ds;
- @@ -1161,27 +1185,15 @@ static int dsa_port_phylink_register(str
- {
- struct dsa_switch *ds = dp->ds;
- struct device_node *port_dn = dp->dn;
- - phy_interface_t mode;
- int err;
-
- - err = of_get_phy_mode(port_dn, &mode);
- - if (err)
- - mode = PHY_INTERFACE_MODE_NA;
- -
- dp->pl_config.dev = ds->dev;
- dp->pl_config.type = PHYLINK_DEV;
- dp->pl_config.pcs_poll = ds->pcs_poll;
-
- - if (ds->ops->phylink_get_interfaces)
- - ds->ops->phylink_get_interfaces(ds, dp->index,
- - dp->pl_config.supported_interfaces);
- -
- - dp->pl = phylink_create(&dp->pl_config, of_fwnode_handle(port_dn),
- - mode, &dsa_port_phylink_mac_ops);
- - if (IS_ERR(dp->pl)) {
- - pr_err("error creating PHYLINK: %ld\n", PTR_ERR(dp->pl));
- - return PTR_ERR(dp->pl);
- - }
- + err = dsa_port_phylink_create(dp);
- + if (err)
- + return err;
-
- err = phylink_of_phy_connect(dp->pl, port_dn, 0);
- if (err && err != -ENODEV) {
- --- a/net/dsa/slave.c
- +++ b/net/dsa/slave.c
- @@ -1817,14 +1817,9 @@ static int dsa_slave_phy_setup(struct ne
- struct dsa_port *dp = dsa_slave_to_port(slave_dev);
- struct device_node *port_dn = dp->dn;
- struct dsa_switch *ds = dp->ds;
- - phy_interface_t mode;
- u32 phy_flags = 0;
- int ret;
-
- - ret = of_get_phy_mode(port_dn, &mode);
- - if (ret)
- - mode = PHY_INTERFACE_MODE_NA;
- -
- dp->pl_config.dev = &slave_dev->dev;
- dp->pl_config.type = PHYLINK_NETDEV;
-
- @@ -1837,17 +1832,9 @@ static int dsa_slave_phy_setup(struct ne
- dp->pl_config.poll_fixed_state = true;
- }
-
- - if (ds->ops->phylink_get_interfaces)
- - ds->ops->phylink_get_interfaces(ds, dp->index,
- - dp->pl_config.supported_interfaces);
- -
- - dp->pl = phylink_create(&dp->pl_config, of_fwnode_handle(port_dn), mode,
- - &dsa_port_phylink_mac_ops);
- - if (IS_ERR(dp->pl)) {
- - netdev_err(slave_dev,
- - "error creating PHYLINK: %ld\n", PTR_ERR(dp->pl));
- - return PTR_ERR(dp->pl);
- - }
- + ret = dsa_port_phylink_create(dp);
- + if (ret)
- + return ret;
-
- if (ds->ops->get_phy_flags)
- phy_flags = ds->ops->get_phy_flags(ds, dp->index);
|