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:
Andrew Lunn 2019-11-04 02:40:33 +01:00 коммит произвёл David S. Miller
Родитель 5d1fcaf35d
Коммит 0c65b2b90d
53 изменённых файлов: 201 добавлений и 149 удалений

Просмотреть файл

@ -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) {
interface = PHY_INTERFACE_MODE_MII; if (err == -ENODEV)
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,11 +398,11 @@ 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) {
case PHY_INTERFACE_MODE_NA: case PHY_INTERFACE_MODE_NA:

Просмотреть файл

@ -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,11 +1761,9 @@ 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 */

Просмотреть файл

@ -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;