[e16e8f2] | 1 | #ifndef _SAL_PROC_H |
---|
| 2 | #define _SAL_PROC_H |
---|
| 3 | // |
---|
| 4 | // |
---|
| 5 | //Copyright (c) 1999 Intel Corporation |
---|
| 6 | // |
---|
| 7 | //Module Name: |
---|
| 8 | // |
---|
| 9 | // SalProc.h |
---|
| 10 | // |
---|
| 11 | //Abstract: |
---|
| 12 | // |
---|
| 13 | // Main SAL interface routins for IA-64 calls. |
---|
| 14 | // |
---|
| 15 | // |
---|
| 16 | //Revision History |
---|
| 17 | // |
---|
| 18 | // |
---|
| 19 | |
---|
| 20 | // return value that mimicks r8,r9,r10 & r11 registers |
---|
| 21 | typedef struct { |
---|
| 22 | UINT64 p0; |
---|
| 23 | UINT64 p1; |
---|
| 24 | UINT64 p2; |
---|
| 25 | UINT64 p3; |
---|
| 26 | } rArg; |
---|
| 27 | |
---|
| 28 | #define SAL_PCI_CONFIG_READ 0x01000010 |
---|
| 29 | #define SAL_PCI_CONFIG_WRITE 0x01000011 |
---|
| 30 | |
---|
| 31 | typedef VOID (*PFN)(); |
---|
| 32 | typedef rArg (*PFN_SAL_PROC)(UINT64,UINT64,UINT64,UINT64,UINT64,UINT64,UINT64,UINT64); |
---|
| 33 | typedef rArg (*PFN_SAL_CALLBACK)(UINT64,UINT64,UINT64,UINT64,UINT64,UINT64,UINT64,UINT64); |
---|
| 34 | |
---|
| 35 | typedef struct _PLABEL { |
---|
| 36 | UINT64 ProcEntryPoint; |
---|
| 37 | UINT64 GP; |
---|
| 38 | } PLABEL; |
---|
| 39 | |
---|
| 40 | typedef struct tagIA32_BIOS_REGISTER_STATE { |
---|
| 41 | |
---|
| 42 | // general registers |
---|
| 43 | UINT32 eax; |
---|
| 44 | UINT32 ecx; |
---|
| 45 | UINT32 edx; |
---|
| 46 | UINT32 ebx; |
---|
| 47 | |
---|
| 48 | // stack registers |
---|
| 49 | UINT32 esp; |
---|
| 50 | UINT32 ebp; |
---|
| 51 | UINT32 esi; |
---|
| 52 | UINT32 edi; |
---|
| 53 | |
---|
| 54 | // eflags |
---|
| 55 | UINT32 eflags; |
---|
| 56 | |
---|
| 57 | // instruction pointer |
---|
| 58 | UINT32 eip; |
---|
| 59 | |
---|
| 60 | UINT16 cs; |
---|
| 61 | UINT16 ds; |
---|
| 62 | UINT16 es; |
---|
| 63 | UINT16 fs; |
---|
| 64 | UINT16 gs; |
---|
| 65 | UINT16 ss; |
---|
| 66 | |
---|
| 67 | // Reserved |
---|
| 68 | UINT32 Reserved1; |
---|
| 69 | UINT64 Reserved2; |
---|
| 70 | } IA32_BIOS_REGISTER_STATE; |
---|
| 71 | |
---|
| 72 | VOID EFIInitMsg(VOID); |
---|
| 73 | |
---|
| 74 | EFI_STATUS |
---|
| 75 | PlRegisterAndStartTimer( |
---|
| 76 | IN UINTN Period |
---|
| 77 | ); |
---|
| 78 | |
---|
| 79 | EFI_STATUS |
---|
| 80 | PlDeRegisterAndCancelTimer(VOID); |
---|
| 81 | |
---|
| 82 | VOID |
---|
| 83 | SalProc ( |
---|
| 84 | IN UINT64 Arg1, |
---|
| 85 | IN UINT64 Arg2, |
---|
| 86 | IN UINT64 Arg3, |
---|
| 87 | IN UINT64 Arg4, |
---|
| 88 | IN UINT64 Arg5, |
---|
| 89 | IN UINT64 Arg6, |
---|
| 90 | IN UINT64 Arg7, |
---|
| 91 | IN UINT64 Arg8, |
---|
| 92 | OUT rArg *Results OPTIONAL |
---|
| 93 | ); |
---|
| 94 | |
---|
| 95 | VOID |
---|
| 96 | SalCallBack ( |
---|
| 97 | IN UINT64 Arg1, |
---|
| 98 | IN UINT64 Arg2, |
---|
| 99 | IN UINT64 Arg3, |
---|
| 100 | IN UINT64 Arg4, |
---|
| 101 | IN UINT64 Arg5, |
---|
| 102 | IN UINT64 Arg6, |
---|
| 103 | IN UINT64 Arg7, |
---|
| 104 | IN UINT64 Arg8, |
---|
| 105 | OUT rArg *Results OPTIONAL |
---|
| 106 | ); |
---|
| 107 | |
---|
| 108 | VOID |
---|
| 109 | RUNTIMEFUNCTION |
---|
| 110 | RtSalCallBack ( |
---|
| 111 | IN UINT64 Arg1, |
---|
| 112 | IN UINT64 Arg2, |
---|
| 113 | IN UINT64 Arg3, |
---|
| 114 | IN UINT64 Arg4, |
---|
| 115 | IN UINT64 Arg5, |
---|
| 116 | IN UINT64 Arg6, |
---|
| 117 | IN UINT64 Arg7, |
---|
| 118 | IN UINT64 Arg8, |
---|
| 119 | OUT rArg *Results OPTIONAL |
---|
| 120 | ); |
---|
| 121 | |
---|
| 122 | |
---|
| 123 | extern PLABEL RtGlobalSalProcEntry; |
---|
| 124 | extern PLABEL RtGlobalSALCallBack; |
---|
| 125 | |
---|
| 126 | #pragma pack(1) |
---|
| 127 | // |
---|
| 128 | // SAL System Table |
---|
| 129 | // |
---|
| 130 | typedef struct { |
---|
| 131 | UINT32 Signature; |
---|
| 132 | UINT32 Length; |
---|
| 133 | UINT16 Revision; |
---|
| 134 | UINT16 EntryCount; |
---|
| 135 | UINT8 CheckSum; |
---|
| 136 | UINT8 Reserved[7]; |
---|
| 137 | UINT16 SALA_Ver; |
---|
| 138 | UINT16 SALB_Ver; |
---|
| 139 | UINT8 OemId[32]; |
---|
| 140 | UINT8 ProductID[32]; |
---|
| 141 | UINT8 Reserved2[8]; |
---|
| 142 | } SAL_SYSTEM_TABLE_HDR; |
---|
| 143 | |
---|
| 144 | #define SAL_ST_ENTRY_POINT 0 |
---|
| 145 | #define SAL_ST_MEMORY_DESCRIPTOR 1 |
---|
| 146 | #define SAL_ST_PLATFORM_FEATURES 2 |
---|
| 147 | #define SAL_ST_TR_USAGE 3 |
---|
| 148 | #define SAL_ST_PTC 4 |
---|
| 149 | #define SAL_ST_AP_WAKEUP 5 |
---|
| 150 | |
---|
| 151 | typedef struct { |
---|
| 152 | UINT8 Type; // Type == 0 |
---|
| 153 | UINT8 Reserved[7]; |
---|
| 154 | UINT64 PalProcEntry; |
---|
| 155 | UINT64 SalProcEntry; |
---|
| 156 | UINT64 GlobalDataPointer; |
---|
| 157 | UINT64 Reserved2[2]; |
---|
| 158 | } SAL_ST_ENTRY_POINT_DESCRIPTOR; |
---|
| 159 | |
---|
| 160 | typedef struct { |
---|
| 161 | UINT8 Type; // Type == 1 |
---|
| 162 | UINT8 NeedVirtualRegistration; |
---|
| 163 | UINT8 MemoryAttributes; |
---|
| 164 | UINT8 PageAccessRights; |
---|
| 165 | UINT8 SupportedAttributes; |
---|
| 166 | UINT8 Reserved; |
---|
| 167 | UINT16 MemoryType; |
---|
| 168 | UINT64 PhysicalMemoryAddress; |
---|
| 169 | UINT32 Length; |
---|
| 170 | UINT32 Reserved1; |
---|
| 171 | UINT64 OemReserved; |
---|
| 172 | } SAL_ST_MEMORY_DESCRIPTOR_ENTRY; |
---|
| 173 | |
---|
| 174 | // |
---|
| 175 | // MemoryType info |
---|
| 176 | // |
---|
| 177 | #define SAL_SAPIC_IPI_BLOCK 0x0002 |
---|
| 178 | #define SAL_IO_PORT_MAPPING 0x0003 |
---|
| 179 | |
---|
| 180 | typedef struct { |
---|
| 181 | UINT8 Type; // Type == 2 |
---|
| 182 | UINT8 PlatformFeatures; |
---|
| 183 | UINT8 Reserved[14]; |
---|
| 184 | } SAL_ST_MEMORY_DECRIPTOR; |
---|
| 185 | |
---|
| 186 | typedef struct { |
---|
| 187 | UINT8 Type; // Type == 3 |
---|
| 188 | UINT8 TRType; |
---|
| 189 | UINT8 TRNumber; |
---|
| 190 | UINT8 Reserved[5]; |
---|
| 191 | UINT64 VirtualAddress; |
---|
| 192 | UINT64 EncodedPageSize; |
---|
| 193 | UINT64 Reserved1; |
---|
| 194 | } SAL_ST_TR_DECRIPTOR; |
---|
| 195 | |
---|
| 196 | typedef struct { |
---|
| 197 | UINT64 NumberOfProcessors; |
---|
| 198 | UINT64 LocalIDRegister; |
---|
| 199 | } SAL_COHERENCE_DOMAIN_INFO; |
---|
| 200 | |
---|
| 201 | typedef struct { |
---|
| 202 | UINT8 Type; // Type == 4 |
---|
| 203 | UINT8 Reserved[3]; |
---|
| 204 | UINT32 NumberOfDomains; |
---|
| 205 | SAL_COHERENCE_DOMAIN_INFO *DomainInformation; |
---|
| 206 | } SAL_ST_CACHE_COHERENCE_DECRIPTOR; |
---|
| 207 | |
---|
| 208 | typedef struct { |
---|
| 209 | UINT8 Type; // Type == 5 |
---|
| 210 | UINT8 WakeUpType; |
---|
| 211 | UINT8 Reserved[6]; |
---|
| 212 | UINT64 ExternalInterruptVector; |
---|
| 213 | } SAL_ST_AP_WAKEUP_DECRIPTOR; |
---|
| 214 | |
---|
| 215 | typedef struct { |
---|
| 216 | SAL_SYSTEM_TABLE_HDR Header; |
---|
| 217 | SAL_ST_ENTRY_POINT_DESCRIPTOR Entry0; |
---|
| 218 | } SAL_SYSTEM_TABLE_ASCENDING_ORDER; |
---|
| 219 | |
---|
| 220 | #define FIT_ENTRY_PTR (0x100000000 - 32) // 4GB - 24 |
---|
| 221 | #define FIT_PALA_ENTRY (0x100000000 - 48) // 4GB - 32 |
---|
| 222 | #define FIT_PALB_TYPE 01 |
---|
| 223 | |
---|
| 224 | typedef struct { |
---|
| 225 | UINT64 Address; |
---|
| 226 | UINT8 Size[3]; |
---|
| 227 | UINT8 Reserved; |
---|
| 228 | UINT16 Revision; |
---|
| 229 | UINT8 Type:7; |
---|
| 230 | UINT8 CheckSumValid:1; |
---|
| 231 | UINT8 CheckSum; |
---|
| 232 | } FIT_ENTRY; |
---|
| 233 | |
---|
| 234 | #pragma pack() |
---|
| 235 | |
---|
| 236 | typedef |
---|
| 237 | rArg |
---|
| 238 | (*CALL_SAL_PROC)( |
---|
| 239 | IN UINT64 Arg1, |
---|
| 240 | IN UINT64 Arg2, |
---|
| 241 | IN UINT64 Arg3, |
---|
| 242 | IN UINT64 Arg4, |
---|
| 243 | IN UINT64 Arg5, |
---|
| 244 | IN UINT64 Arg6, |
---|
| 245 | IN UINT64 Arg7, |
---|
| 246 | IN UINT64 Arg8 |
---|
| 247 | ); |
---|
| 248 | |
---|
| 249 | typedef |
---|
| 250 | rArg |
---|
| 251 | (*CALL_PAL_PROC)( |
---|
| 252 | IN UINT64 Arg1, |
---|
| 253 | IN UINT64 Arg2, |
---|
| 254 | IN UINT64 Arg3, |
---|
| 255 | IN UINT64 Arg4 |
---|
| 256 | ); |
---|
| 257 | |
---|
| 258 | extern CALL_SAL_PROC GlobalSalProc; |
---|
| 259 | extern CALL_PAL_PROC GlobalPalProc; |
---|
| 260 | extern PLABEL SalProcPlabel; |
---|
| 261 | extern PLABEL PalProcPlabel; |
---|
| 262 | |
---|
| 263 | #endif |
---|
| 264 | |
---|