1{
2    "$id": "http://redfish.dmtf.org/schemas/v1/StorageController.v1_8_0.json",
3    "$ref": "#/definitions/StorageController",
4    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5    "copyright": "Copyright 2014-2024 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
6    "definitions": {
7        "ANAAccessState": {
8            "enum": [
9                "Optimized",
10                "NonOptimized",
11                "Inaccessible",
12                "PersistentLoss"
13            ],
14            "enumDescriptions": {
15                "Inaccessible": "Namespaces in this group are inaccessible.  Commands are not able to access user data of namespaces in the ANA group.",
16                "NonOptimized": "Commands processed by a controller that reports this state for an ANA group provide non-optimized access characteristics, such as lower performance or non-optimal use of subsystem resources, to any namespace in the ANA group.",
17                "Optimized": "Commands processed by a controller provide optimized access to any namespace in the ANA group.",
18                "PersistentLoss": "The group is persistently inaccessible.  Commands are persistently not able to access user data of namespaces in the ANA group."
19            },
20            "type": "string"
21        },
22        "ANACharacteristics": {
23            "additionalProperties": false,
24            "description": "The ANA characteristics and volume information for a storage controller.",
25            "longDescription": "This type shall contain the ANA characteristics and volume information for a storage controller.",
26            "patternProperties": {
27                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
28                    "description": "This property shall specify a valid odata or Redfish property.",
29                    "type": [
30                        "array",
31                        "boolean",
32                        "integer",
33                        "number",
34                        "null",
35                        "object",
36                        "string"
37                    ]
38                }
39            },
40            "properties": {
41                "AccessState": {
42                    "anyOf": [
43                        {
44                            "$ref": "#/definitions/ANAAccessState"
45                        },
46                        {
47                            "type": "null"
48                        }
49                    ],
50                    "description": "Reported ANA access state.",
51                    "longDescription": "This property shall contain the reported ANA access state.",
52                    "readonly": true
53                },
54                "Volume": {
55                    "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume",
56                    "description": "The specified volume.",
57                    "longDescription": "This property shall contain a link to a resource of type `Volume`.",
58                    "readonly": true
59                }
60            },
61            "type": "object"
62        },
63        "Actions": {
64            "additionalProperties": false,
65            "description": "The available actions for this resource.",
66            "longDescription": "This type shall contain the available actions for this resource.",
67            "patternProperties": {
68                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
69                    "description": "This property shall specify a valid odata or Redfish property.",
70                    "type": [
71                        "array",
72                        "boolean",
73                        "integer",
74                        "number",
75                        "null",
76                        "object",
77                        "string"
78                    ]
79                }
80            },
81            "properties": {
82                "#StorageController.AttachNamespaces": {
83                    "$ref": "#/definitions/AttachNamespaces"
84                },
85                "#StorageController.DetachNamespaces": {
86                    "$ref": "#/definitions/DetachNamespaces"
87                },
88                "#StorageController.SecurityReceive": {
89                    "$ref": "#/definitions/SecurityReceive"
90                },
91                "#StorageController.SecuritySend": {
92                    "$ref": "#/definitions/SecuritySend"
93                },
94                "Oem": {
95                    "$ref": "#/definitions/OemActions",
96                    "description": "The available OEM-specific actions for this resource.",
97                    "longDescription": "This property shall contain the available OEM-specific actions for this resource."
98                }
99            },
100            "type": "object"
101        },
102        "AttachDetachNamespacesResponse": {
103            "additionalProperties": false,
104            "description": "The response body for the `AttachNamespaces` and `DetachNamespaces` actions.",
105            "longDescription": "This type shall contain the properties found in the response body for the `AttachNamespaces` and `DetachNamespaces` actions.",
106            "patternProperties": {
107                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
108                    "description": "This property shall specify a valid odata or Redfish property.",
109                    "type": [
110                        "array",
111                        "boolean",
112                        "integer",
113                        "number",
114                        "null",
115                        "object",
116                        "string"
117                    ]
118                }
119            },
120            "properties": {
121                "AttachedVolumes": {
122                    "description": "An array of links to volumes that are attached to this controller instance.",
123                    "items": {
124                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume"
125                    },
126                    "longDescription": "This property shall contain an array of links to resources of type `Volume` that are attached to this instance of storage controller.",
127                    "readonly": true,
128                    "type": "array",
129                    "versionAdded": "v1_7_0"
130                },
131                "AttachedVolumes@odata.count": {
132                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
133                }
134            },
135            "required": [
136                "AttachedVolumes"
137            ],
138            "type": "object"
139        },
140        "AttachNamespaces": {
141            "actionResponse": {
142                "$ref": "#/definitions/AttachDetachNamespacesResponse"
143            },
144            "additionalProperties": false,
145            "description": "This action attaches referenced namespaces to the storage controller.  Attached namespaces are added to the `AttachedVolumes` property in `Links`.",
146            "longDescription": "This action shall attach referenced namespaces to the storage controller.  Services shall add the attached namespaces to the `AttachedVolumes` property in `Links`.",
147            "parameters": {
148                "Namespaces": {
149                    "description": "The namespaces to attach to the storage controller.",
150                    "items": {
151                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume"
152                    },
153                    "longDescription": "This parameter shall contain an array of links to resources of type `Volume` that represent the namespaces to attach to the storage controller.",
154                    "requiredParameter": true,
155                    "type": "array"
156                }
157            },
158            "patternProperties": {
159                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
160                    "description": "This property shall specify a valid odata or Redfish property.",
161                    "type": [
162                        "array",
163                        "boolean",
164                        "integer",
165                        "number",
166                        "null",
167                        "object",
168                        "string"
169                    ]
170                }
171            },
172            "properties": {
173                "target": {
174                    "description": "Link to invoke action",
175                    "format": "uri-reference",
176                    "type": "string"
177                },
178                "title": {
179                    "description": "Friendly action name",
180                    "type": "string"
181                }
182            },
183            "type": "object",
184            "versionAdded": "v1_7_0"
185        },
186        "CacheSummary": {
187            "additionalProperties": false,
188            "description": "This type describes the cache memory of the storage controller in general detail.",
189            "longDescription": "This type shall contain properties that describe the cache memory for a storage controller.",
190            "patternProperties": {
191                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
192                    "description": "This property shall specify a valid odata or Redfish property.",
193                    "type": [
194                        "array",
195                        "boolean",
196                        "integer",
197                        "number",
198                        "null",
199                        "object",
200                        "string"
201                    ]
202                }
203            },
204            "properties": {
205                "PersistentCacheSizeMiB": {
206                    "description": "The portion of the cache memory that is persistent, measured in MiB.",
207                    "longDescription": "This property shall contain the amount of cache memory that is persistent as measured in mebibytes.  This size shall be less than or equal to the `TotalCacheSizeMiB`.",
208                    "minimum": 0,
209                    "readonly": true,
210                    "type": [
211                        "integer",
212                        "null"
213                    ],
214                    "units": "MiBy"
215                },
216                "Status": {
217                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
218                    "description": "The status and health of the resource and its subordinate or dependent resources.",
219                    "longDescription": "This property shall contain any status or health properties of the resource."
220                },
221                "TotalCacheSizeMiB": {
222                    "description": "The total configured cache memory, measured in MiB.",
223                    "longDescription": "This property shall contain the amount of configured cache memory as measured in mebibytes.",
224                    "minimum": 0,
225                    "readonly": true,
226                    "type": [
227                        "integer",
228                        "null"
229                    ],
230                    "units": "MiBy"
231                }
232            },
233            "required": [
234                "TotalCacheSizeMiB"
235            ],
236            "type": "object"
237        },
238        "DetachNamespaces": {
239            "actionResponse": {
240                "$ref": "#/definitions/AttachDetachNamespacesResponse"
241            },
242            "additionalProperties": false,
243            "description": "This action detaches referenced namespaces from the storage controller.  Detached namespaces are removed from the `AttachedVolumes` property in `Links`.",
244            "longDescription": "This action shall detach referenced namespaces from the storage controller.  Services shall remove the detached namespaces from the `AttachedVolumes` property in `Links`.",
245            "parameters": {
246                "Namespaces": {
247                    "description": "The namespaces to detach from the storage controller.",
248                    "items": {
249                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume"
250                    },
251                    "longDescription": "This parameter shall contain an array of links to resources of type `Volume` that represent the namespaces to detach from the storage controller.",
252                    "requiredParameter": true,
253                    "type": "array"
254                }
255            },
256            "patternProperties": {
257                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
258                    "description": "This property shall specify a valid odata or Redfish property.",
259                    "type": [
260                        "array",
261                        "boolean",
262                        "integer",
263                        "number",
264                        "null",
265                        "object",
266                        "string"
267                    ]
268                }
269            },
270            "properties": {
271                "target": {
272                    "description": "Link to invoke action",
273                    "format": "uri-reference",
274                    "type": "string"
275                },
276                "title": {
277                    "description": "Friendly action name",
278                    "type": "string"
279                }
280            },
281            "type": "object",
282            "versionAdded": "v1_7_0"
283        },
284        "Links": {
285            "additionalProperties": false,
286            "description": "The links to other resources that are related to this resource.",
287            "longDescription": "This Redfish Specification-described type shall contain links to resources that are related to but are not contained by, or subordinate to, this resource.",
288            "patternProperties": {
289                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
290                    "description": "This property shall specify a valid odata or Redfish property.",
291                    "type": [
292                        "array",
293                        "boolean",
294                        "integer",
295                        "number",
296                        "null",
297                        "object",
298                        "string"
299                    ]
300                }
301            },
302            "properties": {
303                "AttachedVolumes": {
304                    "description": "An array of links to volumes that are attached to this controller instance.",
305                    "items": {
306                        "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/Volume"
307                    },
308                    "longDescription": "This property shall contain an array of links to resources of type `Volume` that are attached to this instance of storage controller.",
309                    "readonly": true,
310                    "type": "array"
311                },
312                "AttachedVolumes@odata.count": {
313                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
314                },
315                "Batteries": {
316                    "description": "The batteries that provide power to this storage controller during a power-loss event.",
317                    "items": {
318                        "$ref": "http://redfish.dmtf.org/schemas/v1/Battery.json#/definitions/Battery"
319                    },
320                    "longDescription": "This property shall contain an array of links to resources of type `Battery` that represent the batteries that provide power to this storage controller during a power-loss event, such as with battery-backed RAID controllers.  This property shall not be present if the batteries power the containing chassis as a whole rather than the individual storage controller.",
321                    "readonly": true,
322                    "type": "array",
323                    "versionAdded": "v1_6_0"
324                },
325                "Batteries@odata.count": {
326                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
327                },
328                "Endpoints": {
329                    "description": "An array of links to the endpoints that connect to this controller.",
330                    "items": {
331                        "$ref": "http://redfish.dmtf.org/schemas/v1/Endpoint.json#/definitions/Endpoint"
332                    },
333                    "longDescription": "This property shall contain an array of links to resources of type `Endpoint` with which this controller is associated.",
334                    "readonly": true,
335                    "type": "array"
336                },
337                "Endpoints@odata.count": {
338                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
339                },
340                "NVMeDiscoveredSubsystems": {
341                    "description": "The NVMe subsystems discovered by this discovery controller.",
342                    "items": {
343                        "$ref": "http://redfish.dmtf.org/schemas/v1/Storage.json#/definitions/Storage"
344                    },
345                    "longDescription": "This property shall contain an array of links to resources of type `Storage` that represent the NVMe subsystems discovered by this discovery controller.  This property shall only be present if `ControllerType` in `NVMeControllerProperties` contains `Discovery`.",
346                    "readonly": true,
347                    "type": "array",
348                    "versionAdded": "v1_7_0"
349                },
350                "NVMeDiscoveredSubsystems@odata.count": {
351                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
352                },
353                "NetworkDeviceFunctions": {
354                    "description": "The network device functions that provide connectivity to this controller.",
355                    "items": {
356                        "$ref": "http://redfish.dmtf.org/schemas/v1/NetworkDeviceFunction.json#/definitions/NetworkDeviceFunction"
357                    },
358                    "longDescription": "This property shall contain an array of links to resources of type `NetworkDeviceFunction` that represent the devices that provide connectivity to this controller.",
359                    "readonly": true,
360                    "type": "array",
361                    "versionAdded": "v1_3_0"
362                },
363                "NetworkDeviceFunctions@odata.count": {
364                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
365                },
366                "Oem": {
367                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
368                    "description": "The OEM extension property.",
369                    "longDescription": "This property shall contain the OEM extensions.  All values for properties contained in this object shall conform to the Redfish Specification-described requirements."
370                },
371                "PCIeFunctions": {
372                    "description": "An array of links to the PCIe functions that the storage controller produces.",
373                    "items": {
374                        "$ref": "http://redfish.dmtf.org/schemas/v1/PCIeFunction.json#/definitions/PCIeFunction"
375                    },
376                    "longDescription": "This property shall contain an array of links to resources of type `PCIeFunction` that represent the PCIe functions associated with this resource.",
377                    "readonly": true,
378                    "type": "array"
379                },
380                "PCIeFunctions@odata.count": {
381                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
382                }
383            },
384            "type": "object"
385        },
386        "NVMeControllerAttributes": {
387            "additionalProperties": false,
388            "description": "The NVMe controller attributes for a storage controller.",
389            "longDescription": "This type shall contain NVMe controller attributes for a storage controller.",
390            "patternProperties": {
391                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
392                    "description": "This property shall specify a valid odata or Redfish property.",
393                    "type": [
394                        "array",
395                        "boolean",
396                        "integer",
397                        "number",
398                        "null",
399                        "object",
400                        "string"
401                    ]
402                }
403            },
404            "properties": {
405                "ReportsNamespaceGranularity": {
406                    "description": "Indicates whether or not the controller supports reporting of Namespace Granularity.",
407                    "longDescription": "This property shall indicate whether or not the controller supports reporting of Namespace Granularity.",
408                    "readonly": true,
409                    "type": [
410                        "boolean",
411                        "null"
412                    ]
413                },
414                "ReportsUUIDList": {
415                    "description": "Indicates whether or not the controller supports reporting of a UUID list.",
416                    "longDescription": "This property shall indicate whether or not the controller supports reporting of a UUID list.",
417                    "readonly": true,
418                    "type": [
419                        "boolean",
420                        "null"
421                    ]
422                },
423                "Supports128BitHostId": {
424                    "description": "Indicates whether or not the controller supports a 128-bit Host Identifier.",
425                    "longDescription": "This property shall indicate whether or not the controller supports a 128-bit Host Identifier.",
426                    "readonly": true,
427                    "type": [
428                        "boolean",
429                        "null"
430                    ]
431                },
432                "SupportsEnduranceGroups": {
433                    "description": "Indicates whether or not the controller supports Endurance Groups.",
434                    "longDescription": "This property shall indicate whether or not the controller supports Endurance Groups.",
435                    "readonly": true,
436                    "type": [
437                        "boolean",
438                        "null"
439                    ]
440                },
441                "SupportsExceedingPowerOfNonOperationalState": {
442                    "description": "Indicates whether or not the controller supports exceeding Power of Non-Operational State in order to execute controller-initiated background operations in a non-operational power state.",
443                    "longDescription": "This property shall indicate whether or not the controller supports exceeding Power of Non-Operational State in order to execute controller-initiated background operations in a non-operational power state.",
444                    "readonly": true,
445                    "type": [
446                        "boolean",
447                        "null"
448                    ]
449                },
450                "SupportsNVMSets": {
451                    "description": "Indicates whether or not the controller supports NVM Sets.",
452                    "longDescription": "This property shall indicate whether or not the controller supports NVM Sets.",
453                    "readonly": true,
454                    "type": [
455                        "boolean",
456                        "null"
457                    ]
458                },
459                "SupportsPredictableLatencyMode": {
460                    "description": "Indicates whether or not the controller supports Predictable Latency Mode.",
461                    "longDescription": "This property shall indicate whether or not the controller supports Predictable Latency Mode.",
462                    "readonly": true,
463                    "type": [
464                        "boolean",
465                        "null"
466                    ]
467                },
468                "SupportsReadRecoveryLevels": {
469                    "description": "Indicates whether or not the controller supports Read Recovery Levels.",
470                    "longDescription": "This property shall indicate whether or not the controller supports Read Recovery Levels.",
471                    "readonly": true,
472                    "type": [
473                        "boolean",
474                        "null"
475                    ]
476                },
477                "SupportsReservations": {
478                    "description": "Indicates if the controller supports reservations.",
479                    "longDescription": "This property shall indicate if the controller supports reservations.",
480                    "readonly": true,
481                    "type": [
482                        "boolean",
483                        "null"
484                    ],
485                    "versionAdded": "v1_2_0"
486                },
487                "SupportsSQAssociations": {
488                    "description": "Indicates whether or not the controller supports SQ Associations.",
489                    "longDescription": "This property shall indicate whether or not the controller supports SQ Associations.",
490                    "readonly": true,
491                    "type": [
492                        "boolean",
493                        "null"
494                    ]
495                },
496                "SupportsTrafficBasedKeepAlive": {
497                    "description": "Indicates whether or not the controller supports restarting the Keep Alive Timer if traffic is processed from an admin command or I/O during a Keep Alive Timeout interval.",
498                    "longDescription": "This property shall indicate whether or not the controller supports restarting the Keep Alive Timer if traffic is processed from an admin command or I/O during a Keep Alive Timeout interval.",
499                    "readonly": true,
500                    "type": [
501                        "boolean",
502                        "null"
503                    ]
504                }
505            },
506            "type": "object"
507        },
508        "NVMeControllerProperties": {
509            "additionalProperties": false,
510            "description": "NVMe-related properties for a storage controller.",
511            "longDescription": "This type shall contain NVMe-related properties for a storage controller.",
512            "patternProperties": {
513                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
514                    "description": "This property shall specify a valid odata or Redfish property.",
515                    "type": [
516                        "array",
517                        "boolean",
518                        "integer",
519                        "number",
520                        "null",
521                        "object",
522                        "string"
523                    ]
524                }
525            },
526            "properties": {
527                "ANACharacteristics": {
528                    "description": "The ANA characteristics and volume information.",
529                    "items": {
530                        "anyOf": [
531                            {
532                                "$ref": "#/definitions/ANACharacteristics"
533                            },
534                            {
535                                "type": "null"
536                            }
537                        ]
538                    },
539                    "longDescription": "This property shall contain the ANA characteristics and volume information.",
540                    "type": "array"
541                },
542                "AllocatedCompletionQueues": {
543                    "description": "The number of I/O completion queues allocated to this NVMe I/O controller.",
544                    "longDescription": "This property shall contain the number of I/O completion queues allocated to this NVMe I/O controller.",
545                    "readonly": true,
546                    "type": [
547                        "integer",
548                        "null"
549                    ],
550                    "versionAdded": "v1_4_0"
551                },
552                "AllocatedSubmissionQueues": {
553                    "description": "The number of I/O submission queues allocated to this NVMe I/O controller.",
554                    "longDescription": "This property shall contain the number of I/O submission queues allocated to this NVMe I/O controller.",
555                    "readonly": true,
556                    "type": [
557                        "integer",
558                        "null"
559                    ],
560                    "versionAdded": "v1_4_0"
561                },
562                "ControllerType": {
563                    "anyOf": [
564                        {
565                            "$ref": "#/definitions/NVMeControllerType"
566                        },
567                        {
568                            "type": "null"
569                        }
570                    ],
571                    "description": "The type of NVMe controller.",
572                    "longDescription": "This property shall contain the type of NVMe controller.",
573                    "readonly": true
574                },
575                "MaxAttachedNamespaces": {
576                    "description": "The maximum number of attached namespaces allowed by this NVMe I/O controller.",
577                    "longDescription": "This property shall contain the maximum number of attached namespaces allowed by this NVMe I/O controller.",
578                    "minimum": 0,
579                    "readonly": true,
580                    "type": [
581                        "integer",
582                        "null"
583                    ],
584                    "versionAdded": "v1_8_0"
585                },
586                "MaxQueueSize": {
587                    "description": "The maximum individual queue size that an NVMe I/O controller supports.",
588                    "longDescription": "This property shall contain the maximum individual queue entry size supported per queue.  This is a zero-based value, where the minimum value is one, indicating two entries.  For PCIe, this applies to both submission and completion queues.  For NVMe-oF, this applies only to submission queues.",
589                    "readonly": true,
590                    "type": [
591                        "integer",
592                        "null"
593                    ]
594                },
595                "NVMeControllerAttributes": {
596                    "anyOf": [
597                        {
598                            "$ref": "#/definitions/NVMeControllerAttributes"
599                        },
600                        {
601                            "type": "null"
602                        }
603                    ],
604                    "description": "The NVMe controller attributes.",
605                    "longDescription": "This property shall contain NVMe controller attributes."
606                },
607                "NVMeSMARTCriticalWarnings": {
608                    "anyOf": [
609                        {
610                            "$ref": "#/definitions/NVMeSMARTCriticalWarnings"
611                        },
612                        {
613                            "type": "null"
614                        }
615                    ],
616                    "description": "The NVMe SMART Critical Warnings for this storage controller.  This property contains possible triggers for the predictive drive failure warning for the corresponding drive.",
617                    "longDescription": "This property shall contain the NVMe SMART Critical Warnings for this storage controller.  This property can contain possible triggers for the predictive drive failure warning for the corresponding drive."
618                },
619                "NVMeVersion": {
620                    "description": "The version of the NVMe Base Specification supported.",
621                    "longDescription": "This property shall contain the version of the NVMe Base Specification supported.",
622                    "readonly": true,
623                    "type": [
624                        "string",
625                        "null"
626                    ]
627                }
628            },
629            "type": "object"
630        },
631        "NVMeControllerType": {
632            "enum": [
633                "Admin",
634                "Discovery",
635                "IO"
636            ],
637            "enumDescriptions": {
638                "Admin": "The NVMe controller is an admin controller.",
639                "Discovery": "The NVMe controller is a discovery controller.",
640                "IO": "The NVMe controller is an I/O controller."
641            },
642            "type": "string"
643        },
644        "NVMeSMARTCriticalWarnings": {
645            "additionalProperties": false,
646            "description": "The NVMe SMART Critical Warnings for a storage controller.",
647            "longDescription": "This type shall contain the NVMe SMART Critical Warnings for a storage controller.",
648            "patternProperties": {
649                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
650                    "description": "This property shall specify a valid odata or Redfish property.",
651                    "type": [
652                        "array",
653                        "boolean",
654                        "integer",
655                        "number",
656                        "null",
657                        "object",
658                        "string"
659                    ]
660                }
661            },
662            "properties": {
663                "MediaInReadOnly": {
664                    "description": "Indicates the media has been placed in read-only mode.",
665                    "longDescription": "This property shall indicate the media has been placed in read-only mode.  This is not set when the read-only condition of the media is a result of a change in the write protection state of a namespace.",
666                    "readonly": true,
667                    "type": [
668                        "boolean",
669                        "null"
670                    ]
671                },
672                "OverallSubsystemDegraded": {
673                    "description": "Indicates that the NVM subsystem reliability has been compromised.",
674                    "longDescription": "This property shall indicate that the NVM subsystem reliability has been compromised.",
675                    "readonly": true,
676                    "type": [
677                        "boolean",
678                        "null"
679                    ]
680                },
681                "PMRUnreliable": {
682                    "description": "The Persistent Memory Region has become unreliable.",
683                    "longDescription": "This property shall indicate that the Persistent Memory Region has become unreliable.  PCIe memory reads can return invalid data or generate poisoned PCIe TLP(s).  Persistent Memory Region memory writes might not update memory or might update memory with undefined data.  The Persistent Memory Region might also have become non-persistent.",
684                    "readonly": true,
685                    "type": [
686                        "boolean",
687                        "null"
688                    ]
689                },
690                "PowerBackupFailed": {
691                    "description": "Indicates that the volatile memory backup device has failed.",
692                    "longDescription": "This property shall indicate that the volatile memory backup device has failed.",
693                    "readonly": true,
694                    "type": [
695                        "boolean",
696                        "null"
697                    ]
698                },
699                "SpareCapacityWornOut": {
700                    "description": "Indicates that the available spare capacity has fallen below the threshold.",
701                    "longDescription": "This property shall indicate that the available spare capacity has fallen below the threshold.",
702                    "readonly": true,
703                    "type": [
704                        "boolean",
705                        "null"
706                    ]
707                }
708            },
709            "type": "object"
710        },
711        "OemActions": {
712            "additionalProperties": true,
713            "description": "The available OEM-specific actions for this resource.",
714            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
715            "patternProperties": {
716                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
717                    "description": "This property shall specify a valid odata or Redfish property.",
718                    "type": [
719                        "array",
720                        "boolean",
721                        "integer",
722                        "number",
723                        "null",
724                        "object",
725                        "string"
726                    ]
727                }
728            },
729            "properties": {},
730            "type": "object"
731        },
732        "Rates": {
733            "additionalProperties": false,
734            "description": "This type describes the various controller rates used for processes such as volume rebuild or consistency checks.",
735            "longDescription": "This type shall contain all the rate settings available on the controller.",
736            "patternProperties": {
737                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
738                    "description": "This property shall specify a valid odata or Redfish property.",
739                    "type": [
740                        "array",
741                        "boolean",
742                        "integer",
743                        "number",
744                        "null",
745                        "object",
746                        "string"
747                    ]
748                }
749            },
750            "properties": {
751                "ConsistencyCheckRatePercent": {
752                    "description": "The percentage of controller resources used for performing a data consistency check on volumes.",
753                    "longDescription": "This property shall contain the percentage, `0` to `100`, of controller resources used for checking data consistency on volumes.",
754                    "maximum": 100,
755                    "minimum": 0,
756                    "readonly": false,
757                    "type": [
758                        "integer",
759                        "null"
760                    ],
761                    "units": "%"
762                },
763                "RebuildRatePercent": {
764                    "description": "The percentage of controller resources used for rebuilding/repairing volumes.",
765                    "longDescription": "This property shall contain the percentage, `0` to `100`, of controller resources used for rebuilding volumes.",
766                    "maximum": 100,
767                    "minimum": 0,
768                    "readonly": false,
769                    "type": [
770                        "integer",
771                        "null"
772                    ],
773                    "units": "%"
774                },
775                "TransformationRatePercent": {
776                    "description": "The percentage of controller resources used for transforming volumes from one configuration to another.",
777                    "longDescription": "This property shall contain the percentage, `0` to `100`, of controller resources used for transforming volumes.",
778                    "maximum": 100,
779                    "minimum": 0,
780                    "readonly": false,
781                    "type": [
782                        "integer",
783                        "null"
784                    ],
785                    "units": "%"
786                }
787            },
788            "type": "object"
789        },
790        "SecurityReceive": {
791            "actionResponse": {
792                "$ref": "#/definitions/SecurityReceiveResponse"
793            },
794            "additionalProperties": false,
795            "description": "This action transfers security protocol data from the controller.  The data transferred from the controller contains the status and data result of one or more `SecuritySend` action requests that were previously submitted to the controller.",
796            "longDescription": "This action shall transfer security protocol data from the controller.  The contents of the request are specified by the 'SECURITY PROTOCOL IN command' section of the SPC-5 Specification.",
797            "parameters": {
798                "AllocationLength": {
799                    "description": "Allocated size for received data.",
800                    "longDescription": "This parameter shall contain the allocated size of the received data, which imposes a maximum length of the data.  The response may contain padding to meet this length.",
801                    "requiredParameter": true,
802                    "type": "integer"
803                },
804                "SecurityProtocol": {
805                    "description": "The security protocol number.",
806                    "longDescription": "This parameter shall contain the numeric identifier of the security protocol, as defined by the 'SECURITY PROTOCOL field in SECURITY PROTOCOL IN command' table of the SPC-5 Specification, and possibly extended by transport-specific standards.  Services shall only accept the values `0`, `1`, or `2`.",
807                    "requiredParameter": true,
808                    "type": "integer"
809                },
810                "SecurityProtocolSpecific": {
811                    "description": "The security protocol-specific parameter.",
812                    "longDescription": "This parameter shall contain the security protocol-specific data for the transfer operation.  The value is defined by the protocol specified by the SecurityProtocolSpecific parameter.",
813                    "requiredParameter": true,
814                    "type": "integer"
815                }
816            },
817            "patternProperties": {
818                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
819                    "description": "This property shall specify a valid odata or Redfish property.",
820                    "type": [
821                        "array",
822                        "boolean",
823                        "integer",
824                        "number",
825                        "null",
826                        "object",
827                        "string"
828                    ]
829                }
830            },
831            "properties": {
832                "target": {
833                    "description": "Link to invoke action",
834                    "format": "uri-reference",
835                    "type": "string"
836                },
837                "title": {
838                    "description": "Friendly action name",
839                    "type": "string"
840                }
841            },
842            "type": "object",
843            "versionAdded": "v1_7_0"
844        },
845        "SecurityReceiveResponse": {
846            "additionalProperties": false,
847            "description": "The security data transferred from a controller.",
848            "longDescription": "This object shall contain the security data transferred from a controller.",
849            "patternProperties": {
850                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
851                    "description": "This property shall specify a valid odata or Redfish property.",
852                    "type": [
853                        "array",
854                        "boolean",
855                        "integer",
856                        "number",
857                        "null",
858                        "object",
859                        "string"
860                    ]
861                }
862            },
863            "properties": {
864                "Data": {
865                    "description": "The Base64-encoded security protocol data.",
866                    "longDescription": "This property shall contain a Base64-encoded string of the security protocol data transferred from a controller.",
867                    "readonly": true,
868                    "type": "string",
869                    "versionAdded": "v1_7_0"
870                }
871            },
872            "type": "object"
873        },
874        "SecuritySend": {
875            "additionalProperties": false,
876            "description": "This action transfers security protocol data to the controller.  The data transferred to the controller contains security protocol-specific commands to be performed by the controller.",
877            "longDescription": "This action shall transfer security protocol data to the controller.  The contents of the request are specified by the 'SECURITY PROTOCOL OUT command' section of the SPC-5 Specification.",
878            "parameters": {
879                "Data": {
880                    "description": "The data to transfer.",
881                    "longDescription": "This parameter shall contain a Base64-encoded string of the security protocol data to transfer.",
882                    "requiredParameter": true,
883                    "type": "string"
884                },
885                "SecurityProtocol": {
886                    "description": "The security protocol number.",
887                    "longDescription": "This parameter shall contain the numeric identifier of the security protocol, as defined by the 'SECURITY PROTOCOL field in SECURITY PROTOCOL OUT command' table of the SPC-5 Specification, and possibly extended by transport-specific standards.  Services shall only accept the values `1` or `2`.",
888                    "requiredParameter": true,
889                    "type": "integer"
890                },
891                "SecurityProtocolSpecific": {
892                    "description": "The security protocol-specific parameter.",
893                    "longDescription": "This parameter shall contain the security protocol-specific data for the transfer operation.  The value is defined by the protocol specified by the SecurityProtocolSpecific parameter.",
894                    "requiredParameter": true,
895                    "type": "integer"
896                }
897            },
898            "patternProperties": {
899                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
900                    "description": "This property shall specify a valid odata or Redfish property.",
901                    "type": [
902                        "array",
903                        "boolean",
904                        "integer",
905                        "number",
906                        "null",
907                        "object",
908                        "string"
909                    ]
910                }
911            },
912            "properties": {
913                "target": {
914                    "description": "Link to invoke action",
915                    "format": "uri-reference",
916                    "type": "string"
917                },
918                "title": {
919                    "description": "Friendly action name",
920                    "type": "string"
921                }
922            },
923            "type": "object",
924            "versionAdded": "v1_7_0"
925        },
926        "StorageController": {
927            "additionalProperties": false,
928            "description": "The `StorageController` schema describes a storage controller and its properties.  A storage controller represents a physical or virtual storage device that produces volumes.",
929            "longDescription": "This resource shall represent a storage controller in the Redfish Specification.",
930            "patternProperties": {
931                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
932                    "description": "This property shall specify a valid odata or Redfish property.",
933                    "type": [
934                        "array",
935                        "boolean",
936                        "integer",
937                        "number",
938                        "null",
939                        "object",
940                        "string"
941                    ]
942                }
943            },
944            "properties": {
945                "@odata.context": {
946                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
947                },
948                "@odata.etag": {
949                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
950                },
951                "@odata.id": {
952                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
953                },
954                "@odata.type": {
955                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
956                },
957                "Actions": {
958                    "$ref": "#/definitions/Actions",
959                    "description": "The available actions for this resource.",
960                    "longDescription": "This property shall contain the available actions for this resource."
961                },
962                "Assembly": {
963                    "$ref": "http://redfish.dmtf.org/schemas/v1/Assembly.json#/definitions/Assembly",
964                    "description": "The link to the assembly associated with this storage controller.",
965                    "longDescription": "This property shall contain a link to a resource of type `Assembly`.",
966                    "readonly": true
967                },
968                "AssetTag": {
969                    "description": "The user-assigned asset tag for this storage controller.",
970                    "longDescription": "This property shall track the storage controller for inventory purposes.",
971                    "readonly": false,
972                    "type": [
973                        "string",
974                        "null"
975                    ]
976                },
977                "CacheSummary": {
978                    "$ref": "#/definitions/CacheSummary",
979                    "description": "The cache memory of the storage controller in general detail.",
980                    "longDescription": "This property shall contain properties that describe the cache memory for this resource."
981                },
982                "Certificates": {
983                    "$ref": "http://redfish.dmtf.org/schemas/v1/CertificateCollection.json#/definitions/CertificateCollection",
984                    "description": "The link to a collection of certificates for device identity and attestation.",
985                    "longDescription": "This property shall contain a link to a resource collection of type `CertificateCollection` that contains certificates for device identity and attestation.",
986                    "readonly": true,
987                    "versionAdded": "v1_1_0"
988                },
989                "ControllerRates": {
990                    "$ref": "#/definitions/Rates",
991                    "description": "This property describes the various controller rates used for processes such as volume rebuild or consistency checks.",
992                    "longDescription": "This object shall contain all the rate settings available on the controller."
993                },
994                "Description": {
995                    "anyOf": [
996                        {
997                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
998                        },
999                        {
1000                            "type": "null"
1001                        }
1002                    ],
1003                    "readonly": true
1004                },
1005                "EnvironmentMetrics": {
1006                    "$ref": "http://redfish.dmtf.org/schemas/v1/EnvironmentMetrics.json#/definitions/EnvironmentMetrics",
1007                    "description": "The link to the environment metrics for this storage controller.",
1008                    "longDescription": "This property shall contain a link to a resource of type `EnvironmentMetrics` that represents the environment metrics for this storage controller.",
1009                    "readonly": true,
1010                    "versionAdded": "v1_2_0"
1011                },
1012                "FirmwareVersion": {
1013                    "description": "The firmware version of this storage controller.",
1014                    "longDescription": "This property shall contain the firmware version as defined by the manufacturer for the associated storage controller.",
1015                    "readonly": true,
1016                    "type": [
1017                        "string",
1018                        "null"
1019                    ]
1020                },
1021                "Id": {
1022                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
1023                    "readonly": true
1024                },
1025                "Identifiers": {
1026                    "description": "The durable names for the storage controller.",
1027                    "items": {
1028                        "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Identifier"
1029                    },
1030                    "longDescription": "This property shall contain a list of all known durable names for the associated storage controller.",
1031                    "type": "array"
1032                },
1033                "Links": {
1034                    "$ref": "#/definitions/Links",
1035                    "description": "The links to other resources that are related to this resource.",
1036                    "longDescription": "This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource."
1037                },
1038                "Location": {
1039                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Location",
1040                    "description": "The location of the storage controller.",
1041                    "longDescription": "This property shall contain the location information of the associated storage controller."
1042                },
1043                "Manufacturer": {
1044                    "description": "The manufacturer of this storage controller.",
1045                    "longDescription": "This property shall contain the name of the organization responsible for producing the storage controller.  This organization may be the entity from which the storage controller is purchased, but this is not necessarily true.",
1046                    "readonly": true,
1047                    "type": [
1048                        "string",
1049                        "null"
1050                    ]
1051                },
1052                "Measurements": {
1053                    "deprecated": "This property has been deprecated in favor of the `ComponentIntegrity` resource.",
1054                    "description": "An array of DSP0274-defined measurement blocks.",
1055                    "items": {
1056                        "$ref": "http://redfish.dmtf.org/schemas/v1/SoftwareInventory.json#/definitions/MeasurementBlock"
1057                    },
1058                    "longDescription": "This property shall contain an array of DSP0274-defined measurement blocks.",
1059                    "type": "array",
1060                    "versionAdded": "v1_1_0",
1061                    "versionDeprecated": "v1_5_0"
1062                },
1063                "Metrics": {
1064                    "anyOf": [
1065                        {
1066                            "$ref": "http://redfish.dmtf.org/schemas/v1/StorageControllerMetrics.json#/definitions/StorageControllerMetrics"
1067                        },
1068                        {
1069                            "type": "null"
1070                        }
1071                    ],
1072                    "description": "The link to the metrics associated with this storage controller.",
1073                    "longDescription": "This property shall contain a link to the metrics associated with this storage controller.",
1074                    "readonly": true,
1075                    "versionAdded": "v1_7_0"
1076                },
1077                "Model": {
1078                    "description": "The model number for the storage controller.",
1079                    "longDescription": "This property shall contain the name by which the manufacturer generally refers to the storage controller.",
1080                    "readonly": true,
1081                    "type": [
1082                        "string",
1083                        "null"
1084                    ]
1085                },
1086                "NVMeControllerProperties": {
1087                    "$ref": "#/definitions/NVMeControllerProperties",
1088                    "description": "The NVMe-related properties for this storage controller.",
1089                    "longDescription": "This property shall contain NVMe-related properties for this storage controller."
1090                },
1091                "Name": {
1092                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
1093                    "readonly": true
1094                },
1095                "Oem": {
1096                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
1097                    "description": "The OEM extension property.",
1098                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
1099                },
1100                "PCIeInterface": {
1101                    "$ref": "http://redfish.dmtf.org/schemas/v1/PCIeDevice.json#/definitions/PCIeInterface",
1102                    "description": "The PCIe interface details for this controller.",
1103                    "longDescription": "This property shall contain details on the PCIe interface that connects this PCIe-based controller to its host."
1104                },
1105                "PartNumber": {
1106                    "description": "The part number for this storage controller.",
1107                    "longDescription": "This property shall contain a part number assigned by the organization that is responsible for producing or manufacturing the storage controller.",
1108                    "readonly": true,
1109                    "type": [
1110                        "string",
1111                        "null"
1112                    ]
1113                },
1114                "Ports": {
1115                    "$ref": "http://redfish.dmtf.org/schemas/v1/PortCollection.json#/definitions/PortCollection",
1116                    "description": "The link to the collection of ports that exist on the storage controller.",
1117                    "longDescription": "This property shall contain a link to a resource collection of type `PortCollection`.",
1118                    "readonly": true
1119                },
1120                "SKU": {
1121                    "description": "The SKU for this storage controller.",
1122                    "longDescription": "This property shall contain the stock-keeping unit number for this storage controller.",
1123                    "readonly": true,
1124                    "type": [
1125                        "string",
1126                        "null"
1127                    ]
1128                },
1129                "SerialNumber": {
1130                    "description": "The serial number for this storage controller.",
1131                    "longDescription": "This property shall contain a manufacturer-allocated number that identifies the storage controller.",
1132                    "readonly": true,
1133                    "type": [
1134                        "string",
1135                        "null"
1136                    ]
1137                },
1138                "SpeedGbps": {
1139                    "description": "The maximum speed of the storage controller's device interface.",
1140                    "longDescription": "This property shall represent the maximum supported speed of the storage bus interface, in Gbit/s.  The specified interface connects the controller to the storage devices, not the controller to a host.  For example, SAS bus not PCIe host bus.",
1141                    "minimum": 0,
1142                    "readonly": true,
1143                    "type": [
1144                        "number",
1145                        "null"
1146                    ],
1147                    "units": "Gbit/s"
1148                },
1149                "Status": {
1150                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
1151                    "description": "The status and health of the resource and its subordinate or dependent resources.",
1152                    "longDescription": "This property shall contain any status or health properties of the resource."
1153                },
1154                "SupportedControllerProtocols": {
1155                    "description": "The supported set of protocols for communicating with this storage controller.",
1156                    "items": {
1157                        "$ref": "http://redfish.dmtf.org/schemas/v1/Protocol.json#/definitions/Protocol"
1158                    },
1159                    "longDescription": "This property shall contain the supported set of protocols for communicating with this storage controller.",
1160                    "readonly": true,
1161                    "type": "array"
1162                },
1163                "SupportedDeviceProtocols": {
1164                    "description": "The protocols that the storage controller can use to communicate with attached devices.",
1165                    "items": {
1166                        "$ref": "http://redfish.dmtf.org/schemas/v1/Protocol.json#/definitions/Protocol"
1167                    },
1168                    "longDescription": "This property shall contain the set of protocols this storage controller can use to communicate with attached devices.",
1169                    "readonly": true,
1170                    "type": "array"
1171                },
1172                "SupportedRAIDTypes": {
1173                    "description": "The set of RAID types supported by the storage controller.",
1174                    "items": {
1175                        "anyOf": [
1176                            {
1177                                "$ref": "http://redfish.dmtf.org/schemas/swordfish/v1/Volume.json#/definitions/RAIDType"
1178                            },
1179                            {
1180                                "type": "null"
1181                            }
1182                        ]
1183                    },
1184                    "longDescription": "This property shall contain an array of all the RAID types supported by this controller.",
1185                    "readonly": true,
1186                    "type": "array"
1187                }
1188            },
1189            "required": [
1190                "@odata.id",
1191                "@odata.type",
1192                "Id",
1193                "Name"
1194            ],
1195            "type": "object"
1196        }
1197    },
1198    "language": "en",
1199    "owningEntity": "DMTF",
1200    "release": "2024.3",
1201    "title": "#StorageController.v1_8_0.StorageController"
1202}