Message ID | f57a340f615991ed2771d8af4b1a908dec436a5e.1486333475.git.chunkeey@googlemail.com |
---|---|
State | RFC, archived |
Delegated to: | David Miller |
Headers | show |
Le 02/05/17 à 14:25, Christian Lamparter a écrit : > This patch adds documentation for a new "phy-handler" property > and "mdio" sub-node. These allows the enumeration of PHYs which > are supported by the phy library under drivers/net/phy. > > The EMAC ethernet controller in IBM and AMCC 4xx chips is > currently stuck with a few privately defined phy > implementations. It has no support for PHYs which > are supported by the generic phylib. > > Signed-off-by: Christian Lamparter <chunkeey@googlemail.com> > --- > .../devicetree/bindings/powerpc/4xx/emac.txt | 60 +++++++++++++++++++++- > 1 file changed, 58 insertions(+), 2 deletions(-) > > diff --git a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > index 712baf6c3e24..0572d053c35a 100644 > --- a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > +++ b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > @@ -71,6 +71,8 @@ > For Axon it can be absent, though my current driver > doesn't handle phy-address yet so for now, keep > 0x00ffffff in it. > + - phy-handle : See net/ethernet.txt file; used to describe > + configurations where a external PHY is used. > - rx-fifo-size-gige : 1 cell, Rx fifo size in bytes for 1000 Mb/sec > operations (if absent the value is the same as > rx-fifo-size). For Axon, either absent or 2048. > @@ -82,7 +84,18 @@ > - tah-channel : 1 cell, optional. If appropriate, channel used on the > TAH engine. > > - Example: > + - mdio subnode : When the EMAC has a phy connected to its local > + mdio, which us supported by the kernel's network > + PHY library in drivers/net/phy, there must be device > + tree subnode with the following required properties: > + - #address-cells: Must be <1>. > + - #size-cells: Must be <0>. > + > + For each phy on the mdio bus, there must be a node > + with the following fields: > + - reg: phy id used to communicate to phy. > + - device_type: Must be "ethernet-phy". Just provide a reference to Documentation/devicetree/bindings/net/phy.txt and Documentation/devicetree/bindings/net/ethernet.txt here. device_type is not required. > + Examples: > > EMAC0: ethernet@40000800 { > device_type = "network"; > @@ -104,6 +117,50 @@ > zmii-channel = <0>; > }; > > + EMAC1: ethernet@ef600c00 { > + device_type = "network"; > + compatible = "ibm,emac-apm821xx", "ibm,emac4sync"; > + interrupt-parent = <&EMAC1>; > + interrupts = <0 1>; > + #interrupt-cells = <1>; > + #address-cells = <0>; > + #size-cells = <0>; > + interrupt-map = <0 &UIC2 0x10 IRQ_TYPE_LEVEL_HIGH /* Status */ > + 1 &UIC2 0x14 IRQ_TYPE_LEVEL_HIGH /* Wake */>; > + reg = <0xef600c00 0x000000c4>; > + local-mac-address = [000000000000]; /* Filled in by U-Boot */ > + mal-device = <&MAL0>; > + mal-tx-channel = <0>; > + mal-rx-channel = <0>; > + cell-index = <0>; > + max-frame-size = <9000>; > + rx-fifo-size = <16384>; > + tx-fifo-size = <2048>; > + fifo-entry-size = <10>; > + phy-mode = "rgmii"; > + phy-map = <0x00000000>; If you have a proper mdio subnode, this property becomes irrelevant and should be unused. > + phy-handle = <&phy0>; > + rgmii-device = <&RGMII0>; > + rgmii-channel = <0>; > + tah-device = <&TAH0>; > + tah-channel = <0>; > + has-inverted-stacr-oc; > + has-new-stacr-staopc; > + > + mdio { > + #address-cells = <1>; > + #size-cells = <0>; > + > + phy0: ethernet-phy@0 { > + device_type = "ethernet-phy"; > + reg = <0>; > + > + qca,ar8327-initvals = < > + 0x0010 0x40000000>; > + }; > + }; > + > + > ii) McMAL node > > Required properties: > @@ -145,4 +202,3 @@ > - revision : as provided by the RGMII new version register if > available. > For Axon: 0x0000012a > - >
On Sun, Feb 05, 2017 at 11:25:05PM +0100, Christian Lamparter wrote: > This patch adds documentation for a new "phy-handler" property s/phy-handler/phy-handle/ > and "mdio" sub-node. These allows the enumeration of PHYs which > are supported by the phy library under drivers/net/phy. > > The EMAC ethernet controller in IBM and AMCC 4xx chips is > currently stuck with a few privately defined phy > implementations. It has no support for PHYs which > are supported by the generic phylib. > > Signed-off-by: Christian Lamparter <chunkeey@googlemail.com> > --- > .../devicetree/bindings/powerpc/4xx/emac.txt | 60 +++++++++++++++++++++- > 1 file changed, 58 insertions(+), 2 deletions(-) Otherwise, Acked-by: Rob Herring <robh@kernel.org>
On Sunday, February 5, 2017 2:33:44 PM CET Florian Fainelli wrote: > Le 02/05/17 à 14:25, Christian Lamparter a écrit : > > This patch adds documentation for a new "phy-handler" property > > and "mdio" sub-node. These allows the enumeration of PHYs which > > are supported by the phy library under drivers/net/phy. > > > > The EMAC ethernet controller in IBM and AMCC 4xx chips is > > currently stuck with a few privately defined phy > > implementations. It has no support for PHYs which > > are supported by the generic phylib. > > > > Signed-off-by: Christian Lamparter <chunkeey@googlemail.com> > > --- > > .../devicetree/bindings/powerpc/4xx/emac.txt | 60 +++++++++++++++++++++- > > 1 file changed, 58 insertions(+), 2 deletions(-) > > > > diff --git a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > > index 712baf6c3e24..0572d053c35a 100644 > > --- a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > > +++ b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt > > @@ -71,6 +71,8 @@ > > For Axon it can be absent, though my current driver > > doesn't handle phy-address yet so for now, keep > > 0x00ffffff in it. > > + - phy-handle : See net/ethernet.txt file; used to describe > > + configurations where a external PHY is used. > > - rx-fifo-size-gige : 1 cell, Rx fifo size in bytes for 1000 Mb/sec > > operations (if absent the value is the same as > > rx-fifo-size). For Axon, either absent or 2048. > > @@ -82,7 +84,18 @@ > > - tah-channel : 1 cell, optional. If appropriate, channel used on the > > TAH engine. > > > > - Example: > > + - mdio subnode : When the EMAC has a phy connected to its local > > + mdio, which us supported by the kernel's network > > + PHY library in drivers/net/phy, there must be device > > + tree subnode with the following required properties: > > + - #address-cells: Must be <1>. > > + - #size-cells: Must be <0>. > > + > > + For each phy on the mdio bus, there must be a node > > + with the following fields: > > + - reg: phy id used to communicate to phy. > > + - device_type: Must be "ethernet-phy". > > Just provide a reference to > Documentation/devicetree/bindings/net/phy.txt and > Documentation/devicetree/bindings/net/ethernet.txt here. device_type is > not required. Yes, I added a reference there. > > > + Examples: > > > > EMAC0: ethernet@40000800 { > > device_type = "network"; > > @@ -104,6 +117,50 @@ > > zmii-channel = <0>; > > }; > > > > + EMAC1: ethernet@ef600c00 { > > + device_type = "network"; > > + compatible = "ibm,emac-apm821xx", "ibm,emac4sync"; > > + interrupt-parent = <&EMAC1>; > > + interrupts = <0 1>; > > + #interrupt-cells = <1>; > > + #address-cells = <0>; > > + #size-cells = <0>; > > + interrupt-map = <0 &UIC2 0x10 IRQ_TYPE_LEVEL_HIGH /* Status */ > > + 1 &UIC2 0x14 IRQ_TYPE_LEVEL_HIGH /* Wake */>; > > + reg = <0xef600c00 0x000000c4>; > > + local-mac-address = [000000000000]; /* Filled in by U-Boot */ > > + mal-device = <&MAL0>; > > + mal-tx-channel = <0>; > > + mal-rx-channel = <0>; > > + cell-index = <0>; > > + max-frame-size = <9000>; > > + rx-fifo-size = <16384>; > > + tx-fifo-size = <2048>; > > + fifo-entry-size = <10>; > > + phy-mode = "rgmii"; > > + phy-map = <0x00000000>; > > If you have a proper mdio subnode, this property becomes irrelevant and > should be unused. This is emac.c doing. It defaults to 0xffff... if the property is absent. <http://lxr.free-electrons.com/source/drivers/net/ethernet/ibm/emac/core.c#L2578> > > + phy-handle = <&phy0>; > > + rgmii-device = <&RGMII0>; > > + rgmii-channel = <0>; > > + tah-device = <&TAH0>; > > + tah-channel = <0>; > > + has-inverted-stacr-oc; > > + has-new-stacr-staopc; > > + > > + mdio { > > + #address-cells = <1>; > > + #size-cells = <0>; > > + > > + phy0: ethernet-phy@0 { > > + device_type = "ethernet-phy"; > > + reg = <0>; > > + > > + qca,ar8327-initvals = < > > + 0x0010 0x40000000>; > > + }; > > + }; > > + > > + > > ii) McMAL node > > > > Required properties: > > @@ -145,4 +202,3 @@ > > - revision : as provided by the RGMII new version register if > > available. > > For Axon: 0x0000012a > > - > > > > >
diff --git a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt index 712baf6c3e24..0572d053c35a 100644 --- a/Documentation/devicetree/bindings/powerpc/4xx/emac.txt +++ b/Documentation/devicetree/bindings/powerpc/4xx/emac.txt @@ -71,6 +71,8 @@ For Axon it can be absent, though my current driver doesn't handle phy-address yet so for now, keep 0x00ffffff in it. + - phy-handle : See net/ethernet.txt file; used to describe + configurations where a external PHY is used. - rx-fifo-size-gige : 1 cell, Rx fifo size in bytes for 1000 Mb/sec operations (if absent the value is the same as rx-fifo-size). For Axon, either absent or 2048. @@ -82,7 +84,18 @@ - tah-channel : 1 cell, optional. If appropriate, channel used on the TAH engine. - Example: + - mdio subnode : When the EMAC has a phy connected to its local + mdio, which us supported by the kernel's network + PHY library in drivers/net/phy, there must be device + tree subnode with the following required properties: + - #address-cells: Must be <1>. + - #size-cells: Must be <0>. + + For each phy on the mdio bus, there must be a node + with the following fields: + - reg: phy id used to communicate to phy. + - device_type: Must be "ethernet-phy". + Examples: EMAC0: ethernet@40000800 { device_type = "network"; @@ -104,6 +117,50 @@ zmii-channel = <0>; }; + EMAC1: ethernet@ef600c00 { + device_type = "network"; + compatible = "ibm,emac-apm821xx", "ibm,emac4sync"; + interrupt-parent = <&EMAC1>; + interrupts = <0 1>; + #interrupt-cells = <1>; + #address-cells = <0>; + #size-cells = <0>; + interrupt-map = <0 &UIC2 0x10 IRQ_TYPE_LEVEL_HIGH /* Status */ + 1 &UIC2 0x14 IRQ_TYPE_LEVEL_HIGH /* Wake */>; + reg = <0xef600c00 0x000000c4>; + local-mac-address = [000000000000]; /* Filled in by U-Boot */ + mal-device = <&MAL0>; + mal-tx-channel = <0>; + mal-rx-channel = <0>; + cell-index = <0>; + max-frame-size = <9000>; + rx-fifo-size = <16384>; + tx-fifo-size = <2048>; + fifo-entry-size = <10>; + phy-mode = "rgmii"; + phy-map = <0x00000000>; + phy-handle = <&phy0>; + rgmii-device = <&RGMII0>; + rgmii-channel = <0>; + tah-device = <&TAH0>; + tah-channel = <0>; + has-inverted-stacr-oc; + has-new-stacr-staopc; + + mdio { + #address-cells = <1>; + #size-cells = <0>; + + phy0: ethernet-phy@0 { + device_type = "ethernet-phy"; + reg = <0>; + + qca,ar8327-initvals = < + 0x0010 0x40000000>; + }; + }; + + ii) McMAL node Required properties: @@ -145,4 +202,3 @@ - revision : as provided by the RGMII new version register if available. For Axon: 0x0000012a -
This patch adds documentation for a new "phy-handler" property and "mdio" sub-node. These allows the enumeration of PHYs which are supported by the phy library under drivers/net/phy. The EMAC ethernet controller in IBM and AMCC 4xx chips is currently stuck with a few privately defined phy implementations. It has no support for PHYs which are supported by the generic phylib. Signed-off-by: Christian Lamparter <chunkeey@googlemail.com> --- .../devicetree/bindings/powerpc/4xx/emac.txt | 60 +++++++++++++++++++++- 1 file changed, 58 insertions(+), 2 deletions(-)