* davinci_emac: follow phylib changes @ 2012-09-28 15:00 Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 1/3] davinci_emac: return 0 on successful transmit Jan Luebbe ` (2 more replies) 0 siblings, 3 replies; 5+ messages in thread From: Jan Luebbe @ 2012-09-28 15:00 UTC (permalink / raw) To: barebox Since v1 I've dropped the useless casts from void* and switched to using platform_data. _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH v2 1/3] davinci_emac: return 0 on successful transmit 2012-09-28 15:00 davinci_emac: follow phylib changes Jan Luebbe @ 2012-09-28 15:00 ` Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 2/3] davinci_emac: adjust to new phylib framework Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 3/3] davinci_emac: get rid of mdio wrapper functions Jan Luebbe 2 siblings, 0 replies; 5+ messages in thread From: Jan Luebbe @ 2012-09-28 15:00 UTC (permalink / raw) To: barebox The _send function should not return the length of the transmitted packet. Signed-off-by: Jan Luebbe <jlu@pengutronix.de> --- drivers/net/davinci_emac.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c index 09fcb63..7f39972 100644 --- a/drivers/net/davinci_emac.c +++ b/drivers/net/davinci_emac.c @@ -410,7 +410,7 @@ static int davinci_emac_send(struct eth_device *edev, void *packet, int length) { struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; uint64_t start; - int ret_status = -1; + int ret_status; dev_dbg(priv->dev, "+ emac_send (length %d)\n", length); @@ -437,7 +437,7 @@ static int davinci_emac_send(struct eth_device *edev, void *packet, int length) if (readl(priv->adap_emac + EMAC_TXINTSTATRAW) & 0x01) { /* Acknowledge the TX descriptor */ writel(BD_TO_HW(priv->emac_tx_desc), priv->adap_emac + EMAC_TX0CP); - ret_status = length; + ret_status = 0; break; } if (is_timeout(start, 100 * MSECOND)) { -- 1.7.10.4 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH v2 2/3] davinci_emac: adjust to new phylib framework 2012-09-28 15:00 davinci_emac: follow phylib changes Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 1/3] davinci_emac: return 0 on successful transmit Jan Luebbe @ 2012-09-28 15:00 ` Jan Luebbe 2012-09-28 15:33 ` Jean-Christophe PLAGNIOL-VILLARD 2012-09-28 15:00 ` [PATCH v2 3/3] davinci_emac: get rid of mdio wrapper functions Jan Luebbe 2 siblings, 1 reply; 5+ messages in thread From: Jan Luebbe @ 2012-09-28 15:00 UTC (permalink / raw) To: barebox Also pass flags using platform_data and remove useless casts from void*. Signed-off-by: Jan Luebbe <jlu@pengutronix.de> --- drivers/net/Kconfig | 2 +- drivers/net/davinci_emac.c | 81 ++++++++++++++++++++++++++------------------ include/net/davinci_emac.h | 13 +++++++ 3 files changed, 62 insertions(+), 34 deletions(-) create mode 100644 include/net/davinci_emac.h diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig index b0da2c5..b3e5a83 100644 --- a/drivers/net/Kconfig +++ b/drivers/net/Kconfig @@ -48,7 +48,7 @@ config DRIVER_NET_SMC91111 config DRIVER_NET_DAVINCI_EMAC bool "TI Davinci/OMAP EMAC ethernet driver" depends on ARCH_DAVINCI || ARCH_OMAP3 - select MIIDEV + select PHYLIB config DRIVER_NET_DM9K bool "Davicom dm9k[E|A|B] ethernet driver" diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c index 7f39972..52786e0 100644 --- a/drivers/net/davinci_emac.c +++ b/drivers/net/davinci_emac.c @@ -43,18 +43,19 @@ #include <io.h> #include <clock.h> #include <net.h> -#include <miidev.h> #include <malloc.h> #include <init.h> #include <asm/mmu.h> #include <asm/system.h> +#include <linux/phy.h> #include <mach/emac_defs.h> +#include <net/davinci_emac.h> #include "davinci_emac.h" struct davinci_emac_priv { struct device_d *dev; struct eth_device edev; - struct mii_device miidev; + struct mii_bus miibus; /* EMAC Addresses */ void __iomem *adap_emac; /* = EMAC_BASE_ADDR */ @@ -72,8 +73,10 @@ struct davinci_emac_priv { /* Receive packet buffers */ unsigned char *emac_rx_buffers; /* [EMAC_MAX_RX_BUFFERS * (EMAC_MAX_ETHERNET_PKT_SIZE + EMAC_PKT_ALIGN)] */ - /* PHY address for a discovered PHY (0xff - not found) */ - uint8_t active_phy_addr; /* = 0xff */ + /* PHY-specific information */ + phy_interface_t interface; + uint8_t phy_addr; + uint32_t phy_flags; /* mac_addr[0] goes out on the wire first */ uint8_t mac_addr[6]; @@ -149,7 +152,6 @@ static int davinci_eth_phy_read(struct davinci_emac_priv *priv, uint8_t phy_addr /* Write to a PHY register via MDIO inteface. Blocks until operation is complete. */ static int davinci_eth_phy_write(struct davinci_emac_priv *priv, uint8_t phy_addr, uint8_t reg_num, uint16_t data) { - while (readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0) & MDIO_USERACCESS0_GO); dev_dbg(priv->dev, "emac_phy_write: addr=0x%02x reg=0x%02x data=0x%04x\n", @@ -167,16 +169,16 @@ static int davinci_eth_phy_write(struct davinci_emac_priv *priv, uint8_t phy_add return 1; } -static int davinci_miidev_read(struct mii_device *dev, int addr, int reg) +static int davinci_miibus_read(struct mii_bus *bus, int addr, int reg) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)dev->edev->priv; + struct davinci_emac_priv *priv = bus->priv; uint16_t value = 0; return davinci_eth_phy_read(priv, addr, reg, &value) ? value : -1; } -static int davinci_miidev_write(struct mii_device *dev, int addr, int reg, int value) +static int davinci_miibus_write(struct mii_bus *bus, int addr, int reg, u16 value) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)dev->edev->priv; + struct davinci_emac_priv *priv = (struct davinci_emac_priv *)bus->priv; return davinci_eth_phy_write(priv, addr, reg, value) ? 0 : -1; } @@ -191,7 +193,7 @@ static int davinci_emac_get_ethaddr(struct eth_device *edev, unsigned char *adr) */ static int davinci_emac_set_ethaddr(struct eth_device *edev, unsigned char *addr) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; + struct davinci_emac_priv *priv = edev->priv; int i; for (i = 0; i < sizeof(priv->mac_addr); i++) @@ -207,7 +209,7 @@ static int davinci_emac_init(struct eth_device *edev) static int davinci_emac_open(struct eth_device *edev) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; + struct davinci_emac_priv *priv = edev->priv; uint32_t clkdiv, cnt; void __iomem *rx_desc; unsigned long mac_hi, mac_lo; @@ -318,16 +320,11 @@ static int davinci_emac_open(struct eth_device *edev) /* Start receive process */ writel(BD_TO_HW(priv->emac_rx_desc), priv->adap_emac + EMAC_RX0HDP); - ret = miidev_wait_aneg(&priv->miidev); + ret = phy_device_connect(edev, &priv->miibus, priv->phy_addr, NULL, + priv->phy_flags, priv->interface); if (ret) return ret; - ret = miidev_get_status(&priv->miidev); - if (ret < 0) - return ret; - - miidev_print_status(&priv->miidev); - dev_dbg(priv->dev, "- emac_open\n"); return 0; @@ -378,7 +375,7 @@ static void davinci_eth_ch_teardown(struct davinci_emac_priv *priv, int ch) static void davinci_emac_halt(struct eth_device *edev) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; + struct davinci_emac_priv *priv = edev->priv; dev_dbg(priv->dev, "+ emac_halt\n"); @@ -408,7 +405,7 @@ static void davinci_emac_halt(struct eth_device *edev) */ static int davinci_emac_send(struct eth_device *edev, void *packet, int length) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; + struct davinci_emac_priv *priv = edev->priv; uint64_t start; int ret_status; @@ -455,7 +452,7 @@ static int davinci_emac_send(struct eth_device *edev, void *packet, int length) */ static int davinci_emac_recv(struct eth_device *edev) { - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; + struct davinci_emac_priv *priv = edev->priv; void __iomem *rx_curr_desc, *curr_desc, *tail_desc; unsigned char *pkt; int status, len, ret = -1; @@ -531,11 +528,19 @@ out: static int davinci_emac_probe(struct device_d *dev) { + struct davinci_emac_platform_data *pdata; struct davinci_emac_priv *priv; uint64_t start; + uint32_t phy_mask; dev_dbg(dev, "+ emac_probe\n"); + if (!dev->platform_data) { + dev_err(dev, "no platform_data\n"); + return -ENODEV; + } + pdata = dev->platform_data; + priv = xzalloc(sizeof(*priv)); dev->priv = priv; @@ -556,9 +561,6 @@ static int davinci_emac_probe(struct device_d *dev) /* Receive packet buffers */ priv->emac_rx_buffers = xmemalign(4096, EMAC_MAX_RX_BUFFERS * (EMAC_MAX_ETHERNET_PKT_SIZE + EMAC_PKT_ALIGN)); - /* PHY address for a discovered PHY (0xff - not found) */ - priv->active_phy_addr = 0xff; - priv->edev.priv = priv; priv->edev.init = davinci_emac_init; priv->edev.open = davinci_emac_open; @@ -573,22 +575,35 @@ static int davinci_emac_probe(struct device_d *dev) start = get_time_ns(); while (1) { - if (readl(priv->adap_mdio + EMAC_MDIO_ALIVE)) + phy_mask = readl(priv->adap_mdio + EMAC_MDIO_ALIVE); + if (phy_mask) { + dev_info(dev, "detected phy mask 0x%x\n", phy_mask); + phy_mask = ~phy_mask; break; + } if (is_timeout(start, 256 * MSECOND)) { - dev_err(dev, "No ETH PHY detected!\n"); + dev_err(dev, "no live phy, scanning all\n"); + phy_mask = 0; break; } } - priv->miidev.read = davinci_miidev_read; - priv->miidev.write = davinci_miidev_write; - priv->miidev.address = 0x01; - priv->miidev.flags = MIIDEV_FORCE_LINK; - priv->miidev.edev = &priv->edev; - priv->miidev.parent = dev; + if (pdata->flags & DAVINCI_EMAC_RMII) + priv->interface = PHY_INTERFACE_MODE_RMII; + else + priv->interface = PHY_INTERFACE_MODE_MII; + + priv->phy_addr = pdata->phy_addr; + priv->phy_flags = pdata->flags & DAVINCI_EMAC_FORCE_LINK ? + PHYLIB_FORCE_LINK : 0; + + priv->miibus.read = davinci_miibus_read; + priv->miibus.write = davinci_miibus_write; + priv->miibus.priv = priv; + priv->miibus.parent = dev; + priv->miibus.phy_mask = phy_mask; - mii_register(&priv->miidev); + mdiobus_register(&priv->miibus); eth_register(&priv->edev); diff --git a/include/net/davinci_emac.h b/include/net/davinci_emac.h new file mode 100644 index 0000000..c962dc9 --- /dev/null +++ b/include/net/davinci_emac.h @@ -0,0 +1,13 @@ +#ifndef __NET_DAVINCI_EMAC_H__ +#define __NET_DAVINCI_EMAC_H__ + +#define DAVINCI_EMAC_MII (0 << 0) +#define DAVINCI_EMAC_RMII (1 << 0) +#define DAVINCI_EMAC_FORCE_LINK (1 << 1) + +struct davinci_emac_platform_data { + unsigned int flags; + int phy_addr; +}; + +#endif /* __NET_DAVINCI_EMAC_H__ */ -- 1.7.10.4 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2 2/3] davinci_emac: adjust to new phylib framework 2012-09-28 15:00 ` [PATCH v2 2/3] davinci_emac: adjust to new phylib framework Jan Luebbe @ 2012-09-28 15:33 ` Jean-Christophe PLAGNIOL-VILLARD 0 siblings, 0 replies; 5+ messages in thread From: Jean-Christophe PLAGNIOL-VILLARD @ 2012-09-28 15:33 UTC (permalink / raw) To: Jan Luebbe; +Cc: barebox On 17:00 Fri 28 Sep , Jan Luebbe wrote: > Also pass flags using platform_data and remove useless casts from void*. > > Signed-off-by: Jan Luebbe <jlu@pengutronix.de> > --- > drivers/net/Kconfig | 2 +- > drivers/net/davinci_emac.c | 81 ++++++++++++++++++++++++++------------------ > include/net/davinci_emac.h | 13 +++++++ > 3 files changed, 62 insertions(+), 34 deletions(-) > create mode 100644 include/net/davinci_emac.h > > diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig > index b0da2c5..b3e5a83 100644 > --- a/drivers/net/Kconfig > +++ b/drivers/net/Kconfig > @@ -48,7 +48,7 @@ config DRIVER_NET_SMC91111 > config DRIVER_NET_DAVINCI_EMAC > bool "TI Davinci/OMAP EMAC ethernet driver" > depends on ARCH_DAVINCI || ARCH_OMAP3 > - select MIIDEV > + select PHYLIB > > config DRIVER_NET_DM9K > bool "Davicom dm9k[E|A|B] ethernet driver" > diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c > index 7f39972..52786e0 100644 > --- a/drivers/net/davinci_emac.c > +++ b/drivers/net/davinci_emac.c > @@ -43,18 +43,19 @@ > #include <io.h> > #include <clock.h> > #include <net.h> > -#include <miidev.h> > #include <malloc.h> > #include <init.h> > #include <asm/mmu.h> > #include <asm/system.h> > +#include <linux/phy.h> > #include <mach/emac_defs.h> > +#include <net/davinci_emac.h> > #include "davinci_emac.h" > > struct davinci_emac_priv { > struct device_d *dev; > struct eth_device edev; > - struct mii_device miidev; > + struct mii_bus miibus; > > /* EMAC Addresses */ > void __iomem *adap_emac; /* = EMAC_BASE_ADDR */ > @@ -72,8 +73,10 @@ struct davinci_emac_priv { > /* Receive packet buffers */ > unsigned char *emac_rx_buffers; /* [EMAC_MAX_RX_BUFFERS * (EMAC_MAX_ETHERNET_PKT_SIZE + EMAC_PKT_ALIGN)] */ > > - /* PHY address for a discovered PHY (0xff - not found) */ > - uint8_t active_phy_addr; /* = 0xff */ > + /* PHY-specific information */ > + phy_interface_t interface; > + uint8_t phy_addr; > + uint32_t phy_flags; > > /* mac_addr[0] goes out on the wire first */ > uint8_t mac_addr[6]; > @@ -149,7 +152,6 @@ static int davinci_eth_phy_read(struct davinci_emac_priv *priv, uint8_t phy_addr > /* Write to a PHY register via MDIO inteface. Blocks until operation is complete. */ > static int davinci_eth_phy_write(struct davinci_emac_priv *priv, uint8_t phy_addr, uint8_t reg_num, uint16_t data) > { > - > while (readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0) & MDIO_USERACCESS0_GO); > > dev_dbg(priv->dev, "emac_phy_write: addr=0x%02x reg=0x%02x data=0x%04x\n", > @@ -167,16 +169,16 @@ static int davinci_eth_phy_write(struct davinci_emac_priv *priv, uint8_t phy_add > return 1; > } > > -static int davinci_miidev_read(struct mii_device *dev, int addr, int reg) > +static int davinci_miibus_read(struct mii_bus *bus, int addr, int reg) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)dev->edev->priv; > + struct davinci_emac_priv *priv = bus->priv; > uint16_t value = 0; > return davinci_eth_phy_read(priv, addr, reg, &value) ? value : -1; > } > > -static int davinci_miidev_write(struct mii_device *dev, int addr, int reg, int value) > +static int davinci_miibus_write(struct mii_bus *bus, int addr, int reg, u16 value) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)dev->edev->priv; > + struct davinci_emac_priv *priv = (struct davinci_emac_priv *)bus->priv; > return davinci_eth_phy_write(priv, addr, reg, value) ? 0 : -1; > } > > @@ -191,7 +193,7 @@ static int davinci_emac_get_ethaddr(struct eth_device *edev, unsigned char *adr) > */ > static int davinci_emac_set_ethaddr(struct eth_device *edev, unsigned char *addr) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; > + struct davinci_emac_priv *priv = edev->priv; > int i; > > for (i = 0; i < sizeof(priv->mac_addr); i++) > @@ -207,7 +209,7 @@ static int davinci_emac_init(struct eth_device *edev) > > static int davinci_emac_open(struct eth_device *edev) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; > + struct davinci_emac_priv *priv = edev->priv; > uint32_t clkdiv, cnt; > void __iomem *rx_desc; > unsigned long mac_hi, mac_lo; > @@ -318,16 +320,11 @@ static int davinci_emac_open(struct eth_device *edev) > /* Start receive process */ > writel(BD_TO_HW(priv->emac_rx_desc), priv->adap_emac + EMAC_RX0HDP); > > - ret = miidev_wait_aneg(&priv->miidev); > + ret = phy_device_connect(edev, &priv->miibus, priv->phy_addr, NULL, > + priv->phy_flags, priv->interface); > if (ret) > return ret; > > - ret = miidev_get_status(&priv->miidev); > - if (ret < 0) > - return ret; > - > - miidev_print_status(&priv->miidev); > - > dev_dbg(priv->dev, "- emac_open\n"); > > return 0; > @@ -378,7 +375,7 @@ static void davinci_eth_ch_teardown(struct davinci_emac_priv *priv, int ch) > > static void davinci_emac_halt(struct eth_device *edev) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; > + struct davinci_emac_priv *priv = edev->priv; > > dev_dbg(priv->dev, "+ emac_halt\n"); > > @@ -408,7 +405,7 @@ static void davinci_emac_halt(struct eth_device *edev) > */ > static int davinci_emac_send(struct eth_device *edev, void *packet, int length) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; > + struct davinci_emac_priv *priv = edev->priv; > uint64_t start; > int ret_status; > > @@ -455,7 +452,7 @@ static int davinci_emac_send(struct eth_device *edev, void *packet, int length) > */ > static int davinci_emac_recv(struct eth_device *edev) > { > - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)edev->priv; > + struct davinci_emac_priv *priv = edev->priv; > void __iomem *rx_curr_desc, *curr_desc, *tail_desc; > unsigned char *pkt; > int status, len, ret = -1; > @@ -531,11 +528,19 @@ out: > > static int davinci_emac_probe(struct device_d *dev) > { > + struct davinci_emac_platform_data *pdata; > struct davinci_emac_priv *priv; > uint64_t start; > + uint32_t phy_mask; > > dev_dbg(dev, "+ emac_probe\n"); > > + if (!dev->platform_data) { > + dev_err(dev, "no platform_data\n"); > + return -ENODEV; > + } > + pdata = dev->platform_data; > + > priv = xzalloc(sizeof(*priv)); > dev->priv = priv; > > @@ -556,9 +561,6 @@ static int davinci_emac_probe(struct device_d *dev) > /* Receive packet buffers */ > priv->emac_rx_buffers = xmemalign(4096, EMAC_MAX_RX_BUFFERS * (EMAC_MAX_ETHERNET_PKT_SIZE + EMAC_PKT_ALIGN)); > > - /* PHY address for a discovered PHY (0xff - not found) */ > - priv->active_phy_addr = 0xff; > - > priv->edev.priv = priv; > priv->edev.init = davinci_emac_init; > priv->edev.open = davinci_emac_open; > @@ -573,22 +575,35 @@ static int davinci_emac_probe(struct device_d *dev) > > start = get_time_ns(); > while (1) { > - if (readl(priv->adap_mdio + EMAC_MDIO_ALIVE)) > + phy_mask = readl(priv->adap_mdio + EMAC_MDIO_ALIVE); > + if (phy_mask) { > + dev_info(dev, "detected phy mask 0x%x\n", phy_mask); > + phy_mask = ~phy_mask; > break; > + } > if (is_timeout(start, 256 * MSECOND)) { > - dev_err(dev, "No ETH PHY detected!\n"); > + dev_err(dev, "no live phy, scanning all\n"); > + phy_mask = 0; > break; > } > } > > - priv->miidev.read = davinci_miidev_read; > - priv->miidev.write = davinci_miidev_write; > - priv->miidev.address = 0x01; > - priv->miidev.flags = MIIDEV_FORCE_LINK; > - priv->miidev.edev = &priv->edev; > - priv->miidev.parent = dev; > + if (pdata->flags & DAVINCI_EMAC_RMII) > + priv->interface = PHY_INTERFACE_MODE_RMII; > + else > + priv->interface = PHY_INTERFACE_MODE_MII; > + > + priv->phy_addr = pdata->phy_addr; > + priv->phy_flags = pdata->flags & DAVINCI_EMAC_FORCE_LINK ? > + PHYLIB_FORCE_LINK : 0; > + > + priv->miibus.read = davinci_miibus_read; > + priv->miibus.write = davinci_miibus_write; > + priv->miibus.priv = priv; > + priv->miibus.parent = dev; > + priv->miibus.phy_mask = phy_mask; > > - mii_register(&priv->miidev); > + mdiobus_register(&priv->miibus); > > eth_register(&priv->edev); > > diff --git a/include/net/davinci_emac.h b/include/net/davinci_emac.h > new file mode 100644 > index 0000000..c962dc9 > --- /dev/null > +++ b/include/net/davinci_emac.h > @@ -0,0 +1,13 @@ > +#ifndef __NET_DAVINCI_EMAC_H__ > +#define __NET_DAVINCI_EMAC_H__ > + > +#define DAVINCI_EMAC_MII (0 << 0) > +#define DAVINCI_EMAC_RMII (1 << 0) > +#define DAVINCI_EMAC_FORCE_LINK (1 << 1) why encode this? use 2 bool Best Regards, J. _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH v2 3/3] davinci_emac: get rid of mdio wrapper functions 2012-09-28 15:00 davinci_emac: follow phylib changes Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 1/3] davinci_emac: return 0 on successful transmit Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 2/3] davinci_emac: adjust to new phylib framework Jan Luebbe @ 2012-09-28 15:00 ` Jan Luebbe 2 siblings, 0 replies; 5+ messages in thread From: Jan Luebbe @ 2012-09-28 15:00 UTC (permalink / raw) To: barebox Signed-off-by: Jan Luebbe <jlu@pengutronix.de> --- drivers/net/davinci_emac.c | 51 +++++++++++++++++--------------------------- 1 file changed, 19 insertions(+), 32 deletions(-) diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c index 52786e0..997dc7b 100644 --- a/drivers/net/davinci_emac.c +++ b/drivers/net/davinci_emac.c @@ -122,64 +122,51 @@ static void davinci_eth_mdio_enable(struct davinci_emac_priv *priv) while (readl(priv->adap_mdio + EMAC_MDIO_CONTROL) & MDIO_CONTROL_IDLE); } -/* Read a PHY register via MDIO inteface. Returns 1 on success, 0 otherwise */ -static int davinci_eth_phy_read(struct davinci_emac_priv *priv, uint8_t phy_addr, uint8_t reg_num, uint16_t *data) +static int davinci_miibus_read(struct mii_bus *bus, int addr, int reg) { - int tmp; + struct davinci_emac_priv *priv = bus->priv; + uint16_t value; + int tmp; while (readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0) & MDIO_USERACCESS0_GO); writel(MDIO_USERACCESS0_GO | MDIO_USERACCESS0_WRITE_READ | - ((reg_num & 0x1f) << 21) | - ((phy_addr & 0x1f) << 16), + ((reg & 0x1f) << 21) | + ((addr & 0x1f) << 16), priv->adap_mdio + EMAC_MDIO_USERACCESS0); /* Wait for command to complete */ while ((tmp = readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0)) & MDIO_USERACCESS0_GO); if (tmp & MDIO_USERACCESS0_ACK) { - *data = tmp & 0xffff; - dev_dbg(priv->dev, "emac_phy_read: addr=0x%02x reg=0x%02x data=0x%04x\n", - phy_addr, reg_num, *data); - return 1; + value = tmp & 0xffff; + dev_dbg(priv->dev, "davinci_miibus_read: addr=0x%02x reg=0x%02x value=0x%04x\n", + addr, reg, value); + return value; } - *data = -1; - return 0; + return -1; } -/* Write to a PHY register via MDIO inteface. Blocks until operation is complete. */ -static int davinci_eth_phy_write(struct davinci_emac_priv *priv, uint8_t phy_addr, uint8_t reg_num, uint16_t data) +static int davinci_miibus_write(struct mii_bus *bus, int addr, int reg, u16 value) { + struct davinci_emac_priv *priv = bus->priv; while (readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0) & MDIO_USERACCESS0_GO); - dev_dbg(priv->dev, "emac_phy_write: addr=0x%02x reg=0x%02x data=0x%04x\n", - phy_addr, reg_num, data); + dev_dbg(priv->dev, "davinci_miibus_write: addr=0x%02x reg=0x%02x value=0x%04x\n", + addr, reg, value); writel(MDIO_USERACCESS0_GO | MDIO_USERACCESS0_WRITE_WRITE | - ((reg_num & 0x1f) << 21) | - ((phy_addr & 0x1f) << 16) | - (data & 0xffff), + ((reg & 0x1f) << 21) | + ((addr & 0x1f) << 16) | + (value & 0xffff), priv->adap_mdio + EMAC_MDIO_USERACCESS0); /* Wait for command to complete */ while (readl(priv->adap_mdio + EMAC_MDIO_USERACCESS0) & MDIO_USERACCESS0_GO); - return 1; -} - -static int davinci_miibus_read(struct mii_bus *bus, int addr, int reg) -{ - struct davinci_emac_priv *priv = bus->priv; - uint16_t value = 0; - return davinci_eth_phy_read(priv, addr, reg, &value) ? value : -1; -} - -static int davinci_miibus_write(struct mii_bus *bus, int addr, int reg, u16 value) -{ - struct davinci_emac_priv *priv = (struct davinci_emac_priv *)bus->priv; - return davinci_eth_phy_write(priv, addr, reg, value) ? 0 : -1; + return 0; } static int davinci_emac_get_ethaddr(struct eth_device *edev, unsigned char *adr) -- 1.7.10.4 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2012-09-28 15:36 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2012-09-28 15:00 davinci_emac: follow phylib changes Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 1/3] davinci_emac: return 0 on successful transmit Jan Luebbe 2012-09-28 15:00 ` [PATCH v2 2/3] davinci_emac: adjust to new phylib framework Jan Luebbe 2012-09-28 15:33 ` Jean-Christophe PLAGNIOL-VILLARD 2012-09-28 15:00 ` [PATCH v2 3/3] davinci_emac: get rid of mdio wrapper functions Jan Luebbe
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox