hc
2024-10-12 a5969cabbb4660eab42b6ef0412cbbd1200cf14d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
Properties for an MDIO bus multiplexer consumer device
 
This is a special case of MDIO mux  when MDIO mux is defined as a consumer
of a mux producer device. The mux producer can be of any type like mmio mux
producer, gpio mux producer or generic register based mux producer.
 
Required properties in addition to the MDIO Bus multiplexer properties:
 
- compatible : should be "mmio-mux-multiplexer"
- mux-controls : mux controller node to use for operating the mux
- mdio-parent-bus : phandle to the parent MDIO bus.
 
each child node of mdio bus multiplexer consumer device represent a mdio
bus.
 
for more information please refer
Documentation/devicetree/bindings/mux/mux-controller.txt
and Documentation/devicetree/bindings/net/mdio-mux.txt
 
Example:
In below example the Mux producer and consumer are separate nodes.
 
&i2c0 {
   fpga@66 { // fpga connected to i2c
       compatible = "fsl,lx2160aqds-fpga", "fsl,fpga-qixis-i2c",
                "simple-mfd";
       reg = <0x66>;
 
       mux: mux-controller { // Mux Producer
           compatible = "reg-mux";
           #mux-control-cells = <1>;
           mux-reg-masks = <0x54 0xf8>, /* 0: reg 0x54, bits 7:3 */
                   <0x54 0x07>; /* 1: reg 0x54, bits 2:0 */
       };
   };
};
 
mdio-mux-1 { // Mux consumer
   compatible = "mdio-mux-multiplexer";
   mux-controls = <&mux 0>;
   mdio-parent-bus = <&emdio1>;
   #address-cells = <1>;
   #size-cells = <0>;
 
   mdio@0 {
       reg = <0x0>;
       #address-cells = <1>;
       #size-cells = <0>;
   };
 
   mdio@8 {
       reg = <0x8>;
       #address-cells = <1>;
       #size-cells = <0>;
   };
 
   ..
   ..
};
 
mdio-mux-2 { // Mux consumer
   compatible = "mdio-mux-multiplexer";
   mux-controls = <&mux 1>;
   mdio-parent-bus = <&emdio2>;
   #address-cells = <1>;
   #size-cells = <0>;
 
   mdio@0 {
       reg = <0x0>;
       #address-cells = <1>;
       #size-cells = <0>;
   };
 
   mdio@1 {
       reg = <0x1>;
       #address-cells = <1>;
       #size-cells = <0>;
   };
 
   ..
   ..
};