]> git.baikalelectronics.ru Git - kernel.git/commit
Merge branch 'dsa-mv88e6xxx-port-operation-refine'
authorDavid S. Miller <davem@davemloft.net>
Fri, 4 Nov 2016 18:40:01 +0000 (14:40 -0400)
committerDavid S. Miller <davem@davemloft.net>
Fri, 4 Nov 2016 18:40:01 +0000 (14:40 -0400)
commitae286af8552f3c08bd51e6362f1d3c6f7d7598a4
tree5731f39f46b1b3762138b5c47a15a1c26e9bfe02
parentcceb1597df3e55a4171b47fcd1b93e7edbedb850
parentde916b1243a9bb78325621707e3353b88674cc85
Merge branch 'dsa-mv88e6xxx-port-operation-refine'

Vivien Didelot says:

====================
net: dsa: mv88e6xxx: refine port operations

The Marvell chips have one internal SMI device per port, containing a
set of registers used to configure a port's link, STP state, default
VLAN or addresses database, etc.

This patchset creates port files to implement the port operations as
described in datasheets, and extend the chip ops structure with them.

Patches 1 to 6 implement accessors for port's STP state, port based VLAN
map, default FID, default VID, and 802.1Q mode.

Patches 7 to 11 implement the port's MAC setup of link state, duplex
mode, RGMII delay and speed, all accessed through port's register 0x01.

The new port's MAC setup code is used to re-implement the adjust_link
code and correctly force the link down before changing any of the MAC
settings, as requested by the datasheets.

The port's MAC accessors use values compatible with struct phy_device
(e.g. DUPLEX_FULL) and extend them when needed (e.g. SPEED_MAX).

Changes in v2:

  - Strictly use new _UNFORCED values instead of re-using _UNKNOWN ones.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>