hc
2024-09-20 cf4ce59b3b70238352c7f1729f0f7223214828ad
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
* APM X-Gene SoC EDAC node
 
EDAC node is defined to describe on-chip error detection and correction.
The follow error types are supported:
 
  memory controller    - Memory controller
  PMD (L1/L2)        - Processor module unit (PMD) L1/L2 cache
  L3            - L3 cache controller
  SoC            - SoC IP's such as Ethernet, SATA, and etc
 
The following section describes the EDAC DT node binding.
 
Required properties:
- compatible        : Shall be "apm,xgene-edac".
- regmap-csw        : Regmap of the CPU switch fabric (CSW) resource.
- regmap-mcba        : Regmap of the MCB-A (memory bridge) resource.
- regmap-mcbb        : Regmap of the MCB-B (memory bridge) resource.
- regmap-efuse        : Regmap of the PMD efuse resource.
- regmap-rb        : Regmap of the register bus resource. This property
             is optional only for compatibility. If the RB
             error conditions are not cleared, it will
             continuously generate interrupt.
- reg            : First resource shall be the CPU bus (PCP) resource.
- interrupts            : Interrupt-specifier for MCU, PMD, L3, or SoC error
             IRQ(s).
 
Required properties for memory controller subnode:
- compatible        : Shall be "apm,xgene-edac-mc".
- reg            : First resource shall be the memory controller unit
                          (MCU) resource.
- memory-controller    : Instance number of the memory controller.
 
Required properties for PMD subnode:
- compatible        : Shall be "apm,xgene-edac-pmd" or
                          "apm,xgene-edac-pmd-v2".
- reg            : First resource shall be the PMD resource.
- pmd-controller    : Instance number of the PMD controller.
 
Required properties for L3 subnode:
- compatible        : Shall be "apm,xgene-edac-l3" or
                          "apm,xgene-edac-l3-v2".
- reg            : First resource shall be the L3 EDAC resource.
 
Required properties for SoC subnode:
- compatible        : Shall be "apm,xgene-edac-soc-v1" for revision 1 or
                          "apm,xgene-edac-l3-soc" for general value reporting
                          only.
- reg            : First resource shall be the SoC EDAC resource.
 
Example:
   csw: csw@7e200000 {
       compatible = "apm,xgene-csw", "syscon";
       reg = <0x0 0x7e200000 0x0 0x1000>;
   };
 
   mcba: mcba@7e700000 {
       compatible = "apm,xgene-mcb", "syscon";
       reg = <0x0 0x7e700000 0x0 0x1000>;
   };
 
   mcbb: mcbb@7e720000 {
       compatible = "apm,xgene-mcb", "syscon";
       reg = <0x0 0x7e720000 0x0 0x1000>;
   };
 
   efuse: efuse@1054a000 {
       compatible = "apm,xgene-efuse", "syscon";
       reg = <0x0 0x1054a000 0x0 0x20>;
   };
 
   rb: rb@7e000000 {
       compatible = "apm,xgene-rb", "syscon";
       reg = <0x0 0x7e000000 0x0 0x10>;
   };
 
   edac@78800000 {
       compatible = "apm,xgene-edac";
       #address-cells = <2>;
       #size-cells = <2>;
       ranges;
       regmap-csw = <&csw>;
       regmap-mcba = <&mcba>;
       regmap-mcbb = <&mcbb>;
       regmap-efuse = <&efuse>;
       regmap-rb = <&rb>;
       reg = <0x0 0x78800000 0x0 0x100>;
       interrupts = <0x0 0x20 0x4>,
                <0x0 0x21 0x4>,
                <0x0 0x27 0x4>;
 
       edacmc@7e800000 {
           compatible = "apm,xgene-edac-mc";
           reg = <0x0 0x7e800000 0x0 0x1000>;
           memory-controller = <0>;
       };
 
       edacpmd@7c000000 {
           compatible = "apm,xgene-edac-pmd";
           reg = <0x0 0x7c000000 0x0 0x200000>;
           pmd-controller = <0>;
       };
 
       edacl3@7e600000 {
           compatible = "apm,xgene-edac-l3";
           reg = <0x0 0x7e600000 0x0 0x1000>;
       };
 
       edacsoc@7e930000 {
           compatible = "apm,xgene-edac-soc-v1";
           reg = <0x0 0x7e930000 0x0 0x1000>;
       };
   };