diff options
Diffstat (limited to 'net/eth.c')
| -rw-r--r-- | net/eth.c | 62 | 
1 files changed, 58 insertions, 4 deletions
| @@ -26,7 +26,7 @@  #include <net.h>  #include <miiphy.h> -#if (CONFIG_COMMANDS & CFG_CMD_NET) && defined(CONFIG_NET_MULTI) +#if defined(CONFIG_CMD_NET) && defined(CONFIG_NET_MULTI)  #ifdef CFG_GT_6426x  extern int gt6426x_eth_initialize(bd_t *bis); @@ -40,6 +40,7 @@ extern int eth_3com_initialize(bd_t*);  extern int fec_initialize(bd_t*);  extern int inca_switch_initialize(bd_t*);  extern int mpc5xxx_fec_initialize(bd_t*); +extern int mpc512x_fec_initialize(bd_t*);  extern int mpc8220_fec_initialize(bd_t*);  extern int mv6436x_eth_initialize(bd_t *);  extern int mv6446x_eth_initialize(bd_t *); @@ -144,7 +145,7 @@ int eth_initialize(bd_t *bis)  	eth_current = NULL;  	show_boot_progress (64); -#if defined(CONFIG_MII) || (CONFIG_COMMANDS & CFG_CMD_MII) +#if defined(CONFIG_MII) || defined(CONFIG_CMD_MII)  	miiphy_init();  #endif @@ -169,6 +170,9 @@ int eth_initialize(bd_t *bis)  #if defined(CONFIG_MPC5xxx_FEC)  	mpc5xxx_fec_initialize(bis);  #endif +#if defined(CONFIG_MPC512x_FEC) +	mpc512x_fec_initialize (bis); +#endif  #if defined(CONFIG_MPC8220_FEC)  	mpc8220_fec_initialize(bis);  #endif @@ -353,6 +357,51 @@ void eth_set_enetaddr(int num, char *addr) {  	memcpy(dev->enetaddr, enetaddr, 6);  } +#ifdef CONFIG_MCAST_TFTP +/* Multicast. + * mcast_addr: multicast ipaddr from which multicast Mac is made + * join: 1=join, 0=leave. + */ +int eth_mcast_join( IPaddr_t mcast_ip, u8 join) +{ + u8 mcast_mac[6]; +	if (!eth_current || !eth_current->mcast) +		return -1; +	mcast_mac[5] = htonl(mcast_ip) & 0xff; +	mcast_mac[4] = (htonl(mcast_ip)>>8) & 0xff; +	mcast_mac[3] = (htonl(mcast_ip)>>16) & 0x7f; +	mcast_mac[2] = 0x5e; +	mcast_mac[1] = 0x0; +	mcast_mac[0] = 0x1; +	return eth_current->mcast(eth_current, mcast_mac, join); +} + +/* the 'way' for ethernet-CRC-32. Spliced in from Linux lib/crc32.c + * and this is the ethernet-crc method needed for TSEC -- and perhaps + * some other adapter -- hash tables + */ +#define CRCPOLY_LE 0xedb88320 +u32 ether_crc (size_t len, unsigned char const *p) +{ +	int i; +	u32 crc; +	crc = ~0; +	while (len--) { +		crc ^= *p++; +		for (i = 0; i < 8; i++) +			crc = (crc >> 1) ^ ((crc & 1) ? CRCPOLY_LE : 0); +	} +	/* an reverse the bits, cuz of way they arrive -- last-first */ +	crc = (crc >> 16) | (crc << 16); +	crc = (crc >> 8 & 0x00ff00ff) | (crc << 8 & 0xff00ff00); +	crc = (crc >> 4 & 0x0f0f0f0f) | (crc << 4 & 0xf0f0f0f0); +	crc = (crc >> 2 & 0x33333333) | (crc << 2 & 0xcccccccc); +	crc = (crc >> 1 & 0x55555555) | (crc << 1 & 0xaaaaaaaa); +	return crc; +} + +#endif +  int eth_init(bd_t *bis)  { @@ -458,16 +507,18 @@ char *eth_get_name (void)  {  	return (eth_current ? eth_current->name : "unknown");  } -#elif (CONFIG_COMMANDS & CFG_CMD_NET) && !defined(CONFIG_NET_MULTI) +#elif defined(CONFIG_CMD_NET) && !defined(CONFIG_NET_MULTI)  extern int at91rm9200_miiphy_initialize(bd_t *bis);  extern int emac4xx_miiphy_initialize(bd_t *bis);  extern int mcf52x2_miiphy_initialize(bd_t *bis);  extern int ns7520_miiphy_initialize(bd_t *bis); +extern int dm644x_eth_miiphy_initialize(bd_t *bis); +  int eth_initialize(bd_t *bis)  { -#if defined(CONFIG_MII) || (CONFIG_COMMANDS & CFG_CMD_MII) +#if defined(CONFIG_MII) || defined(CONFIG_CMD_MII)  	miiphy_init();  #endif @@ -484,6 +535,9 @@ int eth_initialize(bd_t *bis)  #if defined(CONFIG_NETARM)  	ns7520_miiphy_initialize(bis);  #endif +#if defined(CONFIG_DRIVER_TI_EMAC) +	dm644x_eth_miiphy_initialize(bis); +#endif  	return 0;  }  #endif |