aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAkinobu Mita <akinobu.mita@gmail.com>2016-05-14 01:55:48 -0400
committerDavid S. Miller <davem@davemloft.net>2016-05-16 13:55:48 -0400
commitd41cd5f7e2fce8d3c5b1345a7cf9ed3f0d2d99c1 (patch)
tree09228413f8205e255ef04dda4fd9b013d349515b
parente9f0cd94c1697ad6c98422a1953105c8ffc515f3 (diff)
net: w5100: fix MAC filtering for W5500
W5500 has different bit position for MAC filter in Socket n mode register from W5100 and W5200. Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com> Cc: Mike Sinkovsky <msink@permonline.ru> Cc: David S. Miller <davem@davemloft.net> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/ethernet/wiznet/w5100.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/drivers/net/ethernet/wiznet/w5100.c b/drivers/net/ethernet/wiznet/w5100.c
index df0ba2b2b93a..7c6d5081242e 100644
--- a/drivers/net/ethernet/wiznet/w5100.c
+++ b/drivers/net/ethernet/wiznet/w5100.c
@@ -63,8 +63,9 @@ MODULE_LICENSE("GPL");
63#define S0_REGS(priv) ((priv)->s0_regs) 63#define S0_REGS(priv) ((priv)->s0_regs)
64 64
65#define W5100_S0_MR(priv) (S0_REGS(priv) + W5100_Sn_MR) 65#define W5100_S0_MR(priv) (S0_REGS(priv) + W5100_Sn_MR)
66#define S0_MR_MACRAW 0x04 /* MAC RAW mode (promiscuous) */ 66#define S0_MR_MACRAW 0x04 /* MAC RAW mode */
67#define S0_MR_MACRAW_MF 0x44 /* MAC RAW mode (filtered) */ 67#define S0_MR_MF 0x40 /* MAC Filter for W5100 and W5200 */
68#define W5500_S0_MR_MF 0x80 /* MAC Filter for W5500 */
68#define W5100_S0_CR(priv) (S0_REGS(priv) + W5100_Sn_CR) 69#define W5100_S0_CR(priv) (S0_REGS(priv) + W5100_Sn_CR)
69#define S0_CR_OPEN 0x01 /* OPEN command */ 70#define S0_CR_OPEN 0x01 /* OPEN command */
70#define S0_CR_CLOSE 0x10 /* CLOSE command */ 71#define S0_CR_CLOSE 0x10 /* CLOSE command */
@@ -702,8 +703,16 @@ static int w5100_hw_reset(struct w5100_priv *priv)
702 703
703static void w5100_hw_start(struct w5100_priv *priv) 704static void w5100_hw_start(struct w5100_priv *priv)
704{ 705{
705 w5100_write(priv, W5100_S0_MR(priv), priv->promisc ? 706 u8 mode = S0_MR_MACRAW;
706 S0_MR_MACRAW : S0_MR_MACRAW_MF); 707
708 if (!priv->promisc) {
709 if (priv->ops->chip_id == W5500)
710 mode |= W5500_S0_MR_MF;
711 else
712 mode |= S0_MR_MF;
713 }
714
715 w5100_write(priv, W5100_S0_MR(priv), mode);
707 w5100_command(priv, S0_CR_OPEN); 716 w5100_command(priv, S0_CR_OPEN);
708 w5100_enable_intr(priv); 717 w5100_enable_intr(priv);
709} 718}