/*++ Copyright (c) 2004 - 2006, Intel Corporation All rights reserved. This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. Module Name: ExtendedSalGuid.h Abstract: --*/ #ifndef _EXTENDED_SAL_GUID_H_ #define _EXTENDED_SAL_GUID_H_ // // Extended SAL Services protocol GUIDs // #define EFI_EXTENDED_SAL_BASE_IO_SERVICES_PROTOCOL_GUID \ { 0x5aea42b5, 0x31e1, 0x4515, {0xbc, 0x31, 0xb8, 0xd5, 0x25, 0x75, 0x65, 0xa6} } #define EFI_EXTENDED_SAL_STALL_SERVICES_PROTOCOL_GUID \ { 0x53a58d06, 0xac27, 0x4d8c, {0xb5, 0xe9, 0xf0, 0x8a, 0x80, 0x65, 0x41, 0x70} } #define EFI_EXTENDED_SAL_LOCK_SERVICES_PROTOCOL_GUID \ { 0x76b75c23, 0xfe4f, 0x4e17, {0xa2, 0xad, 0x1a, 0x65, 0x3d, 0xbb, 0x49, 0x4a} } #define EFI_EXTENDED_SAL_VIRTUAL_SERVICES_PROTOCOL_GUID \ { 0xc1a74056, 0x260e, 0x4871, {0xa0, 0x31, 0xe6, 0x45, 0xa6, 0x5b, 0x6e, 0x11} } #define EFI_EXTENDED_SAL_RTC_SERVICES_PROTOCOL_GUID \ { 0x7e97a470, 0xefdb, 0x4d02, {0x8f, 0xce, 0x61, 0x90, 0xd2, 0x7b, 0xa2, 0x96} } #define EFI_EXTENDED_SAL_VARIABLE_SERVICES_PROTOCOL_GUID \ { 0x4ecb6c53, 0xc641, 0x4370, {0x8c, 0xb2, 0x3b, 0x0e, 0x49, 0x6e, 0x83, 0x78} } #define EFI_EXTENDED_SAL_MTC_SERVICES_PROTOCOL_GUID \ { 0x899afd18, 0x75e8, 0x408b, {0xa4, 0x1a, 0x6e, 0x2e, 0x7e, 0xcd, 0xf4, 0x54} } #define EFI_EXTENDED_SAL_RESET_SERVICES_PROTOCOL_GUID \ { 0x7d019990, 0x8ce1, 0x46f5, {0xa7, 0x76, 0x3c, 0x51, 0x98, 0x67, 0x6a, 0xa0} } #define EFI_EXTENDED_SAL_STATUS_CODE_SERVICES_PROTOCOL_GUID \ { 0xdbd91d, 0x55e9, 0x420f, {0x96, 0x39, 0x5e, 0x9f, 0x84, 0x37, 0xb4, 0x4f} } #define EFI_EXTENDED_SAL_FV_BLOCK_SERVICES_PROTOCOL_GUID \ { 0xa2271df1, 0xbcbb, 0x4f1d, {0x98, 0xa9, 0x06, 0xbc, 0x17, 0x2f, 0x07, 0x1a} } #define EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID \ { 0x697d81a2, 0xcf18, 0x4dc0, {0x9e, 0x0d, 0x06, 0x11, 0x3b, 0x61, 0x8a, 0x3f} } #define EFI_EXTENDED_SAL_PAL_SERVICES_PROTOCOL_GUID \ { 0xe1cd9d21, 0x0fc2, 0x438d, {0x97, 0x03, 0x04, 0xe6, 0x6d, 0x96, 0x1e, 0x57} } #define EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID \ { 0xd9e9fa06, 0x0fe0, 0x41c3, {0x96, 0xfb, 0x83, 0x42, 0x5a, 0x33, 0x94, 0xf8} } #define EFI_EXTENDED_SAL_MCA_SERVICES_PROTOCOL_GUID \ { 0x2a591128, 0x6cc7, 0x42b1, {0x8a, 0xf0, 0x58, 0x93, 0x3b, 0x68, 0x2d, 0xbb} } #define EFI_EXTENDED_SAL_PCI_SERVICES_PROTOCOL_GUID \ { 0xa46b1a31, 0xad66, 0x4905, {0x92, 0xf6, 0x2b, 0x46, 0x59, 0xdc, 0x30, 0x63} } #define EFI_EXTENDED_SAL_CACHE_SERVICES_PROTOCOL_GUID \ { 0xedc9494, 0x2743, 0x4ba5, {0x88, 0x18, 0x0a, 0xef, 0x52, 0x13, 0xf1, 0x88} } #define EFI_EXTENDED_SAL_MCA_LOG_SERVICES_PROTOCOL_GUID \ { 0xcb3fd86e, 0x38a3, 0x4c03, {0x9a, 0x5c, 0x90, 0xcf, 0xa3, 0xa2, 0xab, 0x7a} } #define EFI_EXTENDED_SAL_ELOG_SERVICES_PROTOCOL_GUID \ { 0xd5e4ee5f, 0x3e0a, 0x453c, {0xa7, 0x25, 0xb6, 0x92, 0xbb, 0x6, 0x36, 0x5a} } #define EFI_EXTENDED_SAL_SENSOR_SERVICES_PROTOCOL_GUID \ { 0x4a153b6e, 0x85a1, 0x4982, {0x98, 0xf4, 0x6a, 0x8c, 0xfc, 0xa4, 0xab, 0xa1} } #define EFI_EXTENDED_SAL_SM_COM_LAYER_SERVICES_PROTOCOL_GUID \ { 0x4356799, 0x81b7, 0x4e08, {0xa3, 0x8d, 0xd9, 0x78, 0xfa, 0x47, 0xba, 0x42} } #define EFI_EXTENDED_SAL_SST_GUID \ { 0x38802700, 0x868a, 0x4b4e, {0x81, 0xd4, 0x4f, 0x1b, 0xdc, 0xcf, 0xb4, 0x6f} } // // Extended Sal Proc Function IDs. // // // BugBug: These enums are name colisions waiting to happen. They should all be // prefixed with Esal! It might be better to just make them #define, so // they would be all caps. // typedef enum { IoRead, IoWrite, MemRead, MemWrite } EFI_EXTENDED_SAL_BASE_IO_SERVICES_FUNC_ID; typedef enum { Stall } EFI_EXTENDED_SAL_STALL_FUNC_ID; typedef enum { InitializeLockService, AcquireLockService, ReleaseLockService, MaxLockServiceFunctionId } EFI_EXTENDED_SAL_LOCK_SERVICES_FUNC_ID; // // BugBug : Covert the first 3 functions into a lib functions // and move SalRegisterPhysicalAddress to SAL BASE Class // typedef enum { SetVirtualAddress, IsVirtual, IsEfiRuntime, SalRegisterPhysicalAddress } EFI_EXTENDED_SAL_VIRTUAL_SERVICES_FUNC_ID; typedef enum { GetTime, SetTime, GetWakeupTime, SetWakeupTime, GetRtcFreq, InitializeThreshold, BumpThresholdCount, GetThresholdCount } EFI_EXTENDED_SAL_RTC_SERVICES_FUNC_ID; typedef enum { EsalGetVariable, EsalGetNextVariableName, EsalSetVariable #if (EFI_SPECIFICATION_VERSION >= 0x00020000) , EsalQueryVariableInfo #endif } EFI_EXTENDED_SAL_VARIABLE_SERVICES_FUNC_ID; typedef enum { GetNextHighMonotonicCount } EFI_EXTENDED_SAL_MTC_SERVICES_FUNC_ID; typedef enum { ResetSystem } EFI_EXTENDED_SAL_RESET_SERVICES_FUNC_ID; typedef enum { StatusCode } EFI_EXTENDED_SAL_STATUS_CODE_FUNC_ID; typedef enum { ReportStatusCode } EFI_EXTENDED_SAL_STATUS_CODE_SERVICES_FUNC_ID; typedef enum { Read, Write, EraseBlock, GetVolumeAttributes, SetVolumeAttributes, GetPhysicalAddress, GetBlockSize, EraseCustomBlockRange, } EFI_EXTENDED_SAL_FV_BLOCK_SERVICES_FUNC_ID; typedef enum { AddCpuData, RemoveCpuData, ModifyCpuData, GetCpuDataByID, GetCpuDataByIndex, SendIpi, CurrentProcInfo, NumProcessors, SetMinState, GetMinState } EFI_EXTENDED_SAL_MP_SERVICES_FUNC_ID; typedef enum { PalProc, SetNewPalEntry, GetNewPalEntry } EFI_EXTENDED_SAL_PAL_SERVICES_FUNC_ID; typedef enum { SalSetVectors, SalMcRendez, SalMcSetParams, EsalGetVectors, EsalMcGetParams, EsalMcGetMcParams, EsalGetMcCheckinFlags, EsalGetPlatformBaseFreq } EFI_EXTENDED_SAL_BASE_SERVICES_FUNC_ID; typedef enum { McaGetStateInfo, McaRegisterCpu } EFI_EXTENDED_SAL_MCA_SERVICES_FUNC_ID; typedef enum { SalPciConfigRead, SalPciConfigWrite } EFI_EXTENDED_SAL_PCI_SERVICES_FUNC_ID; typedef enum { SalCacheInit, SalCacheFlush } EFI_EXTENDED_SAL_CACHE_SERVICES_FUNC_ID; typedef enum { SalGetStateInfo, SalGetStateInfoSize, SalClearStateInfo, EsalGetStateBuffer, EsalSaveStateBuffer } EFI_EXTENDED_SAL_MCA_LOG_SERVICES_FUNC_ID; typedef enum { SalSetEventLogData, SalGetEventLogData, SalEraseEventLogData, SalActivateEventLogData } EFI_EXTENDED_SAL_ELOG_SERVICES_FUNC_ID; typedef enum { EsalGetComControllerInfo, EsalSendComData, EsalReceiveComData } EFI_EXTENDED_SAL_SM_COM_LAYER_SERVICES_FUNC_ID; typedef enum { SalUpdatePal } EFI_EXTENDED_SAL_UPDATE_PAL_SERVICES_FUNC_ID; typedef enum { EsalReadSensorInfo, EsalReadSensorStatus, EsalRearmSensor, EsalReadSensorData } EFI_EXTENDED_SAL_SENSOR_SERVICES_FUNC_ID; typedef struct { UINT64 ProtoData; } ESAL_GUID_DUMMY_PROTOCOL; extern EFI_GUID gEfiExtendedSalBaseIoServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalStallServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalLockServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalVirtualServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalRtcServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalVariableServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalMtcServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalResetServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalStatusCodeServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalFvBlockServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalMpServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalPalServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalBaseServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalMcaServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalPciServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalCacheServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalMcaLogServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalElogServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalSensorServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalSmComLayerServicesProtocolGuid; extern EFI_GUID gEfiExtendedSalSstGuid; #endif