2 Main SAL API's defined in Intel Itanium Processor Family System Abstraction
3 Layer Specification Revision 3.2 (December 2003)
5 Copyright (c) 2006 - 2008, Intel Corporation
6 All rights reserved. This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
20 /// SAL return status type
22 typedef UINTN EFI_SAL_STATUS
;
25 /// Call completed without error.
27 #define EFI_SAL_SUCCESS ((EFI_SAL_STATUS) 0)
29 /// Call completed without error but some information was lost due to overflow.
31 #define EFI_SAL_OVERFLOW ((EFI_SAL_STATUS) 1)
33 /// Call completed without error; effect a warm boot of the system to complete the update.
35 #define EFI_SAL_WARM_BOOT_NEEDED ((EFI_SAL_STATUS) 2)
37 /// More information is available for retrieval.
39 #define EFI_SAL_MORE_RECORDS ((EFI_SAL_STATUS) 3)
43 #define EFI_SAL_NOT_IMPLEMENTED ((EFI_SAL_STATUS) - 1)
47 #define EFI_SAL_INVALID_ARGUMENT ((EFI_SAL_STATUS) - 2)
49 /// Call completed without error.
51 #define EFI_SAL_ERROR ((EFI_SAL_STATUS) - 3)
53 /// Virtual address not registered.
55 #define EFI_SAL_VIRTUAL_ADDRESS_ERROR ((EFI_SAL_STATUS) - 4)
57 /// No information available.
59 #define EFI_SAL_NO_INFORMATION ((EFI_SAL_STATUS) - 5)
61 /// Scratch buffer required.
63 #define EFI_SAL_NOT_ENOUGH_SCRATCH ((EFI_SAL_STATUS) - 9)
66 /// Return registers from SAL
70 /// SAL return status value in r8
72 EFI_SAL_STATUS Status
;
74 /// SAL returned value in r9
78 /// SAL returned value in r10
82 /// SAL returned value in r11
88 Prototype of SAL procedures.
90 @param Arg0 Functional identifier.
91 The upper 32 bits are ignored and only the lower 32 bits
92 are used. The following functional identifiers are defined:
93 0x01XXXXXX - Architected SAL functional group.
94 0x02XXXXXX to 0x03XXXXXX - OEM SAL functional group. Each OEM is
95 allowed to use the entire range in the 0x02XXXXXX to 0x03XXXXXX range.
96 0x04XXXXXX to 0xFFFFFFFF - Reserved.
97 @param Arg1 The first parameter of the architected/OEM specific SAL functions.
98 @param Arg2 The second parameter of the architected/OEM specific SAL functions.
99 @param Arg3 The third parameter passed to the ESAL function based
100 @param Arg4 The fourth parameter passed to the ESAL function based
101 @param Arg5 The fifth parameter passed to the ESAL function based
102 @param Arg6 The sixth parameter passed to the ESAL function
103 @param Arg7 The seventh parameter passed to the ESAL function based
105 @return r8 Return status: positive number indicates successful,
106 negative number indicates failure.
107 r9 Other return parameter in r9.
108 r10 Other return parameter in r10.
109 r11 Other return parameter in r11.
115 IN UINT64 FunctionId
,
126 // SAL Procedure FunctionId definition
130 /// Register software code locations with SAL.
132 #define EFI_SAL_SET_VECTORS 0x01000000
134 /// Return Machine State information obtained by SAL.
136 #define EFI_SAL_GET_STATE_INFO 0x01000001
138 /// Obtain size of Machine State information.
140 #define EFI_SAL_GET_STATE_INFO_SIZE 0x01000002
142 /// Clear Machine State information.
144 #define EFI_SAL_CLEAR_STATE_INFO 0x01000003
146 /// Cause the processor to go into a spin loop within SAL.
148 #define EFI_SAL_MC_RENDEZ 0x01000004
150 /// Register the machine check interface layer with SAL.
152 #define EFI_SAL_MC_SET_PARAMS 0x01000005
154 /// Register the physical addresses of locations needed by SAL.
156 #define EFI_SAL_REGISTER_PHYSICAL_ADDR 0x01000006
158 /// Flush the instruction or data caches.
160 #define EFI_SAL_CACHE_FLUSH 0x01000008
162 /// Initialize the instruction and data caches.
164 #define EFI_SAL_CACHE_INIT 0x01000009
166 /// Read from the PCI configuration space.
168 #define EFI_SAL_PCI_CONFIG_READ 0x01000010
170 /// Write to the PCI configuration space.
172 #define EFI_SAL_PCI_CONFIG_WRITE 0x01000011
174 /// Return the base frequency of the platform.
176 #define EFI_SAL_FREQ_BASE 0x01000012
178 /// Returns information on the physical processor mapping within the platform.
180 #define EFI_SAL_PHYSICAL_ID_INFO 0x01000013
182 /// Update the contents of firmware blocks.
184 #define EFI_SAL_UPDATE_PAL 0x01000020
186 #define EFI_SAL_FUNCTION_ID_MASK 0x0000ffff
187 #define EFI_SAL_MAX_SAL_FUNCTION_ID 0x00000021
190 // SAL Procedure parameter definitions
191 // Not much point in using typedefs or enums because all params
192 // are UINT64 and the entry point is common
196 // Parameter of EFI_SAL_SET_VECTORS
200 #define EFI_SAL_SET_MCA_VECTOR 0x0
201 #define EFI_SAL_SET_INIT_VECTOR 0x1
202 #define EFI_SAL_SET_BOOT_RENDEZ_VECTOR 0x2
204 /// Format of length_cs_n argument.
208 UINT64 ChecksumValid
: 1;
209 UINT64 Reserved1
: 7;
210 UINT64 ByteChecksum
: 8;
211 UINT64 Reserved2
: 16;
212 } SAL_SET_VECTORS_CS_N
;
215 // Parameter of EFI_SAL_GET_STATE_INFO, EFI_SAL_GET_STATE_INFO_SIZE, and EFI_SAL_CLEAR_STATE_INFO
217 // Type of information
219 #define EFI_SAL_MCA_STATE_INFO 0x0
220 #define EFI_SAL_INIT_STATE_INFO 0x1
221 #define EFI_SAL_CMC_STATE_INFO 0x2
222 #define EFI_SAL_CP_STATE_INFO 0x3
225 // Parameter of EFI_SAL_MC_SET_PARAMS
227 // Unsigned 64-bit integer value for the parameter type of the machine check interface
229 #define EFI_SAL_MC_SET_RENDEZ_PARAM 0x1
230 #define EFI_SAL_MC_SET_WAKEUP_PARAM 0x2
231 #define EFI_SAL_MC_SET_CPE_PARAM 0x3
233 // Unsigned 64-bit integer value indicating whether interrupt vector or
234 // memory address is specified
236 #define EFI_SAL_MC_SET_INTR_PARAM 0x1
237 #define EFI_SAL_MC_SET_MEM_PARAM 0x2
240 // Parameter of EFI_SAL_REGISTER_PAL_PHYSICAL_ADDR
242 // The encoded value of the entity whose physical address is registered
244 #define EFI_SAL_REGISTER_PAL_ADDR 0x0
247 // Parameter of EFI_SAL_CACHE_FLUSH
249 // Unsigned 64-bit integer denoting type of cache flush operation
251 #define EFI_SAL_FLUSH_I_CACHE 0x01
252 #define EFI_SAL_FLUSH_D_CACHE 0x02
253 #define EFI_SAL_FLUSH_BOTH_CACHE 0x03
254 #define EFI_SAL_FLUSH_MAKE_COHERENT 0x04
257 // Parameter of EFI_SAL_PCI_CONFIG_READ and EFI_SAL_PCI_CONFIG_WRITE
261 #define EFI_SAL_PCI_CONFIG_ONE_BYTE 0x1
262 #define EFI_SAL_PCI_CONFIG_TWO_BYTES 0x2
263 #define EFI_SAL_PCI_CONFIG_FOUR_BYTES 0x4
265 // The type of PCI configuration address
267 #define EFI_SAL_PCI_COMPATIBLE_ADDRESS 0x0
268 #define EFI_SAL_PCI_EXTENDED_REGISTER_ADDRESS 0x1
270 /// Format of PCI Compatible Address
278 UINT64 Reserved
: 32;
281 /// Format of Extended Register Address
285 UINT64 ExtendedRegister
: 4;
290 UINT64 Reserved
: 20;
291 } SAL_PCI_EXTENDED_REGISTER_ADDRESS
;
294 // Parameter of EFI_SAL_FREQ_BASE
296 // Unsigned 64-bit integer specifying the type of clock source
298 #define EFI_SAL_CPU_INPUT_FREQ_BASE 0x0
299 #define EFI_SAL_PLATFORM_IT_FREQ_BASE 0x1
300 #define EFI_SAL_PLATFORM_RTC_FREQ_BASE 0x2
303 // Parameter and return value of EFI_SAL_UPDATE_PAL
305 // Return parameter provides additional information on the
306 // failure when the status field contains a value of -3,
309 #define EFI_SAL_UPDATE_BAD_PAL_VERSION ((UINT64) -1)
310 #define EFI_SAL_UPDATE_PAL_AUTH_FAIL ((UINT64) -2)
311 #define EFI_SAL_UPDATE_PAL_BAD_TYPE ((UINT64) -3)
312 #define EFI_SAL_UPDATE_PAL_READONLY ((UINT64) -4)
313 #define EFI_SAL_UPDATE_PAL_WRITE_FAIL ((UINT64) -10)
314 #define EFI_SAL_UPDATE_PAL_ERASE_FAIL ((UINT64) -11)
315 #define EFI_SAL_UPDATE_PAL_READ_FAIL ((UINT64) -12)
316 #define EFI_SAL_UPDATE_PAL_CANT_FIT ((UINT64) -13)
318 /// 64-byte header of update data block.
327 } SAL_UPDATE_PAL_DATA_BLOCK
;
329 /// Data structure pointed by parameter param_buf.
330 /// It is a 16-byte aligned data structure in memory with a length of 32 bytes
331 /// that describes the new firmware. This information is organized in the form
332 /// of a linked list with each element describing one firmware component.
334 typedef struct _SAL_UPDATE_PAL_INFO_BLOCK
{
335 struct _SAL_UPDATE_PAL_INFO_BLOCK
*Next
;
336 struct SAL_UPDATE_PAL_DATA_BLOCK
*DataBlock
;
339 } SAL_UPDATE_PAL_INFO_BLOCK
;
342 /// SAL System Table Definitions
347 /// The ASCII string representation of "SST_" which confirms the presence of the table.
351 /// The length of the entire table in bytes, starting from offset zero and including the
352 /// header and all entries indicated by the EntryCount field.
356 /// The revision number of the Itanium Processor Family System Abstraction Layer
357 /// Specification supported by the SAL implementation in binary coded decimal (BCD) format.
361 /// The number of entries in the variable portion of the table.
365 /// A modulo checksum of the entire table and the entries following this table.
369 /// Unused, must be zero.
373 /// Version Number of the SAL_A firmware implementation in BCD format.
377 /// Version Number of the SAL_B firmware implementation in BCD format.
381 /// An ASCII identification string which uniquely identifies the manufacturer
382 /// of the system hardware.
386 /// An ASCII identification string which uniquely identifies a family of
387 /// compatible products from the manufacturer.
391 /// Unused, must be zero.
394 } SAL_SYSTEM_TABLE_HEADER
;
397 #define EFI_SAL_ST_HEADER_SIGNATURE "SST_"
398 #define EFI_SAL_REVISION 0x0320
402 #define EFI_SAL_ST_ENTRY_POINT 0
403 #define EFI_SAL_ST_MEMORY_DESCRIPTOR 1
404 #define EFI_SAL_ST_PLATFORM_FEATURES 2
405 #define EFI_SAL_ST_TR_USAGE 3
406 #define EFI_SAL_ST_PTC 4
407 #define EFI_SAL_ST_AP_WAKEUP 5
410 // SAL System Type Sizes
412 #define EFI_SAL_ST_ENTRY_POINT_SIZE 48
413 #define EFI_SAL_ST_MEMORY_DESCRIPTOR_SIZE 32
414 #define EFI_SAL_ST_PLATFORM_FEATURES_SIZE 16
415 #define EFI_SAL_ST_TR_USAGE_SIZE 32
416 #define EFI_SAL_ST_PTC_SIZE 16
417 #define EFI_SAL_ST_AP_WAKEUP_SIZE 16
421 /// Format Entrypoint Descriptor Entry
424 UINT8 Type
; ///< Type here should be 0
428 UINT64 SalGlobalDataPointer
;
430 } SAL_ST_ENTRY_POINT_DESCRIPTOR
;
434 /// Format Platform Features Descriptor Entry
437 UINT8 Type
; ///< Type here should be 2
438 UINT8 PlatformFeatures
;
440 } SAL_ST_PLATFORM_FEATURES
;
443 // Value of Platform Feature List
445 #define SAL_PLAT_FEAT_BUS_LOCK 0x01
446 #define SAL_PLAT_FEAT_PLAT_IPI_HINT 0x02
447 #define SAL_PLAT_FEAT_PROC_IPI_HINT 0x04
451 /// Format of Translation Register Descriptor Entry
454 UINT8 Type
; ///< Type here should be 3
458 UINT64 VirtualAddress
;
459 UINT64 EncodedPageSize
;
461 } SAL_ST_TR_DECRIPTOR
;
464 // Type of Translation Register
466 #define EFI_SAL_ST_TR_USAGE_INSTRUCTION 00
467 #define EFI_SAL_ST_TR_USAGE_DATA 01
471 /// Definition of Coherence Domain Information
474 UINT64 NumberOfProcessors
;
475 UINT64 LocalIDRegister
;
476 } SAL_COHERENCE_DOMAIN_INFO
;
481 /// Format of Purge Translation Cache Coherence Domain Entry
484 UINT8 Type
; ///< Type here should be 4
486 UINT32 NumberOfDomains
;
487 SAL_COHERENCE_DOMAIN_INFO
*DomainInformation
;
488 } SAL_ST_CACHE_COHERENCE_DECRIPTOR
;
493 /// Format of Application Processor Wake-Up Descriptor Entry
496 UINT8 Type
; ///< Type here should be 5
499 UINT64 ExternalInterruptVector
;
500 } SAL_ST_AP_WAKEUP_DECRIPTOR
;
504 /// Format of Firmware Interface Table (FIT) Entry
512 UINT8 CheckSumValid
: 1;
518 #define EFI_SAL_FIT_FIT_HEADER_TYPE 0x00
519 #define EFI_SAL_FIT_PAL_B_TYPE 0x01
521 // Type from 0x02 to 0x0D is reserved.
523 #define EFI_SAL_FIT_PROCESSOR_SPECIFIC_PAL_A_TYPE 0x0E
524 #define EFI_SAL_FIT_PAL_A_TYPE 0x0F
526 // OEM-defined type range is from 0x10 to 0x7E.
527 // Here we defined the PEI_CORE type as 0x10
529 #define EFI_SAL_FIT_PEI_CORE_TYPE 0x10
530 #define EFI_SAL_FIT_UNUSED_TYPE 0x7F
535 #define EFI_SAL_FIT_ENTRY_PTR (0x100000000 - 32) // 4GB - 24
536 #define EFI_SAL_FIT_PALA_ENTRY (0x100000000 - 48) // 4GB - 32
537 #define EFI_SAL_FIT_PALB_TYPE 01
540 // Following definitions are for Error Record Structure
544 /// Format of TimeStamp field in Record Header
557 /// Definition of Record Header
563 UINT8 ValidationBits
;
565 SAL_TIME_STAMP TimeStamp
;
566 UINT8 OemPlatformId
[16];
569 /// Definition of Section Header
574 UINT8 ErrorRecoveryInfo
;
576 UINT32 SectionLength
;
580 /// GUID of Processor Machine Check Errors
582 #define SAL_PROCESSOR_ERROR_RECORD_INFO \
584 0xe429faf1, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
587 // Bit masks for valid bits of MOD_ERROR_INFO
589 #define CHECK_INFO_VALID_BIT_MASK 0x1
590 #define REQUESTOR_ID_VALID_BIT_MASK 0x2
591 #define RESPONDER_ID_VALID_BIT_MASK 0x4
592 #define TARGER_ID_VALID_BIT_MASK 0x8
593 #define PRECISE_IP_VALID_BIT_MASK 0x10
595 /// Definition of MOD_ERROR_INFO_STRUCT
598 UINT64 InfoValid
: 1;
600 UINT64 RespValid
: 1;
601 UINT64 TargetValid
: 1;
603 UINT64 Reserved
: 59;
611 /// Definition of CPUID_INFO_STRUCT
623 // Bit masks for PSI_STATIC_STRUCT.ValidFieldBits
625 #define MIN_STATE_VALID_BIT_MASK 0x1
626 #define BR_VALID_BIT_MASK 0x2
627 #define CR_VALID_BIT_MASK 0x4
628 #define AR_VALID_BIT_MASK 0x8
629 #define RR_VALID_BIT_MASK 0x10
630 #define FR_VALID_BIT_MASK 0x20
632 /// Definition of PSI_STATIC_STRUCT
635 UINT64 ValidFieldBits
;
636 UINT8 MinStateInfo
[1024];
644 // Bit masks for SAL_PROCESSOR_ERROR_RECORD.ValidationBits
646 #define PROC_ERROR_MAP_VALID_BIT_MASK 0x1
647 #define PROC_STATE_PARAMETER_VALID_BIT_MASK 0x2
648 #define PROC_CR_LID_VALID_BIT_MASK 0x4
649 #define PROC_STATIC_STRUCT_VALID_BIT_MASK 0x8
650 #define CPU_INFO_VALID_BIT_MASK 0x1000000
652 /// Definition of Processor Machine Check Error Record
655 SAL_SEC_HEADER SectionHeader
;
656 UINT64 ValidationBits
;
658 UINT64 ProcStateParameter
;
660 MOD_ERROR_INFO CacheError
[15];
661 MOD_ERROR_INFO TlbError
[15];
662 MOD_ERROR_INFO BusError
[15];
663 MOD_ERROR_INFO RegFileCheck
[15];
664 MOD_ERROR_INFO MsCheck
[15];
666 PSI_STATIC_STRUCT PsiValidData
;
667 } SAL_PROCESSOR_ERROR_RECORD
;
670 /// GUID of Platform Memory Device Error Info
672 #define SAL_MEMORY_ERROR_RECORD_INFO \
674 0xe429faf2, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
677 // Bit masks for SAL_MEMORY_ERROR_RECORD.ValidationBits
679 #define MEMORY_ERROR_STATUS_VALID_BIT_MASK 0x1
680 #define MEMORY_PHYSICAL_ADDRESS_VALID_BIT_MASK 0x2
681 #define MEMORY_ADDR_BIT_MASK 0x4
682 #define MEMORY_NODE_VALID_BIT_MASK 0x8
683 #define MEMORY_CARD_VALID_BIT_MASK 0x10
684 #define MEMORY_MODULE_VALID_BIT_MASK 0x20
685 #define MEMORY_BANK_VALID_BIT_MASK 0x40
686 #define MEMORY_DEVICE_VALID_BIT_MASK 0x80
687 #define MEMORY_ROW_VALID_BIT_MASK 0x100
688 #define MEMORY_COLUMN_VALID_BIT_MASK 0x200
689 #define MEMORY_BIT_POSITION_VALID_BIT_MASK 0x400
690 #define MEMORY_PLATFORM_REQUESTOR_ID_VALID_BIT_MASK 0x800
691 #define MEMORY_PLATFORM_RESPONDER_ID_VALID_BIT_MASK 0x1000
692 #define MEMORY_PLATFORM_TARGET_VALID_BIT_MASK 0x2000
693 #define MEMORY_PLATFORM_BUS_SPECIFIC_DATA_VALID_BIT_MASK 0x4000
694 #define MEMORY_PLATFORM_OEM_ID_VALID_BIT_MASK 0x8000
695 #define MEMORY_PLATFORM_OEM_DATA_STRUCT_VALID_BIT_MASK 0x10000
697 /// Definition of Platform Memory Device Error Info Record
700 SAL_SEC_HEADER SectionHeader
;
701 UINT64 ValidationBits
;
702 UINT64 MemErrorStatus
;
703 UINT64 MemPhysicalAddress
;
704 UINT64 MemPhysicalAddressMask
;
712 UINT16 MemBitPosition
;
713 UINT64 ModRequestorId
;
714 UINT64 ModResponderId
;
716 UINT64 BusSpecificData
;
717 UINT8 MemPlatformOemId
[16];
718 } SAL_MEMORY_ERROR_RECORD
;
721 /// GUID of Platform PCI Bus Error Info
723 #define SAL_PCI_BUS_ERROR_RECORD_INFO \
725 0xe429faf4, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
728 // Bit masks for SAL_PCI_BUS_ERROR_RECORD.ValidationBits
730 #define PCI_BUS_ERROR_STATUS_VALID_BIT_MASK 0x1
731 #define PCI_BUS_ERROR_TYPE_VALID_BIT_MASK 0x2
732 #define PCI_BUS_ID_VALID_BIT_MASK 0x4
733 #define PCI_BUS_ADDRESS_VALID_BIT_MASK 0x8
734 #define PCI_BUS_DATA_VALID_BIT_MASK 0x10
735 #define PCI_BUS_CMD_VALID_BIT_MASK 0x20
736 #define PCI_BUS_REQUESTOR_ID_VALID_BIT_MASK 0x40
737 #define PCI_BUS_RESPONDER_ID_VALID_BIT_MASK 0x80
738 #define PCI_BUS_TARGET_VALID_BIT_MASK 0x100
739 #define PCI_BUS_OEM_ID_VALID_BIT_MASK 0x200
740 #define PCI_BUS_OEM_DATA_STRUCT_VALID_BIT_MASK 0x400
747 /// Definition of Platform PCI Bus Error Info Record
750 SAL_SEC_HEADER SectionHeader
;
751 UINT64 ValidationBits
;
752 UINT64 PciBusErrorStatus
;
753 UINT16 PciBusErrorType
;
756 UINT64 PciBusAddress
;
758 UINT64 PciBusCommand
;
759 UINT64 PciBusRequestorId
;
760 UINT64 PciBusResponderId
;
761 UINT64 PciBusTargetId
;
762 UINT8 PciBusOemId
[16];
763 } SAL_PCI_BUS_ERROR_RECORD
;
766 /// GUID of Platform PCI Component Error Info
768 #define SAL_PCI_COMP_ERROR_RECORD_INFO \
770 0xe429faf6, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
773 // Bit masks for SAL_PCI_COMPONENT_ERROR_RECORD.ValidationBits
775 #define PCI_COMP_ERROR_STATUS_VALID_BIT_MASK 0x1
776 #define PCI_COMP_INFO_VALID_BIT_MASK 0x2
777 #define PCI_COMP_MEM_NUM_VALID_BIT_MASK 0x4
778 #define PCI_COMP_IO_NUM_VALID_BIT_MASK 0x8
779 #define PCI_COMP_REG_DATA_PAIR_VALID_BIT_MASK 0x10
780 #define PCI_COMP_OEM_DATA_STRUCT_VALID_BIT_MASK 0x20
782 /// Format of PCI Component Information to identify the device
788 UINT8 FunctionNumber
;
795 /// Definition of Platform PCI Component Error Info
798 SAL_SEC_HEADER SectionHeader
;
799 UINT64 ValidationBits
;
800 UINT64 PciComponentErrorStatus
;
801 PCI_COMP_INFO PciComponentInfo
;
802 UINT32 PciComponentMemNum
;
803 UINT32 PciComponentIoNum
;
804 UINT8 PciBusOemId
[16];
805 } SAL_PCI_COMPONENT_ERROR_RECORD
;
808 /// Platform SEL Device Error Info
810 #define SAL_SEL_DEVICE_ERROR_RECORD_INFO \
812 0xe429faf3, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
815 // Bit masks for SAL_SEL_DEVICE_ERROR_RECORD.ValidationBits
817 #define SEL_RECORD_ID_VALID_BIT_MASK 0x1;
818 #define SEL_RECORD_TYPE_VALID_BIT_MASK 0x2;
819 #define SEL_GENERATOR_ID_VALID_BIT_MASK 0x4;
820 #define SEL_EVM_REV_VALID_BIT_MASK 0x8;
821 #define SEL_SENSOR_TYPE_VALID_BIT_MASK 0x10;
822 #define SEL_SENSOR_NUM_VALID_BIT_MASK 0x20;
823 #define SEL_EVENT_DIR_TYPE_VALID_BIT_MASK 0x40;
824 #define SEL_EVENT_DATA1_VALID_BIT_MASK 0x80;
825 #define SEL_EVENT_DATA2_VALID_BIT_MASK 0x100;
826 #define SEL_EVENT_DATA3_VALID_BIT_MASK 0x200;
828 /// Definition of Platform SEL Device Error Info Record
831 SAL_SEC_HEADER SectionHeader
;
832 UINT64 ValidationBits
;
844 } SAL_SEL_DEVICE_ERROR_RECORD
;
847 /// GUID of Platform SMBIOS Device Error Info
849 #define SAL_SMBIOS_ERROR_RECORD_INFO \
851 0xe429faf5, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
854 // Bit masks for SAL_SMBIOS_DEVICE_ERROR_RECORD.ValidationBits
856 #define SMBIOS_EVENT_TYPE_VALID_BIT_MASK 0x1
857 #define SMBIOS_LENGTH_VALID_BIT_MASK 0x2
858 #define SMBIOS_TIME_STAMP_VALID_BIT_MASK 0x4
859 #define SMBIOS_DATA_VALID_BIT_MASK 0x8
861 /// Definition of Platform SMBIOS Device Error Info Record
864 SAL_SEC_HEADER SectionHeader
;
865 UINT64 ValidationBits
;
866 UINT8 SmbiosEventType
;
868 UINT8 SmbiosBcdTimeStamp
[6];
869 } SAL_SMBIOS_DEVICE_ERROR_RECORD
;
872 /// GUID of Platform Specific Error Info
874 #define SAL_PLATFORM_ERROR_RECORD_INFO \
876 0xe429faf7, 0x3cb7, 0x11d4, {0xbc, 0xa7, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 } \
879 // Bit masks for SAL_PLATFORM_SPECIFIC_ERROR_RECORD.ValidationBits
881 #define PLATFORM_ERROR_STATUS_VALID_BIT_MASK 0x1
882 #define PLATFORM_REQUESTOR_ID_VALID_BIT_MASK 0x2
883 #define PLATFORM_RESPONDER_ID_VALID_BIT_MASK 0x4
884 #define PLATFORM_TARGET_VALID_BIT_MASK 0x8
885 #define PLATFORM_SPECIFIC_DATA_VALID_BIT_MASK 0x10
886 #define PLATFORM_OEM_ID_VALID_BIT_MASK 0x20
887 #define PLATFORM_OEM_DATA_STRUCT_VALID_BIT_MASK 0x40
888 #define PLATFORM_OEM_DEVICE_PATH_VALID_BIT_MASK 0x80
890 /// Definition of Platform Specific Error Info Record
893 SAL_SEC_HEADER SectionHeader
;
894 UINT64 ValidationBits
;
895 UINT64 PlatformErrorStatus
;
896 UINT64 PlatformRequestorId
;
897 UINT64 PlatformResponderId
;
898 UINT64 PlatformTargetId
;
899 UINT64 PlatformBusSpecificData
;
900 UINT8 OemComponentId
[16];
901 } SAL_PLATFORM_SPECIFIC_ERROR_RECORD
;
904 /// Union of all the possible SAL Error Record Types
907 SAL_RECORD_HEADER
*RecordHeader
;
908 SAL_PROCESSOR_ERROR_RECORD
*SalProcessorRecord
;
909 SAL_PCI_BUS_ERROR_RECORD
*SalPciBusRecord
;
910 SAL_PCI_COMPONENT_ERROR_RECORD
*SalPciComponentRecord
;
911 SAL_SEL_DEVICE_ERROR_RECORD
*ImpiRecord
;
912 SAL_SMBIOS_DEVICE_ERROR_RECORD
*SmbiosRecord
;
913 SAL_PLATFORM_SPECIFIC_ERROR_RECORD
*PlatformRecord
;
914 SAL_MEMORY_ERROR_RECORD
*MemoryRecord
;
916 } SAL_ERROR_RECORDS_POINTERS
;