xref: /openbmc/bmcweb/features/redfish/schema/dmtf/json-schema/DriveMetrics.v1_2_1.json (revision f2a8e57ede74a8252100b2281e3f4d170aa69391)
1*f2a8e57eSGunnar Mills{
2*f2a8e57eSGunnar Mills    "$id": "http://redfish.dmtf.org/schemas/v1/DriveMetrics.v1_2_1.json",
3*f2a8e57eSGunnar Mills    "$ref": "#/definitions/DriveMetrics",
4*f2a8e57eSGunnar Mills    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5*f2a8e57eSGunnar Mills    "copyright": "Copyright 2014-2024 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
6*f2a8e57eSGunnar Mills    "definitions": {
7*f2a8e57eSGunnar Mills        "Actions": {
8*f2a8e57eSGunnar Mills            "additionalProperties": false,
9*f2a8e57eSGunnar Mills            "description": "The available actions for this resource.",
10*f2a8e57eSGunnar Mills            "longDescription": "This type shall contain the available actions for this resource.",
11*f2a8e57eSGunnar Mills            "patternProperties": {
12*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
13*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
14*f2a8e57eSGunnar Mills                    "type": [
15*f2a8e57eSGunnar Mills                        "array",
16*f2a8e57eSGunnar Mills                        "boolean",
17*f2a8e57eSGunnar Mills                        "integer",
18*f2a8e57eSGunnar Mills                        "number",
19*f2a8e57eSGunnar Mills                        "null",
20*f2a8e57eSGunnar Mills                        "object",
21*f2a8e57eSGunnar Mills                        "string"
22*f2a8e57eSGunnar Mills                    ]
23*f2a8e57eSGunnar Mills                }
24*f2a8e57eSGunnar Mills            },
25*f2a8e57eSGunnar Mills            "properties": {
26*f2a8e57eSGunnar Mills                "Oem": {
27*f2a8e57eSGunnar Mills                    "$ref": "#/definitions/OemActions",
28*f2a8e57eSGunnar Mills                    "description": "The available OEM-specific actions for this resource.",
29*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the available OEM-specific actions for this resource."
30*f2a8e57eSGunnar Mills                }
31*f2a8e57eSGunnar Mills            },
32*f2a8e57eSGunnar Mills            "type": "object"
33*f2a8e57eSGunnar Mills        },
34*f2a8e57eSGunnar Mills        "DriveMetrics": {
35*f2a8e57eSGunnar Mills            "additionalProperties": false,
36*f2a8e57eSGunnar Mills            "description": "The usage and health statistics for a drive.",
37*f2a8e57eSGunnar Mills            "longDescription": "The `DriveMetrics` schema shall contain the usage and health statistics for a drive in a Redfish implementation.",
38*f2a8e57eSGunnar Mills            "patternProperties": {
39*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
40*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
41*f2a8e57eSGunnar Mills                    "type": [
42*f2a8e57eSGunnar Mills                        "array",
43*f2a8e57eSGunnar Mills                        "boolean",
44*f2a8e57eSGunnar Mills                        "integer",
45*f2a8e57eSGunnar Mills                        "number",
46*f2a8e57eSGunnar Mills                        "null",
47*f2a8e57eSGunnar Mills                        "object",
48*f2a8e57eSGunnar Mills                        "string"
49*f2a8e57eSGunnar Mills                    ]
50*f2a8e57eSGunnar Mills                }
51*f2a8e57eSGunnar Mills            },
52*f2a8e57eSGunnar Mills            "properties": {
53*f2a8e57eSGunnar Mills                "@odata.context": {
54*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
55*f2a8e57eSGunnar Mills                },
56*f2a8e57eSGunnar Mills                "@odata.etag": {
57*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
58*f2a8e57eSGunnar Mills                },
59*f2a8e57eSGunnar Mills                "@odata.id": {
60*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
61*f2a8e57eSGunnar Mills                },
62*f2a8e57eSGunnar Mills                "@odata.type": {
63*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
64*f2a8e57eSGunnar Mills                },
65*f2a8e57eSGunnar Mills                "Actions": {
66*f2a8e57eSGunnar Mills                    "$ref": "#/definitions/Actions",
67*f2a8e57eSGunnar Mills                    "description": "The available actions for this resource.",
68*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the available actions for this resource."
69*f2a8e57eSGunnar Mills                },
70*f2a8e57eSGunnar Mills                "BadBlockCount": {
71*f2a8e57eSGunnar Mills                    "description": "The total number of bad blocks reported by the drive.",
72*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the total number of bad blocks reported by the drive.",
73*f2a8e57eSGunnar Mills                    "readonly": true,
74*f2a8e57eSGunnar Mills                    "type": [
75*f2a8e57eSGunnar Mills                        "integer",
76*f2a8e57eSGunnar Mills                        "null"
77*f2a8e57eSGunnar Mills                    ]
78*f2a8e57eSGunnar Mills                },
79*f2a8e57eSGunnar Mills                "CorrectableIOReadErrorCount": {
80*f2a8e57eSGunnar Mills                    "description": "The number of correctable read errors for the lifetime of the drive.",
81*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the number of correctable read errors for the lifetime of the drive.",
82*f2a8e57eSGunnar Mills                    "readonly": true,
83*f2a8e57eSGunnar Mills                    "type": [
84*f2a8e57eSGunnar Mills                        "integer",
85*f2a8e57eSGunnar Mills                        "null"
86*f2a8e57eSGunnar Mills                    ]
87*f2a8e57eSGunnar Mills                },
88*f2a8e57eSGunnar Mills                "CorrectableIOWriteErrorCount": {
89*f2a8e57eSGunnar Mills                    "description": "The number of correctable write errors for the lifetime of the drive.",
90*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the number of correctable write errors for the lifetime of the drive.",
91*f2a8e57eSGunnar Mills                    "readonly": true,
92*f2a8e57eSGunnar Mills                    "type": [
93*f2a8e57eSGunnar Mills                        "integer",
94*f2a8e57eSGunnar Mills                        "null"
95*f2a8e57eSGunnar Mills                    ]
96*f2a8e57eSGunnar Mills                },
97*f2a8e57eSGunnar Mills                "Description": {
98*f2a8e57eSGunnar Mills                    "anyOf": [
99*f2a8e57eSGunnar Mills                        {
100*f2a8e57eSGunnar Mills                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
101*f2a8e57eSGunnar Mills                        },
102*f2a8e57eSGunnar Mills                        {
103*f2a8e57eSGunnar Mills                            "type": "null"
104*f2a8e57eSGunnar Mills                        }
105*f2a8e57eSGunnar Mills                    ],
106*f2a8e57eSGunnar Mills                    "readonly": true
107*f2a8e57eSGunnar Mills                },
108*f2a8e57eSGunnar Mills                "Id": {
109*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
110*f2a8e57eSGunnar Mills                    "readonly": true
111*f2a8e57eSGunnar Mills                },
112*f2a8e57eSGunnar Mills                "NVMeSMART": {
113*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/StorageControllerMetrics.json#/definitions/NVMeSMARTMetrics",
114*f2a8e57eSGunnar Mills                    "description": "The NVMe SMART metrics for the drive.",
115*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the NVMe SMART metrics for the drive as defined by the NVMe SMART/Health Information log page.  This property shall not be present if the service represents NVMe controllers in the drive as StorageController resources."
116*f2a8e57eSGunnar Mills                },
117*f2a8e57eSGunnar Mills                "Name": {
118*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
119*f2a8e57eSGunnar Mills                    "readonly": true
120*f2a8e57eSGunnar Mills                },
121*f2a8e57eSGunnar Mills                "NativeCommandQueueDepth": {
122*f2a8e57eSGunnar Mills                    "description": "The current depth of the Native Command Queue.",
123*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the current depth of the Native Command Queue as defined by the SATA Specification.",
124*f2a8e57eSGunnar Mills                    "readonly": true,
125*f2a8e57eSGunnar Mills                    "type": [
126*f2a8e57eSGunnar Mills                        "integer",
127*f2a8e57eSGunnar Mills                        "null"
128*f2a8e57eSGunnar Mills                    ],
129*f2a8e57eSGunnar Mills                    "versionAdded": "v1_1_0"
130*f2a8e57eSGunnar Mills                },
131*f2a8e57eSGunnar Mills                "Oem": {
132*f2a8e57eSGunnar Mills                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
133*f2a8e57eSGunnar Mills                    "description": "The OEM extension property.",
134*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
135*f2a8e57eSGunnar Mills                },
136*f2a8e57eSGunnar Mills                "PowerOnHours": {
137*f2a8e57eSGunnar Mills                    "description": "The number of power-on hours for the lifetime of the drive.",
138*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the number of power-on hours for the lifetime of the drive.",
139*f2a8e57eSGunnar Mills                    "readonly": true,
140*f2a8e57eSGunnar Mills                    "type": [
141*f2a8e57eSGunnar Mills                        "number",
142*f2a8e57eSGunnar Mills                        "null"
143*f2a8e57eSGunnar Mills                    ]
144*f2a8e57eSGunnar Mills                },
145*f2a8e57eSGunnar Mills                "ReadIOKiBytes": {
146*f2a8e57eSGunnar Mills                    "description": "The number of kibibytes read.",
147*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the total number of kibibytes read from the time of last reset or wrap.",
148*f2a8e57eSGunnar Mills                    "readonly": true,
149*f2a8e57eSGunnar Mills                    "type": [
150*f2a8e57eSGunnar Mills                        "integer",
151*f2a8e57eSGunnar Mills                        "null"
152*f2a8e57eSGunnar Mills                    ],
153*f2a8e57eSGunnar Mills                    "units": "KiBy",
154*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
155*f2a8e57eSGunnar Mills                },
156*f2a8e57eSGunnar Mills                "UncorrectableIOReadErrorCount": {
157*f2a8e57eSGunnar Mills                    "description": "The number of uncorrectable read errors for the lifetime of the drive.",
158*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the number of uncorrectable read errors for the lifetime of the drive.",
159*f2a8e57eSGunnar Mills                    "readonly": true,
160*f2a8e57eSGunnar Mills                    "type": [
161*f2a8e57eSGunnar Mills                        "integer",
162*f2a8e57eSGunnar Mills                        "null"
163*f2a8e57eSGunnar Mills                    ]
164*f2a8e57eSGunnar Mills                },
165*f2a8e57eSGunnar Mills                "UncorrectableIOWriteErrorCount": {
166*f2a8e57eSGunnar Mills                    "description": "The number of uncorrectable write errors for the lifetime of the drive.",
167*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the number of uncorrectable write errors for the lifetime of the drive.",
168*f2a8e57eSGunnar Mills                    "readonly": true,
169*f2a8e57eSGunnar Mills                    "type": [
170*f2a8e57eSGunnar Mills                        "integer",
171*f2a8e57eSGunnar Mills                        "null"
172*f2a8e57eSGunnar Mills                    ]
173*f2a8e57eSGunnar Mills                },
174*f2a8e57eSGunnar Mills                "WriteIOKiBytes": {
175*f2a8e57eSGunnar Mills                    "description": "The number of kibibytes written.",
176*f2a8e57eSGunnar Mills                    "longDescription": "This property shall contain the total number of kibibytes written from the time of last reset or wrap.",
177*f2a8e57eSGunnar Mills                    "readonly": true,
178*f2a8e57eSGunnar Mills                    "type": [
179*f2a8e57eSGunnar Mills                        "integer",
180*f2a8e57eSGunnar Mills                        "null"
181*f2a8e57eSGunnar Mills                    ],
182*f2a8e57eSGunnar Mills                    "units": "KiBy",
183*f2a8e57eSGunnar Mills                    "versionAdded": "v1_2_0"
184*f2a8e57eSGunnar Mills                }
185*f2a8e57eSGunnar Mills            },
186*f2a8e57eSGunnar Mills            "required": [
187*f2a8e57eSGunnar Mills                "@odata.id",
188*f2a8e57eSGunnar Mills                "@odata.type",
189*f2a8e57eSGunnar Mills                "Id",
190*f2a8e57eSGunnar Mills                "Name"
191*f2a8e57eSGunnar Mills            ],
192*f2a8e57eSGunnar Mills            "type": "object"
193*f2a8e57eSGunnar Mills        },
194*f2a8e57eSGunnar Mills        "OemActions": {
195*f2a8e57eSGunnar Mills            "additionalProperties": true,
196*f2a8e57eSGunnar Mills            "description": "The available OEM-specific actions for this resource.",
197*f2a8e57eSGunnar Mills            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
198*f2a8e57eSGunnar Mills            "patternProperties": {
199*f2a8e57eSGunnar Mills                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
200*f2a8e57eSGunnar Mills                    "description": "This property shall specify a valid odata or Redfish property.",
201*f2a8e57eSGunnar Mills                    "type": [
202*f2a8e57eSGunnar Mills                        "array",
203*f2a8e57eSGunnar Mills                        "boolean",
204*f2a8e57eSGunnar Mills                        "integer",
205*f2a8e57eSGunnar Mills                        "number",
206*f2a8e57eSGunnar Mills                        "null",
207*f2a8e57eSGunnar Mills                        "object",
208*f2a8e57eSGunnar Mills                        "string"
209*f2a8e57eSGunnar Mills                    ]
210*f2a8e57eSGunnar Mills                }
211*f2a8e57eSGunnar Mills            },
212*f2a8e57eSGunnar Mills            "properties": {},
213*f2a8e57eSGunnar Mills            "type": "object"
214*f2a8e57eSGunnar Mills        }
215*f2a8e57eSGunnar Mills    },
216*f2a8e57eSGunnar Mills    "language": "en",
217*f2a8e57eSGunnar Mills    "owningEntity": "DMTF",
218*f2a8e57eSGunnar Mills    "release": "2023.3",
219*f2a8e57eSGunnar Mills    "title": "#DriveMetrics.v1_2_1.DriveMetrics"
220*f2a8e57eSGunnar Mills}