mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	net: of_get_phy_mode: Change API to solve int/unit warnings
Before this change of_get_phy_mode() returned an enum, phy_interface_t. On error, -ENODEV etc, is returned. If the result of the function is stored in a variable of type phy_interface_t, and the compiler has decided to represent this as an unsigned int, comparision with -ENODEV etc, is a signed vs unsigned comparision. Fix this problem by changing the API. Make the function return an error, or 0 on success, and pass a pointer, of type phy_interface_t, where the phy mode should be stored. v2: Return with *interface set to PHY_INTERFACE_MODE_NA on error. Add error checks to all users of of_get_phy_mode() Fixup a few reverse christmas tree errors Fixup a few slightly malformed reverse christmas trees v3: Fix 0-day reported errors. Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									5d1fcaf35d
								
							
						
					
					
						commit
						0c65b2b90d
					
				| @ -381,8 +381,9 @@ static void bcm_sf2_identify_ports(struct bcm_sf2_priv *priv, | |||||||
| 				   struct device_node *dn) | 				   struct device_node *dn) | ||||||
| { | { | ||||||
| 	struct device_node *port; | 	struct device_node *port; | ||||||
| 	int mode; |  | ||||||
| 	unsigned int port_num; | 	unsigned int port_num; | ||||||
|  | 	phy_interface_t mode; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	priv->moca_port = -1; | 	priv->moca_port = -1; | ||||||
| 
 | 
 | ||||||
| @ -395,8 +396,8 @@ static void bcm_sf2_identify_ports(struct bcm_sf2_priv *priv, | |||||||
| 		 * has completed, since they might be turned off at that | 		 * has completed, since they might be turned off at that | ||||||
| 		 * time | 		 * time | ||||||
| 		 */ | 		 */ | ||||||
| 		mode = of_get_phy_mode(port); | 		err = of_get_phy_mode(port, &mode); | ||||||
| 		if (mode < 0) | 		if (err) | ||||||
| 			continue; | 			continue; | ||||||
| 
 | 
 | ||||||
| 		if (mode == PHY_INTERFACE_MODE_INTERNAL) | 		if (mode == PHY_INTERFACE_MODE_INTERNAL) | ||||||
|  | |||||||
| @ -422,6 +422,7 @@ EXPORT_SYMBOL(ksz_switch_alloc); | |||||||
| int ksz_switch_register(struct ksz_device *dev, | int ksz_switch_register(struct ksz_device *dev, | ||||||
| 			const struct ksz_dev_ops *ops) | 			const struct ksz_dev_ops *ops) | ||||||
| { | { | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	if (dev->pdata) | 	if (dev->pdata) | ||||||
| @ -456,9 +457,9 @@ int ksz_switch_register(struct ksz_device *dev, | |||||||
| 	 * device tree. | 	 * device tree. | ||||||
| 	 */ | 	 */ | ||||||
| 	if (dev->dev->of_node) { | 	if (dev->dev->of_node) { | ||||||
| 		ret = of_get_phy_mode(dev->dev->of_node); | 		ret = of_get_phy_mode(dev->dev->of_node, &interface); | ||||||
| 		if (ret >= 0) | 		if (ret == 0) | ||||||
| 			dev->interface = ret; | 			dev->interface = interface; | ||||||
| 		dev->synclko_125 = of_property_read_bool(dev->dev->of_node, | 		dev->synclko_125 = of_property_read_bool(dev->dev->of_node, | ||||||
| 							 "microchip,synclko-125"); | 							 "microchip,synclko-125"); | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -1340,7 +1340,9 @@ mt7530_setup(struct dsa_switch *ds) | |||||||
| 
 | 
 | ||||||
| 	if (!dsa_is_unused_port(ds, 5)) { | 	if (!dsa_is_unused_port(ds, 5)) { | ||||||
| 		priv->p5_intf_sel = P5_INTF_SEL_GMAC5; | 		priv->p5_intf_sel = P5_INTF_SEL_GMAC5; | ||||||
| 		interface = of_get_phy_mode(dsa_to_port(ds, 5)->dn); | 		ret = of_get_phy_mode(dsa_to_port(ds, 5)->dn, &interface); | ||||||
|  | 		if (ret && ret != -ENODEV) | ||||||
|  | 			return ret; | ||||||
| 	} else { | 	} else { | ||||||
| 		/* Scan the ethernet nodes. look for GMAC1, lookup used phy */ | 		/* Scan the ethernet nodes. look for GMAC1, lookup used phy */ | ||||||
| 		for_each_child_of_node(dn, mac_np) { | 		for_each_child_of_node(dn, mac_np) { | ||||||
| @ -1354,7 +1356,9 @@ mt7530_setup(struct dsa_switch *ds) | |||||||
| 
 | 
 | ||||||
| 			phy_node = of_parse_phandle(mac_np, "phy-handle", 0); | 			phy_node = of_parse_phandle(mac_np, "phy-handle", 0); | ||||||
| 			if (phy_node->parent == priv->dev->of_node->parent) { | 			if (phy_node->parent == priv->dev->of_node->parent) { | ||||||
| 				interface = of_get_phy_mode(mac_np); | 				ret = of_get_phy_mode(mac_np, &interface); | ||||||
|  | 				if (ret && ret != -ENODEV) | ||||||
|  | 					return ret; | ||||||
| 				id = of_mdio_parse_addr(ds->dev, phy_node); | 				id = of_mdio_parse_addr(ds->dev, phy_node); | ||||||
| 				if (id == 0) | 				if (id == 0) | ||||||
| 					priv->p5_intf_sel = P5_INTF_SEL_PHY_P0; | 					priv->p5_intf_sel = P5_INTF_SEL_PHY_P0; | ||||||
|  | |||||||
| @ -639,7 +639,8 @@ static int | |||||||
| qca8k_setup(struct dsa_switch *ds) | qca8k_setup(struct dsa_switch *ds) | ||||||
| { | { | ||||||
| 	struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv; | 	struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv; | ||||||
| 	int ret, i, phy_mode = -1; | 	phy_interface_t phy_mode = PHY_INTERFACE_MODE_NA; | ||||||
|  | 	int ret, i; | ||||||
| 	u32 mask; | 	u32 mask; | ||||||
| 
 | 
 | ||||||
| 	/* Make sure that port 0 is the cpu port */ | 	/* Make sure that port 0 is the cpu port */ | ||||||
| @ -661,10 +662,10 @@ qca8k_setup(struct dsa_switch *ds) | |||||||
| 		return ret; | 		return ret; | ||||||
| 
 | 
 | ||||||
| 	/* Initialize CPU port pad mode (xMII type, delays...) */ | 	/* Initialize CPU port pad mode (xMII type, delays...) */ | ||||||
| 	phy_mode = of_get_phy_mode(dsa_to_port(ds, QCA8K_CPU_PORT)->dn); | 	ret = of_get_phy_mode(dsa_to_port(ds, QCA8K_CPU_PORT)->dn, &phy_mode); | ||||||
| 	if (phy_mode < 0) { | 	if (ret) { | ||||||
| 		pr_err("Can't find phy-mode for master device\n"); | 		pr_err("Can't find phy-mode for master device\n"); | ||||||
| 		return phy_mode; | 		return ret; | ||||||
| 	} | 	} | ||||||
| 	ret = qca8k_set_pad_ctrl(priv, QCA8K_CPU_PORT, phy_mode); | 	ret = qca8k_set_pad_ctrl(priv, QCA8K_CPU_PORT, phy_mode); | ||||||
| 	if (ret < 0) | 	if (ret < 0) | ||||||
|  | |||||||
| @ -584,8 +584,9 @@ static int sja1105_parse_ports_node(struct sja1105_private *priv, | |||||||
| 
 | 
 | ||||||
| 	for_each_child_of_node(ports_node, child) { | 	for_each_child_of_node(ports_node, child) { | ||||||
| 		struct device_node *phy_node; | 		struct device_node *phy_node; | ||||||
| 		int phy_mode; | 		phy_interface_t phy_mode; | ||||||
| 		u32 index; | 		u32 index; | ||||||
|  | 		int err; | ||||||
| 
 | 
 | ||||||
| 		/* Get switch port number from DT */ | 		/* Get switch port number from DT */ | ||||||
| 		if (of_property_read_u32(child, "reg", &index) < 0) { | 		if (of_property_read_u32(child, "reg", &index) < 0) { | ||||||
| @ -596,8 +597,8 @@ static int sja1105_parse_ports_node(struct sja1105_private *priv, | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		/* Get PHY mode from DT */ | 		/* Get PHY mode from DT */ | ||||||
| 		phy_mode = of_get_phy_mode(child); | 		err = of_get_phy_mode(child, &phy_mode); | ||||||
| 		if (phy_mode < 0) { | 		if (err) { | ||||||
| 			dev_err(dev, "Failed to read phy-mode or " | 			dev_err(dev, "Failed to read phy-mode or " | ||||||
| 				"phy-interface-type property for port %d\n", | 				"phy-interface-type property for port %d\n", | ||||||
| 				index); | 				index); | ||||||
|  | |||||||
| @ -730,12 +730,12 @@ static int altera_tse_phy_get_addr_mdio_create(struct net_device *dev) | |||||||
| { | { | ||||||
| 	struct altera_tse_private *priv = netdev_priv(dev); | 	struct altera_tse_private *priv = netdev_priv(dev); | ||||||
| 	struct device_node *np = priv->device->of_node; | 	struct device_node *np = priv->device->of_node; | ||||||
| 	int ret = 0; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	priv->phy_iface = of_get_phy_mode(np); | 	ret = of_get_phy_mode(np, &priv->phy_iface); | ||||||
| 
 | 
 | ||||||
| 	/* Avoid get phy addr and create mdio if no phy is present */ | 	/* Avoid get phy addr and create mdio if no phy is present */ | ||||||
| 	if (!priv->phy_iface) | 	if (ret) | ||||||
| 		return 0; | 		return 0; | ||||||
| 
 | 
 | ||||||
| 	/* try to get PHY address from device tree, use PHY autodetection if
 | 	/* try to get PHY address from device tree, use PHY autodetection if
 | ||||||
|  | |||||||
| @ -20,9 +20,10 @@ | |||||||
| static int emac_arc_probe(struct platform_device *pdev) | static int emac_arc_probe(struct platform_device *pdev) | ||||||
| { | { | ||||||
| 	struct device *dev = &pdev->dev; | 	struct device *dev = &pdev->dev; | ||||||
| 	struct net_device *ndev; |  | ||||||
| 	struct arc_emac_priv *priv; | 	struct arc_emac_priv *priv; | ||||||
| 	int interface, err; | 	phy_interface_t interface; | ||||||
|  | 	struct net_device *ndev; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	if (!dev->of_node) | 	if (!dev->of_node) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| @ -37,9 +38,13 @@ static int emac_arc_probe(struct platform_device *pdev) | |||||||
| 	priv->drv_name = DRV_NAME; | 	priv->drv_name = DRV_NAME; | ||||||
| 	priv->drv_version = DRV_VERSION; | 	priv->drv_version = DRV_VERSION; | ||||||
| 
 | 
 | ||||||
| 	interface = of_get_phy_mode(dev->of_node); | 	err = of_get_phy_mode(dev->of_node, &interface); | ||||||
| 	if (interface < 0) | 	if (err) { | ||||||
|  | 		if (err == -ENODEV) | ||||||
| 			interface = PHY_INTERFACE_MODE_MII; | 			interface = PHY_INTERFACE_MODE_MII; | ||||||
|  | 		else | ||||||
|  | 			goto out_netdev; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	priv->clk = devm_clk_get(dev, "hclk"); | 	priv->clk = devm_clk_get(dev, "hclk"); | ||||||
| 	if (IS_ERR(priv->clk)) { | 	if (IS_ERR(priv->clk)) { | ||||||
|  | |||||||
| @ -97,8 +97,9 @@ static int emac_rockchip_probe(struct platform_device *pdev) | |||||||
| 	struct net_device *ndev; | 	struct net_device *ndev; | ||||||
| 	struct rockchip_priv_data *priv; | 	struct rockchip_priv_data *priv; | ||||||
| 	const struct of_device_id *match; | 	const struct of_device_id *match; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	u32 data; | 	u32 data; | ||||||
| 	int err, interface; | 	int err; | ||||||
| 
 | 
 | ||||||
| 	if (!pdev->dev.of_node) | 	if (!pdev->dev.of_node) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| @ -114,7 +115,9 @@ static int emac_rockchip_probe(struct platform_device *pdev) | |||||||
| 	priv->emac.drv_version = DRV_VERSION; | 	priv->emac.drv_version = DRV_VERSION; | ||||||
| 	priv->emac.set_mac_speed = emac_rockchip_set_mac_speed; | 	priv->emac.set_mac_speed = emac_rockchip_set_mac_speed; | ||||||
| 
 | 
 | ||||||
| 	interface = of_get_phy_mode(dev->of_node); | 	err = of_get_phy_mode(dev->of_node, &interface); | ||||||
|  | 	if (err) | ||||||
|  | 		goto out_netdev; | ||||||
| 
 | 
 | ||||||
| 	/* RK3036/RK3066/RK3188 SoCs only support RMII */ | 	/* RK3036/RK3066/RK3188 SoCs only support RMII */ | ||||||
| 	if (interface != PHY_INTERFACE_MODE_RMII) { | 	if (interface != PHY_INTERFACE_MODE_RMII) { | ||||||
|  | |||||||
| @ -1744,10 +1744,9 @@ static int ag71xx_probe(struct platform_device *pdev) | |||||||
| 		eth_random_addr(ndev->dev_addr); | 		eth_random_addr(ndev->dev_addr); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	ag->phy_if_mode = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, ag->phy_if_mode); | ||||||
| 	if (ag->phy_if_mode < 0) { | 	if (err) { | ||||||
| 		netif_err(ag, probe, ndev, "missing phy-mode property in DT\n"); | 		netif_err(ag, probe, ndev, "missing phy-mode property in DT\n"); | ||||||
| 		err = ag->phy_if_mode; |  | ||||||
| 		goto err_free; | 		goto err_free; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1371,8 +1371,8 @@ static int nb8800_probe(struct platform_device *pdev) | |||||||
| 	priv = netdev_priv(dev); | 	priv = netdev_priv(dev); | ||||||
| 	priv->base = base; | 	priv->base = base; | ||||||
| 
 | 
 | ||||||
| 	priv->phy_mode = of_get_phy_mode(pdev->dev.of_node); | 	ret = of_get_phy_mode(pdev->dev.of_node, &priv->phy_mode); | ||||||
| 	if (priv->phy_mode < 0) | 	if (ret) | ||||||
| 		priv->phy_mode = PHY_INTERFACE_MODE_RGMII; | 		priv->phy_mode = PHY_INTERFACE_MODE_RGMII; | ||||||
| 
 | 
 | ||||||
| 	priv->clk = devm_clk_get(&pdev->dev, NULL); | 	priv->clk = devm_clk_get(&pdev->dev, NULL); | ||||||
|  | |||||||
| @ -287,7 +287,7 @@ struct nb8800_priv { | |||||||
| 	struct device_node		*phy_node; | 	struct device_node		*phy_node; | ||||||
| 
 | 
 | ||||||
| 	/* PHY connection type from DT */ | 	/* PHY connection type from DT */ | ||||||
| 	int				phy_mode; | 	phy_interface_t			phy_mode; | ||||||
| 
 | 
 | ||||||
| 	/* Current link status */ | 	/* Current link status */ | ||||||
| 	int				speed; | 	int				speed; | ||||||
|  | |||||||
| @ -2479,9 +2479,9 @@ static int bcm_sysport_probe(struct platform_device *pdev) | |||||||
| 	priv->netdev = dev; | 	priv->netdev = dev; | ||||||
| 	priv->pdev = pdev; | 	priv->pdev = pdev; | ||||||
| 
 | 
 | ||||||
| 	priv->phy_interface = of_get_phy_mode(dn); | 	ret = of_get_phy_mode(dn, &priv->phy_interface); | ||||||
| 	/* Default to GMII interface mode */ | 	/* Default to GMII interface mode */ | ||||||
| 	if ((int)priv->phy_interface < 0) | 	if (ret) | ||||||
| 		priv->phy_interface = PHY_INTERFACE_MODE_GMII; | 		priv->phy_interface = PHY_INTERFACE_MODE_GMII; | ||||||
| 
 | 
 | ||||||
| 	/* In the case of a fixed PHY, the DT node associated
 | 	/* In the case of a fixed PHY, the DT node associated
 | ||||||
|  | |||||||
| @ -436,7 +436,7 @@ static int bcmgenet_mii_of_init(struct bcmgenet_priv *priv) | |||||||
| 	struct device_node *dn = priv->pdev->dev.of_node; | 	struct device_node *dn = priv->pdev->dev.of_node; | ||||||
| 	struct device *kdev = &priv->pdev->dev; | 	struct device *kdev = &priv->pdev->dev; | ||||||
| 	struct phy_device *phydev; | 	struct phy_device *phydev; | ||||||
| 	int phy_mode; | 	phy_interface_t phy_mode; | ||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	/* Fetch the PHY phandle */ | 	/* Fetch the PHY phandle */ | ||||||
| @ -454,10 +454,10 @@ static int bcmgenet_mii_of_init(struct bcmgenet_priv *priv) | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* Get the link mode */ | 	/* Get the link mode */ | ||||||
| 	phy_mode = of_get_phy_mode(dn); | 	ret = of_get_phy_mode(dn, &phy_mode); | ||||||
| 	if (phy_mode < 0) { | 	if (ret) { | ||||||
| 		dev_err(kdev, "invalid PHY mode property\n"); | 		dev_err(kdev, "invalid PHY mode property\n"); | ||||||
| 		return phy_mode; | 		return ret; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	priv->phy_interface = phy_mode; | 	priv->phy_interface = phy_mode; | ||||||
|  | |||||||
| @ -4182,6 +4182,7 @@ static int macb_probe(struct platform_device *pdev) | |||||||
| 	unsigned int queue_mask, num_queues; | 	unsigned int queue_mask, num_queues; | ||||||
| 	bool native_io; | 	bool native_io; | ||||||
| 	struct phy_device *phydev; | 	struct phy_device *phydev; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	struct net_device *dev; | 	struct net_device *dev; | ||||||
| 	struct resource *regs; | 	struct resource *regs; | ||||||
| 	void __iomem *mem; | 	void __iomem *mem; | ||||||
| @ -4308,12 +4309,12 @@ static int macb_probe(struct platform_device *pdev) | |||||||
| 		macb_get_hwaddr(bp); | 		macb_get_hwaddr(bp); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	err = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &interface); | ||||||
| 	if (err < 0) | 	if (err) | ||||||
| 		/* not found in DT, MII by default */ | 		/* not found in DT, MII by default */ | ||||||
| 		bp->phy_interface = PHY_INTERFACE_MODE_MII; | 		bp->phy_interface = PHY_INTERFACE_MODE_MII; | ||||||
| 	else | 	else | ||||||
| 		bp->phy_interface = err; | 		bp->phy_interface = interface; | ||||||
| 
 | 
 | ||||||
| 	/* IP specific init */ | 	/* IP specific init */ | ||||||
| 	err = init(pdev); | 	err = init(pdev); | ||||||
|  | |||||||
| @ -1612,7 +1612,7 @@ static int ftgmac100_setup_mdio(struct net_device *netdev) | |||||||
| { | { | ||||||
| 	struct ftgmac100 *priv = netdev_priv(netdev); | 	struct ftgmac100 *priv = netdev_priv(netdev); | ||||||
| 	struct platform_device *pdev = to_platform_device(priv->dev); | 	struct platform_device *pdev = to_platform_device(priv->dev); | ||||||
| 	int phy_intf = PHY_INTERFACE_MODE_RGMII; | 	phy_interface_t phy_intf = PHY_INTERFACE_MODE_RGMII; | ||||||
| 	struct device_node *np = pdev->dev.of_node; | 	struct device_node *np = pdev->dev.of_node; | ||||||
| 	int i, err = 0; | 	int i, err = 0; | ||||||
| 	u32 reg; | 	u32 reg; | ||||||
| @ -1637,8 +1637,8 @@ static int ftgmac100_setup_mdio(struct net_device *netdev) | |||||||
| 	/* Get PHY mode from device-tree */ | 	/* Get PHY mode from device-tree */ | ||||||
| 	if (np) { | 	if (np) { | ||||||
| 		/* Default to RGMII. It's a gigabit part after all */ | 		/* Default to RGMII. It's a gigabit part after all */ | ||||||
| 		phy_intf = of_get_phy_mode(np); | 		err = of_get_phy_mode(np, &phy_intf); | ||||||
| 		if (phy_intf < 0) | 		if (err) | ||||||
| 			phy_intf = PHY_INTERFACE_MODE_RGMII; | 			phy_intf = PHY_INTERFACE_MODE_RGMII; | ||||||
| 
 | 
 | ||||||
| 		/* Aspeed only supports these. I don't know about other IP
 | 		/* Aspeed only supports these. I don't know about other IP
 | ||||||
|  | |||||||
| @ -44,10 +44,11 @@ static struct device_node *dpaa2_mac_get_node(u16 dpmac_id) | |||||||
| static int dpaa2_mac_get_if_mode(struct device_node *node, | static int dpaa2_mac_get_if_mode(struct device_node *node, | ||||||
| 				 struct dpmac_attr attr) | 				 struct dpmac_attr attr) | ||||||
| { | { | ||||||
| 	int if_mode; | 	phy_interface_t if_mode; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	if_mode = of_get_phy_mode(node); | 	err = of_get_phy_mode(node, &if_mode); | ||||||
| 	if (if_mode >= 0) | 	if (!err) | ||||||
| 		return if_mode; | 		return if_mode; | ||||||
| 
 | 
 | ||||||
| 	if_mode = phy_mode(attr.eth_if); | 	if_mode = phy_mode(attr.eth_if); | ||||||
|  | |||||||
| @ -784,8 +784,8 @@ static int enetc_of_get_phy(struct enetc_ndev_priv *priv) | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	priv->if_mode = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &priv->if_mode); | ||||||
| 	if ((int)priv->if_mode < 0) { | 	if (err) { | ||||||
| 		dev_err(priv->dev, "missing phy type\n"); | 		dev_err(priv->dev, "missing phy type\n"); | ||||||
| 		of_node_put(priv->phy_node); | 		of_node_put(priv->phy_node); | ||||||
| 		if (of_phy_is_fixed_link(np)) | 		if (of_phy_is_fixed_link(np)) | ||||||
|  | |||||||
| @ -3393,6 +3393,7 @@ fec_probe(struct platform_device *pdev) | |||||||
| { | { | ||||||
| 	struct fec_enet_private *fep; | 	struct fec_enet_private *fep; | ||||||
| 	struct fec_platform_data *pdata; | 	struct fec_platform_data *pdata; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	struct net_device *ndev; | 	struct net_device *ndev; | ||||||
| 	int i, irq, ret = 0; | 	int i, irq, ret = 0; | ||||||
| 	const struct of_device_id *of_id; | 	const struct of_device_id *of_id; | ||||||
| @ -3465,15 +3466,15 @@ fec_probe(struct platform_device *pdev) | |||||||
| 	} | 	} | ||||||
| 	fep->phy_node = phy_node; | 	fep->phy_node = phy_node; | ||||||
| 
 | 
 | ||||||
| 	ret = of_get_phy_mode(pdev->dev.of_node); | 	ret = of_get_phy_mode(pdev->dev.of_node, &interface); | ||||||
| 	if (ret < 0) { | 	if (ret) { | ||||||
| 		pdata = dev_get_platdata(&pdev->dev); | 		pdata = dev_get_platdata(&pdev->dev); | ||||||
| 		if (pdata) | 		if (pdata) | ||||||
| 			fep->phy_interface = pdata->phy; | 			fep->phy_interface = pdata->phy; | ||||||
| 		else | 		else | ||||||
| 			fep->phy_interface = PHY_INTERFACE_MODE_MII; | 			fep->phy_interface = PHY_INTERFACE_MODE_MII; | ||||||
| 	} else { | 	} else { | ||||||
| 		fep->phy_interface = ret; | 		fep->phy_interface = interface; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fep->clk_ipg = devm_clk_get(&pdev->dev, "ipg"); | 	fep->clk_ipg = devm_clk_get(&pdev->dev, "ipg"); | ||||||
|  | |||||||
| @ -608,7 +608,7 @@ static int mac_probe(struct platform_device *_of_dev) | |||||||
| 	const u8		*mac_addr; | 	const u8		*mac_addr; | ||||||
| 	u32			 val; | 	u32			 val; | ||||||
| 	u8			fman_id; | 	u8			fman_id; | ||||||
| 	int			phy_if; | 	phy_interface_t          phy_if; | ||||||
| 
 | 
 | ||||||
| 	dev = &_of_dev->dev; | 	dev = &_of_dev->dev; | ||||||
| 	mac_node = dev->of_node; | 	mac_node = dev->of_node; | ||||||
| @ -776,8 +776,8 @@ static int mac_probe(struct platform_device *_of_dev) | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* Get the PHY connection type */ | 	/* Get the PHY connection type */ | ||||||
| 	phy_if = of_get_phy_mode(mac_node); | 	err = of_get_phy_mode(mac_node, &phy_if); | ||||||
| 	if (phy_if < 0) { | 	if (err) { | ||||||
| 		dev_warn(dev, | 		dev_warn(dev, | ||||||
| 			 "of_get_phy_mode() for %pOF failed. Defaulting to SGMII\n", | 			 "of_get_phy_mode() for %pOF failed. Defaulting to SGMII\n", | ||||||
| 			 mac_node); | 			 mac_node); | ||||||
|  | |||||||
| @ -641,6 +641,7 @@ static int gfar_of_init(struct platform_device *ofdev, struct net_device **pdev) | |||||||
| 	const char *model; | 	const char *model; | ||||||
| 	const void *mac_addr; | 	const void *mac_addr; | ||||||
| 	int err = 0, i; | 	int err = 0, i; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	struct net_device *dev = NULL; | 	struct net_device *dev = NULL; | ||||||
| 	struct gfar_private *priv = NULL; | 	struct gfar_private *priv = NULL; | ||||||
| 	struct device_node *np = ofdev->dev.of_node; | 	struct device_node *np = ofdev->dev.of_node; | ||||||
| @ -805,9 +806,9 @@ static int gfar_of_init(struct platform_device *ofdev, struct net_device **pdev) | |||||||
| 	 * rgmii-id really needs to be specified. Other types can be | 	 * rgmii-id really needs to be specified. Other types can be | ||||||
| 	 * detected by hardware | 	 * detected by hardware | ||||||
| 	 */ | 	 */ | ||||||
| 	err = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &interface); | ||||||
| 	if (err >= 0) | 	if (!err) | ||||||
| 		priv->interface = err; | 		priv->interface = interface; | ||||||
| 	else | 	else | ||||||
| 		priv->interface = gfar_get_interface(dev); | 		priv->interface = gfar_get_interface(dev); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -211,7 +211,7 @@ struct hip04_priv { | |||||||
| #if defined(CONFIG_HI13X1_GMAC) | #if defined(CONFIG_HI13X1_GMAC) | ||||||
| 	void __iomem *sysctrl_base; | 	void __iomem *sysctrl_base; | ||||||
| #endif | #endif | ||||||
| 	int phy_mode; | 	phy_interface_t phy_mode; | ||||||
| 	int chan; | 	int chan; | ||||||
| 	unsigned int port; | 	unsigned int port; | ||||||
| 	unsigned int group; | 	unsigned int group; | ||||||
| @ -961,10 +961,9 @@ static int hip04_mac_probe(struct platform_device *pdev) | |||||||
| 		goto init_fail; | 		goto init_fail; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	priv->phy_mode = of_get_phy_mode(node); | 	ret = of_get_phy_mode(node, &priv->phy_mode); | ||||||
| 	if (priv->phy_mode < 0) { | 	if (ret) { | ||||||
| 		dev_warn(d, "not find phy-mode\n"); | 		dev_warn(d, "not find phy-mode\n"); | ||||||
| 		ret = -EINVAL; |  | ||||||
| 		goto init_fail; | 		goto init_fail; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1193,10 +1193,9 @@ static int hix5hd2_dev_probe(struct platform_device *pdev) | |||||||
| 	if (ret) | 	if (ret) | ||||||
| 		goto err_free_mdio; | 		goto err_free_mdio; | ||||||
| 
 | 
 | ||||||
| 	priv->phy_mode = of_get_phy_mode(node); | 	ret = of_get_phy_mode(node, &priv->phy_mode); | ||||||
| 	if ((int)priv->phy_mode < 0) { | 	if (ret) { | ||||||
| 		netdev_err(ndev, "not find phy-mode\n"); | 		netdev_err(ndev, "not find phy-mode\n"); | ||||||
| 		ret = -EINVAL; |  | ||||||
| 		goto err_mdiobus; | 		goto err_mdiobus; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2849,6 +2849,7 @@ static int emac_init_config(struct emac_instance *dev) | |||||||
| { | { | ||||||
| 	struct device_node *np = dev->ofdev->dev.of_node; | 	struct device_node *np = dev->ofdev->dev.of_node; | ||||||
| 	const void *p; | 	const void *p; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	/* Read config from device-tree */ | 	/* Read config from device-tree */ | ||||||
| 	if (emac_read_uint_prop(np, "mal-device", &dev->mal_ph, 1)) | 	if (emac_read_uint_prop(np, "mal-device", &dev->mal_ph, 1)) | ||||||
| @ -2897,8 +2898,8 @@ static int emac_init_config(struct emac_instance *dev) | |||||||
| 		dev->mal_burst_size = 256; | 		dev->mal_burst_size = 256; | ||||||
| 
 | 
 | ||||||
| 	/* PHY mode needs some decoding */ | 	/* PHY mode needs some decoding */ | ||||||
| 	dev->phy_mode = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &dev->phy_mode); | ||||||
| 	if (dev->phy_mode < 0) | 	if (err) | ||||||
| 		dev->phy_mode = PHY_INTERFACE_MODE_NA; | 		dev->phy_mode = PHY_INTERFACE_MODE_NA; | ||||||
| 
 | 
 | ||||||
| 	/* Check EMAC version */ | 	/* Check EMAC version */ | ||||||
|  | |||||||
| @ -2959,15 +2959,16 @@ static void set_params(struct mv643xx_eth_private *mp, | |||||||
| static int get_phy_mode(struct mv643xx_eth_private *mp) | static int get_phy_mode(struct mv643xx_eth_private *mp) | ||||||
| { | { | ||||||
| 	struct device *dev = mp->dev->dev.parent; | 	struct device *dev = mp->dev->dev.parent; | ||||||
| 	int iface = -1; | 	phy_interface_t iface; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	if (dev->of_node) | 	if (dev->of_node) | ||||||
| 		iface = of_get_phy_mode(dev->of_node); | 		err = of_get_phy_mode(dev->of_node, &iface); | ||||||
| 
 | 
 | ||||||
| 	/* Historical default if unspecified. We could also read/write
 | 	/* Historical default if unspecified. We could also read/write
 | ||||||
| 	 * the interface state in the PSC1 | 	 * the interface state in the PSC1 | ||||||
| 	 */ | 	 */ | ||||||
| 	if (iface < 0) | 	if (!dev->of_node || err) | ||||||
| 		iface = PHY_INTERFACE_MODE_GMII; | 		iface = PHY_INTERFACE_MODE_GMII; | ||||||
| 	return iface; | 	return iface; | ||||||
| } | } | ||||||
|  | |||||||
| @ -4797,9 +4797,9 @@ static int mvneta_probe(struct platform_device *pdev) | |||||||
| 	struct phy *comphy; | 	struct phy *comphy; | ||||||
| 	const char *dt_mac_addr; | 	const char *dt_mac_addr; | ||||||
| 	char hw_mac_addr[ETH_ALEN]; | 	char hw_mac_addr[ETH_ALEN]; | ||||||
|  | 	phy_interface_t phy_mode; | ||||||
| 	const char *mac_from; | 	const char *mac_from; | ||||||
| 	int tx_csum_limit; | 	int tx_csum_limit; | ||||||
| 	int phy_mode; |  | ||||||
| 	int err; | 	int err; | ||||||
| 	int cpu; | 	int cpu; | ||||||
| 
 | 
 | ||||||
| @ -4812,10 +4812,9 @@ static int mvneta_probe(struct platform_device *pdev) | |||||||
| 	if (dev->irq == 0) | 	if (dev->irq == 0) | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 
 | 
 | ||||||
| 	phy_mode = of_get_phy_mode(dn); | 	err = of_get_phy_mode(dn, &phy_mode); | ||||||
| 	if (phy_mode < 0) { | 	if (err) { | ||||||
| 		dev_err(&pdev->dev, "incorrect phy-mode\n"); | 		dev_err(&pdev->dev, "incorrect phy-mode\n"); | ||||||
| 		err = -EINVAL; |  | ||||||
| 		goto err_free_irq; | 		goto err_free_irq; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1489,8 +1489,10 @@ static int pxa168_eth_probe(struct platform_device *pdev) | |||||||
| 			goto err_netdev; | 			goto err_netdev; | ||||||
| 		} | 		} | ||||||
| 		of_property_read_u32(np, "reg", &pep->phy_addr); | 		of_property_read_u32(np, "reg", &pep->phy_addr); | ||||||
| 		pep->phy_intf = of_get_phy_mode(pdev->dev.of_node); |  | ||||||
| 		of_node_put(np); | 		of_node_put(np); | ||||||
|  | 		err = of_get_phy_mode(pdev->dev.of_node, &pep->phy_intf); | ||||||
|  | 		if (err && err != -ENODEV) | ||||||
|  | 			goto err_netdev; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* Hardware supports only 3 ports */ | 	/* Hardware supports only 3 ports */ | ||||||
|  | |||||||
| @ -2758,9 +2758,10 @@ static const struct net_device_ops mtk_netdev_ops = { | |||||||
| static int mtk_add_mac(struct mtk_eth *eth, struct device_node *np) | static int mtk_add_mac(struct mtk_eth *eth, struct device_node *np) | ||||||
| { | { | ||||||
| 	const __be32 *_id = of_get_property(np, "reg", NULL); | 	const __be32 *_id = of_get_property(np, "reg", NULL); | ||||||
|  | 	phy_interface_t phy_mode; | ||||||
| 	struct phylink *phylink; | 	struct phylink *phylink; | ||||||
| 	int phy_mode, id, err; |  | ||||||
| 	struct mtk_mac *mac; | 	struct mtk_mac *mac; | ||||||
|  | 	int id, err; | ||||||
| 
 | 
 | ||||||
| 	if (!_id) { | 	if (!_id) { | ||||||
| 		dev_err(eth->dev, "missing mac id\n"); | 		dev_err(eth->dev, "missing mac id\n"); | ||||||
| @ -2805,10 +2806,9 @@ static int mtk_add_mac(struct mtk_eth *eth, struct device_node *np) | |||||||
| 	mac->hw_stats->reg_offset = id * MTK_STAT_OFFSET; | 	mac->hw_stats->reg_offset = id * MTK_STAT_OFFSET; | ||||||
| 
 | 
 | ||||||
| 	/* phylink create */ | 	/* phylink create */ | ||||||
| 	phy_mode = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &phy_mode); | ||||||
| 	if (phy_mode < 0) { | 	if (err) { | ||||||
| 		dev_err(eth->dev, "incorrect phy-mode\n"); | 		dev_err(eth->dev, "incorrect phy-mode\n"); | ||||||
| 		err = -EINVAL; |  | ||||||
| 		goto free_netdev; | 		goto free_netdev; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -364,12 +364,12 @@ static int mscc_ocelot_probe(struct platform_device *pdev) | |||||||
| 
 | 
 | ||||||
| 	for_each_available_child_of_node(ports, portnp) { | 	for_each_available_child_of_node(ports, portnp) { | ||||||
| 		struct device_node *phy_node; | 		struct device_node *phy_node; | ||||||
|  | 		phy_interface_t phy_mode; | ||||||
| 		struct phy_device *phy; | 		struct phy_device *phy; | ||||||
| 		struct resource *res; | 		struct resource *res; | ||||||
| 		struct phy *serdes; | 		struct phy *serdes; | ||||||
| 		void __iomem *regs; | 		void __iomem *regs; | ||||||
| 		char res_name[8]; | 		char res_name[8]; | ||||||
| 		int phy_mode; |  | ||||||
| 		u32 port; | 		u32 port; | ||||||
| 
 | 
 | ||||||
| 		if (of_property_read_u32(portnp, "reg", &port)) | 		if (of_property_read_u32(portnp, "reg", &port)) | ||||||
| @ -398,10 +398,10 @@ static int mscc_ocelot_probe(struct platform_device *pdev) | |||||||
| 			goto out_put_ports; | 			goto out_put_ports; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		phy_mode = of_get_phy_mode(portnp); | 		err = of_get_phy_mode(portnp, &phy_mode); | ||||||
| 		if (phy_mode < 0) | 		if (err && err != -ENODEV) | ||||||
| 			ocelot->ports[port]->phy_mode = PHY_INTERFACE_MODE_NA; | 			goto out_put_ports; | ||||||
| 		else | 
 | ||||||
| 		ocelot->ports[port]->phy_mode = phy_mode; | 		ocelot->ports[port]->phy_mode = phy_mode; | ||||||
| 
 | 
 | ||||||
| 		switch (ocelot->ports[port]->phy_mode) { | 		switch (ocelot->ports[port]->phy_mode) { | ||||||
|  | |||||||
| @ -1346,10 +1346,9 @@ static int nixge_probe(struct platform_device *pdev) | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	priv->phy_mode = of_get_phy_mode(pdev->dev.of_node); | 	err = of_get_phy_mode(pdev->dev.of_node, &priv->phy_mode); | ||||||
| 	if ((int)priv->phy_mode < 0) { | 	if (err) { | ||||||
| 		netdev_err(ndev, "not find \"phy-mode\" property\n"); | 		netdev_err(ndev, "not find \"phy-mode\" property\n"); | ||||||
| 		err = -EINVAL; |  | ||||||
| 		goto unregister_mdio; | 		goto unregister_mdio; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2046,7 +2046,9 @@ static int ravb_probe(struct platform_device *pdev) | |||||||
| 	spin_lock_init(&priv->lock); | 	spin_lock_init(&priv->lock); | ||||||
| 	INIT_WORK(&priv->work, ravb_tx_timeout_work); | 	INIT_WORK(&priv->work, ravb_tx_timeout_work); | ||||||
| 
 | 
 | ||||||
| 	priv->phy_interface = of_get_phy_mode(np); | 	error = of_get_phy_mode(np, &priv->phy_interface); | ||||||
|  | 	if (error && error != -ENODEV) | ||||||
|  | 		goto out_release; | ||||||
| 
 | 
 | ||||||
| 	priv->no_avb_link = of_property_read_bool(np, "renesas,no-ether-link"); | 	priv->no_avb_link = of_property_read_bool(np, "renesas,no-ether-link"); | ||||||
| 	priv->avb_link_active_low = | 	priv->avb_link_active_low = | ||||||
|  | |||||||
| @ -3183,6 +3183,7 @@ static struct sh_eth_plat_data *sh_eth_parse_dt(struct device *dev) | |||||||
| { | { | ||||||
| 	struct device_node *np = dev->of_node; | 	struct device_node *np = dev->of_node; | ||||||
| 	struct sh_eth_plat_data *pdata; | 	struct sh_eth_plat_data *pdata; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	const char *mac_addr; | 	const char *mac_addr; | ||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| @ -3190,10 +3191,10 @@ static struct sh_eth_plat_data *sh_eth_parse_dt(struct device *dev) | |||||||
| 	if (!pdata) | 	if (!pdata) | ||||||
| 		return NULL; | 		return NULL; | ||||||
| 
 | 
 | ||||||
| 	ret = of_get_phy_mode(np); | 	ret = of_get_phy_mode(np, &interface); | ||||||
| 	if (ret < 0) | 	if (ret) | ||||||
| 		return NULL; | 		return NULL; | ||||||
| 	pdata->phy_interface = ret; | 	pdata->phy_interface = interface; | ||||||
| 
 | 
 | ||||||
| 	mac_addr = of_get_mac_address(np); | 	mac_addr = of_get_mac_address(np); | ||||||
| 	if (!IS_ERR(mac_addr)) | 	if (!IS_ERR(mac_addr)) | ||||||
|  | |||||||
| @ -30,12 +30,15 @@ static int sxgbe_probe_config_dt(struct platform_device *pdev, | |||||||
| { | { | ||||||
| 	struct device_node *np = pdev->dev.of_node; | 	struct device_node *np = pdev->dev.of_node; | ||||||
| 	struct sxgbe_dma_cfg *dma_cfg; | 	struct sxgbe_dma_cfg *dma_cfg; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	if (!np) | 	if (!np) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 
 | 
 | ||||||
| 	*mac = of_get_mac_address(np); | 	*mac = of_get_mac_address(np); | ||||||
| 	plat->interface = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &plat->interface); | ||||||
|  | 	if (err && err != -ENODEV) | ||||||
|  | 		return err; | ||||||
| 
 | 
 | ||||||
| 	plat->bus_id = of_alias_get_id(np, "ethernet"); | 	plat->bus_id = of_alias_get_id(np, "ethernet"); | ||||||
| 	if (plat->bus_id < 0) | 	if (plat->bus_id < 0) | ||||||
|  | |||||||
| @ -1565,10 +1565,10 @@ static int ave_probe(struct platform_device *pdev) | |||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 
 | 
 | ||||||
| 	np = dev->of_node; | 	np = dev->of_node; | ||||||
| 	phy_mode = of_get_phy_mode(np); | 	ret = of_get_phy_mode(np, &phy_mode); | ||||||
| 	if ((int)phy_mode < 0) { | 	if (ret) { | ||||||
| 		dev_err(dev, "phy-mode not found\n"); | 		dev_err(dev, "phy-mode not found\n"); | ||||||
| 		return -EINVAL; | 		return ret; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	irq = platform_get_irq(pdev, 0); | 	irq = platform_get_irq(pdev, 0); | ||||||
|  | |||||||
| @ -61,9 +61,10 @@ static void anarion_gmac_exit(struct platform_device *pdev, void *priv) | |||||||
| 
 | 
 | ||||||
| static struct anarion_gmac *anarion_config_dt(struct platform_device *pdev) | static struct anarion_gmac *anarion_config_dt(struct platform_device *pdev) | ||||||
| { | { | ||||||
| 	int phy_mode; |  | ||||||
| 	void __iomem *ctl_block; |  | ||||||
| 	struct anarion_gmac *gmac; | 	struct anarion_gmac *gmac; | ||||||
|  | 	phy_interface_t phy_mode; | ||||||
|  | 	void __iomem *ctl_block; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	ctl_block = devm_platform_ioremap_resource(pdev, 1); | 	ctl_block = devm_platform_ioremap_resource(pdev, 1); | ||||||
| 	if (IS_ERR(ctl_block)) { | 	if (IS_ERR(ctl_block)) { | ||||||
| @ -78,7 +79,10 @@ static struct anarion_gmac *anarion_config_dt(struct platform_device *pdev) | |||||||
| 
 | 
 | ||||||
| 	gmac->ctl_block = (uintptr_t)ctl_block; | 	gmac->ctl_block = (uintptr_t)ctl_block; | ||||||
| 
 | 
 | ||||||
| 	phy_mode = of_get_phy_mode(pdev->dev.of_node); | 	err = of_get_phy_mode(pdev->dev.of_node, &phy_mode); | ||||||
|  | 	if (err) | ||||||
|  | 		return ERR_PTR(err); | ||||||
|  | 
 | ||||||
| 	switch (phy_mode) { | 	switch (phy_mode) { | ||||||
| 	case PHY_INTERFACE_MODE_RGMII:		/* Fall through */ | 	case PHY_INTERFACE_MODE_RGMII:		/* Fall through */ | ||||||
| 	case PHY_INTERFACE_MODE_RGMII_ID	/* Fall through */: | 	case PHY_INTERFACE_MODE_RGMII_ID	/* Fall through */: | ||||||
|  | |||||||
| @ -189,9 +189,10 @@ static int ipq806x_gmac_set_speed(struct ipq806x_gmac *gmac, unsigned int speed) | |||||||
| static int ipq806x_gmac_of_parse(struct ipq806x_gmac *gmac) | static int ipq806x_gmac_of_parse(struct ipq806x_gmac *gmac) | ||||||
| { | { | ||||||
| 	struct device *dev = &gmac->pdev->dev; | 	struct device *dev = &gmac->pdev->dev; | ||||||
|  | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	gmac->phy_mode = of_get_phy_mode(dev->of_node); | 	ret = of_get_phy_mode(dev->of_node, &gmac->phy_mode); | ||||||
| 	if ((int)gmac->phy_mode < 0) { | 	if (ret) { | ||||||
| 		dev_err(dev, "missing phy mode property\n"); | 		dev_err(dev, "missing phy mode property\n"); | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -54,7 +54,7 @@ struct mediatek_dwmac_plat_data { | |||||||
| 	struct device_node *np; | 	struct device_node *np; | ||||||
| 	struct regmap *peri_regmap; | 	struct regmap *peri_regmap; | ||||||
| 	struct device *dev; | 	struct device *dev; | ||||||
| 	int phy_mode; | 	phy_interface_t phy_mode; | ||||||
| 	bool rmii_rxc; | 	bool rmii_rxc; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -243,6 +243,7 @@ static int mediatek_dwmac_config_dt(struct mediatek_dwmac_plat_data *plat) | |||||||
| { | { | ||||||
| 	struct mac_delay_struct *mac_delay = &plat->mac_delay; | 	struct mac_delay_struct *mac_delay = &plat->mac_delay; | ||||||
| 	u32 tx_delay_ps, rx_delay_ps; | 	u32 tx_delay_ps, rx_delay_ps; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	plat->peri_regmap = syscon_regmap_lookup_by_phandle(plat->np, "mediatek,pericfg"); | 	plat->peri_regmap = syscon_regmap_lookup_by_phandle(plat->np, "mediatek,pericfg"); | ||||||
| 	if (IS_ERR(plat->peri_regmap)) { | 	if (IS_ERR(plat->peri_regmap)) { | ||||||
| @ -250,10 +251,10 @@ static int mediatek_dwmac_config_dt(struct mediatek_dwmac_plat_data *plat) | |||||||
| 		return PTR_ERR(plat->peri_regmap); | 		return PTR_ERR(plat->peri_regmap); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	plat->phy_mode = of_get_phy_mode(plat->np); | 	err = of_get_phy_mode(plat->np, &plat->phy_mode); | ||||||
| 	if (plat->phy_mode < 0) { | 	if (err) { | ||||||
| 		dev_err(plat->dev, "not find phy-mode\n"); | 		dev_err(plat->dev, "not find phy-mode\n"); | ||||||
| 		return -EINVAL; | 		return err; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (!of_property_read_u32(plat->np, "mediatek,tx-delay-ps", &tx_delay_ps)) { | 	if (!of_property_read_u32(plat->np, "mediatek,tx-delay-ps", &tx_delay_ps)) { | ||||||
|  | |||||||
| @ -338,10 +338,9 @@ static int meson8b_dwmac_probe(struct platform_device *pdev) | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	dwmac->dev = &pdev->dev; | 	dwmac->dev = &pdev->dev; | ||||||
| 	dwmac->phy_mode = of_get_phy_mode(pdev->dev.of_node); | 	ret = of_get_phy_mode(pdev->dev.of_node, &dwmac->phy_mode); | ||||||
| 	if ((int)dwmac->phy_mode < 0) { | 	if (ret) { | ||||||
| 		dev_err(&pdev->dev, "missing phy-mode property\n"); | 		dev_err(&pdev->dev, "missing phy-mode property\n"); | ||||||
| 		ret = -EINVAL; |  | ||||||
| 		goto err_remove_config_dt; | 		goto err_remove_config_dt; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -37,7 +37,7 @@ struct rk_gmac_ops { | |||||||
| 
 | 
 | ||||||
| struct rk_priv_data { | struct rk_priv_data { | ||||||
| 	struct platform_device *pdev; | 	struct platform_device *pdev; | ||||||
| 	int phy_iface; | 	phy_interface_t phy_iface; | ||||||
| 	struct regulator *regulator; | 	struct regulator *regulator; | ||||||
| 	bool suspended; | 	bool suspended; | ||||||
| 	const struct rk_gmac_ops *ops; | 	const struct rk_gmac_ops *ops; | ||||||
| @ -1224,7 +1224,7 @@ static struct rk_priv_data *rk_gmac_setup(struct platform_device *pdev, | |||||||
| 	if (!bsp_priv) | 	if (!bsp_priv) | ||||||
| 		return ERR_PTR(-ENOMEM); | 		return ERR_PTR(-ENOMEM); | ||||||
| 
 | 
 | ||||||
| 	bsp_priv->phy_iface = of_get_phy_mode(dev->of_node); | 	of_get_phy_mode(dev->of_node, &bsp_priv->phy_iface); | ||||||
| 	bsp_priv->ops = ops; | 	bsp_priv->ops = ops; | ||||||
| 
 | 
 | ||||||
| 	bsp_priv->regulator = devm_regulator_get_optional(dev, "phy"); | 	bsp_priv->regulator = devm_regulator_get_optional(dev, "phy"); | ||||||
|  | |||||||
| @ -116,7 +116,7 @@ | |||||||
| #define ETH_PHY_SEL_MII		0x0 | #define ETH_PHY_SEL_MII		0x0 | ||||||
| 
 | 
 | ||||||
| struct sti_dwmac { | struct sti_dwmac { | ||||||
| 	int interface;		/* MII interface */ | 	phy_interface_t interface;	/* MII interface */ | ||||||
| 	bool ext_phyclk;	/* Clock from external PHY */ | 	bool ext_phyclk;	/* Clock from external PHY */ | ||||||
| 	u32 tx_retime_src;	/* TXCLK Retiming*/ | 	u32 tx_retime_src;	/* TXCLK Retiming*/ | ||||||
| 	struct clk *clk;	/* PHY clock */ | 	struct clk *clk;	/* PHY clock */ | ||||||
| @ -269,7 +269,12 @@ static int sti_dwmac_parse_data(struct sti_dwmac *dwmac, | |||||||
| 		return err; | 		return err; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	dwmac->interface = of_get_phy_mode(np); | 	err = of_get_phy_mode(np, &dwmac->interface); | ||||||
|  | 	if (err && err != -ENODEV) { | ||||||
|  | 		dev_err(dev, "Can't get phy-mode\n"); | ||||||
|  | 		return err; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	dwmac->regmap = regmap; | 	dwmac->regmap = regmap; | ||||||
| 	dwmac->gmac_en = of_property_read_bool(np, "st,gmac_en"); | 	dwmac->gmac_en = of_property_read_bool(np, "st,gmac_en"); | ||||||
| 	dwmac->ext_phyclk = of_property_read_bool(np, "st,ext-phyclk"); | 	dwmac->ext_phyclk = of_property_read_bool(np, "st,ext-phyclk"); | ||||||
|  | |||||||
| @ -1105,6 +1105,7 @@ static int sun8i_dwmac_probe(struct platform_device *pdev) | |||||||
| 	struct stmmac_resources stmmac_res; | 	struct stmmac_resources stmmac_res; | ||||||
| 	struct sunxi_priv_data *gmac; | 	struct sunxi_priv_data *gmac; | ||||||
| 	struct device *dev = &pdev->dev; | 	struct device *dev = &pdev->dev; | ||||||
|  | 	phy_interface_t interface; | ||||||
| 	int ret; | 	int ret; | ||||||
| 	struct stmmac_priv *priv; | 	struct stmmac_priv *priv; | ||||||
| 	struct net_device *ndev; | 	struct net_device *ndev; | ||||||
| @ -1178,10 +1179,10 @@ static int sun8i_dwmac_probe(struct platform_device *pdev) | |||||||
| 		return ret; | 		return ret; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	ret = of_get_phy_mode(dev->of_node); | 	ret = of_get_phy_mode(dev->of_node, &interface); | ||||||
| 	if (ret < 0) | 	if (ret) | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 	plat_dat->interface = ret; | 	plat_dat->interface = interface; | ||||||
| 
 | 
 | ||||||
| 	/* platform data specifying hardware features and callbacks.
 | 	/* platform data specifying hardware features and callbacks.
 | ||||||
| 	 * hardware features were copied from Allwinner drivers. | 	 * hardware features were copied from Allwinner drivers. | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ | |||||||
| #include "stmmac_platform.h" | #include "stmmac_platform.h" | ||||||
| 
 | 
 | ||||||
| struct sunxi_priv_data { | struct sunxi_priv_data { | ||||||
| 	int interface; | 	phy_interface_t interface; | ||||||
| 	int clk_enabled; | 	int clk_enabled; | ||||||
| 	struct clk *tx_clk; | 	struct clk *tx_clk; | ||||||
| 	struct regulator *regulator; | 	struct regulator *regulator; | ||||||
| @ -118,7 +118,11 @@ static int sun7i_gmac_probe(struct platform_device *pdev) | |||||||
| 		goto err_remove_config_dt; | 		goto err_remove_config_dt; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	gmac->interface = of_get_phy_mode(dev->of_node); | 	ret = of_get_phy_mode(dev->of_node, &gmac->interface); | ||||||
|  | 	if (ret && ret != -ENODEV) { | ||||||
|  | 		dev_err(dev, "Can't get phy-mode\n"); | ||||||
|  | 		goto err_remove_config_dt; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	gmac->tx_clk = devm_clk_get(dev, "allwinner_gmac_tx"); | 	gmac->tx_clk = devm_clk_get(dev, "allwinner_gmac_tx"); | ||||||
| 	if (IS_ERR(gmac->tx_clk)) { | 	if (IS_ERR(gmac->tx_clk)) { | ||||||
|  | |||||||
| @ -412,9 +412,9 @@ stmmac_probe_config_dt(struct platform_device *pdev, const char **mac) | |||||||
| 		*mac = NULL; | 		*mac = NULL; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	plat->phy_interface = of_get_phy_mode(np); | 	rc = of_get_phy_mode(np, &plat->phy_interface); | ||||||
| 	if (plat->phy_interface < 0) | 	if (rc) | ||||||
| 		return ERR_PTR(plat->phy_interface); | 		return ERR_PTR(rc); | ||||||
| 
 | 
 | ||||||
| 	plat->interface = stmmac_of_get_mac_mode(np); | 	plat->interface = stmmac_of_get_mac_mode(np); | ||||||
| 	if (plat->interface < 0) | 	if (plat->interface < 0) | ||||||
|  | |||||||
| @ -2619,11 +2619,10 @@ static int cpsw_probe_dt(struct cpsw_platform_data *data, | |||||||
| 				i); | 				i); | ||||||
| 			goto no_phy_slave; | 			goto no_phy_slave; | ||||||
| 		} | 		} | ||||||
| 		slave_data->phy_if = of_get_phy_mode(slave_node); | 		ret = of_get_phy_mode(slave_node, &slave_data->phy_if); | ||||||
| 		if (slave_data->phy_if < 0) { | 		if (ret) { | ||||||
| 			dev_err(&pdev->dev, "Missing or malformed slave[%d] phy-mode property\n", | 			dev_err(&pdev->dev, "Missing or malformed slave[%d] phy-mode property\n", | ||||||
| 				i); | 				i); | ||||||
| 			ret = slave_data->phy_if; |  | ||||||
| 			goto err_node_put; | 			goto err_node_put; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -275,7 +275,7 @@ struct cpsw_slave_data { | |||||||
| 	struct device_node *slave_node; | 	struct device_node *slave_node; | ||||||
| 	struct device_node *phy_node; | 	struct device_node *phy_node; | ||||||
| 	char		phy_id[MII_BUS_ID_SIZE]; | 	char		phy_id[MII_BUS_ID_SIZE]; | ||||||
| 	int		phy_if; | 	phy_interface_t	phy_if; | ||||||
| 	u8		mac_addr[ETH_ALEN]; | 	u8		mac_addr[ETH_ALEN]; | ||||||
| 	u16		dual_emac_res_vlan;	/* Reserved VLAN for DualEMAC */ | 	u16		dual_emac_res_vlan;	/* Reserved VLAN for DualEMAC */ | ||||||
| 	struct phy	*ifphy; | 	struct phy	*ifphy; | ||||||
|  | |||||||
| @ -2291,6 +2291,7 @@ static int gbe_slave_open(struct gbe_intf *gbe_intf) | |||||||
| 	struct gbe_slave *slave = gbe_intf->slave; | 	struct gbe_slave *slave = gbe_intf->slave; | ||||||
| 	phy_interface_t phy_mode; | 	phy_interface_t phy_mode; | ||||||
| 	bool has_phy = false; | 	bool has_phy = false; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	void (*hndlr)(struct net_device *) = gbe_adjust_link; | 	void (*hndlr)(struct net_device *) = gbe_adjust_link; | ||||||
| 
 | 
 | ||||||
| @ -2320,11 +2321,11 @@ static int gbe_slave_open(struct gbe_intf *gbe_intf) | |||||||
| 		slave->phy_port_t = PORT_MII; | 		slave->phy_port_t = PORT_MII; | ||||||
| 	} else if (slave->link_interface == RGMII_LINK_MAC_PHY) { | 	} else if (slave->link_interface == RGMII_LINK_MAC_PHY) { | ||||||
| 		has_phy = true; | 		has_phy = true; | ||||||
| 		phy_mode = of_get_phy_mode(slave->node); | 		err = of_get_phy_mode(slave->node, &phy_mode); | ||||||
| 		/* if phy-mode is not present, default to
 | 		/* if phy-mode is not present, default to
 | ||||||
| 		 * PHY_INTERFACE_MODE_RGMII | 		 * PHY_INTERFACE_MODE_RGMII | ||||||
| 		 */ | 		 */ | ||||||
| 		if (phy_mode < 0) | 		if (err) | ||||||
| 			phy_mode = PHY_INTERFACE_MODE_RGMII; | 			phy_mode = PHY_INTERFACE_MODE_RGMII; | ||||||
| 
 | 
 | ||||||
| 		if (!phy_interface_mode_is_rgmii(phy_mode)) { | 		if (!phy_interface_mode_is_rgmii(phy_mode)) { | ||||||
|  | |||||||
| @ -1761,12 +1761,10 @@ static int axienet_probe(struct platform_device *pdev) | |||||||
| 			goto free_netdev; | 			goto free_netdev; | ||||||
| 		} | 		} | ||||||
| 	} else { | 	} else { | ||||||
| 		lp->phy_mode = of_get_phy_mode(pdev->dev.of_node); | 		ret = of_get_phy_mode(pdev->dev.of_node, &lp->phy_mode); | ||||||
| 		if ((int)lp->phy_mode < 0) { | 		if (ret) | ||||||
| 			ret = -EINVAL; |  | ||||||
| 			goto free_netdev; | 			goto free_netdev; | ||||||
| 	} | 	} | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	/* Find the DMA node, map the DMA registers, and decode the DMA IRQs */ | 	/* Find the DMA node, map the DMA registers, and decode the DMA IRQs */ | ||||||
| 	np = of_parse_phandle(pdev->dev.of_node, "axistream-connected", 0); | 	np = of_parse_phandle(pdev->dev.of_node, "axistream-connected", 0); | ||||||
|  | |||||||
| @ -361,8 +361,8 @@ struct phy_device *of_phy_get_and_connect(struct net_device *dev, | |||||||
| 	struct phy_device *phy; | 	struct phy_device *phy; | ||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	iface = of_get_phy_mode(np); | 	ret = of_get_phy_mode(np, &iface); | ||||||
| 	if ((int)iface < 0) | 	if (ret) | ||||||
| 		return NULL; | 		return NULL; | ||||||
| 	if (of_phy_is_fixed_link(np)) { | 	if (of_phy_is_fixed_link(np)) { | ||||||
| 		ret = of_phy_register_fixed_link(np); | 		ret = of_phy_register_fixed_link(np); | ||||||
|  | |||||||
| @ -15,16 +15,20 @@ | |||||||
| /**
 | /**
 | ||||||
|  * of_get_phy_mode - Get phy mode for given device_node |  * of_get_phy_mode - Get phy mode for given device_node | ||||||
|  * @np:	Pointer to the given device_node |  * @np:	Pointer to the given device_node | ||||||
|  |  * @interface: Pointer to the result | ||||||
|  * |  * | ||||||
|  * The function gets phy interface string from property 'phy-mode' or |  * The function gets phy interface string from property 'phy-mode' or | ||||||
|  * 'phy-connection-type', and return its index in phy_modes table, or errno in |  * 'phy-connection-type'. The index in phy_modes table is set in | ||||||
|  * error case. |  * interface and 0 returned. In case of error interface is set to | ||||||
|  |  * PHY_INTERFACE_MODE_NA and an errno is returned, e.g. -ENODEV. | ||||||
|  */ |  */ | ||||||
| int of_get_phy_mode(struct device_node *np) | int of_get_phy_mode(struct device_node *np, phy_interface_t *interface) | ||||||
| { | { | ||||||
| 	const char *pm; | 	const char *pm; | ||||||
| 	int err, i; | 	int err, i; | ||||||
| 
 | 
 | ||||||
|  | 	*interface = PHY_INTERFACE_MODE_NA; | ||||||
|  | 
 | ||||||
| 	err = of_property_read_string(np, "phy-mode", &pm); | 	err = of_property_read_string(np, "phy-mode", &pm); | ||||||
| 	if (err < 0) | 	if (err < 0) | ||||||
| 		err = of_property_read_string(np, "phy-connection-type", &pm); | 		err = of_property_read_string(np, "phy-connection-type", &pm); | ||||||
| @ -32,8 +36,10 @@ int of_get_phy_mode(struct device_node *np) | |||||||
| 		return err; | 		return err; | ||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < PHY_INTERFACE_MODE_MAX; i++) | 	for (i = 0; i < PHY_INTERFACE_MODE_MAX; i++) | ||||||
| 		if (!strcasecmp(pm, phy_modes(i))) | 		if (!strcasecmp(pm, phy_modes(i))) { | ||||||
| 			return i; | 			*interface = i; | ||||||
|  | 			return 0; | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 	return -ENODEV; | 	return -ENODEV; | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,15 +6,18 @@ | |||||||
| #ifndef __LINUX_OF_NET_H | #ifndef __LINUX_OF_NET_H | ||||||
| #define __LINUX_OF_NET_H | #define __LINUX_OF_NET_H | ||||||
| 
 | 
 | ||||||
|  | #include <linux/phy.h> | ||||||
|  | 
 | ||||||
| #ifdef CONFIG_OF_NET | #ifdef CONFIG_OF_NET | ||||||
| #include <linux/of.h> | #include <linux/of.h> | ||||||
| 
 | 
 | ||||||
| struct net_device; | struct net_device; | ||||||
| extern int of_get_phy_mode(struct device_node *np); | extern int of_get_phy_mode(struct device_node *np, phy_interface_t *interface); | ||||||
| extern const void *of_get_mac_address(struct device_node *np); | extern const void *of_get_mac_address(struct device_node *np); | ||||||
| extern struct net_device *of_find_net_device_by_node(struct device_node *np); | extern struct net_device *of_find_net_device_by_node(struct device_node *np); | ||||||
| #else | #else | ||||||
| static inline int of_get_phy_mode(struct device_node *np) | static inline int of_get_phy_mode(struct device_node *np, | ||||||
|  | 				  phy_interface_t *interface) | ||||||
| { | { | ||||||
| 	return -ENODEV; | 	return -ENODEV; | ||||||
| } | } | ||||||
|  | |||||||
| @ -13,6 +13,7 @@ | |||||||
| #define __STMMAC_PLATFORM_DATA | #define __STMMAC_PLATFORM_DATA | ||||||
| 
 | 
 | ||||||
| #include <linux/platform_device.h> | #include <linux/platform_device.h> | ||||||
|  | #include <linux/phy.h> | ||||||
| 
 | 
 | ||||||
| #define MTL_MAX_RX_QUEUES	8 | #define MTL_MAX_RX_QUEUES	8 | ||||||
| #define MTL_MAX_TX_QUEUES	8 | #define MTL_MAX_TX_QUEUES	8 | ||||||
| @ -132,7 +133,7 @@ struct plat_stmmacenet_data { | |||||||
| 	int bus_id; | 	int bus_id; | ||||||
| 	int phy_addr; | 	int phy_addr; | ||||||
| 	int interface; | 	int interface; | ||||||
| 	int phy_interface; | 	phy_interface_t phy_interface; | ||||||
| 	struct stmmac_mdio_bus_data *mdio_bus_data; | 	struct stmmac_mdio_bus_data *mdio_bus_data; | ||||||
| 	struct device_node *phy_node; | 	struct device_node *phy_node; | ||||||
| 	struct device_node *phylink_node; | 	struct device_node *phylink_node; | ||||||
|  | |||||||
| @ -10,6 +10,8 @@ | |||||||
| #ifndef __SXGBE_PLATFORM_H__ | #ifndef __SXGBE_PLATFORM_H__ | ||||||
| #define __SXGBE_PLATFORM_H__ | #define __SXGBE_PLATFORM_H__ | ||||||
| 
 | 
 | ||||||
|  | #include <linux/phy.h> | ||||||
|  | 
 | ||||||
| /* MDC Clock Selection define*/ | /* MDC Clock Selection define*/ | ||||||
| #define SXGBE_CSR_100_150M	0x0	/* MDC = clk_scr_i/62 */ | #define SXGBE_CSR_100_150M	0x0	/* MDC = clk_scr_i/62 */ | ||||||
| #define SXGBE_CSR_150_250M	0x1	/* MDC = clk_scr_i/102 */ | #define SXGBE_CSR_150_250M	0x1	/* MDC = clk_scr_i/102 */ | ||||||
| @ -38,7 +40,7 @@ struct sxgbe_plat_data { | |||||||
| 	char *phy_bus_name; | 	char *phy_bus_name; | ||||||
| 	int bus_id; | 	int bus_id; | ||||||
| 	int phy_addr; | 	int phy_addr; | ||||||
| 	int interface; | 	phy_interface_t interface; | ||||||
| 	struct sxgbe_mdio_bus_data *mdio_bus_data; | 	struct sxgbe_mdio_bus_data *mdio_bus_data; | ||||||
| 	struct sxgbe_dma_cfg *dma_cfg; | 	struct sxgbe_dma_cfg *dma_cfg; | ||||||
| 	int clk_csr; | 	int clk_csr; | ||||||
|  | |||||||
| @ -561,7 +561,7 @@ static int dsa_port_fixed_link_register_of(struct dsa_port *dp) | |||||||
| 	struct dsa_switch *ds = dp->ds; | 	struct dsa_switch *ds = dp->ds; | ||||||
| 	struct phy_device *phydev; | 	struct phy_device *phydev; | ||||||
| 	int port = dp->index; | 	int port = dp->index; | ||||||
| 	int mode; | 	phy_interface_t mode; | ||||||
| 	int err; | 	int err; | ||||||
| 
 | 
 | ||||||
| 	err = of_phy_register_fixed_link(dn); | 	err = of_phy_register_fixed_link(dn); | ||||||
| @ -574,8 +574,8 @@ static int dsa_port_fixed_link_register_of(struct dsa_port *dp) | |||||||
| 
 | 
 | ||||||
| 	phydev = of_phy_find_device(dn); | 	phydev = of_phy_find_device(dn); | ||||||
| 
 | 
 | ||||||
| 	mode = of_get_phy_mode(dn); | 	err = of_get_phy_mode(dn, &mode); | ||||||
| 	if (mode < 0) | 	if (err) | ||||||
| 		mode = PHY_INTERFACE_MODE_NA; | 		mode = PHY_INTERFACE_MODE_NA; | ||||||
| 	phydev->interface = mode; | 	phydev->interface = mode; | ||||||
| 
 | 
 | ||||||
| @ -593,10 +593,11 @@ static int dsa_port_phylink_register(struct dsa_port *dp) | |||||||
| { | { | ||||||
| 	struct dsa_switch *ds = dp->ds; | 	struct dsa_switch *ds = dp->ds; | ||||||
| 	struct device_node *port_dn = dp->dn; | 	struct device_node *port_dn = dp->dn; | ||||||
| 	int mode, err; | 	phy_interface_t mode; | ||||||
|  | 	int err; | ||||||
| 
 | 
 | ||||||
| 	mode = of_get_phy_mode(port_dn); | 	err = of_get_phy_mode(port_dn, &mode); | ||||||
| 	if (mode < 0) | 	if (err) | ||||||
| 		mode = PHY_INTERFACE_MODE_NA; | 		mode = PHY_INTERFACE_MODE_NA; | ||||||
| 
 | 
 | ||||||
| 	dp->pl_config.dev = ds->dev; | 	dp->pl_config.dev = ds->dev; | ||||||
|  | |||||||
| @ -1313,11 +1313,12 @@ static int dsa_slave_phy_setup(struct net_device *slave_dev) | |||||||
| 	struct dsa_port *dp = dsa_slave_to_port(slave_dev); | 	struct dsa_port *dp = dsa_slave_to_port(slave_dev); | ||||||
| 	struct device_node *port_dn = dp->dn; | 	struct device_node *port_dn = dp->dn; | ||||||
| 	struct dsa_switch *ds = dp->ds; | 	struct dsa_switch *ds = dp->ds; | ||||||
|  | 	phy_interface_t mode; | ||||||
| 	u32 phy_flags = 0; | 	u32 phy_flags = 0; | ||||||
| 	int mode, ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	mode = of_get_phy_mode(port_dn); | 	ret = of_get_phy_mode(port_dn, &mode); | ||||||
| 	if (mode < 0) | 	if (ret) | ||||||
| 		mode = PHY_INTERFACE_MODE_NA; | 		mode = PHY_INTERFACE_MODE_NA; | ||||||
| 
 | 
 | ||||||
| 	dp->pl_config.dev = &slave_dev->dev; | 	dp->pl_config.dev = &slave_dev->dev; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Andrew Lunn
						Andrew Lunn