]> git.proxmox.com Git - mirror_edk2.git/blob - IntelFrameworkPkg/Include/Common/DataHubRecords.h
bac5915361fa0b753a3f8000ebff5f288a4b732d
[mirror_edk2.git] / IntelFrameworkPkg / Include / Common / DataHubRecords.h
1 /** @file
2 This file defines GUIDs and associated data structures for records posted to the Data Hub.
3 The producers of these records use these definitions to construct records.
4 The consumers of these records use these definitions to retrieve, filter and parse records.
5
6 Copyright (c) 2007, Intel Corporation
7 All rights reserved. This program and the accompanying materials
8 are licensed and made available under the terms and conditions of the BSD License
9 which accompanies this distribution. The full text of the license may be found at
10 http://opensource.org/licenses/bsd-license.php
11
12 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
14
15 Module Name: DataHubRecords.h
16
17 @par Revision Reference:
18 DataHubRecord.h include all data hub sub class defitions from Cache subclass
19 spec 0.9, DataHub SubClass spec 0.9, Memory SubClass Spec 0.9, Processor
20 Subclass spec 0.9,Misc SubClass spec 0.9.
21
22 **/
23
24 #ifndef _DATAHUB_RECORDS_H_
25 #define _DATAHUB_RECORDS_H_
26
27 #define EFI_PROCESSOR_SUBCLASS_VERSION 0x00010000
28
29 #include <Protocol/DevicePath.h>
30
31 #pragma pack(1)
32
33 typedef struct _USB_PORT_DEVICE_PATH {
34 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
35 PCI_DEVICE_PATH PciBusDevicePath;
36 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
37 } USB_PORT_DEVICE_PATH;
38
39 //
40 // IDE
41 //
42 typedef struct _IDE_DEVICE_PATH {
43 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
44 PCI_DEVICE_PATH PciBusDevicePath;
45 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
46 } IDE_DEVICE_PATH;
47
48 //
49 // RMC Connector
50 //
51 typedef struct _RMC_CONN_DEVICE_PATH {
52 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
53 PCI_DEVICE_PATH PciBridgeDevicePath;
54 PCI_DEVICE_PATH PciBusDevicePath;
55 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
56 } RMC_CONN_DEVICE_PATH;
57
58 //
59 // RIDE
60 //
61 typedef struct _RIDE_DEVICE_PATH {
62 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
63 PCI_DEVICE_PATH PciBridgeDevicePath;
64 PCI_DEVICE_PATH PciBusDevicePath;
65 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
66 } RIDE_DEVICE_PATH;
67
68 //
69 // Gigabit NIC
70 //
71 typedef struct _GB_NIC_DEVICE_PATH {
72 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
73 PCI_DEVICE_PATH PciBridgeDevicePath;
74 PCI_DEVICE_PATH PciXBridgeDevicePath;
75 PCI_DEVICE_PATH PciXBusDevicePath;
76 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
77 } GB_NIC_DEVICE_PATH;
78
79 //
80 // P/S2 Connector
81 //
82 typedef struct _PS2_CONN_DEVICE_PATH {
83 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
84 PCI_DEVICE_PATH LpcBridgeDevicePath;
85 ACPI_HID_DEVICE_PATH LpcBusDevicePath;
86 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
87 } PS2_CONN_DEVICE_PATH;
88
89 //
90 // Serial Port Connector
91 //
92 typedef struct _SERIAL_CONN_DEVICE_PATH {
93 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
94 PCI_DEVICE_PATH LpcBridgeDevicePath;
95 ACPI_HID_DEVICE_PATH LpcBusDevicePath;
96 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
97 } SERIAL_CONN_DEVICE_PATH;
98
99 //
100 // Parallel Port Connector
101 //
102 typedef struct _PARALLEL_CONN_DEVICE_PATH {
103 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
104 PCI_DEVICE_PATH LpcBridgeDevicePath;
105 ACPI_HID_DEVICE_PATH LpcBusDevicePath;
106 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
107 } PARALLEL_CONN_DEVICE_PATH;
108
109 //
110 // Floopy Connector
111 //
112 typedef struct _FLOOPY_CONN_DEVICE_PATH {
113 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath;
114 PCI_DEVICE_PATH LpcBridgeDevicePath;
115 ACPI_HID_DEVICE_PATH LpcBusDevicePath;
116 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
117 } FLOOPY_CONN_DEVICE_PATH;
118
119 typedef union _EFI_MISC_PORT_DEVICE_PATH {
120 USB_PORT_DEVICE_PATH UsbDevicePath;
121 IDE_DEVICE_PATH IdeDevicePath;
122 RMC_CONN_DEVICE_PATH RmcConnDevicePath;
123 RIDE_DEVICE_PATH RideDevicePath;
124 GB_NIC_DEVICE_PATH GbNicDevicePath;
125 PS2_CONN_DEVICE_PATH Ps2ConnDevicePath;
126 SERIAL_CONN_DEVICE_PATH SerialConnDevicePath;
127 PARALLEL_CONN_DEVICE_PATH ParallelConnDevicePath;
128 FLOOPY_CONN_DEVICE_PATH FloppyConnDevicePath;
129 } EFI_MISC_PORT_DEVICE_PATH;
130
131 #pragma pack()
132
133 //
134 // String Token Definition
135 //
136 #define EFI_STRING_TOKEN UINT16
137
138 typedef struct {
139 UINT32 Version;
140 UINT32 HeaderSize;
141 UINT16 Instance;
142 UINT16 SubInstance;
143 UINT32 RecordType;
144 } EFI_SUBCLASS_TYPE1_HEADER;
145
146 typedef struct {
147 EFI_GUID ProducerName;
148 UINT16 Instance;
149 UINT16 SubInstance;
150 } EFI_INTER_LINK_DATA;
151
152
153 //
154 // EXP data
155 //
156
157 typedef struct {
158 UINT16 Value;
159 UINT16 Exponent;
160 } EFI_EXP_BASE2_DATA;
161
162
163 typedef struct {
164 UINT16 Value;
165 UINT16 Exponent;
166 } EFI_EXP_BASE10_DATA;
167
168 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_MAX_CORE_FREQUENCY_DATA;
169
170 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_MAX_FSB_FREQUENCY_DATA;
171
172 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_CORE_FREQUENCY_DATA;
173
174 typedef EFI_EXP_BASE10_DATA *EFI_PROCESSOR_CORE_FREQUENCY_LIST_DATA;
175
176 typedef EFI_EXP_BASE10_DATA *EFI_PROCESSOR_FSB_FREQUENCY_LIST_DATA;
177
178 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_FSB_FREQUENCY_DATA;
179
180 typedef STRING_REF EFI_PROCESSOR_VERSION_DATA;
181
182 typedef STRING_REF EFI_PROCESSOR_MANUFACTURER_DATA;
183
184 typedef STRING_REF EFI_PROCESSOR_SERIAL_NUMBER_DATA;
185
186 typedef STRING_REF EFI_PROCESSOR_ASSET_TAG_DATA;
187
188 typedef struct {
189 UINT32 ProcessorSteppingId:4;
190 UINT32 ProcessorModel: 4;
191 UINT32 ProcessorFamily: 4;
192 UINT32 ProcessorType: 2;
193 UINT32 ProcessorReserved1: 2;
194 UINT32 ProcessorXModel: 4;
195 UINT32 ProcessorXFamily: 8;
196 UINT32 ProcessorReserved2: 4;
197 } EFI_PROCESSOR_SIGNATURE;
198
199 typedef struct {
200 UINT32 ProcessorBrandIndex :8;
201 UINT32 ProcessorClflush :8;
202 UINT32 ProcessorReserved :8;
203 UINT32 ProcessorDfltApicId :8;
204 } EFI_PROCESSOR_MISC_INFO;
205
206 typedef struct {
207 UINT32 ProcessorFpu: 1;
208 UINT32 ProcessorVme: 1;
209 UINT32 ProcessorDe: 1;
210 UINT32 ProcessorPse: 1;
211 UINT32 ProcessorTsc: 1;
212 UINT32 ProcessorMsr: 1;
213 UINT32 ProcessorPae: 1;
214 UINT32 ProcessorMce: 1;
215 UINT32 ProcessorCx8: 1;
216 UINT32 ProcessorApic: 1;
217 UINT32 ProcessorReserved1: 1;
218 UINT32 ProcessorSep: 1;
219 UINT32 ProcessorMtrr: 1;
220 UINT32 ProcessorPge: 1;
221 UINT32 ProcessorMca: 1;
222 UINT32 ProcessorCmov: 1;
223 UINT32 ProcessorPat: 1;
224 UINT32 ProcessorPse36: 1;
225 UINT32 ProcessorPsn: 1;
226 UINT32 ProcessorClfsh: 1;
227 UINT32 ProcessorReserved2: 1;
228 UINT32 ProcessorDs: 1;
229 UINT32 ProcessorAcpi: 1;
230 UINT32 ProcessorMmx: 1;
231 UINT32 ProcessorFxsr: 1;
232 UINT32 ProcessorSse: 1;
233 UINT32 ProcessorSse2: 1;
234 UINT32 ProcessorSs: 1;
235 UINT32 ProcessorReserved3: 1;
236 UINT32 ProcessorTm: 1;
237 UINT32 ProcessorReserved4: 2;
238 } EFI_PROCESSOR_FEATURE_FLAGS;
239
240 typedef struct {
241 EFI_PROCESSOR_SIGNATURE Signature;
242 EFI_PROCESSOR_MISC_INFO MiscInfo;
243 UINT32 Reserved;
244 EFI_PROCESSOR_FEATURE_FLAGS FeatureFlags;
245 } EFI_PROCESSOR_ID_DATA;
246
247 typedef enum {
248 EfiProcessorOther = 1,
249 EfiProcessorUnknown = 2,
250 EfiCentralProcessor = 3,
251 EfiMathProcessor = 4,
252 EfiDspProcessor = 5,
253 EfiVideoProcessor = 6
254 } EFI_PROCESSOR_TYPE_DATA;
255
256 typedef enum {
257 EfiProcessorFamilyOther = 1,
258 EfiProcessorFamilyUnknown = 2,
259 EfiProcessorFamily8086 = 3,
260 EfiProcessorFamily80286 = 4,
261 EfiProcessorFamilyIntel386 = 5,
262 EfiProcessorFamilyIntel486 = 6,
263 EfiProcessorFamily8087 = 7,
264 EfiProcessorFamily80287 = 8,
265 EfiProcessorFamily80387 = 9,
266 EfiProcessorFamily80487 = 0x0A,
267 EfiProcessorFamilyPentium = 0x0B,
268 EfiProcessorFamilyPentiumPro = 0x0C,
269 EfiProcessorFamilyPentiumII = 0x0D,
270 EfiProcessorFamilyPentiumMMX = 0x0E,
271 EfiProcessorFamilyCeleron = 0x0F,
272 EfiProcessorFamilyPentiumIIXeon = 0x10,
273 EfiProcessorFamilyPentiumIII = 0x11,
274 EfiProcessorFamilyM1 = 0x12,
275 EfiProcessorFamilyM1Reserved1 = 0x13,
276 EfiProcessorFamilyM1Reserved2 = 0x14,
277 EfiProcessorFamilyM1Reserved3 = 0x15,
278 EfiProcessorFamilyM1Reserved4 = 0x16,
279 EfiProcessorFamilyM1Reserved5 = 0x17,
280 EfiProcessorFamilyM1Reserved6 = 0x18,
281 EfiProcessorFamilyK5 = 0x19,
282 EfiProcessorFamilyK5Reserved1 = 0x1A,
283 EfiProcessorFamilyK5Reserved2 = 0x1B,
284 EfiProcessorFamilyK5Reserved3 = 0x1C,
285 EfiProcessorFamilyK5Reserved4 = 0x1D,
286 EfiProcessorFamilyK5Reserved5 = 0x1E,
287 EfiProcessorFamilyK5Reserved6 = 0x1F,
288 EfiProcessorFamilyPowerPC = 0x20,
289 EfiProcessorFamilyPowerPC601 = 0x21,
290 EfiProcessorFamilyPowerPC603 = 0x22,
291 EfiProcessorFamilyPowerPC603Plus = 0x23,
292 EfiProcessorFamilyPowerPC604 = 0x24,
293 EfiProcessorFamilyAlpha2 = 0x30,
294 EfiProcessorFamilyMips = 0x40,
295 EfiProcessorFamilySparc = 0x50,
296 EfiProcessorFamily68040 = 0x60,
297 EfiProcessorFamily68xxx = 0x61,
298 EfiProcessorFamily68000 = 0x62,
299 EfiProcessorFamily68010 = 0x63,
300 EfiProcessorFamily68020 = 0x64,
301 EfiProcessorFamily68030 = 0x65,
302 EfiProcessorFamilyHobbit = 0x70,
303 EfiProcessorFamilyWeitek = 0x80,
304 EfiProcessorFamilyPARISC = 0x90,
305 EfiProcessorFamilyV30 = 0xA0,
306 EfiProcessorFamilyPentiumIIIXeon = 0xB0,
307 EfiProcessorFamilyPentiumIIISpeedStep = 0xB1,
308 EfiProcessorFamilyPentium4 = 0xB2,
309 EfiProcessorFamilyIntelXeon = 0xB3,
310 EfiProcessorFamilyAS400 = 0xB4,
311 EfiProcessorFamilyIntelXeonMP = 0xB5,
312 EfiProcessorFamilyAMDAthlonXP = 0xB6,
313 EfiProcessorFamilyAMDAthlonMP = 0xB7,
314 EfiProcessorFamilyIntelPentiumM = 0xB9,
315 EfiProcessorFamilyIntelCeleronD = 0xBA,
316 EfiProcessorFamilyIntelPentiumD = 0xBB,
317 EfiProcessorFamilyIntelPentiumEx = 0xBC,
318 EfiProcessorFamilyIBM390 = 0xC8,
319 EfiProcessorFamilyG4 = 0xC9,
320 EfiProcessorFamilyG5 = 0xCA,
321 EfiProcessorFamilyi860 = 0xFA,
322 EfiProcessorFamilyi960 = 0xFB
323 } EFI_PROCESSOR_FAMILY_DATA;
324
325 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_VOLTAGE_DATA;
326
327 typedef EFI_PHYSICAL_ADDRESS EFI_PROCESSOR_APIC_BASE_ADDRESS_DATA;
328
329 typedef UINT32 EFI_PROCESSOR_APIC_ID_DATA;
330
331 typedef UINT32 EFI_PROCESSOR_APIC_VERSION_NUMBER_DATA;
332
333 typedef enum {
334 EfiProcessorIa32Microcode = 1,
335 EfiProcessorIpfPalAMicrocode = 2,
336 EfiProcessorIpfPalBMicrocode = 3
337 } EFI_PROCESSOR_MICROCODE_TYPE;
338
339 typedef struct {
340 EFI_PROCESSOR_MICROCODE_TYPE ProcessorMicrocodeType;
341 UINT32 ProcessorMicrocodeRevisionNumber;
342 } EFI_PROCESSOR_MICROCODE_REVISION_DATA;
343
344 typedef struct {
345 UINT32 CpuStatus :3;
346 UINT32 Reserved1 :3;
347 UINT32 SocketPopulated :1;
348 UINT32 Reserved2 :1;
349 UINT32 ApicEnable :1;
350 UINT32 BootApplicationProcessor :1;
351 UINT32 Reserved3 :22;
352 } EFI_PROCESSOR_STATUS_DATA;
353
354 typedef enum {
355 EfiCpuStatusUnknown = 0,
356 EfiCpuStatusEnabled = 1,
357 EfiCpuStatusDisabledByUser = 2,
358 EfiCpuStatusDisabledbyBios = 3,
359 EfiCpuStatusIdle = 4,
360 EfiCpuStatusOther = 7
361 } EFI_CPU_STATUS;
362
363 typedef enum {
364 EfiProcessorSocketOther = 1,
365 EfiProcessorSocketUnknown = 2,
366 EfiProcessorSocketDaughterBoard = 3,
367 EfiProcessorSocketZIF = 4,
368 EfiProcessorSocketReplacePiggyBack = 5,
369 EfiProcessorSocketNone = 6,
370 EfiProcessorSocketLIF = 7,
371 EfiProcessorSocketSlot1 = 8,
372 EfiProcessorSocketSlot2 = 9,
373 EfiProcessorSocket370Pin = 0xA,
374 EfiProcessorSocketSlotA = 0xB,
375 EfiProcessorSocketSlotM = 0xC,
376 EfiProcessorSocket423 = 0xD,
377 EfiProcessorSocketA462 = 0xE,
378 EfiProcessorSocket478 = 0xF,
379 EfiProcessorSocket754 = 0x10,
380 EfiProcessorSocket940 = 0x11,
381 EfiProcessorSocket939 = 0x12,
382 EfiProcessorSocketmPGA604 = 0x13,
383 EfiProcessorSocketLGA771 = 0x14,
384 EfiProcessorSocketLGA775 = 0x15
385
386 } EFI_PROCESSOR_SOCKET_TYPE_DATA;
387
388 typedef STRING_REF EFI_PROCESSOR_SOCKET_NAME_DATA;
389
390 typedef EFI_INTER_LINK_DATA EFI_CACHE_ASSOCIATION_DATA;
391
392 typedef enum {
393 EfiProcessorHealthy = 1,
394 EfiProcessorPerfRestricted = 2,
395 EfiProcessorFuncRestricted = 3
396 } EFI_PROCESSOR_HEALTH_STATUS;
397
398 typedef UINTN EFI_PROCESSOR_PACKAGE_NUMBER_DATA;
399
400
401 typedef enum {
402 ProcessorCoreFrequencyRecordType = 1,
403 ProcessorFsbFrequencyRecordType = 2,
404 ProcessorVersionRecordType = 3,
405 ProcessorManufacturerRecordType = 4,
406 ProcessorSerialNumberRecordType = 5,
407 ProcessorIdRecordType = 6,
408 ProcessorTypeRecordType = 7,
409 ProcessorFamilyRecordType = 8,
410 ProcessorVoltageRecordType = 9,
411 ProcessorApicBaseAddressRecordType = 10,
412 ProcessorApicIdRecordType = 11,
413 ProcessorApicVersionNumberRecordType = 12,
414 CpuUcodeRevisionDataRecordType = 13,
415 ProcessorStatusRecordType = 14,
416 ProcessorSocketTypeRecordType = 15,
417 ProcessorSocketNameRecordType = 16,
418 CacheAssociationRecordType = 17,
419 ProcessorMaxCoreFrequencyRecordType = 18,
420 ProcessorAssetTagRecordType = 19,
421 ProcessorMaxFsbFrequencyRecordType = 20,
422 ProcessorPackageNumberRecordType = 21,
423 ProcessorCoreFrequencyListRecordType = 22,
424 ProcessorFsbFrequencyListRecordType = 23,
425 ProcessorHealthStatusRecordType = 24
426 } EFI_CPU_VARIABLE_RECORD_TYPE;
427
428 typedef union {
429 EFI_PROCESSOR_CORE_FREQUENCY_LIST_DATA ProcessorCoreFrequencyList;
430 EFI_PROCESSOR_FSB_FREQUENCY_LIST_DATA ProcessorFsbFrequencyList;
431 EFI_PROCESSOR_SERIAL_NUMBER_DATA ProcessorSerialNumber;
432 EFI_PROCESSOR_CORE_FREQUENCY_DATA ProcessorCoreFrequency;
433 EFI_PROCESSOR_FSB_FREQUENCY_DATA ProcessorFsbFrequency;
434 EFI_PROCESSOR_MAX_CORE_FREQUENCY_DATA ProcessorMaxCoreFrequency;
435 EFI_PROCESSOR_MAX_FSB_FREQUENCY_DATA ProcessorMaxFsbFrequency;
436 EFI_PROCESSOR_VERSION_DATA ProcessorVersion;
437 EFI_PROCESSOR_MANUFACTURER_DATA ProcessorManufacturer;
438 EFI_PROCESSOR_ID_DATA ProcessorId;
439 EFI_PROCESSOR_TYPE_DATA ProcessorType;
440 EFI_PROCESSOR_FAMILY_DATA ProcessorFamily;
441 EFI_PROCESSOR_VOLTAGE_DATA ProcessorVoltage;
442 EFI_PROCESSOR_APIC_BASE_ADDRESS_DATA ProcessorApicBase;
443 EFI_PROCESSOR_APIC_ID_DATA ProcessorApicId;
444 EFI_PROCESSOR_APIC_VERSION_NUMBER_DATA ProcessorApicVersionNumber;
445 EFI_PROCESSOR_MICROCODE_REVISION_DATA CpuUcodeRevisionData;
446 EFI_PROCESSOR_STATUS_DATA ProcessorStatus;
447 EFI_PROCESSOR_SOCKET_TYPE_DATA ProcessorSocketType;
448 EFI_PROCESSOR_SOCKET_NAME_DATA ProcessorSocketName;
449 EFI_PROCESSOR_ASSET_TAG_DATA ProcessorAssetTag;
450 EFI_PROCESSOR_HEALTH_STATUS ProcessorHealthStatus;
451 EFI_PROCESSOR_PACKAGE_NUMBER_DATA ProcessorPackageNumber;
452 } EFI_CPU_VARIABLE_RECORD;
453
454 typedef struct {
455 EFI_SUBCLASS_TYPE1_HEADER DataRecordHeader;
456 EFI_CPU_VARIABLE_RECORD VariableRecord;
457 } EFI_CPU_DATA_RECORD;
458
459 #define EFI_CACHE_SUBCLASS_VERSION 0x00010000
460
461
462 typedef EFI_EXP_BASE2_DATA EFI_CACHE_SIZE_DATA;
463
464 typedef EFI_EXP_BASE2_DATA EFI_MAXIMUM_CACHE_SIZE_DATA;
465
466 typedef EFI_EXP_BASE10_DATA EFI_CACHE_SPEED_DATA;
467
468 typedef STRING_REF EFI_CACHE_SOCKET_DATA;
469
470 typedef struct {
471 UINT32 Other :1;
472 UINT32 Unknown :1;
473 UINT32 NonBurst :1;
474 UINT32 Burst :1;
475 UINT32 PipelineBurst :1;
476 UINT32 Asynchronous :1;
477 UINT32 Synchronous :1;
478 UINT32 Reserved :25;
479 } EFI_CACHE_SRAM_TYPE_DATA;
480
481 typedef enum {
482 EfiCacheErrorOther = 1,
483 EfiCacheErrorUnknown = 2,
484 EfiCacheErrorNone = 3,
485 EfiCacheErrorParity = 4,
486 EfiCacheErrorSingleBit = 5,
487 EfiCacheErrorMultiBit = 6
488 } EFI_CACHE_ERROR_TYPE_DATA;
489
490 typedef enum {
491 EfiCacheTypeOther = 1,
492 EfiCacheTypeUnknown = 2,
493 EfiCacheTypeInstruction = 3,
494 EfiCacheTypeData = 4,
495 EfiCacheTypeUnified = 5
496 } EFI_CACHE_TYPE_DATA;
497
498 typedef enum {
499 EfiCacheAssociativityOther = 1,
500 EfiCacheAssociativityUnknown = 2,
501 EfiCacheAssociativityDirectMapped = 3,
502 EfiCacheAssociativity2Way = 4,
503 EfiCacheAssociativity4Way = 5,
504 EfiCacheAssociativityFully = 6,
505 EfiCacheAssociativity8Way = 7,
506 EfiCacheAssociativity16Way = 8
507 } EFI_CACHE_ASSOCIATIVITY_DATA;
508
509 typedef struct {
510 UINT32 Level :3;
511 UINT32 Socketed :1;
512 UINT32 Reserved2 :1;
513 UINT32 Location :2;
514 UINT32 Enable :1;
515 UINT32 OperationalMode :2;
516 UINT32 Reserved1 :22;
517 } EFI_CACHE_CONFIGURATION_DATA;
518
519 #define EFI_CACHE_L1 1
520 #define EFI_CACHE_L2 2
521 #define EFI_CACHE_L3 3
522 #define EFI_CACHE_L4 4
523 #define EFI_CACHE_LMAX EFI_CACHE_L4
524
525 #define EFI_CACHE_SOCKETED 1
526 #define EFI_CACHE_NOT_SOCKETED 0
527
528 typedef enum {
529 EfiCacheInternal = 0,
530 EfiCacheExternal = 1,
531 EfiCacheReserved = 2,
532 EfiCacheUnknown = 3
533 } EFI_CACHE_LOCATION;
534
535 #define EFI_CACHE_ENABLED 1
536 #define EFI_CACHE_DISABLED 0
537
538 typedef enum {
539 EfiCacheWriteThrough = 0,
540 EfiCacheWriteBack = 1,
541 EfiCacheDynamicMode = 2,
542 EfiCacheUnknownMode = 3
543 } EFI_CACHE_OPERATIONAL_MODE;
544
545
546
547 typedef enum {
548 CacheSizeRecordType = 1,
549 MaximumSizeCacheRecordType = 2,
550 CacheSpeedRecordType = 3,
551 CacheSocketRecordType = 4,
552 CacheSramTypeRecordType = 5,
553 CacheInstalledSramTypeRecordType = 6,
554 CacheErrorTypeRecordType = 7,
555 CacheTypeRecordType = 8,
556 CacheAssociativityRecordType = 9,
557 CacheConfigRecordType = 10
558 } EFI_CACHE_VARIABLE_RECORD_TYPE;
559
560
561 typedef union {
562 EFI_CACHE_SIZE_DATA CacheSize;
563 EFI_MAXIMUM_CACHE_SIZE_DATA MaximumCacheSize;
564 EFI_CACHE_SPEED_DATA CacheSpeed;
565 EFI_CACHE_SOCKET_DATA CacheSocket;
566 EFI_CACHE_SRAM_TYPE_DATA CacheSramType;
567 EFI_CACHE_SRAM_TYPE_DATA CacheInstalledSramType;
568 EFI_CACHE_ERROR_TYPE_DATA CacheErrorType;
569 EFI_CACHE_TYPE_DATA CacheType;
570 EFI_CACHE_ASSOCIATIVITY_DATA CacheAssociativity;
571 EFI_CACHE_CONFIGURATION_DATA CacheConfig;
572 EFI_CACHE_ASSOCIATION_DATA CacheAssociation;
573 } EFI_CACHE_VARIABLE_RECORD;
574
575 typedef struct {
576 EFI_SUBCLASS_TYPE1_HEADER DataRecordHeader;
577 EFI_CACHE_VARIABLE_RECORD VariableRecord;
578 } EFI_CACHE_DATA_RECORD;
579
580 #define EFI_MEMORY_SUBCLASS_VERSION 0x0100
581
582
583 #define EFI_MEMORY_SIZE_RECORD_NUMBER 0x00000001
584
585 typedef enum _EFI_MEMORY_REGION_TYPE {
586 EfiMemoryRegionMemory = 0x01,
587 EfiMemoryRegionReserved = 0x02,
588 EfiMemoryRegionAcpi = 0x03,
589 EfiMemoryRegionNvs = 0x04
590 } EFI_MEMORY_REGION_TYPE;
591
592 typedef struct {
593 UINT32 ProcessorNumber;
594 UINT16 StartBusNumber;
595 UINT16 EndBusNumber;
596 EFI_MEMORY_REGION_TYPE MemoryRegionType;
597 EFI_EXP_BASE2_DATA MemorySize;
598 EFI_PHYSICAL_ADDRESS MemoryStartAddress;
599 } EFI_MEMORY_SIZE_DATA;
600
601
602 #define EFI_MEMORY_ARRAY_LOCATION_RECORD_NUMBER 0x00000002
603
604 typedef enum _EFI_MEMORY_ARRAY_LOCATION {
605 EfiMemoryArrayLocationOther = 0x01,
606 EfiMemoryArrayLocationUnknown = 0x02,
607 EfiMemoryArrayLocationSystemBoard = 0x03,
608 EfiMemoryArrayLocationIsaAddonCard = 0x04,
609 EfiMemoryArrayLocationEisaAddonCard = 0x05,
610 EfiMemoryArrayLocationPciAddonCard = 0x06,
611 EfiMemoryArrayLocationMcaAddonCard = 0x07,
612 EfiMemoryArrayLocationPcmciaAddonCard = 0x08,
613 EfiMemoryArrayLocationProprietaryAddonCard = 0x09,
614 EfiMemoryArrayLocationNuBus = 0x0A,
615 EfiMemoryArrayLocationPc98C20AddonCard = 0xA0,
616 EfiMemoryArrayLocationPc98C24AddonCard = 0xA1,
617 EfiMemoryArrayLocationPc98EAddonCard = 0xA2,
618 EfiMemoryArrayLocationPc98LocalBusAddonCard = 0xA3
619 } EFI_MEMORY_ARRAY_LOCATION;
620
621 typedef enum _EFI_MEMORY_ARRAY_USE {
622 EfiMemoryArrayUseOther = 0x01,
623 EfiMemoryArrayUseUnknown = 0x02,
624 EfiMemoryArrayUseSystemMemory = 0x03,
625 EfiMemoryArrayUseVideoMemory = 0x04,
626 EfiMemoryArrayUseFlashMemory = 0x05,
627 EfiMemoryArrayUseNonVolatileRam = 0x06,
628 EfiMemoryArrayUseCacheMemory = 0x07,
629 } EFI_MEMORY_ARRAY_USE;
630
631 typedef enum _EFI_MEMORY_ERROR_CORRECTION {
632 EfiMemoryErrorCorrectionOther = 0x01,
633 EfiMemoryErrorCorrectionUnknown = 0x02,
634 EfiMemoryErrorCorrectionNone = 0x03,
635 EfiMemoryErrorCorrectionParity = 0x04,
636 EfiMemoryErrorCorrectionSingleBitEcc = 0x05,
637 EfiMemoryErrorCorrectionMultiBitEcc = 0x06,
638 EfiMemoryErrorCorrectionCrc = 0x07,
639 } EFI_MEMORY_ERROR_CORRECTION;
640
641 typedef struct {
642 EFI_MEMORY_ARRAY_LOCATION MemoryArrayLocation;
643 EFI_MEMORY_ARRAY_USE MemoryArrayUse;
644 EFI_MEMORY_ERROR_CORRECTION MemoryErrorCorrection;
645 EFI_EXP_BASE2_DATA MaximumMemoryCapacity;
646 UINT16 NumberMemoryDevices;
647 } EFI_MEMORY_ARRAY_LOCATION_DATA;
648
649
650 #define EFI_MEMORY_ARRAY_LINK_RECORD_NUMBER 0x00000003
651
652 typedef enum _EFI_MEMORY_FORM_FACTOR {
653 EfiMemoryFormFactorOther = 0x01,
654 EfiMemoryFormFactorUnknown = 0x02,
655 EfiMemoryFormFactorSimm = 0x03,
656 EfiMemoryFormFactorSip = 0x04,
657 EfiMemoryFormFactorChip = 0x05,
658 EfiMemoryFormFactorDip = 0x06,
659 EfiMemoryFormFactorZip = 0x07,
660 EfiMemoryFormFactorProprietaryCard = 0x08,
661 EfiMemoryFormFactorDimm = 0x09,
662 EfiMemoryFormFactorTsop = 0x0A,
663 EfiMemoryFormFactorRowOfChips = 0x0B,
664 EfiMemoryFormFactorRimm = 0x0C,
665 EfiMemoryFormFactorSodimm = 0x0D,
666 EfiMemoryFormFactorSrimm = 0x0E,
667 EfiMemoryFormFactorFbDimm = 0x0F
668 } EFI_MEMORY_FORM_FACTOR;
669
670 typedef enum _EFI_MEMORY_ARRAY_TYPE {
671 EfiMemoryTypeOther = 0x01,
672 EfiMemoryTypeUnknown = 0x02,
673 EfiMemoryTypeDram = 0x03,
674 EfiMemoryTypeEdram = 0x04,
675 EfiMemoryTypeVram = 0x05,
676 EfiMemoryTypeSram = 0x06,
677 EfiMemoryTypeRam = 0x07,
678 EfiMemoryTypeRom = 0x08,
679 EfiMemoryTypeFlash = 0x09,
680 EfiMemoryTypeEeprom = 0x0A,
681 EfiMemoryTypeFeprom = 0x0B,
682 EfiMemoryTypeEprom = 0x0C,
683 EfiMemoryTypeCdram = 0x0D,
684 EfiMemoryType3Dram = 0x0E,
685 EfiMemoryTypeSdram = 0x0F,
686 EfiMemoryTypeSgram = 0x10,
687 EfiMemoryTypeRdram = 0x11,
688 EfiMemoryTypeDdr = 0x12,
689 EfiMemoryTypeDdr2 = 0x13,
690 EfiMemoryTypeDdr2FbDimm = 0x14
691 } EFI_MEMORY_ARRAY_TYPE;
692
693 typedef struct {
694 UINT32 Reserved :1;
695 UINT32 Other :1;
696 UINT32 Unknown :1;
697 UINT32 FastPaged :1;
698 UINT32 StaticColumn :1;
699 UINT32 PseudoStatic :1;
700 UINT32 Rambus :1;
701 UINT32 Synchronous :1;
702 UINT32 Cmos :1;
703 UINT32 Edo :1;
704 UINT32 WindowDram :1;
705 UINT32 CacheDram :1;
706 UINT32 Nonvolatile :1;
707 UINT32 Reserved1 :19;
708 } EFI_MEMORY_TYPE_DETAIL;
709
710 typedef enum {
711 EfiMemoryStateEnabled = 0,
712 EfiMemoryStateUnknown = 1,
713 EfiMemoryStateUnsupported = 2,
714 EfiMemoryStateError = 3,
715 EfiMemoryStateAbsent = 4,
716 EfiMemoryStateDisabled = 5,
717 EfiMemoryStatePartial = 6
718 } EFI_MEMORY_STATE;
719
720 typedef struct {
721 STRING_REF MemoryDeviceLocator;
722 STRING_REF MemoryBankLocator;
723 STRING_REF MemoryManufacturer;
724 STRING_REF MemorySerialNumber;
725 STRING_REF MemoryAssetTag;
726 STRING_REF MemoryPartNumber;
727 EFI_INTER_LINK_DATA MemoryArrayLink;
728 EFI_INTER_LINK_DATA MemorySubArrayLink;
729 UINT16 MemoryTotalWidth;
730 UINT16 MemoryDataWidth;
731 EFI_EXP_BASE2_DATA MemoryDeviceSize;
732 EFI_MEMORY_FORM_FACTOR MemoryFormFactor;
733 UINT8 MemoryDeviceSet;
734 EFI_MEMORY_ARRAY_TYPE MemoryType;
735 EFI_MEMORY_TYPE_DETAIL MemoryTypeDetail;
736 EFI_EXP_BASE10_DATA MemorySpeed;
737 EFI_MEMORY_STATE MemoryState;
738 } EFI_MEMORY_ARRAY_LINK_DATA;
739
740
741 #define EFI_MEMORY_ARRAY_START_ADDRESS_RECORD_NUMBER 0x00000004
742
743 typedef struct {
744 EFI_PHYSICAL_ADDRESS MemoryArrayStartAddress;
745 EFI_PHYSICAL_ADDRESS MemoryArrayEndAddress;
746 EFI_INTER_LINK_DATA PhysicalMemoryArrayLink;
747 UINT16 MemoryArrayPartitionWidth;
748 } EFI_MEMORY_ARRAY_START_ADDRESS_DATA;
749
750
751 #define EFI_MEMORY_DEVICE_START_ADDRESS_RECORD_NUMBER 0x00000005
752
753 typedef struct {
754 EFI_PHYSICAL_ADDRESS MemoryDeviceStartAddress;
755 EFI_PHYSICAL_ADDRESS MemoryDeviceEndAddress;
756 EFI_INTER_LINK_DATA PhysicalMemoryDeviceLink;
757 EFI_INTER_LINK_DATA PhysicalMemoryArrayLink;
758 UINT8 MemoryDevicePartitionRowPosition;
759 UINT8 MemoryDeviceInterleavePosition;
760 UINT8 MemoryDeviceInterleaveDataDepth;
761 } EFI_MEMORY_DEVICE_START_ADDRESS_DATA;
762
763
764 //
765 // Memory. Channel Device Type - SMBIOS Type 37
766 //
767
768 #define EFI_MEMORY_CHANNEL_TYPE_RECORD_NUMBER 0x00000006
769
770 typedef enum _EFI_MEMORY_CHANNEL_TYPE {
771 EfiMemoryChannelTypeOther = 1,
772 EfiMemoryChannelTypeUnknown = 2,
773 EfiMemoryChannelTypeRambus = 3,
774 EfiMemoryChannelTypeSyncLink = 4
775 } EFI_MEMORY_CHANNEL_TYPE;
776
777 typedef struct {
778 EFI_MEMORY_CHANNEL_TYPE MemoryChannelType;
779 UINT8 MemoryChannelMaximumLoad;
780 UINT8 MemoryChannelDeviceCount;
781 } EFI_MEMORY_CHANNEL_TYPE_DATA;
782
783 #define EFI_MEMORY_CHANNEL_DEVICE_RECORD_NUMBER 0x00000007
784
785 typedef struct {
786 UINT8 DeviceId;
787 EFI_INTER_LINK_DATA DeviceLink;
788 UINT8 MemoryChannelDeviceLoad;
789 } EFI_MEMORY_CHANNEL_DEVICE_DATA;
790
791
792
793 typedef union _EFI_MEMORY_SUBCLASS_RECORDS {
794 EFI_MEMORY_SIZE_DATA SizeData;
795 EFI_MEMORY_ARRAY_LOCATION_DATA ArrayLocationData;
796 EFI_MEMORY_ARRAY_LINK_DATA ArrayLink;
797 EFI_MEMORY_ARRAY_START_ADDRESS_DATA ArrayStartAddress;
798 EFI_MEMORY_DEVICE_START_ADDRESS_DATA DeviceStartAddress;
799 EFI_MEMORY_CHANNEL_TYPE_DATA ChannelTypeData;
800 EFI_MEMORY_CHANNEL_DEVICE_DATA ChannelDeviceData;
801 } EFI_MEMORY_SUBCLASS_RECORDS;
802
803 typedef struct {
804 EFI_SUBCLASS_TYPE1_HEADER Header;
805 EFI_MEMORY_SUBCLASS_RECORDS Record;
806 } EFI_MEMORY_SUBCLASS_DRIVER_DATA;
807
808 #define EFI_MISC_SUBCLASS_VERSION 0x0100
809
810 #pragma pack(1)
811 //
812 //////////////////////////////////////////////////////////////////////////////
813 //
814 // Last PCI Bus Number
815 //
816 #define EFI_MISC_LAST_PCI_BUS_RECORD_NUMBER 0x00000001
817
818 typedef struct {
819 UINT8 LastPciBus;
820 } EFI_MISC_LAST_PCI_BUS_DATA;
821
822 //
823 //////////////////////////////////////////////////////////////////////////////
824 //
825 // Misc. BIOS Vendor - SMBIOS Type 0
826 //
827 #define EFI_MISC_BIOS_VENDOR_RECORD_NUMBER 0x00000002
828
829 typedef struct {
830 UINT64 Reserved1 :2;
831 UINT64 Unknown :1;
832 UINT64 BiosCharacteristicsNotSupported :1;
833 UINT64 IsaIsSupported :1;
834 UINT64 McaIsSupported :1;
835 UINT64 EisaIsSupported :1;
836 UINT64 PciIsSupported :1;
837 UINT64 PcmciaIsSupported :1;
838 UINT64 PlugAndPlayIsSupported :1;
839 UINT64 ApmIsSupported :1;
840 UINT64 BiosIsUpgradable :1;
841 UINT64 BiosShadowingAllowed :1;
842 UINT64 VlVesaIsSupported :1;
843 UINT64 EscdSupportIsAvailable :1;
844 UINT64 BootFromCdIsSupported :1;
845 UINT64 SelectableBootIsSupported :1;
846 UINT64 RomBiosIsSocketed :1;
847 UINT64 BootFromPcmciaIsSupported :1;
848 UINT64 EDDSpecificationIsSupported :1;
849 UINT64 JapaneseNecFloppyIsSupported :1;
850 UINT64 JapaneseToshibaFloppyIsSupported :1;
851 UINT64 Floppy525_360IsSupported :1;
852 UINT64 Floppy525_12IsSupported :1;
853 UINT64 Floppy35_720IsSupported :1;
854 UINT64 Floppy35_288IsSupported :1;
855 UINT64 PrintScreenIsSupported :1;
856 UINT64 Keyboard8042IsSupported :1;
857 UINT64 SerialIsSupported :1;
858 UINT64 PrinterIsSupported :1;
859 UINT64 CgaMonoIsSupported :1;
860 UINT64 NecPc98 :1;
861 UINT64 AcpiIsSupported :1;
862 UINT64 UsbLegacyIsSupported :1;
863 UINT64 AgpIsSupported :1;
864 UINT64 I20BootIsSupported :1;
865 UINT64 Ls120BootIsSupported :1;
866 UINT64 AtapiZipDriveBootIsSupported :1;
867 UINT64 Boot1394IsSupported :1;
868 UINT64 SmartBatteryIsSupported :1;
869 UINT64 BiosBootSpecIsSupported :1;
870 UINT64 FunctionKeyNetworkBootIsSupported :1;
871 UINT64 Reserved :22;
872 } EFI_MISC_BIOS_CHARACTERISTICS;
873
874 typedef struct {
875 UINT64 BiosReserved :16;
876 UINT64 SystemReserved :16;
877 UINT64 Reserved :32;
878 } EFI_MISC_BIOS_CHARACTERISTICS_EXTENSION;
879
880 typedef struct {
881 STRING_REF BiosVendor;
882 STRING_REF BiosVersion;
883 STRING_REF BiosReleaseDate;
884 EFI_PHYSICAL_ADDRESS BiosStartingAddress;
885 EFI_EXP_BASE2_DATA BiosPhysicalDeviceSize;
886 EFI_MISC_BIOS_CHARACTERISTICS BiosCharacteristics1;
887 EFI_MISC_BIOS_CHARACTERISTICS_EXTENSION BiosCharacteristics2;
888 UINT8 BiosMajorRelease;
889 UINT8 BiosMinorRelease;
890 UINT8 BiosEmbeddedFirmwareMajorRelease;
891 UINT8 BiosEmbeddedFirmwareMinorRelease;
892 } EFI_MISC_BIOS_VENDOR_DATA;
893
894 //
895 //////////////////////////////////////////////////////////////////////////////
896 //
897 // Misc. System Manufacturer - SMBIOS Type 1
898 //
899 #define EFI_MISC_SYSTEM_MANUFACTURER_RECORD_NUMBER 0x00000003
900
901 typedef enum {
902 EfiSystemWakeupTypeReserved = 0,
903 EfiSystemWakeupTypeOther = 1,
904 EfiSystemWakeupTypeUnknown = 2,
905 EfiSystemWakeupTypeApmTimer = 3,
906 EfiSystemWakeupTypeModemRing = 4,
907 EfiSystemWakeupTypeLanRemote = 5,
908 EfiSystemWakeupTypePowerSwitch = 6,
909 EfiSystemWakeupTypePciPme = 7,
910 EfiSystemWakeupTypeAcPowerRestored = 8,
911 } EFI_MISC_SYSTEM_WAKEUP_TYPE;
912
913 typedef struct {
914 STRING_REF SystemManufacturer;
915 STRING_REF SystemProductName;
916 STRING_REF SystemVersion;
917 STRING_REF SystemSerialNumber;
918 EFI_GUID SystemUuid;
919 EFI_MISC_SYSTEM_WAKEUP_TYPE SystemWakeupType;
920 STRING_REF SystemSKUNumber;
921 STRING_REF SystemFamily;
922 } EFI_MISC_SYSTEM_MANUFACTURER_DATA;
923
924 //
925 //////////////////////////////////////////////////////////////////////////////
926 //
927 // Misc. Base Board Manufacturer - SMBIOS Type 2
928 //
929 #define EFI_MISC_BASE_BOARD_MANUFACTURER_RECORD_NUMBER 0x00000004
930
931 typedef struct {
932 UINT32 Motherboard :1;
933 UINT32 RequiresDaughterCard :1;
934 UINT32 Removable :1;
935 UINT32 Replaceable :1;
936 UINT32 HotSwappable :1;
937 UINT32 Reserved :27;
938 } EFI_BASE_BOARD_FEATURE_FLAGS;
939
940 typedef enum {
941 EfiBaseBoardTypeUnknown = 1,
942 EfiBaseBoardTypeOther = 2,
943 EfiBaseBoardTypeServerBlade = 3,
944 EfiBaseBoardTypeConnectivitySwitch = 4,
945 EfiBaseBoardTypeSystemManagementModule = 5,
946 EfiBaseBoardTypeProcessorModule = 6,
947 EfiBaseBoardTypeIOModule = 7,
948 EfiBaseBoardTypeMemoryModule = 8,
949 EfiBaseBoardTypeDaughterBoard = 9,
950 EfiBaseBoardTypeMotherBoard = 0xA,
951 EfiBaseBoardTypeProcessorMemoryModule = 0xB,
952 EfiBaseBoardTypeProcessorIOModule = 0xC,
953 EfiBaseBoardTypeInterconnectBoard = 0xD,
954 } EFI_BASE_BOARD_TYPE;
955
956 typedef struct {
957 STRING_REF BaseBoardManufacturer;
958 STRING_REF BaseBoardProductName;
959 STRING_REF BaseBoardVersion;
960 STRING_REF BaseBoardSerialNumber;
961 STRING_REF BaseBoardAssetTag;
962 STRING_REF BaseBoardChassisLocation;
963 EFI_BASE_BOARD_FEATURE_FLAGS BaseBoardFeatureFlags;
964 EFI_BASE_BOARD_TYPE BaseBoardType;
965 EFI_INTER_LINK_DATA BaseBoardChassisLink;
966 UINT32 BaseBoardNumberLinks;
967 EFI_INTER_LINK_DATA LinkN;
968 } EFI_MISC_BASE_BOARD_MANUFACTURER_DATA;
969
970 //
971 //////////////////////////////////////////////////////////////////////////////
972 //
973 // Misc. System/Chassis Enclosure - SMBIOS Type 3
974 //
975 #define EFI_MISC_CHASSIS_MANUFACTURER_RECORD_NUMBER 0x00000005
976
977 typedef enum {
978 EfiMiscChassisTypeOther = 0x1,
979 EfiMiscChassisTypeUnknown = 0x2,
980 EfiMiscChassisTypeDeskTop = 0x3,
981 EfiMiscChassisTypeLowProfileDesktop = 0x4,
982 EfiMiscChassisTypePizzaBox = 0x5,
983 EfiMiscChassisTypeMiniTower = 0x6,
984 EfiMiscChassisTypeTower = 0x7,
985 EfiMiscChassisTypePortable = 0x8,
986 EfiMiscChassisTypeLapTop = 0x9,
987 EfiMiscChassisTypeNotebook = 0xA,
988 EfiMiscChassisTypeHandHeld = 0xB,
989 EfiMiscChassisTypeDockingStation = 0xC,
990 EfiMiscChassisTypeAllInOne = 0xD,
991 EfiMiscChassisTypeSubNotebook = 0xE,
992 EfiMiscChassisTypeSpaceSaving = 0xF,
993 EfiMiscChassisTypeLunchBox = 0x10,
994 EfiMiscChassisTypeMainServerChassis = 0x11,
995 EfiMiscChassisTypeExpansionChassis = 0x12,
996 EfiMiscChassisTypeSubChassis = 0x13,
997 EfiMiscChassisTypeBusExpansionChassis = 0x14,
998 EfiMiscChassisTypePeripheralChassis = 0x15,
999 EfiMiscChassisTypeRaidChassis = 0x16,
1000 EfiMiscChassisTypeRackMountChassis = 0x17,
1001 EfiMiscChassisTypeSealedCasePc = 0x18,
1002 EfiMiscChassisMultiSystemChassis = 0x19,
1003 } EFI_MISC_CHASSIS_TYPE;
1004
1005 typedef struct {
1006 UINT32 ChassisType :16;
1007 UINT32 ChassisLockPresent:1;
1008 UINT32 Reserved :15;
1009 } EFI_MISC_CHASSIS_STATUS;
1010
1011 typedef enum {
1012 EfiChassisStateOther = 0x01,
1013 EfiChassisStateUnknown = 0x02,
1014 EfiChassisStateSafe = 0x03,
1015 EfiChassisStateWarning = 0x04,
1016 EfiChassisStateCritical = 0x05,
1017 EfiChassisStateNonRecoverable = 0x06,
1018 } EFI_MISC_CHASSIS_STATE;
1019
1020 typedef enum {
1021 EfiChassisSecurityStatusOther = 0x01,
1022 EfiChassisSecurityStatusUnknown = 0x02,
1023 EfiChassisSecurityStatusNone = 0x03,
1024 EfiChassisSecurityStatusExternalInterfaceLockedOut = 0x04,
1025 EfiChassisSecurityStatusExternalInterfaceLockedEnabled = 0x05,
1026 } EFI_MISC_CHASSIS_SECURITY_STATE;
1027
1028 typedef struct {
1029 UINT32 RecordType :1;
1030 UINT32 Reserved :24;
1031 } EFI_MISC_ELEMENT_TYPE;
1032
1033 typedef struct {
1034 EFI_MISC_ELEMENT_TYPE ChassisElementType;
1035 EFI_INTER_LINK_DATA ChassisElementStructure;
1036 EFI_BASE_BOARD_TYPE ChassisBaseBoard;
1037 UINT32 ChassisElementMinimum;
1038 UINT32 ChassisElementMaximum;
1039 } EFI_MISC_ELEMENTS;
1040
1041 typedef struct {
1042 STRING_REF ChassisManufacturer;
1043 STRING_REF ChassisVersion;
1044 STRING_REF ChassisSerialNumber;
1045 STRING_REF ChassisAssetTag;
1046 EFI_MISC_CHASSIS_STATUS ChassisType;
1047 EFI_MISC_CHASSIS_STATE ChassisBootupState;
1048 EFI_MISC_CHASSIS_STATE ChassisPowerSupplyState;
1049 EFI_MISC_CHASSIS_STATE ChassisThermalState;
1050 EFI_MISC_CHASSIS_SECURITY_STATE ChassisSecurityState;
1051 UINT32 ChassisOemDefined;
1052 UINT32 ChassisHeight;
1053 UINT32 ChassisNumberPowerCords;
1054 UINT32 ChassisElementCount;
1055 UINT32 ChassisElementRecordLength;//
1056 EFI_MISC_ELEMENTS ChassisElements;
1057 } EFI_MISC_CHASSIS_MANUFACTURER_DATA;
1058
1059 //
1060 //////////////////////////////////////////////////////////////////////////////
1061 //
1062 // Misc. Port Connector Information - SMBIOS Type 8
1063 //
1064 #define EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_RECORD_NUMBER 0x00000006
1065
1066 typedef enum {
1067 EfiPortConnectorTypeNone = 0x00,
1068 EfiPortConnectorTypeCentronics = 0x01,
1069 EfiPortConnectorTypeMiniCentronics = 0x02,
1070 EfiPortConnectorTypeProprietary = 0x03,
1071 EfiPortConnectorTypeDB25Male = 0x04,
1072 EfiPortConnectorTypeDB25Female = 0x05,
1073 EfiPortConnectorTypeDB15Male = 0x06,
1074 EfiPortConnectorTypeDB15Female = 0x07,
1075 EfiPortConnectorTypeDB9Male = 0x08,
1076 EfiPortConnectorTypeDB9Female = 0x09,
1077 EfiPortConnectorTypeRJ11 = 0x0A,
1078 EfiPortConnectorTypeRJ45 = 0x0B,
1079 EfiPortConnectorType50PinMiniScsi = 0x0C,
1080 EfiPortConnectorTypeMiniDin = 0x0D,
1081 EfiPortConnectorTypeMicriDin = 0x0E,
1082 EfiPortConnectorTypePS2 = 0x0F,
1083 EfiPortConnectorTypeInfrared = 0x10,
1084 EfiPortConnectorTypeHpHil = 0x11,
1085 EfiPortConnectorTypeUsb = 0x12,
1086 EfiPortConnectorTypeSsaScsi = 0x13,
1087 EfiPortConnectorTypeCircularDin8Male = 0x14,
1088 EfiPortConnectorTypeCircularDin8Female = 0x15,
1089 EfiPortConnectorTypeOnboardIde = 0x16,
1090 EfiPortConnectorTypeOnboardFloppy = 0x17,
1091 EfiPortConnectorType9PinDualInline = 0x18,
1092 EfiPortConnectorType25PinDualInline = 0x19,
1093 EfiPortConnectorType50PinDualInline = 0x1A,
1094 EfiPortConnectorType68PinDualInline = 0x1B,
1095 EfiPortConnectorTypeOnboardSoundInput = 0x1C,
1096 EfiPortConnectorTypeMiniCentronicsType14 = 0x1D,
1097 EfiPortConnectorTypeMiniCentronicsType26 = 0x1E,
1098 EfiPortConnectorTypeHeadPhoneMiniJack = 0x1F,
1099 EfiPortConnectorTypeBNC = 0x20,
1100 EfiPortConnectorType1394 = 0x21,
1101 EfiPortConnectorTypePC98 = 0xA0,
1102 EfiPortConnectorTypePC98Hireso = 0xA1,
1103 EfiPortConnectorTypePCH98 = 0xA2,
1104 EfiPortConnectorTypePC98Note = 0xA3,
1105 EfiPortConnectorTypePC98Full = 0xA4,
1106 EfiPortConnectorTypeOther = 0xFF,
1107 } EFI_MISC_PORT_CONNECTOR_TYPE;
1108
1109 typedef enum {
1110 EfiPortTypeNone = 0x00,
1111 EfiPortTypeParallelXtAtCompatible = 0x01,
1112 EfiPortTypeParallelPortPs2 = 0x02,
1113 EfiPortTypeParallelPortEcp = 0x03,
1114 EfiPortTypeParallelPortEpp = 0x04,
1115 EfiPortTypeParallelPortEcpEpp = 0x05,
1116 EfiPortTypeSerialXtAtCompatible = 0x06,
1117 EfiPortTypeSerial16450Compatible = 0x07,
1118 EfiPortTypeSerial16550Compatible = 0x08,
1119 EfiPortTypeSerial16550ACompatible = 0x09,
1120 EfiPortTypeScsi = 0x0A,
1121 EfiPortTypeMidi = 0x0B,
1122 EfiPortTypeJoyStick = 0x0C,
1123 EfiPortTypeKeyboard = 0x0D,
1124 EfiPortTypeMouse = 0x0E,
1125 EfiPortTypeSsaScsi = 0x0F,
1126 EfiPortTypeUsb = 0x10,
1127 EfiPortTypeFireWire = 0x11,
1128 EfiPortTypePcmciaTypeI = 0x12,
1129 EfiPortTypePcmciaTypeII = 0x13,
1130 EfiPortTypePcmciaTypeIII = 0x14,
1131 EfiPortTypeCardBus = 0x15,
1132 EfiPortTypeAccessBusPort = 0x16,
1133 EfiPortTypeScsiII = 0x17,
1134 EfiPortTypeScsiWide = 0x18,
1135 EfiPortTypePC98 = 0x19,
1136 EfiPortTypePC98Hireso = 0x1A,
1137 EfiPortTypePCH98 = 0x1B,
1138 EfiPortTypeVideoPort = 0x1C,
1139 EfiPortTypeAudioPort = 0x1D,
1140 EfiPortTypeModemPort = 0x1E,
1141 EfiPortTypeNetworkPort = 0x1F,
1142 EfiPortType8251Compatible = 0xA0,
1143 EfiPortType8251FifoCompatible = 0xA1,
1144 EfiPortTypeOther = 0xFF,
1145 } EFI_MISC_PORT_TYPE;
1146
1147 typedef struct {
1148 STRING_REF PortInternalConnectorDesignator;
1149 STRING_REF PortExternalConnectorDesignator;
1150 EFI_MISC_PORT_CONNECTOR_TYPE PortInternalConnectorType;
1151 EFI_MISC_PORT_CONNECTOR_TYPE PortExternalConnectorType;
1152 EFI_MISC_PORT_TYPE PortType;
1153 EFI_MISC_PORT_DEVICE_PATH PortPath;
1154 } EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA;
1155
1156 //
1157 //////////////////////////////////////////////////////////////////////////////
1158 //
1159 // Misc. System Slots - SMBIOS Type 9
1160 //
1161 #define EFI_MISC_SYSTEM_SLOT_DESIGNATION_RECORD_NUMBER 0x00000007
1162
1163 typedef enum {
1164 EfiSlotTypeOther = 0x01,
1165 EfiSlotTypeUnknown = 0x02,
1166 EfiSlotTypeIsa = 0x03,
1167 EfiSlotTypeMca = 0x04,
1168 EfiSlotTypeEisa = 0x05,
1169 EfiSlotTypePci = 0x06,
1170 EfiSlotTypePcmcia = 0x07,
1171 EfiSlotTypeVlVesa = 0x08,
1172 EfiSlotTypeProprietary = 0x09,
1173 EfiSlotTypeProcessorCardSlot = 0x0A,
1174 EfiSlotTypeProprietaryMemoryCardSlot = 0x0B,
1175 EfiSlotTypeIORiserCardSlot = 0x0C,
1176 EfiSlotTypeNuBus = 0x0D,
1177 EfiSlotTypePci66MhzCapable = 0x0E,
1178 EfiSlotTypeAgp = 0x0F,
1179 EfiSlotTypeApg2X = 0x10,
1180 EfiSlotTypeAgp4X = 0x11,
1181 EfiSlotTypePciX = 0x12,
1182 EfiSlotTypeAgp4x = 0x13,
1183 EfiSlotTypePC98C20 = 0xA0,
1184 EfiSlotTypePC98C24 = 0xA1,
1185 EfiSlotTypePC98E = 0xA2,
1186 EfiSlotTypePC98LocalBus = 0xA3,
1187 EfiSlotTypePC98Card = 0xA4,
1188 EfiSlotTypePciExpress = 0xA5
1189 } EFI_MISC_SLOT_TYPE;
1190
1191 typedef enum {
1192 EfiSlotDataBusWidthOther = 0x01,
1193 EfiSlotDataBusWidthUnknown = 0x02,
1194 EfiSlotDataBusWidth8Bit = 0x03,
1195 EfiSlotDataBusWidth16Bit = 0x04,
1196 EfiSlotDataBusWidth32Bit = 0x05,
1197 EfiSlotDataBusWidth64Bit = 0x06,
1198 EfiSlotDataBusWidth128Bit = 0x07,
1199 } EFI_MISC_SLOT_DATA_BUS_WIDTH;
1200
1201 typedef enum {
1202 EfiSlotUsageOther = 1,
1203 EfiSlotUsageUnknown = 2,
1204 EfiSlotUsageAvailable = 3,
1205 EfiSlotUsageInUse = 4,
1206 } EFI_MISC_SLOT_USAGE;
1207
1208 typedef enum {
1209 EfiSlotLengthOther = 1,
1210 EfiSlotLengthUnknown = 2,
1211 EfiSlotLengthShort = 3,
1212 EfiSlotLengthLong = 4
1213 } EFI_MISC_SLOT_LENGTH;
1214
1215 typedef struct {
1216 UINT32 CharacteristicsUnknown :1;
1217 UINT32 Provides50Volts :1;
1218 UINT32 Provides33Volts :1;
1219 UINT32 SharedSlot :1;
1220 UINT32 PcCard16Supported :1;
1221 UINT32 CardBusSupported :1;
1222 UINT32 ZoomVideoSupported :1;
1223 UINT32 ModemRingResumeSupported:1;
1224 UINT32 PmeSignalSupported :1;
1225 UINT32 HotPlugDevicesSupported :1;
1226 UINT32 SmbusSignalSupported :1;
1227 UINT32 Reserved :21;
1228 } EFI_MISC_SLOT_CHARACTERISTICS;
1229
1230 typedef struct {
1231 STRING_REF SlotDesignation;
1232 EFI_MISC_SLOT_TYPE SlotType;
1233 EFI_MISC_SLOT_DATA_BUS_WIDTH SlotDataBusWidth;
1234 EFI_MISC_SLOT_USAGE SlotUsage;
1235 EFI_MISC_SLOT_LENGTH SlotLength;
1236 UINT16 SlotId;
1237 EFI_MISC_SLOT_CHARACTERISTICS SlotCharacteristics;
1238 EFI_DEVICE_PATH_PROTOCOL SlotDevicePath;
1239 } EFI_MISC_SYSTEM_SLOT_DESIGNATION_DATA;
1240
1241 //
1242 //////////////////////////////////////////////////////////////////////////////
1243 //
1244 // Misc. Onboard Device - SMBIOS Type 10
1245 //
1246 #define EFI_MISC_ONBOARD_DEVICE_RECORD_NUMBER 0x00000008
1247
1248 typedef enum {
1249 EfiOnBoardDeviceTypeOther = 1,
1250 EfiOnBoardDeviceTypeUnknown = 2,
1251 EfiOnBoardDeviceTypeVideo = 3,
1252 EfiOnBoardDeviceTypeScsiController = 4,
1253 EfiOnBoardDeviceTypeEthernet = 5,
1254 EfiOnBoardDeviceTypeTokenRing = 6,
1255 EfiOnBoardDeviceTypeSound = 7,
1256 } EFI_MISC_ONBOARD_DEVICE_TYPE;
1257
1258 typedef struct {
1259 UINT32 DeviceType :16;
1260 UINT32 DeviceEnabled :1;
1261 UINT32 Reserved :15;
1262 } EFI_MISC_ONBOARD_DEVICE_STATUS;
1263
1264 typedef struct {
1265 STRING_REF OnBoardDeviceDescription;
1266 EFI_MISC_ONBOARD_DEVICE_STATUS OnBoardDeviceStatus;
1267 EFI_DEVICE_PATH_PROTOCOL OnBoardDevicePath;
1268 } EFI_MISC_ONBOARD_DEVICE_DATA;
1269
1270 //
1271 //////////////////////////////////////////////////////////////////////////////
1272 //
1273 // Misc. BIOS Language Information - SMBIOS Type 11
1274 //
1275 #define EFI_MISC_OEM_STRING_RECORD_NUMBER 0x00000009
1276
1277 typedef struct {
1278 STRING_REF OemStringRef[1];
1279 } EFI_MISC_OEM_STRING_DATA;
1280
1281 //
1282 //////////////////////////////////////////////////////////////////////////////
1283 //
1284 // Misc. System Options - SMBIOS Type 12
1285 //
1286 typedef struct {
1287 STRING_REF SystemOptionStringRef[1];
1288 } EFI_MISC_SYSTEM_OPTION_STRING_DATA;
1289
1290 #define EFI_MISC_SYSTEM_OPTION_STRING_RECORD_NUMBER 0x0000000A
1291
1292 //
1293 //////////////////////////////////////////////////////////////////////////////
1294 //
1295 // Misc. Number of Installable Languages - SMBIOS Type 13
1296 //
1297 #define EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_RECORD_NUMBER 0x0000000B
1298
1299 typedef struct {
1300 UINT32 AbbreviatedLanguageFormat :1;
1301 UINT32 Reserved :31;
1302 } EFI_MISC_LANGUAGE_FLAGS;
1303
1304 typedef struct {
1305 UINT16 NumberOfInstallableLanguages;
1306 EFI_MISC_LANGUAGE_FLAGS LanguageFlags;
1307 UINT16 CurrentLanguageNumber;
1308 } EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_DATA;
1309
1310 //
1311 //////////////////////////////////////////////////////////////////////////////
1312 //
1313 // Misc. System Language String
1314 //
1315 #define EFI_MISC_SYSTEM_LANGUAGE_STRING_RECORD_NUMBER 0x0000000C
1316
1317 typedef struct {
1318 UINT16 LanguageId;
1319 STRING_REF SystemLanguageString;
1320 } EFI_MISC_SYSTEM_LANGUAGE_STRING_DATA;
1321
1322 //
1323 //////////////////////////////////////////////////////////////////////////////
1324 //
1325 // Group Associations - SMBIOS Type 14
1326 //
1327 #define EFI_MISC_GROUP_NAME_RECORD_NUMBER 0x0000000D
1328
1329 typedef struct {
1330 STRING_REF GroupName;
1331 UINT16 NumberGroupItems;
1332 UINT16 GroupId;
1333 } EFI_MISC_GROUP_NAME_DATA;
1334
1335 //
1336 //////////////////////////////////////////////////////////////////////////////
1337 //
1338 // Group Item Set Element
1339 //
1340 #define EFI_MISC_GROUP_ITEM_SET_RECORD_NUMBER 0x0000000E
1341
1342 typedef struct {
1343 EFI_GUID SubClass;
1344 EFI_INTER_LINK_DATA GroupLink;
1345 UINT16 GroupId;
1346 UINT16 GroupElementId;
1347 } EFI_MISC_GROUP_ITEM_SET_DATA;
1348
1349 // Misc. System Event Log - SMBIOS Type 15
1350 //
1351 #define EFI_MISC_SYSTEM_EVENT_LOG_RECORD_NUMBER 0x0000000D
1352 typedef struct {
1353 UINT16 LogAreaLength;
1354 UINT16 LogHeaderStartOffset;
1355 UINT16 LogDataStartOffset;
1356 UINT8 AccessMethod;
1357 UINT8 LogStatus;
1358 UINT32 LogChangeToken;
1359 UINT32 AccessMethodAddress;
1360 UINT8 LogHeaderFormat;
1361 UINT8 NumberOfSupportedLogType;
1362 UINT8 LengthOfLogDescriptor;
1363 } EFI_MISC_SYSTEM_EVENT_LOG_DATA;
1364
1365 //
1366 // Access Method.
1367 // 0x00~0x04: as following definition
1368 // 0x05~0x7f: Available for future assignment.
1369 // 0x80~0xff: BIOS Vendor/OEM-specific.
1370 //
1371 #define ACCESS_INDEXIO_1INDEX8BIT_DATA8BIT 0x00
1372 #define ACCESS_INDEXIO_2INDEX8BIT_DATA8BIT 0X01
1373 #define ACCESS_INDEXIO_1INDEX16BIT_DATA8BIT 0X02
1374 #define ACCESS_MEMORY_MAPPED 0x03
1375 #define ACCESS_GPNV 0x04
1376
1377 //
1378 //////////////////////////////////////////////////////////////////////////////
1379 //
1380 // Misc. Pointing Device Type - SMBIOS Type 21
1381 //
1382 #define EFI_MISC_POINTING_DEVICE_TYPE_RECORD_NUMBER 0x0000000F
1383
1384 typedef enum {
1385 EfiPointingDeviceTypeOther = 0x01,
1386 EfiPointingDeviceTypeUnknown = 0x02,
1387 EfiPointingDeviceTypeMouse = 0x03,
1388 EfiPointingDeviceTypeTrackBall = 0x04,
1389 EfiPointingDeviceTypeTrackPoint = 0x05,
1390 EfiPointingDeviceTypeGlidePoint = 0x06,
1391 EfiPointingDeviceTouchPad = 0x07,
1392 EfiPointingDeviceTouchScreen = 0x08,
1393 EfiPointingDeviceOpticalSensor = 0x09,
1394 } EFI_MISC_POINTING_DEVICE_TYPE;
1395
1396 typedef enum {
1397 EfiPointingDeviceInterfaceOther = 0x01,
1398 EfiPointingDeviceInterfaceUnknown = 0x02,
1399 EfiPointingDeviceInterfaceSerial = 0x03,
1400 EfiPointingDeviceInterfacePs2 = 0x04,
1401 EfiPointingDeviceInterfaceInfrared = 0x05,
1402 EfiPointingDeviceInterfaceHpHil = 0x06,
1403 EfiPointingDeviceInterfaceBusMouse = 0x07,
1404 EfiPointingDeviceInterfaceADB = 0x08,
1405 EfiPointingDeviceInterfaceBusMouseDB9 = 0xA0,
1406 EfiPointingDeviceInterfaceBusMouseMicroDin = 0xA1,
1407 EfiPointingDeviceInterfaceUsb = 0xA2,
1408 } EFI_MISC_POINTING_DEVICE_INTERFACE;
1409
1410 typedef struct {
1411 EFI_MISC_POINTING_DEVICE_TYPE PointingDeviceType;
1412 EFI_MISC_POINTING_DEVICE_INTERFACE PointingDeviceInterface;
1413 UINT16 NumberPointingDeviceButtons;
1414 EFI_DEVICE_PATH_PROTOCOL PointingDevicePath;
1415 } EFI_MISC_PORTING_DEVICE_TYPE_DATA;
1416
1417 //
1418 //////////////////////////////////////////////////////////////////////////////
1419 //
1420 // Portable Battery - SMBIOS Type 22
1421 //
1422 #define EFI_MISC_BATTERY_LOCATION_RECORD_NUMBER 0x00000010
1423
1424 typedef enum {
1425 EfiBatteryDeviceChemistryTypeOther = 0x01,
1426 EfiBatteryDeviceChemistryTypeUnknown = 0x02,
1427 EfiBatteryDeviceChemistryTypeLeadAcid = 0x03,
1428 EfiBatteryDeviceChemistryTypeNickelCadmium = 0x04,
1429 EfiBatteryDeviceChemistryTypeNickelMetalHydride = 0x05,
1430 EfiBatteryDeviceChemistryTypeLithiumIon = 0x06,
1431 EfiBatteryDeviceChemistryTypeZincAir = 0x07,
1432 EfiBatteryDeviceChemistryTypeLithiumPolymer = 0x08,
1433 } EFI_MISC_BATTERY_DEVICE_CHEMISTRY;
1434
1435 typedef struct {
1436 UINT32 Date :5;
1437 UINT32 Month :4;
1438 UINT32 Year :7;
1439 UINT32 Reserved :16;
1440 } EFI_MISC_BATTERY_SBDS_MANUFACTURE_DATE;
1441
1442 typedef struct {
1443 STRING_REF BatteryLocation;
1444 STRING_REF BatteryManufacturer;
1445 STRING_REF BatteryManufactureDate;
1446 STRING_REF BatterySerialNumber;
1447 STRING_REF BatteryDeviceName;
1448 STRING_REF BatterySbdsVersionNumber;
1449 STRING_REF BatterySbdsDeviceChemistry;
1450 EFI_MISC_BATTERY_DEVICE_CHEMISTRY BatteryDeviceChemistry;
1451 EFI_EXP_BASE10_DATA BatteryDesignCapacity;
1452 EFI_EXP_BASE10_DATA BatteryDesignVoltage;
1453 UINT16 BatteryMaximumError;
1454 UINT16 BatterySbdsSerialNumber;
1455 EFI_MISC_BATTERY_SBDS_MANUFACTURE_DATE
1456 BatterySbdsManufacturingDate;
1457 UINT32 BatteryOemSpecific;
1458 } EFI_MISC_BATTERY_LOCATION_DATA;
1459
1460 //
1461 //////////////////////////////////////////////////////////////////////////////
1462 //
1463 // Misc. Reset Capabilities - SMBIOS Type 23
1464 //
1465 #define EFI_MISC_RESET_CAPABILITIES_RECORD_NUMBER 0x00000011
1466
1467 typedef struct {
1468 UINT32 Status :1;
1469 UINT32 BootOption :2;
1470 UINT32 BootOptionOnLimit :2;
1471 UINT32 WatchdogTimerPresent:1;
1472 UINT32 Reserved :26;
1473 } EFI_MISC_RESET_CAPABILITIES_TYPE;
1474
1475 typedef struct {
1476 EFI_MISC_RESET_CAPABILITIES_TYPE ResetCapabilities;
1477 UINT16 ResetCount;
1478 UINT16 ResetLimit;
1479 UINT16 ResetTimerInterval;
1480 UINT16 ResetTimeout;
1481 } EFI_MISC_RESET_CAPABILITIES;
1482
1483 typedef struct {
1484 EFI_MISC_RESET_CAPABILITIES ResetCapabilities;
1485 UINT16 ResetCount;
1486 UINT16 ResetLimit;
1487 UINT16 ResetTimerInterval;
1488 UINT16 ResetTimeout;
1489 } EFI_MISC_RESET_CAPABILITIES_DATA;
1490
1491 //
1492 //////////////////////////////////////////////////////////////////////////////
1493 //
1494 // Misc. Hardware Security - SMBIOS Type 24
1495 //
1496 #define EFI_MISC_HARDWARE_SECURITY_RECORD_NUMBER 0x00000012
1497
1498 typedef enum {
1499 EfiHardwareSecurityStatusDisabled = 0,
1500 EfiHardwareSecurityStatusEnabled = 1,
1501 EfiHardwareSecurityStatusNotImplemented = 2,
1502 EfiHardwareSecurityStatusUnknown = 3
1503 } EFI_MISC_HARDWARE_SECURITY_STATUS;
1504
1505 typedef struct {
1506 EFI_MISC_HARDWARE_SECURITY_STATUS FrontPanelResetStatus :2;
1507 EFI_MISC_HARDWARE_SECURITY_STATUS AdministratorPasswordStatus :2;
1508 EFI_MISC_HARDWARE_SECURITY_STATUS KeyboardPasswordStatus :2;
1509 EFI_MISC_HARDWARE_SECURITY_STATUS PowerOnPasswordStatus :2;
1510 EFI_MISC_HARDWARE_SECURITY_STATUS Reserved :24;
1511 } EFI_MISC_HARDWARE_SECURITY_SETTINGS;
1512
1513 typedef struct {
1514 EFI_MISC_HARDWARE_SECURITY_SETTINGS HardwareSecuritySettings;
1515 } EFI_MISC_HARDWARE_SECURITY_SETTINGS_DATA;
1516
1517 //
1518 //////////////////////////////////////////////////////////////////////////////
1519 //
1520 // System Power Controls - SMBIOS Type 25
1521 //
1522 #define EFI_MISC_SCHEDULED_POWER_ON_MONTH_RECORD_NUMBER 0x00000013
1523
1524 typedef struct {
1525 UINT16 ScheduledPoweronMonth;
1526 UINT16 ScheduledPoweronDayOfMonth;
1527 UINT16 ScheduledPoweronHour;
1528 UINT16 ScheduledPoweronMinute;
1529 UINT16 ScheduledPoweronSecond;
1530 } EFI_MISC_SCHEDULED_POWER_ON_MONTH_DATA;
1531
1532 //
1533 //////////////////////////////////////////////////////////////////////////////
1534 //
1535 // Voltage Probe - SMBIOS Type 26
1536 //
1537 #define EFI_MISC_VOLTAGE_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000014
1538
1539 typedef struct {
1540 UINT32 VoltageProbeSite :5;
1541 UINT32 VoltageProbeStatus :3;
1542 UINT32 Reserved :24;
1543 } EFI_MISC_VOLTAGE_PROBE_LOCATION;
1544
1545 typedef struct {
1546 STRING_REF VoltageProbeDescription;
1547 EFI_MISC_VOLTAGE_PROBE_LOCATION VoltageProbeLocation;
1548 EFI_EXP_BASE10_DATA VoltageProbeMaximumValue;
1549 EFI_EXP_BASE10_DATA VoltageProbeMinimumValue;
1550 EFI_EXP_BASE10_DATA VoltageProbeResolution;
1551 EFI_EXP_BASE10_DATA VoltageProbeTolerance;
1552 EFI_EXP_BASE10_DATA VoltageProbeAccuracy;
1553 EFI_EXP_BASE10_DATA VoltageProbeNominalValue;
1554 EFI_EXP_BASE10_DATA MDLowerNoncriticalThreshold;
1555 EFI_EXP_BASE10_DATA MDUpperNoncriticalThreshold;
1556 EFI_EXP_BASE10_DATA MDLowerCriticalThreshold;
1557 EFI_EXP_BASE10_DATA MDUpperCriticalThreshold;
1558 EFI_EXP_BASE10_DATA MDLowerNonrecoverableThreshold;
1559 EFI_EXP_BASE10_DATA MDUpperNonrecoverableThreshold;
1560 UINT32 VoltageProbeOemDefined;
1561 } EFI_MISC_VOLTAGE_PROBE_DESCRIPTION_DATA;
1562
1563 //
1564 //////////////////////////////////////////////////////////////////////////////
1565 //
1566 // Cooling Device - SMBIOS Type 27
1567 //
1568 #define EFI_MISC_COOLING_DEVICE_TEMP_LINK_RECORD_NUMBER 0x00000015
1569
1570 typedef struct {
1571 UINT32 CoolingDevice :5;
1572 UINT32 CoolingDeviceStatus :3;
1573 UINT32 Reserved :24;
1574 } EFI_MISC_COOLING_DEVICE_TYPE;
1575
1576 typedef struct {
1577 EFI_MISC_COOLING_DEVICE_TYPE CoolingDeviceType;
1578 EFI_INTER_LINK_DATA CoolingDeviceTemperatureLink;
1579 UINT16 CoolingDeviceUnitGroup;
1580 EFI_EXP_BASE10_DATA CoolingDeviceNominalSpeed;
1581 UINT32 CoolingDeviceOemDefined;
1582 } EFI_MISC_COOLING_DEVICE_TEMP_LINK_DATA;
1583
1584 //
1585 //////////////////////////////////////////////////////////////////////////////
1586 //
1587 // Temperature Probe - SMBIOS Type 28
1588 //
1589 #define EFI_MISC_TEMPERATURE_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000016
1590
1591 typedef struct {
1592 UINT32 TemperatureProbeSite :5;
1593 UINT32 TemperatureProbeStatus :3;
1594 UINT32 Reserved :24;
1595 } EFI_MISC_TEMPERATURE_PROBE_LOCATION;
1596
1597 typedef struct {
1598 STRING_REF TemperatureProbeDescription;
1599 EFI_MISC_TEMPERATURE_PROBE_LOCATION
1600 TemperatureProbeLocation;
1601 EFI_EXP_BASE10_DATA TemperatureProbeMaximumValue;
1602 EFI_EXP_BASE10_DATA TemperatureProbeMinimumValue;
1603 EFI_EXP_BASE10_DATA TemperatureProbeResolution;
1604 EFI_EXP_BASE10_DATA TemperatureProbeTolerance;
1605 EFI_EXP_BASE10_DATA TemperatureProbeAccuracy;
1606 EFI_EXP_BASE10_DATA TemperatureProbeNominalValue;
1607 EFI_EXP_BASE10_DATA MDLowerNoncriticalThreshold;
1608 EFI_EXP_BASE10_DATA MDUpperNoncriticalThreshold;
1609 EFI_EXP_BASE10_DATA MDLowerCriticalThreshold;
1610 EFI_EXP_BASE10_DATA MDUpperCriticalThreshold;
1611 EFI_EXP_BASE10_DATA MDLowerNonrecoverableThreshold;
1612 EFI_EXP_BASE10_DATA MDUpperNonrecoverableThreshold;
1613 UINT32 TemperatureProbeOemDefined;
1614 } EFI_MISC_TEMPERATURE_PROBE_DESCRIPTION_DATA;
1615
1616 //
1617 //////////////////////////////////////////////////////////////////////////////
1618 //
1619 // Electrical Current Probe - SMBIOS Type 29
1620 //
1621
1622 #define EFI_MISC_ELECTRICAL_CURRENT_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000017
1623
1624 typedef struct {
1625 UINT32 ElectricalCurrentProbeSite :5;
1626 UINT32 ElectricalCurrentProbeStatus :3;
1627 UINT32 Reserved :24;
1628 } EFI_MISC_ELECTRICAL_CURRENT_PROBE_LOCATION;
1629
1630 typedef struct {
1631 STRING_REF ElectricalCurrentProbeDescription;
1632 EFI_MISC_ELECTRICAL_CURRENT_PROBE_LOCATION
1633 ElectricalCurrentProbeLocation;
1634 EFI_EXP_BASE10_DATA ElectricalCurrentProbeMaximumValue;
1635 EFI_EXP_BASE10_DATA ElectricalCurrentProbeMinimumValue;
1636 EFI_EXP_BASE10_DATA ElectricalCurrentProbeResolution;
1637 EFI_EXP_BASE10_DATA ElectricalCurrentProbeTolerance;
1638 EFI_EXP_BASE10_DATA ElectricalCurrentProbeAccuracy;
1639 EFI_EXP_BASE10_DATA ElectricalCurrentProbeNominalValue;
1640 EFI_EXP_BASE10_DATA MDLowerNoncriticalThreshold;
1641 EFI_EXP_BASE10_DATA MDUpperNoncriticalThreshold;
1642 EFI_EXP_BASE10_DATA MDLowerCriticalThreshold;
1643 EFI_EXP_BASE10_DATA MDUpperCriticalThreshold;
1644 EFI_EXP_BASE10_DATA MDLowerNonrecoverableThreshold;
1645 EFI_EXP_BASE10_DATA MDUpperNonrecoverableThreshold;
1646 UINT32 ElectricalCurrentProbeOemDefined;
1647 } EFI_MISC_ELECTRICAL_CURRENT_PROBE_DESCRIPTION_DATA;
1648
1649 //
1650 //////////////////////////////////////////////////////////////////////////////
1651 //
1652 // Out-of-Band Remote Access - SMBIOS Type 30
1653 //
1654
1655 #define EFI_MISC_REMOTE_ACCESS_MANUFACTURER_DESCRIPTION_RECORD_NUMBER 0x00000018
1656
1657 typedef struct {
1658 UINT32 InboundConnectionEnabled :1;
1659 UINT32 OutboundConnectionEnabled :1;
1660 UINT32 Reserved :30;
1661 } EFI_MISC_REMOTE_ACCESS_CONNECTIONS;
1662
1663 typedef struct {
1664 STRING_REF RemoteAccessManufacturerNameDescription;
1665 EFI_MISC_REMOTE_ACCESS_CONNECTIONS RemoteAccessConnections;
1666 } EFI_MISC_REMOTE_ACCESS_MANUFACTURER_DESCRIPTION_DATA;
1667
1668 //
1669 //////////////////////////////////////////////////////////////////////////////
1670 //
1671 // Misc. BIS Entry Point - SMBIOS Type 31
1672 //
1673 #define EFI_MISC_BIS_ENTRY_POINT_RECORD_NUMBER 0x00000019
1674
1675 typedef struct {
1676 EFI_PHYSICAL_ADDRESS BisEntryPoint;
1677 } EFI_MISC_BIS_ENTRY_POINT_DATA;
1678
1679 //
1680 //////////////////////////////////////////////////////////////////////////////
1681 //
1682 // Misc. Boot Information - SMBIOS Type 32
1683 //
1684 #define EFI_MISC_BOOT_INFORMATION_STATUS_RECORD_NUMBER 0x0000001A
1685
1686 typedef enum {
1687 EfiBootInformationStatusNoError = 0x00,
1688 EfiBootInformationStatusNoBootableMedia = 0x01,
1689 EfiBootInformationStatusNormalOSFailedLoading = 0x02,
1690 EfiBootInformationStatusFirmwareDetectedFailure = 0x03,
1691 EfiBootInformationStatusOSDetectedFailure = 0x04,
1692 EfiBootInformationStatusUserRequestedBoot = 0x05,
1693 EfiBootInformationStatusSystemSecurityViolation = 0x06,
1694 EfiBootInformationStatusPreviousRequestedImage = 0x07,
1695 EfiBootInformationStatusWatchdogTimerExpired = 0x08,
1696 EfiBootInformationStatusStartReserved = 0x09,
1697 EfiBootInformationStatusStartOemSpecific = 0x80,
1698 EfiBootInformationStatusStartProductSpecific = 0xC0,
1699 } EFI_MISC_BOOT_INFORMATION_STATUS_DATA_TYPE;
1700
1701 typedef struct {
1702 EFI_MISC_BOOT_INFORMATION_STATUS_DATA_TYPE BootInformationStatus;
1703 UINT8 BootInformationData[9];
1704 } EFI_MISC_BOOT_INFORMATION_STATUS_DATA;
1705
1706 //
1707 //////////////////////////////////////////////////////////////////////////////
1708 //
1709 // Management Device - SMBIOS Type 34
1710 //
1711 #define EFI_MISC_MANAGEMENT_DEVICE_DESCRIPTION_RECORD_NUMBER 0x0000001B
1712
1713 typedef enum {
1714 EfiManagementDeviceTypeOther = 0x01,
1715 EfiManagementDeviceTypeUnknown = 0x02,
1716 EfiManagementDeviceTypeLm75 = 0x03,
1717 EfiManagementDeviceTypeLm78 = 0x04,
1718 EfiManagementDeviceTypeLm79 = 0x05,
1719 EfiManagementDeviceTypeLm80 = 0x06,
1720 EfiManagementDeviceTypeLm81 = 0x07,
1721 EfiManagementDeviceTypeAdm9240 = 0x08,
1722 EfiManagementDeviceTypeDs1780 = 0x09,
1723 EfiManagementDeviceTypeMaxim1617 = 0x0A,
1724 EfiManagementDeviceTypeGl518Sm = 0x0B,
1725 EfiManagementDeviceTypeW83781D = 0x0C,
1726 EfiManagementDeviceTypeHt82H791 = 0x0D,
1727 } EFI_MISC_MANAGEMENT_DEVICE_TYPE;
1728
1729 typedef enum {
1730 EfiManagementDeviceAddressTypeOther = 1,
1731 EfiManagementDeviceAddressTypeUnknown = 2,
1732 EfiManagementDeviceAddressTypeIOPort = 3,
1733 EfiManagementDeviceAddressTypeMemory = 4,
1734 EfiManagementDeviceAddressTypeSmbus = 5
1735 } EFI_MISC_MANAGEMENT_DEVICE_ADDRESS_TYPE;
1736
1737 typedef struct {
1738 STRING_REF ManagementDeviceDescription;
1739 EFI_MISC_MANAGEMENT_DEVICE_TYPE ManagementDeviceType;
1740 UINTN ManagementDeviceAddress;
1741 EFI_MISC_MANAGEMENT_DEVICE_ADDRESS_TYPE
1742 ManagementDeviceAddressType;
1743 } EFI_MISC_MANAGEMENT_DEVICE_DESCRIPTION_DATA;
1744
1745 //
1746 //////////////////////////////////////////////////////////////////////////////
1747 //
1748 // Management Device Component - SMBIOS Type 35
1749 //
1750
1751 #define EFI_MISC_MANAGEMENT_DEVICE_COMPONENT_DESCRIPTION_RECORD_NUMBER 0x0000001C
1752
1753 typedef struct {
1754 STRING_REF ManagementDeviceComponentDescription;
1755 EFI_INTER_LINK_DATA ManagementDeviceLink;
1756 EFI_INTER_LINK_DATA ManagementDeviceComponentLink;
1757 } EFI_MISC_MANAGEMENT_DEVICE_COMPONENT_DESCRIPTION_DATA;
1758
1759 //
1760 //////////////////////////////////////////////////////////////////////////////
1761 //
1762 // IPMI Data Record - SMBIOS Type 38
1763 //
1764 typedef enum {
1765 EfiIpmiOther = 0,
1766 EfiIpmiKcs = 1,
1767 EfiIpmiSmic = 2,
1768 EfiIpmiBt = 3,
1769 } EFI_MISC_IPMI_INTERFACE_TYPE;
1770
1771 typedef struct {
1772 UINT16 IpmiSpecLeastSignificantDigit:4;
1773 UINT16 IpmiSpecMostSignificantDigit: 4;
1774 UINT16 Reserved: 8;
1775 } EFI_MISC_IPMI_SPECIFICATION_REVISION;
1776
1777 typedef struct {
1778 EFI_MISC_IPMI_INTERFACE_TYPE IpmiInterfaceType;
1779 EFI_MISC_IPMI_SPECIFICATION_REVISION IpmiSpecificationRevision;
1780 UINT16 IpmiI2CSlaveAddress;
1781 UINT16 IpmiNvDeviceAddress;
1782 UINT64 IpmiBaseAddress;
1783 EFI_DEVICE_PATH_PROTOCOL IpmiDevicePath;
1784 } EFI_MISC_IPMI_INTERFACE_TYPE_DATA;
1785
1786 #define EFI_MISC_IPMI_INTERFACE_TYPE_RECORD_NUMBER 0x0000001D
1787
1788 //
1789 //////////////////////////////////////////////////////////////////////////////
1790 //
1791 //System Power supply Record - SMBIOS Type 39
1792 //
1793 typedef struct {
1794 UINT16 PowerSupplyHotReplaceable :1;
1795 UINT16 PowerSupplyPresent :1;
1796 UINT16 PowerSupplyUnplugged :1;
1797 UINT16 InputVoltageRangeSwitch :4;
1798 UINT16 PowerSupplyStatus :3;
1799 UINT16 PowerSupplyType :4;
1800 UINT16 Reserved :2;
1801 } POWER_SUPPLY_CHARACTERISTICS;
1802
1803 typedef struct {
1804 UINT16 PowerUnitGroup;
1805 STRING_REF PowerSupplyLocation;
1806 STRING_REF PowerSupplyDeviceName;
1807 STRING_REF PowerSupplyManufacturer;
1808 STRING_REF PowerSupplySerialNumber;
1809 STRING_REF PowerSupplyAssetTagNumber;
1810 STRING_REF PowerSupplyModelPartNumber;
1811 STRING_REF PowerSupplyRevisionLevel;
1812 UINT16 PowerSupplyMaxPowerCapacity;
1813 POWER_SUPPLY_CHARACTERISTICS PowerSupplyCharacteristics;
1814 EFI_INTER_LINK_DATA PowerSupplyInputVoltageProbeLink;
1815 EFI_INTER_LINK_DATA PowerSupplyCoolingDeviceLink;
1816 EFI_INTER_LINK_DATA PowerSupplyInputCurrentProbeLink;
1817 } EFI_MISC_SYSTEM_POWER_SUPPLY_DATA;
1818
1819 #define EFI_MISC_SYSTEM_POWER_SUPPLY_RECORD_NUMBER 0x0000001E
1820
1821 //
1822 //////////////////////////////////////////////////////////////////////////////
1823 //
1824 // OEM Data Record - SMBIOS Type 0x80-0xFF
1825 //
1826 typedef struct {
1827 UINT8 Type;
1828 UINT8 Length;
1829 UINT16 Handle;
1830 } SMBIOS_STRUCTURE_HDR;
1831
1832 typedef struct {
1833 SMBIOS_STRUCTURE_HDR Header;
1834 UINT8 RawData[1];
1835 } EFI_MISC_SMBIOS_STRUCT_ENCAPSULATION_DATA;
1836
1837 #define EFI_MISC_SMBIOS_STRUCT_ENCAP_RECORD_NUMBER 0x0000001F
1838
1839 //
1840 // Declare the following strutures alias to use them more conviniently.
1841 //
1842 typedef EFI_MISC_LAST_PCI_BUS_DATA EFI_MISC_LAST_PCI_BUS;
1843 typedef EFI_MISC_BIOS_VENDOR_DATA EFI_MISC_BIOS_VENDOR;
1844 typedef EFI_MISC_SYSTEM_MANUFACTURER_DATA EFI_MISC_SYSTEM_MANUFACTURER;
1845 typedef EFI_MISC_BASE_BOARD_MANUFACTURER_DATA EFI_MISC_BASE_BOARD_MANUFACTURER;
1846 typedef EFI_MISC_CHASSIS_MANUFACTURER_DATA EFI_MISC_CHASSIS_MANUFACTURER;
1847 typedef EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR;
1848 typedef EFI_MISC_SYSTEM_SLOT_DESIGNATION_DATA EFI_MISC_SYSTEM_SLOT_DESIGNATION;
1849 typedef EFI_MISC_ONBOARD_DEVICE_DATA EFI_MISC_ONBOARD_DEVICE;
1850 typedef EFI_MISC_PORTING_DEVICE_TYPE_DATA EFI_MISC_ONBOARD_DEVICE_TYPE_DATA;
1851 typedef EFI_MISC_OEM_STRING_DATA EFI_MISC_OEM_STRING;
1852 typedef EFI_MISC_SYSTEM_OPTION_STRING_DATA EFI_MISC_SYSTEM_OPTION_STRING;
1853 typedef EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_DATA EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES;
1854 typedef EFI_MISC_SYSTEM_LANGUAGE_STRING_DATA EFI_MISC_SYSTEM_LANGUAGE_STRING;
1855 typedef EFI_MISC_SYSTEM_EVENT_LOG_DATA EFI_MISC_SYSTEM_EVENT_LOG;
1856 typedef EFI_MISC_BIS_ENTRY_POINT_DATA EFI_MISC_BIS_ENTRY_POINT;
1857 typedef EFI_MISC_BOOT_INFORMATION_STATUS_DATA EFI_MISC_BOOT_INFORMATION_STATUS;
1858 typedef EFI_MISC_SYSTEM_POWER_SUPPLY_DATA EFI_MISC_SYSTEM_POWER_SUPPLY;
1859 typedef EFI_MISC_SMBIOS_STRUCT_ENCAPSULATION_DATA EFI_MISC_SMBIOS_STRUCT_ENCAPSULATION;
1860
1861 typedef union {
1862 EFI_MISC_LAST_PCI_BUS_DATA LastPciBus;
1863 EFI_MISC_BIOS_VENDOR_DATA MiscBiosVendor;
1864 EFI_MISC_SYSTEM_MANUFACTURER_DATA MiscSystemManufacturer;
1865 EFI_MISC_BASE_BOARD_MANUFACTURER_DATA MiscBaseBoardManufacturer;
1866 EFI_MISC_CHASSIS_MANUFACTURER_DATA MiscChassisManufacturer;
1867 EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA MiscPortInternalConnectorDesignator;
1868 EFI_MISC_SYSTEM_SLOT_DESIGNATION_DATA MiscSystemSlotDesignation;
1869 EFI_MISC_ONBOARD_DEVICE_DATA MiscOnboardDevice;
1870 EFI_MISC_OEM_STRING_DATA MiscOemString;
1871 EFI_MISC_SYSTEM_OPTION_STRING_DATA MiscOptionString;
1872 EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_DATA NumberOfInstallableLanguages;
1873 EFI_MISC_SYSTEM_LANGUAGE_STRING_DATA MiscSystemLanguageString;
1874 EFI_MISC_SYSTEM_EVENT_LOG_DATA MiscSystemEventLog;
1875 EFI_MISC_GROUP_NAME_DATA MiscGroupNameData;
1876 EFI_MISC_GROUP_ITEM_SET_DATA MiscGroupItemSetData;
1877 EFI_MISC_PORTING_DEVICE_TYPE_DATA MiscPortingDeviceTypeData;
1878 EFI_MISC_RESET_CAPABILITIES_DATA MiscResetCapablilitiesData;
1879 EFI_MISC_HARDWARE_SECURITY_SETTINGS_DATA MiscHardwareSecuritySettingsData;
1880 EFI_MISC_SCHEDULED_POWER_ON_MONTH_DATA MiscScheduledPowerOnMonthData;
1881 EFI_MISC_VOLTAGE_PROBE_DESCRIPTION_DATA MiscVoltagePorbeDescriptionData;
1882 EFI_MISC_COOLING_DEVICE_TEMP_LINK_DATA MiscCoolingDeviceTempLinkData;
1883 EFI_MISC_TEMPERATURE_PROBE_DESCRIPTION_DATA MiscTemperatureProbeDescriptionData;
1884 EFI_MISC_ELECTRICAL_CURRENT_PROBE_DESCRIPTION_DATA MiscElectricalCurrentProbeDescriptionData;
1885 EFI_MISC_REMOTE_ACCESS_MANUFACTURER_DESCRIPTION_DATA
1886 MiscRemoteAccessManufacturerDescriptionData;
1887 EFI_MISC_BIS_ENTRY_POINT_DATA MiscBisEntryPoint;
1888 EFI_MISC_BOOT_INFORMATION_STATUS_DATA MiscBootInformationStatus;
1889 EFI_MISC_MANAGEMENT_DEVICE_DESCRIPTION_DATA MiscMangementDeviceDescriptionData;
1890 EFI_MISC_MANAGEMENT_DEVICE_COMPONENT_DESCRIPTION_DATA
1891 MiscmangementDeviceComponentDescriptionData;
1892 EFI_MISC_IPMI_INTERFACE_TYPE_DATA MiscIpmiInterfaceTypeData;
1893 EFI_MISC_SYSTEM_POWER_SUPPLY_DATA MiscPowerSupplyInfo;
1894 EFI_MISC_SMBIOS_STRUCT_ENCAPSULATION_DATA MiscSmbiosStructEncapsulation;
1895 } EFI_MISC_SUBCLASS_RECORDS;
1896
1897 //
1898 //
1899 //
1900 typedef struct {
1901 EFI_SUBCLASS_TYPE1_HEADER Header;
1902 EFI_MISC_SUBCLASS_RECORDS Record;
1903 } EFI_MISC_SUBCLASS_DRIVER_DATA;
1904
1905 #pragma pack()
1906
1907 //
1908 // Sub Class Header type1
1909 //
1910
1911 #define EFI_SUBCLASS_INSTANCE_RESERVED 0
1912 #define EFI_SUBCLASS_INSTANCE_NON_APPLICABLE 0xFFFF //16 bit
1913
1914 #endif