# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) %YAML 1.2 --- $id: http://devicetree.org/schemas/phy/mscc,vsc7514-serdes.yaml# $schema: http://devicetree.org/meta-schemas/core.yaml# title: Microsemi Ocelot SerDes muxing maintainers: - Alexandre Belloni <alexandre.belloni@bootlin.com> - UNGLinuxDriver@microchip.com description: | On Microsemi Ocelot, there is a handful of registers in HSIO address space for setting up the SerDes to switch port muxing. A SerDes X can be "muxed" to work with switch port Y or Z for example. One specific SerDes can also be used as a PCIe interface. Hence, a SerDes represents an interface, be it an Ethernet or a PCIe one. There are two kinds of SerDes: SERDES1G supports 10/100Mbps in half/full-duplex and 1000Mbps in full-duplex mode while SERDES6G supports 10/100Mbps in half/full-duplex and 1000/2500Mbps in full-duplex mode. Also, SERDES6G number (aka "macro") 0 is the only interface supporting QSGMII. This is a child of the HSIO syscon ("mscc,ocelot-hsio", see Documentation/devicetree/bindings/mips/mscc.txt) on the Microsemi Ocelot. properties: compatible: enum: - mscc,vsc7514-serdes "#phy-cells": const: 2 description: | The first number defines the input port to use for a given SerDes macro. The second defines the macro to use. They are defined in dt-bindings/phy/phy-ocelot-serdes.h required: - compatible - "#phy-cells" additionalProperties: false examples: - | serdes: serdes { compatible = "mscc,vsc7514-serdes"; #phy-cells = <2>; };