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.
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
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.
15 Module Name: DataHubRecords.h
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.
24 #ifndef _DATAHUB_RECORDS_H_
25 #define _DATAHUB_RECORDS_H_
27 #define EFI_PROCESSOR_SUBCLASS_VERSION 0x00010000
29 #include <Protocol/DevicePath.h>
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
;
42 typedef struct _IDE_DEVICE_PATH
{
43 ACPI_HID_DEVICE_PATH PciRootBridgeDevicePath
;
44 PCI_DEVICE_PATH PciBusDevicePath
;
45 EFI_DEVICE_PATH_PROTOCOL EndDevicePath
;
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
;
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
;
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
;
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
;
90 // Serial Port Connector
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
;
100 // Parallel Port Connector
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
;
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
;
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
;
134 // String Token Definition
136 #define EFI_STRING_TOKEN UINT16
144 } EFI_SUBCLASS_TYPE1_HEADER
;
147 EFI_GUID ProducerName
;
150 } EFI_INTER_LINK_DATA
;
160 } EFI_EXP_BASE2_DATA
;
166 } EFI_EXP_BASE10_DATA
;
168 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_MAX_CORE_FREQUENCY_DATA
;
170 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_MAX_FSB_FREQUENCY_DATA
;
172 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_CORE_FREQUENCY_DATA
;
174 typedef EFI_EXP_BASE10_DATA
*EFI_PROCESSOR_CORE_FREQUENCY_LIST_DATA
;
176 typedef EFI_EXP_BASE10_DATA
*EFI_PROCESSOR_FSB_FREQUENCY_LIST_DATA
;
178 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_FSB_FREQUENCY_DATA
;
180 typedef STRING_REF EFI_PROCESSOR_VERSION_DATA
;
182 typedef STRING_REF EFI_PROCESSOR_MANUFACTURER_DATA
;
184 typedef STRING_REF EFI_PROCESSOR_SERIAL_NUMBER_DATA
;
186 typedef STRING_REF EFI_PROCESSOR_ASSET_TAG_DATA
;
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
;
200 UINT32 ProcessorBrandIndex
:8;
201 UINT32 ProcessorClflush
:8;
202 UINT32 ProcessorReserved
:8;
203 UINT32 ProcessorDfltApicId
:8;
204 } EFI_PROCESSOR_MISC_INFO
;
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
;
241 EFI_PROCESSOR_SIGNATURE Signature
;
242 EFI_PROCESSOR_MISC_INFO MiscInfo
;
244 EFI_PROCESSOR_FEATURE_FLAGS FeatureFlags
;
245 } EFI_PROCESSOR_ID_DATA
;
248 EfiProcessorOther
= 1,
249 EfiProcessorUnknown
= 2,
250 EfiCentralProcessor
= 3,
251 EfiMathProcessor
= 4,
253 EfiVideoProcessor
= 6
254 } EFI_PROCESSOR_TYPE_DATA
;
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
;
325 typedef EFI_EXP_BASE10_DATA EFI_PROCESSOR_VOLTAGE_DATA
;
327 typedef EFI_PHYSICAL_ADDRESS EFI_PROCESSOR_APIC_BASE_ADDRESS_DATA
;
329 typedef UINT32 EFI_PROCESSOR_APIC_ID_DATA
;
331 typedef UINT32 EFI_PROCESSOR_APIC_VERSION_NUMBER_DATA
;
334 EfiProcessorIa32Microcode
= 1,
335 EfiProcessorIpfPalAMicrocode
= 2,
336 EfiProcessorIpfPalBMicrocode
= 3
337 } EFI_PROCESSOR_MICROCODE_TYPE
;
340 EFI_PROCESSOR_MICROCODE_TYPE ProcessorMicrocodeType
;
341 UINT32 ProcessorMicrocodeRevisionNumber
;
342 } EFI_PROCESSOR_MICROCODE_REVISION_DATA
;
347 UINT32 SocketPopulated
:1;
349 UINT32 ApicEnable
:1;
350 UINT32 BootApplicationProcessor
:1;
351 UINT32 Reserved3
:22;
352 } EFI_PROCESSOR_STATUS_DATA
;
355 EfiCpuStatusUnknown
= 0,
356 EfiCpuStatusEnabled
= 1,
357 EfiCpuStatusDisabledByUser
= 2,
358 EfiCpuStatusDisabledbyBios
= 3,
359 EfiCpuStatusIdle
= 4,
360 EfiCpuStatusOther
= 7
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
386 } EFI_PROCESSOR_SOCKET_TYPE_DATA
;
388 typedef STRING_REF EFI_PROCESSOR_SOCKET_NAME_DATA
;
390 typedef EFI_INTER_LINK_DATA EFI_CACHE_ASSOCIATION_DATA
;
393 EfiProcessorHealthy
= 1,
394 EfiProcessorPerfRestricted
= 2,
395 EfiProcessorFuncRestricted
= 3
396 } EFI_PROCESSOR_HEALTH_STATUS
;
398 typedef UINTN EFI_PROCESSOR_PACKAGE_NUMBER_DATA
;
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
;
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
;
455 EFI_SUBCLASS_TYPE1_HEADER DataRecordHeader
;
456 EFI_CPU_VARIABLE_RECORD VariableRecord
;
457 } EFI_CPU_DATA_RECORD
;
459 #define EFI_CACHE_SUBCLASS_VERSION 0x00010000
462 typedef EFI_EXP_BASE2_DATA EFI_CACHE_SIZE_DATA
;
464 typedef EFI_EXP_BASE2_DATA EFI_MAXIMUM_CACHE_SIZE_DATA
;
466 typedef EFI_EXP_BASE10_DATA EFI_CACHE_SPEED_DATA
;
468 typedef STRING_REF EFI_CACHE_SOCKET_DATA
;
475 UINT32 PipelineBurst
:1;
476 UINT32 Asynchronous
:1;
477 UINT32 Synchronous
:1;
479 } EFI_CACHE_SRAM_TYPE_DATA
;
482 EfiCacheErrorOther
= 1,
483 EfiCacheErrorUnknown
= 2,
484 EfiCacheErrorNone
= 3,
485 EfiCacheErrorParity
= 4,
486 EfiCacheErrorSingleBit
= 5,
487 EfiCacheErrorMultiBit
= 6
488 } EFI_CACHE_ERROR_TYPE_DATA
;
491 EfiCacheTypeOther
= 1,
492 EfiCacheTypeUnknown
= 2,
493 EfiCacheTypeInstruction
= 3,
494 EfiCacheTypeData
= 4,
495 EfiCacheTypeUnified
= 5
496 } EFI_CACHE_TYPE_DATA
;
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
;
515 UINT32 OperationalMode
:2;
516 UINT32 Reserved1
:22;
517 } EFI_CACHE_CONFIGURATION_DATA
;
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
525 #define EFI_CACHE_SOCKETED 1
526 #define EFI_CACHE_NOT_SOCKETED 0
529 EfiCacheInternal
= 0,
530 EfiCacheExternal
= 1,
531 EfiCacheReserved
= 2,
533 } EFI_CACHE_LOCATION
;
535 #define EFI_CACHE_ENABLED 1
536 #define EFI_CACHE_DISABLED 0
539 EfiCacheWriteThrough
= 0,
540 EfiCacheWriteBack
= 1,
541 EfiCacheDynamicMode
= 2,
542 EfiCacheUnknownMode
= 3
543 } EFI_CACHE_OPERATIONAL_MODE
;
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
;
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
;
576 EFI_SUBCLASS_TYPE1_HEADER DataRecordHeader
;
577 EFI_CACHE_VARIABLE_RECORD VariableRecord
;
578 } EFI_CACHE_DATA_RECORD
;
580 #define EFI_MEMORY_SUBCLASS_VERSION 0x0100
583 #define EFI_MEMORY_SIZE_RECORD_NUMBER 0x00000001
585 typedef enum _EFI_MEMORY_REGION_TYPE
{
586 EfiMemoryRegionMemory
= 0x01,
587 EfiMemoryRegionReserved
= 0x02,
588 EfiMemoryRegionAcpi
= 0x03,
589 EfiMemoryRegionNvs
= 0x04
590 } EFI_MEMORY_REGION_TYPE
;
593 UINT32 ProcessorNumber
;
594 UINT16 StartBusNumber
;
596 EFI_MEMORY_REGION_TYPE MemoryRegionType
;
597 EFI_EXP_BASE2_DATA MemorySize
;
598 EFI_PHYSICAL_ADDRESS MemoryStartAddress
;
599 } EFI_MEMORY_SIZE_DATA
;
602 #define EFI_MEMORY_ARRAY_LOCATION_RECORD_NUMBER 0x00000002
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
;
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
;
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
;
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
;
650 #define EFI_MEMORY_ARRAY_LINK_RECORD_NUMBER 0x00000003
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
;
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
;
698 UINT32 StaticColumn
:1;
699 UINT32 PseudoStatic
:1;
701 UINT32 Synchronous
:1;
704 UINT32 WindowDram
:1;
706 UINT32 Nonvolatile
:1;
707 UINT32 Reserved1
:19;
708 } EFI_MEMORY_TYPE_DETAIL
;
711 EfiMemoryStateEnabled
= 0,
712 EfiMemoryStateUnknown
= 1,
713 EfiMemoryStateUnsupported
= 2,
714 EfiMemoryStateError
= 3,
715 EfiMemoryStateAbsent
= 4,
716 EfiMemoryStateDisabled
= 5,
717 EfiMemoryStatePartial
= 6
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
;
741 #define EFI_MEMORY_ARRAY_START_ADDRESS_RECORD_NUMBER 0x00000004
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
;
751 #define EFI_MEMORY_DEVICE_START_ADDRESS_RECORD_NUMBER 0x00000005
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
;
765 // Memory. Channel Device Type - SMBIOS Type 37
768 #define EFI_MEMORY_CHANNEL_TYPE_RECORD_NUMBER 0x00000006
770 typedef enum _EFI_MEMORY_CHANNEL_TYPE
{
771 EfiMemoryChannelTypeOther
= 1,
772 EfiMemoryChannelTypeUnknown
= 2,
773 EfiMemoryChannelTypeRambus
= 3,
774 EfiMemoryChannelTypeSyncLink
= 4
775 } EFI_MEMORY_CHANNEL_TYPE
;
778 EFI_MEMORY_CHANNEL_TYPE MemoryChannelType
;
779 UINT8 MemoryChannelMaximumLoad
;
780 UINT8 MemoryChannelDeviceCount
;
781 } EFI_MEMORY_CHANNEL_TYPE_DATA
;
783 #define EFI_MEMORY_CHANNEL_DEVICE_RECORD_NUMBER 0x00000007
787 EFI_INTER_LINK_DATA DeviceLink
;
788 UINT8 MemoryChannelDeviceLoad
;
789 } EFI_MEMORY_CHANNEL_DEVICE_DATA
;
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
;
804 EFI_SUBCLASS_TYPE1_HEADER Header
;
805 EFI_MEMORY_SUBCLASS_RECORDS Record
;
806 } EFI_MEMORY_SUBCLASS_DRIVER_DATA
;
808 #define EFI_MISC_SUBCLASS_VERSION 0x0100
812 //////////////////////////////////////////////////////////////////////////////
814 // Last PCI Bus Number
816 #define EFI_MISC_LAST_PCI_BUS_RECORD_NUMBER 0x00000001
820 } EFI_MISC_LAST_PCI_BUS_DATA
;
823 //////////////////////////////////////////////////////////////////////////////
825 // Misc. BIOS Vendor - SMBIOS Type 0
827 #define EFI_MISC_BIOS_VENDOR_RECORD_NUMBER 0x00000002
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;
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;
872 } EFI_MISC_BIOS_CHARACTERISTICS
;
875 UINT64 BiosReserved
:16;
876 UINT64 SystemReserved
:16;
878 } EFI_MISC_BIOS_CHARACTERISTICS_EXTENSION
;
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
;
895 //////////////////////////////////////////////////////////////////////////////
897 // Misc. System Manufacturer - SMBIOS Type 1
899 #define EFI_MISC_SYSTEM_MANUFACTURER_RECORD_NUMBER 0x00000003
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
;
914 STRING_REF SystemManufacturer
;
915 STRING_REF SystemProductName
;
916 STRING_REF SystemVersion
;
917 STRING_REF SystemSerialNumber
;
919 EFI_MISC_SYSTEM_WAKEUP_TYPE SystemWakeupType
;
920 STRING_REF SystemSKUNumber
;
921 STRING_REF SystemFamily
;
922 } EFI_MISC_SYSTEM_MANUFACTURER_DATA
;
925 //////////////////////////////////////////////////////////////////////////////
927 // Misc. Base Board Manufacturer - SMBIOS Type 2
929 #define EFI_MISC_BASE_BOARD_MANUFACTURER_RECORD_NUMBER 0x00000004
932 UINT32 Motherboard
:1;
933 UINT32 RequiresDaughterCard
:1;
935 UINT32 Replaceable
:1;
936 UINT32 HotSwappable
:1;
938 } EFI_BASE_BOARD_FEATURE_FLAGS
;
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
;
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
;
971 //////////////////////////////////////////////////////////////////////////////
973 // Misc. System/Chassis Enclosure - SMBIOS Type 3
975 #define EFI_MISC_CHASSIS_MANUFACTURER_RECORD_NUMBER 0x00000005
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
;
1006 UINT32 ChassisType
:16;
1007 UINT32 ChassisLockPresent
:1;
1008 UINT32 Reserved
:15;
1009 } EFI_MISC_CHASSIS_STATUS
;
1012 EfiChassisStateOther
= 0x01,
1013 EfiChassisStateUnknown
= 0x02,
1014 EfiChassisStateSafe
= 0x03,
1015 EfiChassisStateWarning
= 0x04,
1016 EfiChassisStateCritical
= 0x05,
1017 EfiChassisStateNonRecoverable
= 0x06,
1018 } EFI_MISC_CHASSIS_STATE
;
1021 EfiChassisSecurityStatusOther
= 0x01,
1022 EfiChassisSecurityStatusUnknown
= 0x02,
1023 EfiChassisSecurityStatusNone
= 0x03,
1024 EfiChassisSecurityStatusExternalInterfaceLockedOut
= 0x04,
1025 EfiChassisSecurityStatusExternalInterfaceLockedEnabled
= 0x05,
1026 } EFI_MISC_CHASSIS_SECURITY_STATE
;
1029 UINT32 RecordType
:1;
1030 UINT32 Reserved
:24;
1031 } EFI_MISC_ELEMENT_TYPE
;
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
;
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
;
1060 //////////////////////////////////////////////////////////////////////////////
1062 // Misc. Port Connector Information - SMBIOS Type 8
1064 #define EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_RECORD_NUMBER 0x00000006
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
;
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
;
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
;
1157 //////////////////////////////////////////////////////////////////////////////
1159 // Misc. System Slots - SMBIOS Type 9
1161 #define EFI_MISC_SYSTEM_SLOT_DESIGNATION_RECORD_NUMBER 0x00000007
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
;
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
;
1202 EfiSlotUsageOther
= 1,
1203 EfiSlotUsageUnknown
= 2,
1204 EfiSlotUsageAvailable
= 3,
1205 EfiSlotUsageInUse
= 4,
1206 } EFI_MISC_SLOT_USAGE
;
1209 EfiSlotLengthOther
= 1,
1210 EfiSlotLengthUnknown
= 2,
1211 EfiSlotLengthShort
= 3,
1212 EfiSlotLengthLong
= 4
1213 } EFI_MISC_SLOT_LENGTH
;
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
;
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
;
1237 EFI_MISC_SLOT_CHARACTERISTICS SlotCharacteristics
;
1238 EFI_DEVICE_PATH_PROTOCOL SlotDevicePath
;
1239 } EFI_MISC_SYSTEM_SLOT_DESIGNATION_DATA
;
1242 //////////////////////////////////////////////////////////////////////////////
1244 // Misc. Onboard Device - SMBIOS Type 10
1246 #define EFI_MISC_ONBOARD_DEVICE_RECORD_NUMBER 0x00000008
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
;
1259 UINT32 DeviceType
:16;
1260 UINT32 DeviceEnabled
:1;
1261 UINT32 Reserved
:15;
1262 } EFI_MISC_ONBOARD_DEVICE_STATUS
;
1265 STRING_REF OnBoardDeviceDescription
;
1266 EFI_MISC_ONBOARD_DEVICE_STATUS OnBoardDeviceStatus
;
1267 EFI_DEVICE_PATH_PROTOCOL OnBoardDevicePath
;
1268 } EFI_MISC_ONBOARD_DEVICE_DATA
;
1271 //////////////////////////////////////////////////////////////////////////////
1273 // Misc. BIOS Language Information - SMBIOS Type 11
1275 #define EFI_MISC_OEM_STRING_RECORD_NUMBER 0x00000009
1278 STRING_REF OemStringRef
[1];
1279 } EFI_MISC_OEM_STRING_DATA
;
1282 //////////////////////////////////////////////////////////////////////////////
1284 // Misc. System Options - SMBIOS Type 12
1287 STRING_REF SystemOptionStringRef
[1];
1288 } EFI_MISC_SYSTEM_OPTION_STRING_DATA
;
1290 #define EFI_MISC_SYSTEM_OPTION_STRING_RECORD_NUMBER 0x0000000A
1293 //////////////////////////////////////////////////////////////////////////////
1295 // Misc. Number of Installable Languages - SMBIOS Type 13
1297 #define EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_RECORD_NUMBER 0x0000000B
1300 UINT32 AbbreviatedLanguageFormat
:1;
1301 UINT32 Reserved
:31;
1302 } EFI_MISC_LANGUAGE_FLAGS
;
1305 UINT16 NumberOfInstallableLanguages
;
1306 EFI_MISC_LANGUAGE_FLAGS LanguageFlags
;
1307 UINT16 CurrentLanguageNumber
;
1308 } EFI_MISC_NUMBER_OF_INSTALLABLE_LANGUAGES_DATA
;
1311 //////////////////////////////////////////////////////////////////////////////
1313 // Misc. System Language String
1315 #define EFI_MISC_SYSTEM_LANGUAGE_STRING_RECORD_NUMBER 0x0000000C
1319 STRING_REF SystemLanguageString
;
1320 } EFI_MISC_SYSTEM_LANGUAGE_STRING_DATA
;
1323 //////////////////////////////////////////////////////////////////////////////
1325 // Group Associations - SMBIOS Type 14
1327 #define EFI_MISC_GROUP_NAME_RECORD_NUMBER 0x0000000D
1330 STRING_REF GroupName
;
1331 UINT16 NumberGroupItems
;
1333 } EFI_MISC_GROUP_NAME_DATA
;
1336 //////////////////////////////////////////////////////////////////////////////
1338 // Group Item Set Element
1340 #define EFI_MISC_GROUP_ITEM_SET_RECORD_NUMBER 0x0000000E
1344 EFI_INTER_LINK_DATA GroupLink
;
1346 UINT16 GroupElementId
;
1347 } EFI_MISC_GROUP_ITEM_SET_DATA
;
1349 // Misc. System Event Log - SMBIOS Type 15
1351 #define EFI_MISC_SYSTEM_EVENT_LOG_RECORD_NUMBER 0x0000000D
1353 UINT16 LogAreaLength
;
1354 UINT16 LogHeaderStartOffset
;
1355 UINT16 LogDataStartOffset
;
1358 UINT32 LogChangeToken
;
1359 UINT32 AccessMethodAddress
;
1360 UINT8 LogHeaderFormat
;
1361 UINT8 NumberOfSupportedLogType
;
1362 UINT8 LengthOfLogDescriptor
;
1363 } EFI_MISC_SYSTEM_EVENT_LOG_DATA
;
1367 // 0x00~0x04: as following definition
1368 // 0x05~0x7f: Available for future assignment.
1369 // 0x80~0xff: BIOS Vendor/OEM-specific.
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
1378 //////////////////////////////////////////////////////////////////////////////
1380 // Misc. Pointing Device Type - SMBIOS Type 21
1382 #define EFI_MISC_POINTING_DEVICE_TYPE_RECORD_NUMBER 0x0000000F
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
;
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
;
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
;
1418 //////////////////////////////////////////////////////////////////////////////
1420 // Portable Battery - SMBIOS Type 22
1422 #define EFI_MISC_BATTERY_LOCATION_RECORD_NUMBER 0x00000010
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
;
1439 UINT32 Reserved
:16;
1440 } EFI_MISC_BATTERY_SBDS_MANUFACTURE_DATE
;
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
;
1461 //////////////////////////////////////////////////////////////////////////////
1463 // Misc. Reset Capabilities - SMBIOS Type 23
1465 #define EFI_MISC_RESET_CAPABILITIES_RECORD_NUMBER 0x00000011
1469 UINT32 BootOption
:2;
1470 UINT32 BootOptionOnLimit
:2;
1471 UINT32 WatchdogTimerPresent
:1;
1472 UINT32 Reserved
:26;
1473 } EFI_MISC_RESET_CAPABILITIES_TYPE
;
1476 EFI_MISC_RESET_CAPABILITIES_TYPE ResetCapabilities
;
1479 UINT16 ResetTimerInterval
;
1480 UINT16 ResetTimeout
;
1481 } EFI_MISC_RESET_CAPABILITIES
;
1484 EFI_MISC_RESET_CAPABILITIES ResetCapabilities
;
1487 UINT16 ResetTimerInterval
;
1488 UINT16 ResetTimeout
;
1489 } EFI_MISC_RESET_CAPABILITIES_DATA
;
1492 //////////////////////////////////////////////////////////////////////////////
1494 // Misc. Hardware Security - SMBIOS Type 24
1496 #define EFI_MISC_HARDWARE_SECURITY_RECORD_NUMBER 0x00000012
1499 EfiHardwareSecurityStatusDisabled
= 0,
1500 EfiHardwareSecurityStatusEnabled
= 1,
1501 EfiHardwareSecurityStatusNotImplemented
= 2,
1502 EfiHardwareSecurityStatusUnknown
= 3
1503 } EFI_MISC_HARDWARE_SECURITY_STATUS
;
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
;
1514 EFI_MISC_HARDWARE_SECURITY_SETTINGS HardwareSecuritySettings
;
1515 } EFI_MISC_HARDWARE_SECURITY_SETTINGS_DATA
;
1518 //////////////////////////////////////////////////////////////////////////////
1520 // System Power Controls - SMBIOS Type 25
1522 #define EFI_MISC_SCHEDULED_POWER_ON_MONTH_RECORD_NUMBER 0x00000013
1525 UINT16 ScheduledPoweronMonth
;
1526 UINT16 ScheduledPoweronDayOfMonth
;
1527 UINT16 ScheduledPoweronHour
;
1528 UINT16 ScheduledPoweronMinute
;
1529 UINT16 ScheduledPoweronSecond
;
1530 } EFI_MISC_SCHEDULED_POWER_ON_MONTH_DATA
;
1533 //////////////////////////////////////////////////////////////////////////////
1535 // Voltage Probe - SMBIOS Type 26
1537 #define EFI_MISC_VOLTAGE_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000014
1540 UINT32 VoltageProbeSite
:5;
1541 UINT32 VoltageProbeStatus
:3;
1542 UINT32 Reserved
:24;
1543 } EFI_MISC_VOLTAGE_PROBE_LOCATION
;
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
;
1564 //////////////////////////////////////////////////////////////////////////////
1566 // Cooling Device - SMBIOS Type 27
1568 #define EFI_MISC_COOLING_DEVICE_TEMP_LINK_RECORD_NUMBER 0x00000015
1571 UINT32 CoolingDevice
:5;
1572 UINT32 CoolingDeviceStatus
:3;
1573 UINT32 Reserved
:24;
1574 } EFI_MISC_COOLING_DEVICE_TYPE
;
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
;
1585 //////////////////////////////////////////////////////////////////////////////
1587 // Temperature Probe - SMBIOS Type 28
1589 #define EFI_MISC_TEMPERATURE_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000016
1592 UINT32 TemperatureProbeSite
:5;
1593 UINT32 TemperatureProbeStatus
:3;
1594 UINT32 Reserved
:24;
1595 } EFI_MISC_TEMPERATURE_PROBE_LOCATION
;
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
;
1617 //////////////////////////////////////////////////////////////////////////////
1619 // Electrical Current Probe - SMBIOS Type 29
1622 #define EFI_MISC_ELECTRICAL_CURRENT_PROBE_DESCRIPTION_RECORD_NUMBER 0x00000017
1625 UINT32 ElectricalCurrentProbeSite
:5;
1626 UINT32 ElectricalCurrentProbeStatus
:3;
1627 UINT32 Reserved
:24;
1628 } EFI_MISC_ELECTRICAL_CURRENT_PROBE_LOCATION
;
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
;
1650 //////////////////////////////////////////////////////////////////////////////
1652 // Out-of-Band Remote Access - SMBIOS Type 30
1655 #define EFI_MISC_REMOTE_ACCESS_MANUFACTURER_DESCRIPTION_RECORD_NUMBER 0x00000018
1658 UINT32 InboundConnectionEnabled
:1;
1659 UINT32 OutboundConnectionEnabled
:1;
1660 UINT32 Reserved
:30;
1661 } EFI_MISC_REMOTE_ACCESS_CONNECTIONS
;
1664 STRING_REF RemoteAccessManufacturerNameDescription
;
1665 EFI_MISC_REMOTE_ACCESS_CONNECTIONS RemoteAccessConnections
;
1666 } EFI_MISC_REMOTE_ACCESS_MANUFACTURER_DESCRIPTION_DATA
;
1669 //////////////////////////////////////////////////////////////////////////////
1671 // Misc. BIS Entry Point - SMBIOS Type 31
1673 #define EFI_MISC_BIS_ENTRY_POINT_RECORD_NUMBER 0x00000019
1676 EFI_PHYSICAL_ADDRESS BisEntryPoint
;
1677 } EFI_MISC_BIS_ENTRY_POINT_DATA
;
1680 //////////////////////////////////////////////////////////////////////////////
1682 // Misc. Boot Information - SMBIOS Type 32
1684 #define EFI_MISC_BOOT_INFORMATION_STATUS_RECORD_NUMBER 0x0000001A
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
;
1702 EFI_MISC_BOOT_INFORMATION_STATUS_DATA_TYPE BootInformationStatus
;
1703 UINT8 BootInformationData
[9];
1704 } EFI_MISC_BOOT_INFORMATION_STATUS_DATA
;
1707 //////////////////////////////////////////////////////////////////////////////
1709 // Management Device - SMBIOS Type 34
1711 #define EFI_MISC_MANAGEMENT_DEVICE_DESCRIPTION_RECORD_NUMBER 0x0000001B
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
;
1730 EfiManagementDeviceAddressTypeOther
= 1,
1731 EfiManagementDeviceAddressTypeUnknown
= 2,
1732 EfiManagementDeviceAddressTypeIOPort
= 3,
1733 EfiManagementDeviceAddressTypeMemory
= 4,
1734 EfiManagementDeviceAddressTypeSmbus
= 5
1735 } EFI_MISC_MANAGEMENT_DEVICE_ADDRESS_TYPE
;
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
;
1746 //////////////////////////////////////////////////////////////////////////////
1748 // Management Device Component - SMBIOS Type 35
1751 #define EFI_MISC_MANAGEMENT_DEVICE_COMPONENT_DESCRIPTION_RECORD_NUMBER 0x0000001C
1754 STRING_REF ManagementDeviceComponentDescription
;
1755 EFI_INTER_LINK_DATA ManagementDeviceLink
;
1756 EFI_INTER_LINK_DATA ManagementDeviceComponentLink
;
1757 } EFI_MISC_MANAGEMENT_DEVICE_COMPONENT_DESCRIPTION_DATA
;
1760 //////////////////////////////////////////////////////////////////////////////
1762 // IPMI Data Record - SMBIOS Type 38
1769 } EFI_MISC_IPMI_INTERFACE_TYPE
;
1772 UINT16 IpmiSpecLeastSignificantDigit
:4;
1773 UINT16 IpmiSpecMostSignificantDigit
: 4;
1775 } EFI_MISC_IPMI_SPECIFICATION_REVISION
;
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
;
1786 #define EFI_MISC_IPMI_INTERFACE_TYPE_RECORD_NUMBER 0x0000001D
1789 //////////////////////////////////////////////////////////////////////////////
1791 //System Power supply Record - SMBIOS Type 39
1794 UINT16 PowerSupplyHotReplaceable
:1;
1795 UINT16 PowerSupplyPresent
:1;
1796 UINT16 PowerSupplyUnplugged
:1;
1797 UINT16 InputVoltageRangeSwitch
:4;
1798 UINT16 PowerSupplyStatus
:3;
1799 UINT16 PowerSupplyType
:4;
1801 } POWER_SUPPLY_CHARACTERISTICS
;
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
;
1819 #define EFI_MISC_SYSTEM_POWER_SUPPLY_RECORD_NUMBER 0x0000001E
1822 //////////////////////////////////////////////////////////////////////////////
1824 // OEM Data Record - SMBIOS Type 0x80-0xFF
1830 } SMBIOS_STRUCTURE_HDR
;
1833 SMBIOS_STRUCTURE_HDR Header
;
1835 } EFI_MISC_SMBIOS_STRUCT_ENCAPSULATION_DATA
;
1837 #define EFI_MISC_SMBIOS_STRUCT_ENCAP_RECORD_NUMBER 0x0000001F
1840 // Declare the following strutures alias to use them more conviniently.
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
;
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
;
1901 EFI_SUBCLASS_TYPE1_HEADER Header
;
1902 EFI_MISC_SUBCLASS_RECORDS Record
;
1903 } EFI_MISC_SUBCLASS_DRIVER_DATA
;
1908 // Sub Class Header type1
1911 #define EFI_SUBCLASS_INSTANCE_RESERVED 0
1912 #define EFI_SUBCLASS_INSTANCE_NON_APPLICABLE 0xFFFF //16 bit