diff options
Diffstat (limited to 'drivers/net/ibm_newemac')
| -rw-r--r-- | drivers/net/ibm_newemac/core.c | 35 | ||||
| -rw-r--r-- | drivers/net/ibm_newemac/emac.h | 19 | ||||
| -rw-r--r-- | drivers/net/ibm_newemac/phy.c | 7 | 
3 files changed, 20 insertions, 41 deletions
| diff --git a/drivers/net/ibm_newemac/core.c b/drivers/net/ibm_newemac/core.c index 079450fe5e96..70cb7d8a3b53 100644 --- a/drivers/net/ibm_newemac/core.c +++ b/drivers/net/ibm_newemac/core.c @@ -39,6 +39,7 @@  #include <linux/bitops.h>  #include <linux/workqueue.h>  #include <linux/of.h> +#include <linux/of_net.h>  #include <linux/slab.h>  #include <asm/processor.h> @@ -2506,18 +2507,6 @@ static int __devinit emac_init_config(struct emac_instance *dev)  {  	struct device_node *np = dev->ofdev->dev.of_node;  	const void *p; -	unsigned int plen; -	const char *pm, *phy_modes[] = { -		[PHY_MODE_NA] = "", -		[PHY_MODE_MII] = "mii", -		[PHY_MODE_RMII] = "rmii", -		[PHY_MODE_SMII] = "smii", -		[PHY_MODE_RGMII] = "rgmii", -		[PHY_MODE_TBI] = "tbi", -		[PHY_MODE_GMII] = "gmii", -		[PHY_MODE_RTBI] = "rtbi", -		[PHY_MODE_SGMII] = "sgmii", -	};  	/* Read config from device-tree */  	if (emac_read_uint_prop(np, "mal-device", &dev->mal_ph, 1)) @@ -2566,23 +2555,9 @@ static int __devinit emac_init_config(struct emac_instance *dev)  		dev->mal_burst_size = 256;  	/* PHY mode needs some decoding */ -	dev->phy_mode = PHY_MODE_NA; -	pm = of_get_property(np, "phy-mode", &plen); -	if (pm != NULL) { -		int i; -		for (i = 0; i < ARRAY_SIZE(phy_modes); i++) -			if (!strcasecmp(pm, phy_modes[i])) { -				dev->phy_mode = i; -				break; -			} -	} - -	/* Backward compat with non-final DT */ -	if (dev->phy_mode == PHY_MODE_NA && pm != NULL && plen == 4) { -		u32 nmode = *(const u32 *)pm; -		if (nmode > PHY_MODE_NA && nmode <= PHY_MODE_SGMII) -			dev->phy_mode = nmode; -	} +	dev->phy_mode = of_get_phy_mode(np); +	if (dev->phy_mode < 0) +		dev->phy_mode = PHY_MODE_NA;  	/* Check EMAC version */  	if (of_device_is_compatible(np, "ibm,emac4sync")) { @@ -2770,7 +2745,7 @@ static int __devinit emac_probe(struct platform_device *ofdev)  	}  	// TODO : request_mem_region  	dev->emacp = ioremap(dev->rsrc_regs.start, -			     dev->rsrc_regs.end - dev->rsrc_regs.start + 1); +			     resource_size(&dev->rsrc_regs));  	if (dev->emacp == NULL) {  		printk(KERN_ERR "%s: Can't map device registers!\n",  		       np->full_name); diff --git a/drivers/net/ibm_newemac/emac.h b/drivers/net/ibm_newemac/emac.h index 8a61b597a169..1568278d759a 100644 --- a/drivers/net/ibm_newemac/emac.h +++ b/drivers/net/ibm_newemac/emac.h @@ -26,6 +26,7 @@  #define __IBM_NEWEMAC_H  #include <linux/types.h> +#include <linux/phy.h>  /* EMAC registers 			Write Access rules */  struct emac_regs { @@ -106,15 +107,15 @@ struct emac_regs {  /*   * PHY mode settings (EMAC <-> ZMII/RGMII bridge <-> PHY)   */ -#define PHY_MODE_NA	0 -#define PHY_MODE_MII	1 -#define PHY_MODE_RMII	2 -#define PHY_MODE_SMII	3 -#define PHY_MODE_RGMII	4 -#define PHY_MODE_TBI	5 -#define PHY_MODE_GMII	6 -#define PHY_MODE_RTBI	7 -#define PHY_MODE_SGMII	8 +#define PHY_MODE_NA	PHY_INTERFACE_MODE_NA +#define PHY_MODE_MII	PHY_INTERFACE_MODE_MII +#define PHY_MODE_RMII	PHY_INTERFACE_MODE_RMII +#define PHY_MODE_SMII	PHY_INTERFACE_MODE_SMII +#define PHY_MODE_RGMII	PHY_INTERFACE_MODE_RGMII +#define PHY_MODE_TBI	PHY_INTERFACE_MODE_TBI +#define PHY_MODE_GMII	PHY_INTERFACE_MODE_GMII +#define PHY_MODE_RTBI	PHY_INTERFACE_MODE_RTBI +#define PHY_MODE_SGMII	PHY_INTERFACE_MODE_SGMII  /* EMACx_MR0 */  #define EMAC_MR0_RXI			0x80000000 diff --git a/drivers/net/ibm_newemac/phy.c b/drivers/net/ibm_newemac/phy.c index ac9d964e59ec..ab4e5969fe65 100644 --- a/drivers/net/ibm_newemac/phy.c +++ b/drivers/net/ibm_newemac/phy.c @@ -28,12 +28,15 @@  #include "emac.h"  #include "phy.h" -static inline int phy_read(struct mii_phy *phy, int reg) +#define phy_read _phy_read +#define phy_write _phy_write + +static inline int _phy_read(struct mii_phy *phy, int reg)  {  	return phy->mdio_read(phy->dev, phy->address, reg);  } -static inline void phy_write(struct mii_phy *phy, int reg, int val) +static inline void _phy_write(struct mii_phy *phy, int reg, int val)  {  	phy->mdio_write(phy->dev, phy->address, reg, val);  } | 
