dsa: add support for the Marvell 88E6131 switch chip
authorLennert Buytenhek <buytenh@wantstofly.org>
Tue, 7 Oct 2008 13:45:18 +0000 (13:45 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 9 Oct 2008 00:24:09 +0000 (17:24 -0700)
commit2e5f032095ff101274dfb03d5fd5e06d9aeb83cd
treeeeb61cf6665452288a25434c54bc8d4ff8031cef
parentcf85d08fdf4548ee46657ccfb7f9949a85145db5
dsa: add support for the Marvell 88E6131 switch chip

Add support for the Marvell 88E6131 switch chip.  This chip only
supports the original (ethertype-less) DSA tagging format.

On the 88E6131, there is a PHY Polling Unit (PPU) which has exclusive
access to each of the PHYs's MII management registers.  If we want to
talk to the PHYs from software, we have to disable the PPU and wait
for it to complete its current transaction before we can do so, and we
need to re-enable the PPU afterwards to make sure that the switch will
notice changes in link state and speed on the individual ports as they
occur.

Since disabling the PPU is rather slow, and since MII management
accesses are typically done in bursts, this patch keeps the PPU disabled
for 10ms after a software access completes.  This makes handling the
PPU slightly more complex, but speeds up something like running ethtool
on one of the switch slave interfaces from ~300ms to ~30ms on typical
hardware.

Signed-off-by: Lennert Buytenhek <buytenh@marvell.com>
Tested-by: Nicolas Pitre <nico@marvell.com>
Tested-by: Peter van Valderen <linux@ddcrew.com>
Tested-by: Dirk Teurlings <dirk@upexia.nl>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/dsa/Kconfig
net/dsa/Makefile
net/dsa/mv88e6131.c [new file with mode: 0644]
net/dsa/mv88e6xxx.c
net/dsa/mv88e6xxx.h