-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
net: dt-bindings: dwmac: Convert mediatek-dwmac to DT schema
Convert mediatek-dwmac to DT schema, and delete old mediatek-dwmac.txt. And there are some changes in .yaml than .txt, others almost keep the same: 1. compatible "const: snps,dwmac-4.20". 2. delete "snps,reset-active-low;" in example, since driver remove this property long ago. 3. add "snps,reset-delay-us = <0 10000 10000>" in example. 4. the example is for rgmii interface, keep related properties only. Signed-off-by: Biao Huang <biao.huang@mediatek.com> Reviewed-by: Rob Herring <robh@kernel.org> Signed-off-by: David S. Miller <davem@davemloft.net>
- Loading branch information
Biao Huang
authored and
David S. Miller
committed
Mar 16, 2022
1 parent
79e1177
commit 150b6ad
Showing
2 changed files
with
155 additions
and
91 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
155 changes: 155 additions & 0 deletions
155
Documentation/devicetree/bindings/net/mediatek-dwmac.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,155 @@ | ||
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) | ||
%YAML 1.2 | ||
--- | ||
$id: http://devicetree.org/schemas/net/mediatek-dwmac.yaml# | ||
$schema: http://devicetree.org/meta-schemas/core.yaml# | ||
|
||
title: MediaTek DWMAC glue layer controller | ||
|
||
maintainers: | ||
- Biao Huang <biao.huang@mediatek.com> | ||
|
||
description: | ||
This file documents platform glue layer for stmmac. | ||
|
||
# We need a select here so we don't match all nodes with 'snps,dwmac' | ||
select: | ||
properties: | ||
compatible: | ||
contains: | ||
enum: | ||
- mediatek,mt2712-gmac | ||
required: | ||
- compatible | ||
|
||
allOf: | ||
- $ref: "snps,dwmac.yaml#" | ||
|
||
properties: | ||
compatible: | ||
items: | ||
- enum: | ||
- mediatek,mt2712-gmac | ||
- const: snps,dwmac-4.20a | ||
|
||
clocks: | ||
items: | ||
- description: AXI clock | ||
- description: APB clock | ||
- description: MAC Main clock | ||
- description: PTP clock | ||
- description: RMII reference clock provided by MAC | ||
|
||
clock-names: | ||
items: | ||
- const: axi | ||
- const: apb | ||
- const: mac_main | ||
- const: ptp_ref | ||
- const: rmii_internal | ||
|
||
mediatek,pericfg: | ||
$ref: /schemas/types.yaml#/definitions/phandle | ||
description: | ||
The phandle to the syscon node that control ethernet | ||
interface and timing delay. | ||
|
||
mediatek,tx-delay-ps: | ||
description: | ||
The internal TX clock delay (provided by this driver) in nanoseconds. | ||
For MT2712 RGMII interface, Allowed value need to be a multiple of 170, | ||
or will round down. Range 0~31*170. | ||
For MT2712 RMII/MII interface, Allowed value need to be a multiple of 550, | ||
or will round down. Range 0~31*550. | ||
|
||
mediatek,rx-delay-ps: | ||
description: | ||
The internal RX clock delay (provided by this driver) in nanoseconds. | ||
For MT2712 RGMII interface, Allowed value need to be a multiple of 170, | ||
or will round down. Range 0~31*170. | ||
For MT2712 RMII/MII interface, Allowed value need to be a multiple of 550, | ||
or will round down. Range 0~31*550. | ||
|
||
mediatek,rmii-rxc: | ||
type: boolean | ||
description: | ||
If present, indicates that the RMII reference clock, which is from external | ||
PHYs, is connected to RXC pin. Otherwise, is connected to TXC pin. | ||
|
||
mediatek,rmii-clk-from-mac: | ||
type: boolean | ||
description: | ||
If present, indicates that MAC provides the RMII reference clock, which | ||
outputs to TXC pin only. | ||
|
||
mediatek,txc-inverse: | ||
type: boolean | ||
description: | ||
If present, indicates that | ||
1. tx clock will be inversed in MII/RGMII case, | ||
2. tx clock inside MAC will be inversed relative to reference clock | ||
which is from external PHYs in RMII case, and it rarely happen. | ||
3. the reference clock, which outputs to TXC pin will be inversed in RMII case | ||
when the reference clock is from MAC. | ||
|
||
mediatek,rxc-inverse: | ||
type: boolean | ||
description: | ||
If present, indicates that | ||
1. rx clock will be inversed in MII/RGMII case. | ||
2. reference clock will be inversed when arrived at MAC in RMII case, when | ||
the reference clock is from external PHYs. | ||
3. the inside clock, which be sent to MAC, will be inversed in RMII case when | ||
the reference clock is from MAC. | ||
|
||
required: | ||
- compatible | ||
- reg | ||
- interrupts | ||
- interrupt-names | ||
- clocks | ||
- clock-names | ||
- phy-mode | ||
- mediatek,pericfg | ||
|
||
unevaluatedProperties: false | ||
|
||
examples: | ||
- | | ||
#include <dt-bindings/clock/mt2712-clk.h> | ||
#include <dt-bindings/gpio/gpio.h> | ||
#include <dt-bindings/interrupt-controller/arm-gic.h> | ||
#include <dt-bindings/interrupt-controller/irq.h> | ||
#include <dt-bindings/power/mt2712-power.h> | ||
eth: ethernet@1101c000 { | ||
compatible = "mediatek,mt2712-gmac", "snps,dwmac-4.20a"; | ||
reg = <0x1101c000 0x1300>; | ||
interrupts = <GIC_SPI 237 IRQ_TYPE_LEVEL_LOW>; | ||
interrupt-names = "macirq"; | ||
phy-mode ="rgmii-rxid"; | ||
mac-address = [00 55 7b b5 7d f7]; | ||
clock-names = "axi", | ||
"apb", | ||
"mac_main", | ||
"ptp_ref", | ||
"rmii_internal"; | ||
clocks = <&pericfg CLK_PERI_GMAC>, | ||
<&pericfg CLK_PERI_GMAC_PCLK>, | ||
<&topckgen CLK_TOP_ETHER_125M_SEL>, | ||
<&topckgen CLK_TOP_ETHER_50M_SEL>, | ||
<&topckgen CLK_TOP_ETHER_50M_RMII_SEL>; | ||
assigned-clocks = <&topckgen CLK_TOP_ETHER_125M_SEL>, | ||
<&topckgen CLK_TOP_ETHER_50M_SEL>, | ||
<&topckgen CLK_TOP_ETHER_50M_RMII_SEL>; | ||
assigned-clock-parents = <&topckgen CLK_TOP_ETHERPLL_125M>, | ||
<&topckgen CLK_TOP_APLL1_D3>, | ||
<&topckgen CLK_TOP_ETHERPLL_50M>; | ||
power-domains = <&scpsys MT2712_POWER_DOMAIN_AUDIO>; | ||
mediatek,pericfg = <&pericfg>; | ||
mediatek,tx-delay-ps = <1530>; | ||
snps,txpbl = <1>; | ||
snps,rxpbl = <1>; | ||
snps,reset-gpio = <&pio 87 GPIO_ACTIVE_LOW>; | ||
snps,reset-delays-us = <0 10000 10000>; | ||
}; |