diff options
-rw-r--r-- | drivers/net/fec.c | 24 | ||||
-rw-r--r-- | drivers/net/fec.h | 4 |
2 files changed, 16 insertions, 12 deletions
diff --git a/drivers/net/fec.c b/drivers/net/fec.c index d7a3ea88eddb..8408b43d50d9 100644 --- a/drivers/net/fec.c +++ b/drivers/net/fec.c | |||
@@ -2243,13 +2243,13 @@ static void set_multicast_list(struct net_device *dev) | |||
2243 | /* Catch all multicast addresses, so set the | 2243 | /* Catch all multicast addresses, so set the |
2244 | * filter to all 1's. | 2244 | * filter to all 1's. |
2245 | */ | 2245 | */ |
2246 | ep->fec_hash_table_high = 0xffffffff; | 2246 | ep->fec_grp_hash_table_high = 0xffffffff; |
2247 | ep->fec_hash_table_low = 0xffffffff; | 2247 | ep->fec_grp_hash_table_low = 0xffffffff; |
2248 | } else { | 2248 | } else { |
2249 | /* Clear filter and add the addresses in hash register. | 2249 | /* Clear filter and add the addresses in hash register. |
2250 | */ | 2250 | */ |
2251 | ep->fec_hash_table_high = 0; | 2251 | ep->fec_grp_hash_table_high = 0; |
2252 | ep->fec_hash_table_low = 0; | 2252 | ep->fec_grp_hash_table_low = 0; |
2253 | 2253 | ||
2254 | dmi = dev->mc_list; | 2254 | dmi = dev->mc_list; |
2255 | 2255 | ||
@@ -2280,9 +2280,9 @@ static void set_multicast_list(struct net_device *dev) | |||
2280 | hash = (crc >> (32 - HASH_BITS)) & 0x3f; | 2280 | hash = (crc >> (32 - HASH_BITS)) & 0x3f; |
2281 | 2281 | ||
2282 | if (hash > 31) | 2282 | if (hash > 31) |
2283 | ep->fec_hash_table_high |= 1 << (hash - 32); | 2283 | ep->fec_grp_hash_table_high |= 1 << (hash - 32); |
2284 | else | 2284 | else |
2285 | ep->fec_hash_table_low |= 1 << hash; | 2285 | ep->fec_grp_hash_table_low |= 1 << hash; |
2286 | } | 2286 | } |
2287 | } | 2287 | } |
2288 | } | 2288 | } |
@@ -2430,11 +2430,15 @@ int __init fec_enet_init(struct net_device *dev) | |||
2430 | */ | 2430 | */ |
2431 | fec_request_intrs(dev); | 2431 | fec_request_intrs(dev); |
2432 | 2432 | ||
2433 | fecp->fec_hash_table_high = 0; | 2433 | fecp->fec_grp_hash_table_high = 0; |
2434 | fecp->fec_hash_table_low = 0; | 2434 | fecp->fec_grp_hash_table_low = 0; |
2435 | fecp->fec_r_buff_size = PKT_MAXBLR_SIZE; | 2435 | fecp->fec_r_buff_size = PKT_MAXBLR_SIZE; |
2436 | fecp->fec_ecntrl = 2; | 2436 | fecp->fec_ecntrl = 2; |
2437 | fecp->fec_r_des_active = 0; | 2437 | fecp->fec_r_des_active = 0; |
2438 | #ifndef CONFIG_M5272 | ||
2439 | fecp->fec_hash_table_high = 0; | ||
2440 | fecp->fec_hash_table_low = 0; | ||
2441 | #endif | ||
2438 | 2442 | ||
2439 | dev->base_addr = (unsigned long)fecp; | 2443 | dev->base_addr = (unsigned long)fecp; |
2440 | 2444 | ||
@@ -2500,8 +2504,8 @@ fec_restart(struct net_device *dev, int duplex) | |||
2500 | 2504 | ||
2501 | /* Reset all multicast. | 2505 | /* Reset all multicast. |
2502 | */ | 2506 | */ |
2503 | fecp->fec_hash_table_high = 0; | 2507 | fecp->fec_grp_hash_table_high = 0; |
2504 | fecp->fec_hash_table_low = 0; | 2508 | fecp->fec_grp_hash_table_low = 0; |
2505 | 2509 | ||
2506 | /* Set maximum receive buffer size. | 2510 | /* Set maximum receive buffer size. |
2507 | */ | 2511 | */ |
diff --git a/drivers/net/fec.h b/drivers/net/fec.h index 1d421606984f..292719daceff 100644 --- a/drivers/net/fec.h +++ b/drivers/net/fec.h | |||
@@ -88,8 +88,8 @@ typedef struct fec { | |||
88 | unsigned long fec_reserved7[158]; | 88 | unsigned long fec_reserved7[158]; |
89 | unsigned long fec_addr_low; /* Low 32bits MAC address */ | 89 | unsigned long fec_addr_low; /* Low 32bits MAC address */ |
90 | unsigned long fec_addr_high; /* High 16bits MAC address */ | 90 | unsigned long fec_addr_high; /* High 16bits MAC address */ |
91 | unsigned long fec_hash_table_high; /* High 32bits hash table */ | 91 | unsigned long fec_grp_hash_table_high;/* High 32bits hash table */ |
92 | unsigned long fec_hash_table_low; /* Low 32bits hash table */ | 92 | unsigned long fec_grp_hash_table_low; /* Low 32bits hash table */ |
93 | unsigned long fec_r_des_start; /* Receive descriptor ring */ | 93 | unsigned long fec_r_des_start; /* Receive descriptor ring */ |
94 | unsigned long fec_x_des_start; /* Transmit descriptor ring */ | 94 | unsigned long fec_x_des_start; /* Transmit descriptor ring */ |
95 | unsigned long fec_r_buff_size; /* Maximum receive buff size */ | 95 | unsigned long fec_r_buff_size; /* Maximum receive buff size */ |