lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1809945.K2DXtKLbxa@diego>
Date:	Sun, 10 Aug 2014 14:03:03 +0200
From:	Heiko Stübner <heiko@...ech.de>
To:	Romain Perier <romain.perier@...il.com>
Cc:	davem@...emloft.net, max.schwarz@...ine.de, b.galvani@...il.com,
	eric.dumazet@...il.com, netdev@...r.kernel.org, arnd@...db.de
Subject: Re: [PATCH 1/2] ethernet: arc: Add support for specific SoC glue layer device tree bindings

Hi Romain,

[I've added Arnd, because he seemed interested in this when we talked about it 
in IRC]

Am Freitag, 8. August 2014, 12:27:54 schrieb Romain Perier:
> Some platforms have special bank registers which might be used to select
> the correct clock or the right mode for Media Indepent Interface
> controllers. Sometimes, it is also required to activate vcc regulators in
> the right order to supply the ethernet controller at the right time. This
> patch is a refactoring of the arc-emac device driver, it adds a new
> software architecture design which allows to add specific platform glue
> layer. Each platform has now its own module which performs custom
> initialization and remove for the target and then calls to the core driver.
> 
> Signed-off-by: Romain Perier <romain.perier@...il.com>

mixing functional changes with general renames makes everything really hard to 
review. At most, you should have them separated into two patches.

I'm not sure how I personally feel about renaming all the core functions for 
this. In my mind they could also simply keep their current naming, as the 
whole IP is supposed to not have to many implementations except the arc (and 
Rockchip one).


[...]

