diff options
Diffstat (limited to 'drivers/net')
| -rw-r--r-- | drivers/net/bfin_mac.c | 2 | ||||
| -rw-r--r-- | drivers/net/fec_mxc.c | 4 | ||||
| -rw-r--r-- | drivers/net/fm/Makefile | 1 | ||||
| -rw-r--r-- | drivers/net/fm/b4860.c | 6 | ||||
| -rw-r--r-- | drivers/net/fm/eth.c | 2 | ||||
| -rw-r--r-- | drivers/net/fm/fm.h | 2 | ||||
| -rw-r--r-- | drivers/net/fm/init.c | 31 | ||||
| -rw-r--r-- | drivers/net/fm/t4240.c | 14 | ||||
| -rw-r--r-- | drivers/net/phy/teranetics.c | 16 | ||||
| -rw-r--r-- | drivers/net/phy/vitesse.c | 67 | ||||
| -rw-r--r-- | drivers/net/smc911x.h | 4 | 
11 files changed, 134 insertions, 15 deletions
| diff --git a/drivers/net/bfin_mac.c b/drivers/net/bfin_mac.c index c63398ebf..0ffd59d49 100644 --- a/drivers/net/bfin_mac.c +++ b/drivers/net/bfin_mac.c @@ -122,8 +122,6 @@ static int bfin_EMAC_send(struct eth_device *dev, void *packet, int length)  {  	int i;  	int result = 0; -	unsigned int *buf; -	buf = (unsigned int *)packet;  	if (length <= 0) {  		printf("Ethernet: bad packet size: %d\n", length); diff --git a/drivers/net/fec_mxc.c b/drivers/net/fec_mxc.c index 4dbcdca4a..da95e285b 100644 --- a/drivers/net/fec_mxc.c +++ b/drivers/net/fec_mxc.c @@ -516,9 +516,7 @@ static int fec_open(struct eth_device *edev)  #ifdef FEC_QUIRK_ENET_MAC  	{  		u32 ecr = readl(&fec->eth->ecntrl) & ~FEC_ECNTRL_SPEED; -		u32 rcr = (readl(&fec->eth->r_cntrl) & -				~(FEC_RCNTRL_RMII | FEC_RCNTRL_RMII_10T)) | -				FEC_RCNTRL_RGMII | FEC_RCNTRL_MII_MODE; +		u32 rcr = readl(&fec->eth->r_cntrl) & ~FEC_RCNTRL_RMII_10T;  		if (speed == _1000BASET)  			ecr |= FEC_ECNTRL_SPEED;  		else if (speed != _100BASET) diff --git a/drivers/net/fm/Makefile b/drivers/net/fm/Makefile index f191c79a2..9aaa82853 100644 --- a/drivers/net/fm/Makefile +++ b/drivers/net/fm/Makefile @@ -46,6 +46,7 @@ COBJS-$(CONFIG_PPC_P4080) += p4080.o  COBJS-$(CONFIG_PPC_P5020) += p5020.o  COBJS-$(CONFIG_PPC_P5040) += p5040.o  COBJS-$(CONFIG_PPC_T4240) += t4240.o +COBJS-$(CONFIG_PPC_T4160) += t4240.o  COBJS-$(CONFIG_PPC_B4420) += b4860.o  COBJS-$(CONFIG_PPC_B4860) += b4860.o  endif diff --git a/drivers/net/fm/b4860.c b/drivers/net/fm/b4860.c index 8cde7afc1..3b5defefa 100644 --- a/drivers/net/fm/b4860.c +++ b/drivers/net/fm/b4860.c @@ -55,8 +55,10 @@ phy_interface_t fman_port_enet_if(enum fm_port port)  	if (is_device_disabled(port))  		return PHY_INTERFACE_MODE_NONE; -	if ((port == FM1_10GEC1 || port == FM1_10GEC2) -			&& (is_serdes_configured(XAUI_FM1))) +	/*B4860 has two 10Gig Mac*/ +	if ((port == FM1_10GEC1 || port == FM1_10GEC2)	&& +	    ((is_serdes_configured(XAUI_FM1_MAC9))	|| +	    (is_serdes_configured(XAUI_FM1_MAC10))))  		return PHY_INTERFACE_MODE_XGMII;  	/* Fix me need to handle RGMII here first */ diff --git a/drivers/net/fm/eth.c b/drivers/net/fm/eth.c index 54b142f47..9b139eeb0 100644 --- a/drivers/net/fm/eth.c +++ b/drivers/net/fm/eth.c @@ -568,6 +568,8 @@ static int fm_eth_init_mac(struct fm_eth *fm_eth, struct ccsr_fman *reg)  	num = fm_eth->num;  #ifdef CONFIG_SYS_FMAN_V3 +	if (fm_eth->type == FM_ETH_10G_E) +		num += 8;  	base = ®->memac[num].fm_memac;  	phyregs = ®->memac[num].fm_memac_mdio;  #else diff --git a/drivers/net/fm/fm.h b/drivers/net/fm/fm.h index 228df330f..ba581e9ef 100644 --- a/drivers/net/fm/fm.h +++ b/drivers/net/fm/fm.h @@ -152,4 +152,6 @@ struct fm_eth {  #define MAX_RXBUF_LOG2		11  #define MAX_RXBUF_LEN		(1 << MAX_RXBUF_LOG2) +#define PORT_IS_ENABLED(port)	fm_info[fm_port_to_index(port)].enabled +  #endif /* __FM_H__ */ diff --git a/drivers/net/fm/init.c b/drivers/net/fm/init.c index ae389b884..5908c3254 100644 --- a/drivers/net/fm/init.c +++ b/drivers/net/fm/init.c @@ -74,9 +74,15 @@ struct fm_eth_info fm_info[] = {  #if (CONFIG_SYS_NUM_FM1_10GEC >= 1)  	FM_TGEC_INFO_INITIALIZER(1, 1),  #endif +#if (CONFIG_SYS_NUM_FM1_10GEC >= 2) +	FM_TGEC_INFO_INITIALIZER(1, 2), +#endif  #if (CONFIG_SYS_NUM_FM2_10GEC >= 1)  	FM_TGEC_INFO_INITIALIZER(2, 1),  #endif +#if (CONFIG_SYS_NUM_FM2_10GEC >= 2) +	FM_TGEC_INFO_INITIALIZER(2, 2), +#endif  };  int fm_standard_init(bd_t *bis) @@ -232,6 +238,26 @@ static void ft_fixup_port(void *blob, struct fm_eth_info *info, char *prop)  		return ;  	} +#ifdef CONFIG_SYS_FMAN_V3 +	/* +	 * Physically FM1_DTSEC9 and FM1_10GEC1 use the same dual-role MAC, when +	 * FM1_10GEC1 is enabled and  FM1_DTSEC9 is disabled, ensure that the +	 * dual-role MAC is not disabled, ditto for other dual-role MACs. +	 */ +	if (((info->port == FM1_DTSEC9) && (PORT_IS_ENABLED(FM1_10GEC1)))	|| +	    ((info->port == FM1_DTSEC10) && (PORT_IS_ENABLED(FM1_10GEC2)))	|| +	    ((info->port == FM1_10GEC1) && (PORT_IS_ENABLED(FM1_DTSEC9)))	|| +	    ((info->port == FM1_10GEC2) && (PORT_IS_ENABLED(FM1_DTSEC10))) +#if (CONFIG_SYS_NUM_FMAN == 2) +										|| +	    ((info->port == FM2_DTSEC9) && (PORT_IS_ENABLED(FM2_10GEC1)))	|| +	    ((info->port == FM2_DTSEC10) && (PORT_IS_ENABLED(FM2_10GEC2)))	|| +	    ((info->port == FM2_10GEC1) && (PORT_IS_ENABLED(FM2_DTSEC9)))	|| +	    ((info->port == FM2_10GEC2) && (PORT_IS_ENABLED(FM2_DTSEC10))) +#endif +	) +		return; +#endif  	/* board code might have caused offset to change */  	off = fdt_node_offset_by_compat_reg(blob, prop, paddr); @@ -249,10 +275,15 @@ void fdt_fixup_fman_ethernet(void *blob)  {  	int i; +#ifdef CONFIG_SYS_FMAN_V3 +	for (i = 0; i < ARRAY_SIZE(fm_info); i++) +		ft_fixup_port(blob, &fm_info[i], "fsl,fman-memac"); +#else  	for (i = 0; i < ARRAY_SIZE(fm_info); i++) {  		if (fm_info[i].type == FM_ETH_1G_E)  			ft_fixup_port(blob, &fm_info[i], "fsl,fman-1g-mac");  		else  			ft_fixup_port(blob, &fm_info[i], "fsl,fman-10g-mac");  	} +#endif  } diff --git a/drivers/net/fm/t4240.c b/drivers/net/fm/t4240.c index 48c530c91..275395f18 100644 --- a/drivers/net/fm/t4240.c +++ b/drivers/net/fm/t4240.c @@ -70,12 +70,18 @@ phy_interface_t fman_port_enet_if(enum fm_port port)  	if (is_device_disabled(port))  		return PHY_INTERFACE_MODE_NONE; -	if ((port == FM1_10GEC1 || port == FM1_10GEC2) -			&& (is_serdes_configured(XAUI_FM1))) +	if ((port == FM1_10GEC1 || port == FM1_10GEC2) && +	    ((is_serdes_configured(XAUI_FM1_MAC9))	|| +	     (is_serdes_configured(XAUI_FM1_MAC10))	|| +	     (is_serdes_configured(XFI_FM1_MAC9))	|| +	     (is_serdes_configured(XFI_FM1_MAC10))))  		return PHY_INTERFACE_MODE_XGMII; -	if ((port == FM2_10GEC1 || port == FM2_10GEC2) -			&& (is_serdes_configured(XAUI_FM2))) +	if ((port == FM2_10GEC1 || port == FM2_10GEC2) && +	    ((is_serdes_configured(XAUI_FM2_MAC9))	|| +	     (is_serdes_configured(XAUI_FM2_MAC10))	|| +	     (is_serdes_configured(XFI_FM2_MAC9))	|| +	     (is_serdes_configured(XFI_FM2_MAC10))))  		return PHY_INTERFACE_MODE_XGMII;  #define FSL_CORENET_RCWSR13_EC1			0x60000000 /* bits 417..418 */ diff --git a/drivers/net/phy/teranetics.c b/drivers/net/phy/teranetics.c index 78447b711..84ce7362f 100644 --- a/drivers/net/phy/teranetics.c +++ b/drivers/net/phy/teranetics.c @@ -34,9 +34,21 @@ int tn2020_config(struct phy_device *phydev)  		unsigned short restart_an = (MDIO_AN_CTRL1_RESTART |  						MDIO_AN_CTRL1_ENABLE |  						MDIO_AN_CTRL1_XNP); +		u8 phy_hwversion; -		phy_write(phydev, 30, 93, 2); -		phy_write(phydev, MDIO_MMD_AN, MDIO_CTRL1, restart_an); +		/* +		 * bit 15:12 of register 30.32 indicates PHY hardware +		 * version. It can be used to distinguish TN80xx from +		 * TN2020. TN2020 needs write 0x2 to 30.93, but TN80xx +		 * needs 0x1. +		 */ +		phy_hwversion = (phy_read(phydev, 30, 32) >> 12) & 0xf; +		if (phy_hwversion <= 3) { +			phy_write(phydev, 30, 93, 2); +			phy_write(phydev, MDIO_MMD_AN, MDIO_CTRL1, restart_an); +		} else { +			phy_write(phydev, 30, 93, 1); +		}  	}  	return 0; diff --git a/drivers/net/phy/vitesse.c b/drivers/net/phy/vitesse.c index 6c5cb9977..c283d823b 100644 --- a/drivers/net/phy/vitesse.c +++ b/drivers/net/phy/vitesse.c @@ -48,6 +48,19 @@  #define MIIM_VSC8601_SKEW_CTRL		0x1c  #define PHY_EXT_PAGE_ACCESS    0x1f +#define PHY_EXT_PAGE_ACCESS_GENERAL	0x10 +#define PHY_EXT_PAGE_ACCESS_EXTENDED3	0x3 + +/* Vitesse VSC8574 control register */ +#define MIIM_VSC8574_MAC_SERDES_CON	0x10 +#define MIIM_VSC8574_MAC_SERDES_ANEG	0x80 +#define MIIM_VSC8574_GENERAL18		0x12 +#define MIIM_VSC8574_GENERAL19		0x13 + +/* Vitesse VSC8574 gerenal purpose register 18 */ +#define MIIM_VSC8574_18G_SGMII		0x80f0 +#define MIIM_VSC8574_18G_QSGMII		0x80e0 +#define MIIM_VSC8574_18G_CMDSTAT	0x8000  /* CIS8201 */  static int vitesse_config(struct phy_device *phydev) @@ -145,6 +158,49 @@ static int vsc8601_config(struct phy_device *phydev)  	return 0;  } +static int vsc8574_config(struct phy_device *phydev) +{ +	u32 val; +	/* configure regiser 19G for MAC */ +	phy_write(phydev, MDIO_DEVAD_NONE, PHY_EXT_PAGE_ACCESS, +		  PHY_EXT_PAGE_ACCESS_GENERAL); + +	val = phy_read(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL19); +	if (phydev->interface == PHY_INTERFACE_MODE_QSGMII) { +		/* set bit 15:14 to '01' for QSGMII mode */ +		val = (val & 0x3fff) | (1 << 14); +		phy_write(phydev, MDIO_DEVAD_NONE, +			  MIIM_VSC8574_GENERAL19, val); +		/* Enable 4 ports MAC QSGMII */ +		phy_write(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL18, +			  MIIM_VSC8574_18G_QSGMII); +	} else { +		/* set bit 15:14 to '00' for SGMII mode */ +		val = val & 0x3fff; +		phy_write(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL19, val); +		/* Enable 4 ports MAC SGMII */ +		phy_write(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL18, +			  MIIM_VSC8574_18G_SGMII); +	} +	val = phy_read(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL18); +	/* When bit 15 is cleared the command has completed */ +	while (val & MIIM_VSC8574_18G_CMDSTAT) +		val = phy_read(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_GENERAL18); + +	/* Enable Serdes Auto-negotiation */ +	phy_write(phydev, MDIO_DEVAD_NONE, PHY_EXT_PAGE_ACCESS, +		  PHY_EXT_PAGE_ACCESS_EXTENDED3); +	val = phy_read(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_MAC_SERDES_CON); +	val = val | MIIM_VSC8574_MAC_SERDES_ANEG; +	phy_write(phydev, MDIO_DEVAD_NONE, MIIM_VSC8574_MAC_SERDES_CON, val); + +	phy_write(phydev, MDIO_DEVAD_NONE, PHY_EXT_PAGE_ACCESS, 0); + +	genphy_config_aneg(phydev); + +	return 0; +} +  static struct phy_driver VSC8211_driver = {  	.name	= "Vitesse VSC8211",  	.uid	= 0xfc4b0, @@ -185,6 +241,16 @@ static struct phy_driver VSC8234_driver = {  	.shutdown = &genphy_shutdown,  }; +static struct phy_driver VSC8574_driver = { +	.name = "Vitesse VSC8574", +	.uid = 0x704a0, +	.mask = 0xffff0, +	.features = PHY_GBIT_FEATURES, +	.config = &vsc8574_config, +	.startup = &vitesse_startup, +	.shutdown = &genphy_shutdown, +}; +  static struct phy_driver VSC8601_driver = {  	.name = "Vitesse VSC8601",  	.uid = 0x70420, @@ -244,6 +310,7 @@ int phy_vitesse_init(void)  	phy_register(&VSC8244_driver);  	phy_register(&VSC8211_driver);  	phy_register(&VSC8221_driver); +	phy_register(&VSC8574_driver);  	phy_register(&VSC8662_driver);  	phy_register(&cis8201_driver);  	phy_register(&cis8204_driver); diff --git a/drivers/net/smc911x.h b/drivers/net/smc911x.h index a290073bb..f63a0695e 100644 --- a/drivers/net/smc911x.h +++ b/drivers/net/smc911x.h @@ -484,7 +484,7 @@ static void smc911x_reset(struct eth_device *dev)  		while (timeout-- &&  			!(smc911x_reg_read(dev, PMT_CTRL) & PMT_CTRL_READY))  			udelay(10); -		if (!timeout) { +		if (timeout < 0) {  			printf(DRIVERNAME  				": timeout waiting for PM restore\n");  			return; @@ -500,7 +500,7 @@ static void smc911x_reset(struct eth_device *dev)  	while (timeout-- && smc911x_reg_read(dev, E2P_CMD) & E2P_CMD_EPC_BUSY)  		udelay(10); -	if (!timeout) { +	if (timeout < 0) {  		printf(DRIVERNAME ": reset timeout\n");  		return;  	} |