2012-07-30 18:17:14 +08:00
|
|
|
TI SoC Ethernet Switch Controller Device Tree Bindings
|
|
|
|
------------------------------------------------------
|
|
|
|
|
|
|
|
Required properties:
|
2015-08-31 14:21:29 +08:00
|
|
|
- compatible : Should be one of the below:-
|
|
|
|
"ti,cpsw" for backward compatible
|
|
|
|
"ti,am335x-cpsw" for AM335x controllers
|
|
|
|
"ti,am4372-cpsw" for AM437x controllers
|
|
|
|
"ti,dra7-cpsw" for DRA7x controllers
|
2012-07-30 18:17:14 +08:00
|
|
|
- reg : physical base address and size of the cpsw
|
|
|
|
registers map
|
|
|
|
- interrupts : property with a value describing the interrupt
|
|
|
|
number
|
|
|
|
- interrupt-parent : The parent interrupt controller
|
|
|
|
- cpdma_channels : Specifies number of channels in CPDMA
|
|
|
|
- ale_entries : Specifies No of entries ALE can hold
|
|
|
|
- bd_ram_size : Specifies internal descriptor RAM size
|
|
|
|
- mac_control : Specifies Default MAC control register content
|
|
|
|
for the specific platform
|
|
|
|
- slaves : Specifies number for slaves
|
2013-03-12 07:16:35 +08:00
|
|
|
- active_slave : Specifies the slave to use for time stamping,
|
|
|
|
ethtool and SIOCGMIIPHY
|
2012-10-29 16:45:19 +08:00
|
|
|
- cpts_clock_mult : Numerator to convert input clock ticks into nanoseconds
|
|
|
|
- cpts_clock_shift : Denominator to convert input clock ticks into nanoseconds
|
2012-07-30 18:17:14 +08:00
|
|
|
|
|
|
|
Optional properties:
|
|
|
|
- ti,hwmods : Must be "cpgmac0"
|
|
|
|
- no_bd_ram : Must be 0 or 1
|
2013-02-11 17:52:20 +08:00
|
|
|
- dual_emac : Specifies Switch to act as Dual EMAC
|
2014-09-29 14:53:17 +08:00
|
|
|
- syscon : Phandle to the system control device node, which is
|
|
|
|
the control module device of the am33x
|
2015-09-07 17:46:44 +08:00
|
|
|
- mode-gpios : Should be added if one/multiple gpio lines are
|
|
|
|
required to be driven so that cpsw data lines
|
|
|
|
can be connected to the phy via selective mux.
|
|
|
|
For example in dra72x-evm, pcf gpio has to be
|
|
|
|
driven low so that cpsw slave 0 and phy data
|
|
|
|
lines are connected via mux.
|
|
|
|
|
2013-03-12 07:16:34 +08:00
|
|
|
|
|
|
|
Slave Properties:
|
|
|
|
Required properties:
|
2014-02-18 07:41:59 +08:00
|
|
|
- phy-mode : See ethernet.txt file in the same directory
|
2013-03-12 07:16:34 +08:00
|
|
|
|
|
|
|
Optional properties:
|
2013-02-11 17:52:20 +08:00
|
|
|
- dual_emac_res_vlan : Specifies VID to be used to segregate the ports
|
2014-09-29 14:53:13 +08:00
|
|
|
- mac-address : See ethernet.txt file in the same directory
|
2016-04-28 09:42:47 +08:00
|
|
|
- phy_id : Specifies slave phy id (deprecated, use phy-handle)
|
2015-10-17 12:04:35 +08:00
|
|
|
- phy-handle : See ethernet.txt file in the same directory
|
2012-07-30 18:17:14 +08:00
|
|
|
|
2015-11-04 05:09:51 +08:00
|
|
|
Slave sub-nodes:
|
|
|
|
- fixed-link : See fixed-link.txt file in the same directory
|
2016-04-28 09:42:47 +08:00
|
|
|
|
|
|
|
Note: Exactly one of phy_id, phy-handle, or fixed-link must be specified.
|
2015-11-04 05:09:51 +08:00
|
|
|
|
2012-07-30 18:17:14 +08:00
|
|
|
Note: "ti,hwmods" field is used to fetch the base address and irq
|
|
|
|
resources from TI, omap hwmod data base during device registration.
|
|
|
|
Future plan is to migrate hwmod data base contents into device tree
|
|
|
|
blob so that, all the required data will be used from device tree dts
|
|
|
|
file.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
|
|
|
|
mac: ethernet@4A100000 {
|
|
|
|
compatible = "ti,cpsw";
|
|
|
|
reg = <0x4A100000 0x1000>;
|
|
|
|
interrupts = <55 0x4>;
|
|
|
|
interrupt-parent = <&intc>;
|
2012-08-06 13:05:58 +08:00
|
|
|
cpdma_channels = <8>;
|
|
|
|
ale_entries = <1024>;
|
|
|
|
bd_ram_size = <0x2000>;
|
|
|
|
no_bd_ram = <0>;
|
|
|
|
rx_descs = <64>;
|
|
|
|
mac_control = <0x20>;
|
|
|
|
slaves = <2>;
|
2013-03-12 07:16:35 +08:00
|
|
|
active_slave = <0>;
|
2012-10-29 16:45:19 +08:00
|
|
|
cpts_clock_mult = <0x80000000>;
|
|
|
|
cpts_clock_shift = <29>;
|
2014-09-29 14:53:17 +08:00
|
|
|
syscon = <&cm>;
|
2012-08-06 13:05:58 +08:00
|
|
|
cpsw_emac0: slave@0 {
|
2012-11-14 17:07:56 +08:00
|
|
|
phy_id = <&davinci_mdio>, <0>;
|
2013-06-04 04:10:10 +08:00
|
|
|
phy-mode = "rgmii-txid";
|
2012-08-06 13:05:58 +08:00
|
|
|
/* Filled in by U-Boot */
|
|
|
|
mac-address = [ 00 00 00 00 00 00 ];
|
2012-07-30 18:17:14 +08:00
|
|
|
};
|
2012-08-06 13:05:58 +08:00
|
|
|
cpsw_emac1: slave@1 {
|
2012-11-14 17:07:56 +08:00
|
|
|
phy_id = <&davinci_mdio>, <1>;
|
2013-06-04 04:10:10 +08:00
|
|
|
phy-mode = "rgmii-txid";
|
2012-08-06 13:05:58 +08:00
|
|
|
/* Filled in by U-Boot */
|
|
|
|
mac-address = [ 00 00 00 00 00 00 ];
|
2012-07-30 18:17:14 +08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
(or)
|
|
|
|
mac: ethernet@4A100000 {
|
|
|
|
compatible = "ti,cpsw";
|
|
|
|
ti,hwmods = "cpgmac0";
|
2012-08-06 13:05:58 +08:00
|
|
|
cpdma_channels = <8>;
|
|
|
|
ale_entries = <1024>;
|
|
|
|
bd_ram_size = <0x2000>;
|
|
|
|
no_bd_ram = <0>;
|
|
|
|
rx_descs = <64>;
|
|
|
|
mac_control = <0x20>;
|
|
|
|
slaves = <2>;
|
2013-03-12 07:16:35 +08:00
|
|
|
active_slave = <0>;
|
2012-10-29 16:45:19 +08:00
|
|
|
cpts_clock_mult = <0x80000000>;
|
|
|
|
cpts_clock_shift = <29>;
|
2014-09-29 14:53:17 +08:00
|
|
|
syscon = <&cm>;
|
2012-08-06 13:05:58 +08:00
|
|
|
cpsw_emac0: slave@0 {
|
2012-11-14 17:07:56 +08:00
|
|
|
phy_id = <&davinci_mdio>, <0>;
|
2013-06-04 04:10:10 +08:00
|
|
|
phy-mode = "rgmii-txid";
|
2012-08-06 13:05:58 +08:00
|
|
|
/* Filled in by U-Boot */
|
|
|
|
mac-address = [ 00 00 00 00 00 00 ];
|
2012-07-30 18:17:14 +08:00
|
|
|
};
|
2012-08-06 13:05:58 +08:00
|
|
|
cpsw_emac1: slave@1 {
|
2012-11-14 17:07:56 +08:00
|
|
|
phy_id = <&davinci_mdio>, <1>;
|
2013-06-04 04:10:10 +08:00
|
|
|
phy-mode = "rgmii-txid";
|
2012-08-06 13:05:58 +08:00
|
|
|
/* Filled in by U-Boot */
|
|
|
|
mac-address = [ 00 00 00 00 00 00 ];
|
2012-07-30 18:17:14 +08:00
|
|
|
};
|
|
|
|
};
|