blob: 0f57f63fcc548697a6d8d036090a42a09aebe247 [file] [log] [blame]
Lawrence Tang079d5812022-07-12 14:15:32 +01001{
Lawrence Tang079d5812022-07-12 14:15:32 +01002 "$schema": "https://json-schema.org/draft/2020-12/schema",
3 "type": "object",
John Chung044afd02024-05-03 19:58:02 +08004 "required": [
5 "validationBits",
6 "errorStatus",
7 "bank",
8 "memoryErrorType",
9 "status",
10 "physicalAddress",
11 "physicalAddressMask",
12 "node",
13 "card",
14 "module",
15 "device",
16 "row",
17 "column",
18 "bitPosition",
19 "rank",
20 "chipID",
21 "requestorID",
22 "responderID",
23 "targetID",
24 "cardSmbiosHandle",
25 "moduleSmbiosHandle"
26 ],
Lawrence Tang079d5812022-07-12 14:15:32 +010027 "additionalProperties": false,
28 "properties": {
29 "validationBits": {
30 "type": "object",
Andrew Adrianced9835a12024-12-05 14:41:42 -080031 "description": "Indicates which fields in this section are valid.",
John Chung044afd02024-05-03 19:58:02 +080032 "required": [
33 "errorStatusValid",
34 "physicalAddressValid",
35 "physicalAddressMaskValid",
36 "nodeValid",
37 "cardValid",
38 "moduleValid",
39 "bankValid",
40 "deviceValid",
41 "rowValid",
42 "columnValid",
43 "rankValid",
44 "bitPositionValid",
45 "chipIDValid",
46 "memoryErrorTypeValid",
47 "statusValid",
48 "requestorIDValid",
49 "responderIDValid",
50 "targetIDValid",
51 "cardHandleValid",
52 "moduleHandleValid",
53 "bankGroupValid",
54 "bankAddressValid"
55 ],
Lawrence Tang079d5812022-07-12 14:15:32 +010056 "properties": {
57 "errorStatusValid": {
58 "type": "boolean"
59 },
60 "physicalAddressValid": {
61 "type": "boolean"
62 },
63 "physicalAddressMaskValid": {
64 "type": "boolean"
65 },
66 "nodeValid": {
67 "type": "boolean"
68 },
69 "cardValid": {
70 "type": "boolean"
71 },
72 "moduleValid": {
73 "type": "boolean"
74 },
75 "bankValid": {
76 "type": "boolean"
77 },
78 "deviceValid": {
79 "type": "boolean"
80 },
81 "rowValid": {
82 "type": "boolean"
83 },
84 "columnValid": {
85 "type": "boolean"
86 },
87 "rankValid": {
88 "type": "boolean"
89 },
90 "bitPositionValid": {
91 "type": "boolean"
92 },
93 "chipIDValid": {
94 "type": "boolean"
95 },
96 "memoryErrorTypeValid": {
97 "type": "boolean"
98 },
99 "statusValid": {
100 "type": "boolean"
101 },
102 "requestorIDValid": {
103 "type": "boolean"
104 },
105 "responderIDValid": {
106 "type": "boolean"
107 },
108 "targetIDValid": {
109 "type": "boolean"
110 },
111 "cardHandleValid": {
112 "type": "boolean"
113 },
114 "moduleHandleValid": {
115 "type": "boolean"
116 },
117 "bankGroupValid": {
118 "type": "boolean"
119 },
120 "bankAddressValid": {
121 "type": "boolean"
122 }
123 }
124 },
125 "errorStatus": {
126 "type": "object",
Andrew Adrianced9835a12024-12-05 14:41:42 -0800127 "description": "Memory error status information.",
Lawrence Tang8a2d7372022-07-12 16:44:49 +0100128 "$ref": "./common/cper-json-error-status.json"
Lawrence Tang079d5812022-07-12 14:15:32 +0100129 },
130 "bank": {
131 "type": "object",
Andrew Adrianced9835a12024-12-05 14:41:42 -0800132 "description": "The bank number of the memory associated with the error.",
Lawrence Tang079d5812022-07-12 14:15:32 +0100133 "oneOf": [
134 {
Aushim Nagarkatti382ad4c2024-09-19 13:39:04 -0700135 "$id": "cper-json-bank0",
Lawrence Tang079d5812022-07-12 14:15:32 +0100136 "type": "object",
137 "required": ["value"],
138 "properties": {
139 "value": {
140 "type": "integer"
141 }
142 }
143 },
144 {
Aushim Nagarkatti382ad4c2024-09-19 13:39:04 -0700145 "$id": "cper-json-bank1",
Lawrence Tang079d5812022-07-12 14:15:32 +0100146 "type": "object",
147 "required": ["address", "group"],
148 "properties": {
149 "address": {
150 "type": "integer"
151 },
152 "group": {
153 "type": "integer"
154 }
155 }
156 }
157 ]
158 },
159 "memoryErrorType": {
160 "type": "object",
Andrew Adrianced9835a12024-12-05 14:41:42 -0800161 "description": "Identifies the type of error that occurred",
Lawrence Tang8a2d7372022-07-12 16:44:49 +0100162 "$ref": "./common/cper-json-nvp.json"
Lawrence Tang079d5812022-07-12 14:15:32 +0100163 },
164 "status": {
165 "type": "object",
Andrew Adrianced9835a12024-12-05 14:41:42 -0800166 "description": "Memory error status information.",
Lawrence Tang079d5812022-07-12 14:15:32 +0100167 "required": ["value", "state"],
168 "properties": {
169 "value": {
170 "type": "integer"
171 },
172 "state": {
173 "type": "string"
174 }
175 }
176 },
177 "physicalAddress": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800178 "type": "integer",
179 "description": "The physical address at which the memory error occurred."
Lawrence Tang079d5812022-07-12 14:15:32 +0100180 },
181 "physicalAddressMask": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800182 "type": "integer",
183 "description": "Defines the valid address bits in the Physical Address field. The mask specifies the granularity of the physical address which is dependent on the hardware implementation factors such as interleaving."
Lawrence Tang079d5812022-07-12 14:15:32 +0100184 },
185 "node": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800186 "type": "integer",
187 "description": "In a multi-node system, this value identifies the node containing the memory in error."
Lawrence Tang079d5812022-07-12 14:15:32 +0100188 },
189 "card": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800190 "type": "integer",
191 "description": "The card number of the memory error location."
Lawrence Tang079d5812022-07-12 14:15:32 +0100192 },
193 "module": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800194 "type": "integer",
195 "description": "The module number of the memory error location."
Lawrence Tang079d5812022-07-12 14:15:32 +0100196 },
197 "device": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800198 "type": "integer",
199 "description": "The device number of the memory associated with the error."
Lawrence Tang079d5812022-07-12 14:15:32 +0100200 },
201 "row": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800202 "type": "integer",
203 "description": "The row number of the memory error location."
Lawrence Tang079d5812022-07-12 14:15:32 +0100204 },
205 "column": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800206 "type": "integer",
207 "description": "The column number of the memory error location."
Lawrence Tang079d5812022-07-12 14:15:32 +0100208 },
209 "bitPosition": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800210 "type": "integer",
211 "description": "The bit position at which the memory error occurred."
Lawrence Tang079d5812022-07-12 14:15:32 +0100212 },
213 "rank": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800214 "type": "integer",
215 "description": "The rank number of the memory error location."
Lawrence Tang079d5812022-07-12 14:15:32 +0100216 },
217 "chipID": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800218 "type": "integer",
219 "description": "The Chip Identification. This is an encoded field used to address the die in 3DS packages."
Lawrence Tang079d5812022-07-12 14:15:32 +0100220 },
221 "requestorID": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800222 "type": "integer",
223 "description": "Hardware address of the device that initiated the transaction that took the error."
Lawrence Tang079d5812022-07-12 14:15:32 +0100224 },
225 "responderID": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800226 "type": "integer",
227 "description": "Hardware address of the device that responded to the transaction."
Lawrence Tang079d5812022-07-12 14:15:32 +0100228 },
229 "targetID": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800230 "type": "integer",
231 "description": "Hardware address of the intended target of the transaction."
Lawrence Tang079d5812022-07-12 14:15:32 +0100232 },
233 "cardSmbiosHandle": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800234 "type": "integer",
235 "description": "This field contains the SMBIOS handle for the Type 16 Memory Array Structure that represents the memory card."
Lawrence Tang079d5812022-07-12 14:15:32 +0100236 },
237 "moduleSmbiosHandle": {
Andrew Adrianced9835a12024-12-05 14:41:42 -0800238 "type": "integer",
239 "description": "This field contains the SMBIOS handle for the Type 17 Memory Device Structure that represents the Memory Module."
Lawrence Tang079d5812022-07-12 14:15:32 +0100240 }
241 }
John Chung044afd02024-05-03 19:58:02 +0800242}