> diff --git a/drivers/net/ethernet/arc/emac_arc.c
> b/drivers/net/ethernet/arc/emac_arc.c new file mode 100644
> index 0000000..80ebb52
> --- /dev/null
> +++ b/drivers/net/ethernet/arc/emac_arc.c
> @@ -0,0 +1,79 @@
> +/**
> + * emac_arc.c - ARC EMAC specific glue layer
> + *
> + * Copyright (C) 2014 Romain Perier
> + *
> + * Romain Perier  <romain.perier@...il.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License as published by
> + * the Free Software Foundation; either version 2 of the License, or
> + * (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + * GNU General Public License for more details.
> + */
> +
> +#include "emac.h"
> +#include <linux/of_net.h>
> +#include <linux/platform_device.h>
> +#include <linux/module.h>
> +#include <linux/clk.h>
> +
> +#define DRV_NAME "arc_emac"
> +#define DRV_VERSION "1.0"
> +
> +static int arc_emac_probe(struct platform_device *pdev)
> +{
> +	struct emac_platform_data *emac_plat_data = NULL;
> +	struct device *dev = &pdev->dev;
> +	int ret = 0;
> +
> +	emac_plat_data = devm_kzalloc(dev, sizeof(*emac_plat_data), GFP_KERNEL);
> +	if (!emac_plat_data)
> +		return -ENOMEM;
> +	emac_plat_data->name = DRV_NAME;
> +	emac_plat_data->version = DRV_VERSION;
> +	emac_plat_data->set_mac_speed = NULL;
> +	emac_plat_data->priv = emac;
> +
> +	emac_plat_data->interface = of_get_phy_mode(dev->of_node);

the original probe function, had an unconditional default value of 
PHY_INTERFACE_MODE_MII . So you should handle the of_get_phy_mode value as 
optional to keep compatibility:

emac_plat_data->interface = of_get_phy_mode(dev->of_node);
if (emac_plat_data->interface < 0)
	emac_plat_data->interface = PHY_INTERFACE_MODE_MII;


Heiko

> +
> +	emac_plat_data->clk = of_clk_get(dev->of_node, 0);
> +        if (IS_ERR(emac_plat_data->clk)) {
> +		dev_err(dev, "failed to retrieve clock from device tree\n");
> +		return PTR_ERR_OR_ZERO(emac_plat_data->clk);
> +	}
> +
> +	return emac_drv_probe(dev, emac_plat_data);
> +}
> +
> +static int arc_emac_remove(struct platform_device *pdev)
> +{
> +	struct net_device *ndev = dev_get_drvdata(&pdev->dev);
> +
> +	return emac_drv_remove(ndev);
> +}
> +
> +static const struct of_device_id arc_emac_dt_ids[] = {
> +	{ .compatible = "snps,arc-emac" },
> +	{ /* Sentinel */ }
> +};
> +
> +static struct platform_driver arc_emac_driver = {
> +	.probe = arc_emac_probe,
> +	.remove = arc_emac_remove,
> +	.driver = {
> +		.name = DRV_NAME,
> +		.owner = THIS_MODULE,
> +		.of_match_table  = arc_emac_dt_ids,
> +	},
> +};
> +
> +module_platform_driver(arc_emac_driver);
> +
> +MODULE_AUTHOR("Romain Perier <romain.perier@...il.com>");
> +MODULE_DESCRIPTION("ARC EMAC driver");
> +MODULE_LICENSE("GPL");
> diff --git a/drivers/net/ethernet/arc/emac_main.c
> b/drivers/net/ethernet/arc/emac_main.c index 18e2fac..ce04890 100644
> --- a/drivers/net/ethernet/arc/emac_main.c
> +++ b/drivers/net/ethernet/arc/emac_main.c
> @@ -11,6 +11,7 @@
>   *		Amit Bhor
>   *		Sameer Dhavale
>   *		Vineet Gupta
> + *		Romain Perier
>   */
> 
>  #include <linux/crc32.h>
> @@ -26,19 +27,17 @@
> 
>  #include "emac.h"
> 
> -#define DRV_NAME	"arc_emac"
> -#define DRV_VERSION	"1.0"
> 
>  /**
> - * arc_emac_adjust_link - Adjust the PHY link duplex.
> + * emac_adjust_link - Adjust the PHY link duplex.
>   * @ndev:	Pointer to the net_device structure.
>   *
>   * This function is called to change the duplex setting after auto
> negotiation * is done by the PHY.
>   */
> -static void arc_emac_adjust_link(struct net_device *ndev)
> +static void emac_adjust_link(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	struct phy_device *phy_dev = priv->phy_dev;
>  	unsigned int reg, state_changed = 0;
> 
> @@ -50,17 +49,19 @@ static void arc_emac_adjust_link(struct net_device
> *ndev) if (priv->speed != phy_dev->speed) {
>  		priv->speed = phy_dev->speed;
>  		state_changed = 1;
> +		if (priv->plat_data->set_mac_speed)
> +			priv->plat_data->set_mac_speed(priv->plat_data->priv, priv-
>speed);
>  	}
> 
>  	if (priv->duplex != phy_dev->duplex) {
> -		reg = arc_reg_get(priv, R_CTRL);
> +		reg = emac_reg_get(priv, R_CTRL);
> 
>  		if (DUPLEX_FULL == phy_dev->duplex)
>  			reg |= ENFL_MASK;
>  		else
>  			reg &= ~ENFL_MASK;
> 
> -		arc_reg_set(priv, R_CTRL, reg);
> +		emac_reg_set(priv, R_CTRL, reg);
>  		priv->duplex = phy_dev->duplex;
>  		state_changed = 1;
>  	}
> @@ -70,7 +71,7 @@ static void arc_emac_adjust_link(struct net_device *ndev)
>  }
> 
>  /**
> - * arc_emac_get_settings - Get PHY settings.
> + * emac_get_settings - Get PHY settings.
>   * @ndev:	Pointer to net_device structure.
>   * @cmd:	Pointer to ethtool_cmd structure.
>   *
> @@ -79,16 +80,16 @@ static void arc_emac_adjust_link(struct net_device
> *ndev) * relevant PHY ethtool API to get the PHY settings.
>   * Issue "ethtool ethX" under linux prompt to execute this function.
>   */
> -static int arc_emac_get_settings(struct net_device *ndev,
> +static int emac_get_settings(struct net_device *ndev,
>  				 struct ethtool_cmd *cmd)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
> 
>  	return phy_ethtool_gset(priv->phy_dev, cmd);
>  }
> 
>  /**
> - * arc_emac_set_settings - Set PHY settings as passed in the argument.
> + * emac_set_settings - Set PHY settings as passed in the argument.
>   * @ndev:	Pointer to net_device structure.
>   * @cmd:	Pointer to ethtool_cmd structure.
>   *
> @@ -98,10 +99,10 @@ static int arc_emac_get_settings(struct net_device
> *ndev, * Issue e.g. "ethtool -s ethX speed 1000" under linux prompt to
> execute this * function.
>   */
> -static int arc_emac_set_settings(struct net_device *ndev,
> -				 struct ethtool_cmd *cmd)
> +static int emac_set_settings(struct net_device *ndev,
> +			     struct ethtool_cmd *cmd)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
> 
>  	if (!capable(CAP_NET_ADMIN))
>  		return -EPERM;
> @@ -110,42 +111,44 @@ static int arc_emac_set_settings(struct net_device
> *ndev, }
> 
>  /**
> - * arc_emac_get_drvinfo - Get EMAC driver information.
> + * emac_get_drvinfo - Get EMAC driver information.
>   * @ndev:	Pointer to net_device structure.
>   * @info:	Pointer to ethtool_drvinfo structure.
>   *
>   * This implements ethtool command for getting the driver information.
>   * Issue "ethtool -i ethX" under linux prompt to execute this function.
>   */
> -static void arc_emac_get_drvinfo(struct net_device *ndev,
> +static void emac_get_drvinfo(struct net_device *ndev,
>  				 struct ethtool_drvinfo *info)
>  {
> -	strlcpy(info->driver, DRV_NAME, sizeof(info->driver));
> -	strlcpy(info->version, DRV_VERSION, sizeof(info->version));
> +	struct emac_priv *priv = netdev_priv(ndev);
> +
> +	strlcpy(info->driver, priv->plat_data->name, sizeof(info->driver));
> +	strlcpy(info->version, priv->plat_data->version, sizeof(info->version));
>  }
> 
> -static const struct ethtool_ops arc_emac_ethtool_ops = {
> -	.get_settings	= arc_emac_get_settings,
> -	.set_settings	= arc_emac_set_settings,
> -	.get_drvinfo	= arc_emac_get_drvinfo,
> +static const struct ethtool_ops emac_ethtool_ops = {
> +	.get_settings	= emac_get_settings,
> +	.set_settings	= emac_set_settings,
> +	.get_drvinfo	= emac_get_drvinfo,
>  	.get_link	= ethtool_op_get_link,
>  };
> 
>  #define FIRST_OR_LAST_MASK	(FIRST_MASK | LAST_MASK)
> 
>  /**
> - * arc_emac_tx_clean - clears processed by EMAC Tx BDs.
> + * emac_tx_clean - clears processed by EMAC Tx BDs.
>   * @ndev:	Pointer to the network device.
>   */
> -static void arc_emac_tx_clean(struct net_device *ndev)
> +static void emac_tx_clean(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	struct net_device_stats *stats = &priv->stats;
>  	unsigned int i;
> 
>  	for (i = 0; i < TX_BD_NUM; i++) {
>  		unsigned int *txbd_dirty = &priv->txbd_dirty;
> -		struct arc_emac_bd *txbd = &priv->txbd[*txbd_dirty];
> +		struct emac_bd *txbd = &priv->txbd[*txbd_dirty];
>  		struct buffer_state *tx_buff = &priv->tx_buff[*txbd_dirty];
>  		struct sk_buff *skb = tx_buff->skb;
>  		unsigned int info = le32_to_cpu(txbd->info);
> @@ -187,7 +190,7 @@ static void arc_emac_tx_clean(struct net_device *ndev)
>  }
> 
>  /**
> - * arc_emac_rx - processing of Rx packets.
> + * emac_rx - processing of Rx packets.
>   * @ndev:	Pointer to the network device.
>   * @budget:	How many BDs to process on 1 call.
>   *
> @@ -195,16 +198,16 @@ static void arc_emac_tx_clean(struct net_device *ndev)
> *
>   * Iterate through Rx BDs and deliver received packages to upper layer.
>   */
> -static int arc_emac_rx(struct net_device *ndev, int budget)
> +static int emac_rx(struct net_device *ndev, int budget)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	unsigned int work_done;
> 
>  	for (work_done = 0; work_done < budget; work_done++) {
>  		unsigned int *last_rx_bd = &priv->last_rx_bd;
>  		struct net_device_stats *stats = &priv->stats;
>  		struct buffer_state *rx_buff = &priv->rx_buff[*last_rx_bd];
> -		struct arc_emac_bd *rxbd = &priv->rxbd[*last_rx_bd];
> +		struct emac_bd *rxbd = &priv->rxbd[*last_rx_bd];
>  		unsigned int pktlen, info = le32_to_cpu(rxbd->info);
>  		struct sk_buff *skb;
>  		dma_addr_t addr;
> @@ -281,55 +284,55 @@ static int arc_emac_rx(struct net_device *ndev, int
> budget) }
> 
>  /**
> - * arc_emac_poll - NAPI poll handler.
> + * emac_poll - NAPI poll handler.
>   * @napi:	Pointer to napi_struct structure.
>   * @budget:	How many BDs to process on 1 call.
>   *
>   * returns:	Number of processed BDs
>   */
> -static int arc_emac_poll(struct napi_struct *napi, int budget)
> +static int emac_poll(struct napi_struct *napi, int budget)
>  {
>  	struct net_device *ndev = napi->dev;
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	unsigned int work_done;
> 
> -	arc_emac_tx_clean(ndev);
> +	emac_tx_clean(ndev);
> 
> -	work_done = arc_emac_rx(ndev, budget);
> +	work_done = emac_rx(ndev, budget);
>  	if (work_done < budget) {
>  		napi_complete(napi);
> -		arc_reg_or(priv, R_ENABLE, RXINT_MASK);
> +		emac_reg_or(priv, R_ENABLE, RXINT_MASK);
>  	}
> 
>  	return work_done;
>  }
> 
>  /**
> - * arc_emac_intr - Global interrupt handler for EMAC.
> + * emac_intr - Global interrupt handler for EMAC.
>   * @irq:		irq number.
>   * @dev_instance:	device instance.
>   *
>   * returns: IRQ_HANDLED for all cases.
>   *
> - * ARC EMAC has only 1 interrupt line, and depending on bits raised in
> + * EMAC has only 1 interrupt line, and depending on bits raised in
>   * STATUS register we may tell what is a reason for interrupt to fire.
>   */
> -static irqreturn_t arc_emac_intr(int irq, void *dev_instance)
> +static irqreturn_t emac_intr(int irq, void *dev_instance)
>  {
>  	struct net_device *ndev = dev_instance;
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	struct net_device_stats *stats = &priv->stats;
>  	unsigned int status;
> 
> -	status = arc_reg_get(priv, R_STATUS);
> +	status = emac_reg_get(priv, R_STATUS);
>  	status &= ~MDIO_MASK;
> 
>  	/* Reset all flags except "MDIO complete" */
> -	arc_reg_set(priv, R_STATUS, status);
> +	emac_reg_set(priv, R_STATUS, status);
> 
>  	if (status & RXINT_MASK) {
>  		if (likely(napi_schedule_prep(&priv->napi))) {
> -			arc_reg_clr(priv, R_ENABLE, RXINT_MASK);
> +			emac_reg_clr(priv, R_ENABLE, RXINT_MASK);
>  			__napi_schedule(&priv->napi);
>  		}
>  	}
> @@ -364,16 +367,16 @@ static irqreturn_t arc_emac_intr(int irq, void
> *dev_instance) }
> 
>  #ifdef CONFIG_NET_POLL_CONTROLLER
> -static void arc_emac_poll_controller(struct net_device *dev)
> +static void emac_poll_controller(struct net_device *dev)
>  {
>  	disable_irq(dev->irq);
> -	arc_emac_intr(dev->irq, dev);
> +	emac_intr(dev->irq, dev);
>  	enable_irq(dev->irq);
>  }
>  #endif
> 
>  /**
> - * arc_emac_open - Open the network device.
> + * emac_open - Open the network device.
>   * @ndev:	Pointer to the network device.
>   *
>   * returns: 0, on success or non-zero error value on failure.
> @@ -382,9 +385,9 @@ static void arc_emac_poll_controller(struct net_device
> *dev) * for the EMAC device and starts the Tx queue.
>   * It also connects to the phy device.
>   */
> -static int arc_emac_open(struct net_device *ndev)
> +static int emac_open(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	struct phy_device *phy_dev = priv->phy_dev;
>  	int i;
> 
> @@ -399,7 +402,7 @@ static int arc_emac_open(struct net_device *ndev)
>  	for (i = 0; i < RX_BD_NUM; i++) {
>  		dma_addr_t addr;
>  		unsigned int *last_rx_bd = &priv->last_rx_bd;
> -		struct arc_emac_bd *rxbd = &priv->rxbd[*last_rx_bd];
> +		struct emac_bd *rxbd = &priv->rxbd[*last_rx_bd];
>  		struct buffer_state *rx_buff = &priv->rx_buff[*last_rx_bd];
> 
>  		rx_buff->skb = netdev_alloc_skb_ip_align(ndev,
> @@ -432,18 +435,18 @@ static int arc_emac_open(struct net_device *ndev)
>  	memset(priv->txbd, 0, TX_RING_SZ);
> 
>  	/* Initialize logical address filter */
> -	arc_reg_set(priv, R_LAFL, 0);
> -	arc_reg_set(priv, R_LAFH, 0);
> +	emac_reg_set(priv, R_LAFL, 0);
> +	emac_reg_set(priv, R_LAFH, 0);
> 
>  	/* Set BD ring pointers for device side */
> -	arc_reg_set(priv, R_RX_RING, (unsigned int)priv->rxbd_dma);
> -	arc_reg_set(priv, R_TX_RING, (unsigned int)priv->txbd_dma);
> +	emac_reg_set(priv, R_RX_RING, (unsigned int)priv->rxbd_dma);
> +	emac_reg_set(priv, R_TX_RING, (unsigned int)priv->txbd_dma);
> 
>  	/* Enable interrupts */
> -	arc_reg_set(priv, R_ENABLE, RXINT_MASK | ERR_MASK);
> +	emac_reg_set(priv, R_ENABLE, RXINT_MASK | ERR_MASK);
> 
>  	/* Set CONTROL */
> -	arc_reg_set(priv, R_CTRL,
> +	emac_reg_set(priv, R_CTRL,
>  		     (RX_BD_NUM << 24) |	/* RX BD table length */
>  		     (TX_BD_NUM << 16) |	/* TX BD table length */
>  		     TXRN_MASK | RXRN_MASK);
> @@ -451,7 +454,7 @@ static int arc_emac_open(struct net_device *ndev)
>  	napi_enable(&priv->napi);
> 
>  	/* Enable EMAC */
> -	arc_reg_or(priv, R_CTRL, EN_MASK);
> +	emac_reg_or(priv, R_CTRL, EN_MASK);
> 
>  	phy_start_aneg(priv->phy_dev);
> 
> @@ -461,24 +464,24 @@ static int arc_emac_open(struct net_device *ndev)
>  }
> 
>  /**
> - * arc_emac_set_rx_mode - Change the receive filtering mode.
> + * emac_set_rx_mode - Change the receive filtering mode.
>   * @ndev:	Pointer to the network device.
>   *
>   * This function enables/disables promiscuous or all-multicast mode
>   * and updates the multicast filtering list of the network device.
>   */
> -static void arc_emac_set_rx_mode(struct net_device *ndev)
> +static void emac_set_rx_mode(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
> 
>  	if (ndev->flags & IFF_PROMISC) {
> -		arc_reg_or(priv, R_CTRL, PROM_MASK);
> +		emac_reg_or(priv, R_CTRL, PROM_MASK);
>  	} else {
> -		arc_reg_clr(priv, R_CTRL, PROM_MASK);
> +		emac_reg_clr(priv, R_CTRL, PROM_MASK);
> 
>  		if (ndev->flags & IFF_ALLMULTI) {
> -			arc_reg_set(priv, R_LAFL, ~0);
> -			arc_reg_set(priv, R_LAFH, ~0);
> +			emac_reg_set(priv, R_LAFL, ~0);
> +			emac_reg_set(priv, R_LAFH, ~0);
>  		} else {
>  			struct netdev_hw_addr *ha;
>  			unsigned int filter[2] = { 0, 0 };
> @@ -489,52 +492,52 @@ static void arc_emac_set_rx_mode(struct net_device
> *ndev) filter[bit >> 5] |= 1 << (bit & 31);
>  			}
> 
> -			arc_reg_set(priv, R_LAFL, filter[0]);
> -			arc_reg_set(priv, R_LAFH, filter[1]);
> +			emac_reg_set(priv, R_LAFL, filter[0]);
> +			emac_reg_set(priv, R_LAFH, filter[1]);
>  		}
>  	}
>  }
> 
>  /**
> - * arc_emac_stop - Close the network device.
> + * emac_stop - Close the network device.
>   * @ndev:	Pointer to the network device.
>   *
>   * This function stops the Tx queue, disables interrupts and frees the IRQ
> for * the EMAC device.
>   * It also disconnects the PHY device associated with the EMAC device.
>   */
> -static int arc_emac_stop(struct net_device *ndev)
> +static int emac_stop(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
> 
>  	napi_disable(&priv->napi);
>  	netif_stop_queue(ndev);
> 
>  	/* Disable interrupts */
> -	arc_reg_clr(priv, R_ENABLE, RXINT_MASK | ERR_MASK);
> +	emac_reg_clr(priv, R_ENABLE, RXINT_MASK | ERR_MASK);
> 
>  	/* Disable EMAC */
> -	arc_reg_clr(priv, R_CTRL, EN_MASK);
> +	emac_reg_clr(priv, R_CTRL, EN_MASK);
> 
>  	return 0;
>  }
> 
>  /**
> - * arc_emac_stats - Get system network statistics.
> + * emac_stats - Get system network statistics.
>   * @ndev:	Pointer to net_device structure.
>   *
>   * Returns the address of the device statistics structure.
>   * Statistics are updated in interrupt handler.
>   */
> -static struct net_device_stats *arc_emac_stats(struct net_device *ndev)
> +static struct net_device_stats *emac_stats(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	struct net_device_stats *stats = &priv->stats;
>  	unsigned long miss, rxerr;
>  	u8 rxcrc, rxfram, rxoflow;
> 
> -	rxerr = arc_reg_get(priv, R_RXERR);
> -	miss = arc_reg_get(priv, R_MISS);
> +	rxerr = emac_reg_get(priv, R_RXERR);
> +	miss = emac_reg_get(priv, R_MISS);
> 
>  	rxcrc = rxerr;
>  	rxfram = rxerr >> 8;
> @@ -552,7 +555,7 @@ static struct net_device_stats *arc_emac_stats(struct
> net_device *ndev) }
> 
>  /**
> - * arc_emac_tx - Starts the data transmission.
> + * emac_tx - Starts the data transmission.
>   * @skb:	sk_buff pointer that contains data to be Transmitted.
>   * @ndev:	Pointer to net_device structure.
>   *
> @@ -561,9 +564,9 @@ static struct net_device_stats *arc_emac_stats(struct
> net_device *ndev) *
>   * This function is invoked from upper layers to initiate transmission.
>   */
> -static int arc_emac_tx(struct sk_buff *skb, struct net_device *ndev)
> +static int emac_tx(struct sk_buff *skb, struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	unsigned int len, *txbd_curr = &priv->txbd_curr;
>  	struct net_device_stats *stats = &priv->stats;
>  	__le32 *info = &priv->txbd[*txbd_curr].info;
> @@ -614,25 +617,25 @@ static int arc_emac_tx(struct sk_buff *skb, struct
> net_device *ndev) if (unlikely((le32_to_cpu(*info) & OWN_MASK) ==
> FOR_EMAC))
>  		netif_stop_queue(ndev);
> 
> -	arc_reg_set(priv, R_STATUS, TXPL_MASK);
> +	emac_reg_set(priv, R_STATUS, TXPL_MASK);
> 
>  	return NETDEV_TX_OK;
>  }
> 
> -static void arc_emac_set_address_internal(struct net_device *ndev)
> +static void emac_set_address_internal(struct net_device *ndev)
>  {
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
>  	unsigned int addr_low, addr_hi;
> 
>  	addr_low = le32_to_cpu(*(__le32 *) &ndev->dev_addr[0]);
>  	addr_hi = le16_to_cpu(*(__le16 *) &ndev->dev_addr[4]);
> 
> -	arc_reg_set(priv, R_ADDRL, addr_low);
> -	arc_reg_set(priv, R_ADDRH, addr_hi);
> +	emac_reg_set(priv, R_ADDRL, addr_low);
> +	emac_reg_set(priv, R_ADDRH, addr_hi);
>  }
> 
>  /**
> - * arc_emac_set_address - Set the MAC address for this device.
> + * emac_set_address - Set the MAC address for this device.
>   * @ndev:	Pointer to net_device structure.
>   * @p:		6 byte Address to be written as MAC address.
>   *
> @@ -642,7 +645,7 @@ static void arc_emac_set_address_internal(struct
> net_device *ndev) * returns:	-EBUSY if the net device is busy or 0 if the
> address is set *		successfully.
>   */
> -static int arc_emac_set_address(struct net_device *ndev, void *p)
> +static int emac_set_address(struct net_device *ndev, void *p)
>  {
>  	struct sockaddr *addr = p;
> 
> @@ -654,141 +657,129 @@ static int arc_emac_set_address(struct net_device
> *ndev, void *p)
> 
>  	memcpy(ndev->dev_addr, addr->sa_data, ndev->addr_len);
> 
> -	arc_emac_set_address_internal(ndev);
> +	emac_set_address_internal(ndev);
> 
>  	return 0;
>  }
> 
> -static const struct net_device_ops arc_emac_netdev_ops = {
> -	.ndo_open		= arc_emac_open,
> -	.ndo_stop		= arc_emac_stop,
> -	.ndo_start_xmit		= arc_emac_tx,
> -	.ndo_set_mac_address	= arc_emac_set_address,
> -	.ndo_get_stats		= arc_emac_stats,
> -	.ndo_set_rx_mode	= arc_emac_set_rx_mode,
> +static const struct net_device_ops emac_netdev_ops = {
> +	.ndo_open		= emac_open,
> +	.ndo_stop		= emac_stop,
> +	.ndo_start_xmit		= emac_tx,
> +	.ndo_set_mac_address	= emac_set_address,
> +	.ndo_get_stats		= emac_stats,
> +	.ndo_set_rx_mode	= emac_set_rx_mode,
>  #ifdef CONFIG_NET_POLL_CONTROLLER
> -	.ndo_poll_controller	= arc_emac_poll_controller,
> +	.ndo_poll_controller	= emac_poll_controller,
>  #endif
>  };
> 
> -static int arc_emac_probe(struct platform_device *pdev)
> +int emac_drv_probe(struct device *dev, const struct emac_platform_data
> *plat_data) {
>  	struct resource res_regs;
>  	struct device_node *phy_node;
> -	struct arc_emac_priv *priv;
> +	struct emac_priv *priv;
>  	struct net_device *ndev;
>  	const char *mac_addr;
>  	unsigned int id, clock_frequency, irq;
>  	int err;
> 
> -	if (!pdev->dev.of_node)
> -		return -ENODEV;
> -
>  	/* Get PHY from device tree */
> -	phy_node = of_parse_phandle(pdev->dev.of_node, "phy", 0);
> +	phy_node = of_parse_phandle(dev->of_node, "phy", 0);
>  	if (!phy_node) {
> -		dev_err(&pdev->dev, "failed to retrieve phy description from device
> tree\n"); +		dev_err(dev, "failed to retrieve phy description from 
device
> tree\n"); return -ENODEV;
>  	}
> 
>  	/* Get EMAC registers base address from device tree */
> -	err = of_address_to_resource(pdev->dev.of_node, 0, &res_regs);
> +	err = of_address_to_resource(dev->of_node, 0, &res_regs);
>  	if (err) {
> -		dev_err(&pdev->dev, "failed to retrieve registers base from device
> tree\n"); +		dev_err(dev, "failed to retrieve registers base from 
device
> tree\n"); return -ENODEV;
>  	}
> 
>  	/* Get IRQ from device tree */
> -	irq = irq_of_parse_and_map(pdev->dev.of_node, 0);
> +	irq = irq_of_parse_and_map(dev->of_node, 0);
>  	if (!irq) {
> -		dev_err(&pdev->dev, "failed to retrieve <irq> value from device 
tree\n");
> +		dev_err(dev, "failed to retrieve <irq> value from device tree\n");
> return -ENODEV;
>  	}
> 
> -	ndev = alloc_etherdev(sizeof(struct arc_emac_priv));
> +	ndev = alloc_etherdev(sizeof(struct emac_priv));
>  	if (!ndev)
>  		return -ENOMEM;
> 
> -	platform_set_drvdata(pdev, ndev);
> -	SET_NETDEV_DEV(ndev, &pdev->dev);
> +	dev_set_drvdata(dev, ndev);
> +	SET_NETDEV_DEV(ndev, dev);
> 
> -	ndev->netdev_ops = &arc_emac_netdev_ops;
> -	ndev->ethtool_ops = &arc_emac_ethtool_ops;
> +	ndev->netdev_ops = &emac_netdev_ops;
> +	ndev->ethtool_ops = &emac_ethtool_ops;
>  	ndev->watchdog_timeo = TX_TIMEOUT;
>  	/* FIXME :: no multicast support yet */
>  	ndev->flags &= ~IFF_MULTICAST;
> 
>  	priv = netdev_priv(ndev);
> -	priv->dev = &pdev->dev;
> +	priv->dev = dev;
>  	priv->ndev = ndev;
> +	priv->plat_data = plat_data;
> 
> -	priv->regs = devm_ioremap_resource(&pdev->dev, &res_regs);
> +	priv->regs = devm_ioremap_resource(dev, &res_regs);
>  	if (IS_ERR(priv->regs)) {
>  		err = PTR_ERR(priv->regs);
>  		goto out_netdev;
>  	}
> -	dev_dbg(&pdev->dev, "Registers base address is 0x%p\n", priv->regs);
> -
> -	priv->clk = of_clk_get(pdev->dev.of_node, 0);
> -	if (IS_ERR(priv->clk)) {
> -		/* Get CPU clock frequency from device tree */
> -		if (of_property_read_u32(pdev->dev.of_node, "clock-frequency",
> -					&clock_frequency)) {
> -			dev_err(&pdev->dev, "failed to retrieve <clock-frequency> from 
device
> tree\n"); -			err = -EINVAL;
> -			goto out_netdev;
> -		}
> -	} else {
> -		err = clk_prepare_enable(priv->clk);
> +	dev_dbg(dev, "Registers base address is 0x%p\n", priv->regs);
> +
> +	if (plat_data->clk) {
> +		err = clk_prepare_enable(plat_data->clk);
>  		if (err) {
> -			dev_err(&pdev->dev, "failed to enable clock\n");
> +			dev_err(dev, "failed to enable clock\n");
>  			goto out_clkget;
>  		}
> -
> -		clock_frequency = clk_get_rate(priv->clk);
> +		clock_frequency = clk_get_rate(plat_data->clk);
>  	}
> 
> -	id = arc_reg_get(priv, R_ID);
> +	id = emac_reg_get(priv, R_ID);
> 
>  	/* Check for EMAC revision 5 or 7, magic number */
>  	if (!(id == 0x0005fd02 || id == 0x0007fd02)) {
> -		dev_err(&pdev->dev, "ARC EMAC not detected, id=0x%x\n", id);
> +		dev_err(dev, "EMAC not detected, id=0x%x\n", id);
>  		err = -ENODEV;
>  		goto out_clken;
>  	}
> -	dev_info(&pdev->dev, "ARC EMAC detected with id: 0x%x\n", id);
> +	dev_info(dev, "EMAC detected with id: 0x%x\n", id);
> 
>  	/* Set poll rate so that it polls every 1 ms */
> -	arc_reg_set(priv, R_POLLRATE, clock_frequency / 1000000);
> +	emac_reg_set(priv, R_POLLRATE, clock_frequency / 1000000);
> 
>  	ndev->irq = irq;
> -	dev_info(&pdev->dev, "IRQ is %d\n", ndev->irq);
> +	dev_dbg(dev, "IRQ is %d\n", ndev->irq);
> 
>  	/* Register interrupt handler for device */
> -	err = devm_request_irq(&pdev->dev, ndev->irq, arc_emac_intr, 0,
> +	err = devm_request_irq(dev, ndev->irq, emac_intr, 0,
>  			       ndev->name, ndev);
>  	if (err) {
> -		dev_err(&pdev->dev, "could not allocate IRQ\n");
> +		dev_err(dev, "could not allocate IRQ\n");
>  		goto out_clken;
>  	}
> 
>  	/* Get MAC address from device tree */
> -	mac_addr = of_get_mac_address(pdev->dev.of_node);
> +	mac_addr = of_get_mac_address(dev->of_node);
> 
>  	if (mac_addr)
>  		memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
>  	else
>  		eth_hw_addr_random(ndev);
> 
> -	arc_emac_set_address_internal(ndev);
> -	dev_info(&pdev->dev, "MAC address is now %pM\n", ndev->dev_addr);
> +	emac_set_address_internal(ndev);
> +	dev_info(dev, "MAC address is now %pM\n", ndev->dev_addr);
> 
>  	/* Do 1 allocation instead of 2 separate ones for Rx and Tx BD rings */
> -	priv->rxbd = dmam_alloc_coherent(&pdev->dev, RX_RING_SZ + TX_RING_SZ,
> +	priv->rxbd = dmam_alloc_coherent(dev, RX_RING_SZ + TX_RING_SZ,
>  					 &priv->rxbd_dma, GFP_KERNEL);
> 
>  	if (!priv->rxbd) {
> -		dev_err(&pdev->dev, "failed to allocate data buffers\n");
> +		dev_err(dev, "failed to allocate data buffers\n");
>  		err = -ENOMEM;
>  		goto out_clken;
>  	}
> @@ -796,31 +787,31 @@ static int arc_emac_probe(struct platform_device
> *pdev) priv->txbd = priv->rxbd + RX_BD_NUM;
> 
>  	priv->txbd_dma = priv->rxbd_dma + RX_RING_SZ;
> -	dev_dbg(&pdev->dev, "EMAC Device addr: Rx Ring [0x%x], Tx Ring[%x]\n",
> +	dev_dbg(dev, "EMAC Device addr: Rx Ring [0x%x], Tx Ring[%x]\n",
>  		(unsigned int)priv->rxbd_dma, (unsigned int)priv->txbd_dma);
> 
> -	err = arc_mdio_probe(pdev, priv);
> +	err = emac_mdio_probe(priv);
>  	if (err) {
> -		dev_err(&pdev->dev, "failed to probe MII bus\n");
> +		dev_err(dev, "failed to probe MII bus\n");
>  		goto out_clken;
>  	}
> 
> -	priv->phy_dev = of_phy_connect(ndev, phy_node, arc_emac_adjust_link, 0,
> -				       PHY_INTERFACE_MODE_MII);
> +	priv->phy_dev = of_phy_connect(ndev, phy_node, emac_adjust_link, 0,
> +				       plat_data->interface);
>  	if (!priv->phy_dev) {
> -		dev_err(&pdev->dev, "of_phy_connect() failed\n");
> +		dev_err(dev, "of_phy_connect() failed\n");
>  		err = -ENODEV;
>  		goto out_mdio;
>  	}
> 
> -	dev_info(&pdev->dev, "connected to %s phy with id 0x%x\n",
> +	dev_info(dev, "connected to %s phy with id 0x%x\n",
>  		 priv->phy_dev->drv->name, priv->phy_dev->phy_id);
> 
> -	netif_napi_add(ndev, &priv->napi, arc_emac_poll, ARC_EMAC_NAPI_WEIGHT);
> +	netif_napi_add(ndev, &priv->napi, emac_poll, EMAC_NAPI_WEIGHT);
> 
>  	err = register_netdev(ndev);
>  	if (err) {
> -		dev_err(&pdev->dev, "failed to register network device\n");
> +		dev_err(dev, "failed to register network device\n");
>  		goto out_netif_api;
>  	}
> 
> @@ -831,32 +822,31 @@ out_netif_api:
>  	phy_disconnect(priv->phy_dev);
>  	priv->phy_dev = NULL;
>  out_mdio:
> -	arc_mdio_remove(priv);
> +	emac_mdio_remove(priv);
>  out_clken:
> -	if (!IS_ERR(priv->clk))
> -		clk_disable_unprepare(priv->clk);
> +	if (!IS_ERR(plat_data->clk))
> +		clk_disable_unprepare(plat_data->clk);
>  out_clkget:
> -	if (!IS_ERR(priv->clk))
> -		clk_put(priv->clk);
> +	if (!IS_ERR(plat_data->clk))
> +		clk_put(plat_data->clk);
>  out_netdev:
>  	free_netdev(ndev);
>  	return err;
>  }
> 
> -static int arc_emac_remove(struct platform_device *pdev)
> +int emac_drv_remove(struct net_device *ndev)
>  {
> -	struct net_device *ndev = platform_get_drvdata(pdev);
> -	struct arc_emac_priv *priv = netdev_priv(ndev);
> +	struct emac_priv *priv = netdev_priv(ndev);
> 
>  	phy_disconnect(priv->phy_dev);
>  	priv->phy_dev = NULL;
> -	arc_mdio_remove(priv);
> +	emac_mdio_remove(priv);
>  	unregister_netdev(ndev);
>  	netif_napi_del(&priv->napi);
> 
> -	if (!IS_ERR(priv->clk)) {
> -		clk_disable_unprepare(priv->clk);
> -		clk_put(priv->clk);
> +	if (priv->plat_data->clk) {
> +		clk_disable_unprepare(priv->plat_data->clk);
> +		clk_put(priv->plat_data->clk);
>  	}
> 
>  	free_netdev(ndev);
> @@ -864,24 +854,6 @@ static int arc_emac_remove(struct platform_device
> *pdev) return 0;
>  }
> 
> -static const struct of_device_id arc_emac_dt_ids[] = {
> -	{ .compatible = "snps,arc-emac" },
> -	{ /* Sentinel */ }
> -};
> -MODULE_DEVICE_TABLE(of, arc_emac_dt_ids);
> -
> -static struct platform_driver arc_emac_driver = {
> -	.probe = arc_emac_probe,
> -	.remove = arc_emac_remove,
> -	.driver = {
> -		.name = DRV_NAME,
> -		.owner = THIS_MODULE,
> -		.of_match_table  = arc_emac_dt_ids,
> -		},
> -};
> -
> -module_platform_driver(arc_emac_driver);
> -
>  MODULE_AUTHOR("Alexey Brodkin <abrodkin@...opsys.com>");
> -MODULE_DESCRIPTION("ARC EMAC driver");
> +MODULE_DESCRIPTION("EMAC driver");
>  MODULE_LICENSE("GPL");
> diff --git a/drivers/net/ethernet/arc/emac_mdio.c
> b/drivers/net/ethernet/arc/emac_mdio.c index 26ba242..b1397ea 100644
> --- a/drivers/net/ethernet/arc/emac_mdio.c
> +++ b/drivers/net/ethernet/arc/emac_mdio.c
> @@ -1,7 +1,7 @@
>  /*
>   * Copyright (C) 2004-2013 Synopsys, Inc. (www.synopsys.com)
>   *
> - * MDIO implementation for ARC EMAC
> + * MDIO implementation for EMAC
>   */
> 
>  #include <linux/delay.h>
> @@ -11,26 +11,26 @@
>  #include "emac.h"
> 
>  /* Number of seconds we wait for "MDIO complete" flag to appear */
> -#define ARC_MDIO_COMPLETE_POLL_COUNT	1
> +#define EMAC_MDIO_COMPLETE_POLL_COUNT	1
> 
>  /**
> - * arc_mdio_complete_wait - Waits until MDIO transaction is completed.
> - * @priv:	Pointer to ARC EMAC private data structure.
> + * emac_mdio_complete_wait - Waits until MDIO transaction is completed.
> + * @priv:	Pointer to EMAC private data structure.
>   *
>   * returns:	0 on success, -ETIMEDOUT on a timeout.
>   */
> -static int arc_mdio_complete_wait(struct arc_emac_priv *priv)
> +static int emac_mdio_complete_wait(struct emac_priv *priv)
>  {
>  	unsigned int i;
> 
> -	for (i = 0; i < ARC_MDIO_COMPLETE_POLL_COUNT * 40; i++) {
> -		unsigned int status = arc_reg_get(priv, R_STATUS);
> +	for (i = 0; i < EMAC_MDIO_COMPLETE_POLL_COUNT * 40; i++) {
> +		unsigned int status = emac_reg_get(priv, R_STATUS);
> 
>  		status &= MDIO_MASK;
> 
>  		if (status) {
>  			/* Reset "MDIO complete" flag */
> -			arc_reg_set(priv, R_STATUS, status);
> +			emac_reg_set(priv, R_STATUS, status);
>  			return 0;
>  		}
> 
> @@ -41,7 +41,7 @@ static int arc_mdio_complete_wait(struct arc_emac_priv
> *priv) }
> 
>  /**
> - * arc_mdio_read - MDIO interface read function.
> + * emac_mdio_read - MDIO interface read function.
>   * @bus:	Pointer to MII bus structure.
>   * @phy_addr:	Address of the PHY device.
>   * @reg_num:	PHY register to read.
> @@ -51,29 +51,29 @@ static int arc_mdio_complete_wait(struct arc_emac_priv
> *priv) * Reads the contents of the requested register from the requested
> PHY * address.
>   */
> -static int arc_mdio_read(struct mii_bus *bus, int phy_addr, int reg_num)
> +static int emac_mdio_read(struct mii_bus *bus, int phy_addr, int reg_num)
>  {
> -	struct arc_emac_priv *priv = bus->priv;
> +	struct emac_priv *priv = bus->priv;
>  	unsigned int value;
>  	int error;
> 
> -	arc_reg_set(priv, R_MDIO,
> +	emac_reg_set(priv, R_MDIO,
>  		    0x60020000 | (phy_addr << 23) | (reg_num << 18));
> 
> -	error = arc_mdio_complete_wait(priv);
> +	error = emac_mdio_complete_wait(priv);
>  	if (error < 0)
>  		return error;
> 
> -	value = arc_reg_get(priv, R_MDIO) & 0xffff;
> +	value = emac_reg_get(priv, R_MDIO) & 0xffff;
> 
> -	dev_dbg(priv->dev, "arc_mdio_read(phy_addr=%i, reg_num=%x) = %x\n",
> +	dev_dbg(priv->dev, "emac_mdio_read(phy_addr=%i, reg_num=%x) = %x\n",
>  		phy_addr, reg_num, value);
> 
>  	return value;
>  }
> 
>  /**
> - * arc_mdio_write - MDIO interface write function.
> + * emac_mdio_write - MDIO interface write function.
>   * @bus:	Pointer to MII bus structure.
>   * @phy_addr:	Address of the PHY device.
>   * @reg_num:	PHY register to write to.
> @@ -83,32 +83,32 @@ static int arc_mdio_read(struct mii_bus *bus, int
> phy_addr, int reg_num) *
>   * Writes the value to the requested register.
>   */
> -static int arc_mdio_write(struct mii_bus *bus, int phy_addr,
> +static int emac_mdio_write(struct mii_bus *bus, int phy_addr,
>  			  int reg_num, u16 value)
>  {
> -	struct arc_emac_priv *priv = bus->priv;
> +	struct emac_priv *priv = bus->priv;
> 
>  	dev_dbg(priv->dev,
> -		"arc_mdio_write(phy_addr=%i, reg_num=%x, value=%x)\n",
> +		"emac_mdio_write(phy_addr=%i, reg_num=%x, value=%x)\n",
>  		phy_addr, reg_num, value);
> 
> -	arc_reg_set(priv, R_MDIO,
> +	emac_reg_set(priv, R_MDIO,
>  		     0x50020000 | (phy_addr << 23) | (reg_num << 18) | value);
> 
> -	return arc_mdio_complete_wait(priv);
> +	return emac_mdio_complete_wait(priv);
>  }
> 
>  /**
> - * arc_mdio_probe - MDIO probe function.
> + * emac_mdio_probe - MDIO probe function.
>   * @pdev:	Pointer to platform device.
> - * @priv:	Pointer to ARC EMAC private data structure.
> + * @priv:	Pointer to EMAC private data structure.
>   *
>   * returns:	0 on success, -ENOMEM when mdiobus_alloc
>   * (to allocate memory for MII bus structure) fails.
>   *
>   * Sets up and registers the MDIO interface.
>   */
> -int arc_mdio_probe(struct platform_device *pdev, struct arc_emac_priv
> *priv) +int emac_mdio_probe(struct emac_priv *priv)
>  {
>  	struct mii_bus *bus;
>  	int error;
> @@ -121,12 +121,12 @@ int arc_mdio_probe(struct platform_device *pdev,
> struct arc_emac_priv *priv) bus->priv = priv;
>  	bus->parent = priv->dev;
>  	bus->name = "Synopsys MII Bus",
> -	bus->read = &arc_mdio_read;
> -	bus->write = &arc_mdio_write;
> +	bus->read = &emac_mdio_read;
> +	bus->write = &emac_mdio_write;
> 
> -	snprintf(bus->id, MII_BUS_ID_SIZE, "%s", pdev->name);
> +	snprintf(bus->id, MII_BUS_ID_SIZE, "%s", bus->name);
> 
> -	error = of_mdiobus_register(bus, pdev->dev.of_node);
> +	error = of_mdiobus_register(bus, priv->dev->of_node);
>  	if (error) {
>  		dev_err(priv->dev, "cannot register MDIO bus %s\n", bus->name);
>  		mdiobus_free(bus);
> @@ -137,12 +137,12 @@ int arc_mdio_probe(struct platform_device *pdev,
> struct arc_emac_priv *priv) }
> 
>  /**
> - * arc_mdio_remove - MDIO remove function.
> - * @priv:	Pointer to ARC EMAC private data structure.
> + * emac_mdio_remove - MDIO remove function.
> + * @priv:	Pointer to EMAC private data structure.
>   *
>   * Unregisters the MDIO and frees any associate memory for MII bus.
>   */
> -int arc_mdio_remove(struct arc_emac_priv *priv)
> +int emac_mdio_remove(struct emac_priv *priv)
>  {
>  	mdiobus_unregister(priv->bus);
>  	mdiobus_free(priv->bus);
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