]> git.proxmox.com Git - mirror_edk2.git/blame - EdkCompatibilityPkg/Foundation/Cpu/Pentium/Include/CpuIA32.h
Include the missing Guid header file to refer the global Guid
[mirror_edk2.git] / EdkCompatibilityPkg / Foundation / Cpu / Pentium / Include / CpuIA32.h
CommitLineData
3eb9473e 1/*++\r
2\r
3Copyright (c) 2004 - 2006, Intel Corporation \r
4All rights reserved. This program and the accompanying materials \r
5are licensed and made available under the terms and conditions of the BSD License \r
6which accompanies this distribution. The full text of the license may be found at \r
7http://opensource.org/licenses/bsd-license.php \r
8 \r
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
11\r
12Module Name:\r
13\r
14 CpuIA32.h\r
15\r
16Abstract:\r
17\r
18--*/\r
19\r
20#ifndef _CPU_IA32_H\r
21#define _CPU_IA32_H\r
22\r
23#include "Tiano.h"\r
24\r
25#define IA32API __cdecl\r
26\r
27typedef struct {\r
28 UINT32 RegEax;\r
29 UINT32 RegEbx;\r
30 UINT32 RegEcx;\r
31 UINT32 RegEdx;\r
32} EFI_CPUID_REGISTER;\r
33\r
34typedef struct {\r
35 UINT32 HeaderVersion;\r
36 UINT32 UpdateRevision;\r
37 UINT32 Date;\r
38 UINT32 ProcessorId;\r
39 UINT32 Checksum;\r
40 UINT32 LoaderRevision;\r
41 UINT32 ProcessorFlags;\r
42 UINT32 DataSize;\r
43 UINT32 TotalSize;\r
44 UINT8 Reserved[12];\r
45} EFI_CPU_MICROCODE_HEADER;\r
46\r
47typedef struct {\r
48 UINT32 ExtendedSignatureCount;\r
49 UINT32 ExtendedTableChecksum; \r
50 UINT8 Reserved[12];\r
51} EFI_CPU_MICROCODE_EXTENDED_TABLE_HEADER;\r
52\r
53typedef struct {\r
54 UINT32 ProcessorSignature;\r
55 UINT32 ProcessorFlag;\r
56 UINT32 ProcessorChecksum;\r
57} EFI_CPU_MICROCODE_EXTENDED_TABLE;\r
58\r
59typedef struct {\r
60 UINT32 Stepping : 4;\r
61 UINT32 Model : 4;\r
62 UINT32 Family : 4;\r
63 UINT32 Type : 2;\r
64 UINT32 Reserved1 : 2;\r
65 UINT32 ExtendedModel : 4;\r
66 UINT32 ExtendedFamily : 8;\r
67 UINT32 Reserved2 : 4;\r
68} EFI_CPU_VERSION;\r
69\r
70#define EFI_CPUID_SIGNATURE 0x0\r
71#define EFI_CPUID_VERSION_INFO 0x1\r
72#define EFI_CPUID_CACHE_INFO 0x2\r
73#define EFI_CPUID_SERIAL_NUMBER 0x3\r
74#define EFI_CPUID_EXTENDED_FUNCTION 0x80000000\r
75#define EFI_CPUID_EXTENDED_CPU_SIG 0x80000001\r
76#define EFI_CPUID_BRAND_STRING1 0x80000002\r
77#define EFI_CPUID_BRAND_STRING2 0x80000003\r
78#define EFI_CPUID_BRAND_STRING3 0x80000004\r
79\r
80#define EFI_MSR_IA32_PLATFORM_ID 0x17\r
81#define EFI_MSR_IA32_APIC_BASE 0x1B\r
82#define EFI_MSR_EBC_HARD_POWERON 0x2A\r
83#define EFI_MSR_EBC_SOFT_POWERON 0x2B\r
84#define BINIT_DRIVER_DISABLE 0x40\r
85#define INTERNAL_MCERR_DISABLE 0x20\r
86#define INITIATOR_MCERR_DISABLE 0x10\r
87#define EFI_MSR_EBC_FREQUENCY_ID 0x2C\r
88#define EFI_MSR_IA32_BIOS_UPDT_TRIG 0x79\r
89#define EFI_MSR_IA32_BIOS_SIGN_ID 0x8B\r
90#define EFI_MSR_PSB_CLOCK_STATUS 0xCD\r
91#define EFI_APIC_GLOBAL_ENABLE 0x800\r
92#define EFI_MSR_IA32_MISC_ENABLE 0x1A0\r
93#define LIMIT_CPUID_MAXVAL_ENABLE_BIT 0x00400000\r
94#define AUTOMATIC_THERMAL_CONTROL_ENABLE_BIT 0x00000008\r
95#define COMPATIBLE_FPU_OPCODE_ENABLE_BIT 0x00000004\r
96#define LOGICAL_PROCESSOR_PRIORITY_ENABLE_BIT 0x00000002\r
97#define FAST_STRING_ENABLE_BIT 0x00000001\r
98\r
99#define EFI_CACHE_VARIABLE_MTRR_BASE 0x200\r
100#define EFI_CACHE_VARIABLE_MTRR_END 0x20F\r
101#define EFI_CACHE_IA32_MTRR_DEF_TYPE 0x2FF\r
102#define EFI_CACHE_MTRR_VALID 0x800\r
103#define EFI_CACHE_FIXED_MTRR_VALID 0x400\r
104#define EFI_CACHE_VALID_ADDRESS 0xFFFFFF000\r
105#define EFI_MSR_VALID_MASK 0xFFFFFFFFF\r
106#define EFI_CACHE_VALID_EXTENDED_ADDRESS 0xFFFFFFFFFF000\r
107#define EFI_MSR_VALID_EXTENDED_MASK 0xFFFFFFFFFFFFF\r
108\r
109#define EFI_IA32_MTRR_FIX64K_00000 0x250\r
110#define EFI_IA32_MTRR_FIX16K_80000 0x258\r
111#define EFI_IA32_MTRR_FIX16K_A0000 0x259\r
112#define EFI_IA32_MTRR_FIX4K_C0000 0x268\r
113#define EFI_IA32_MTRR_FIX4K_C8000 0x269\r
114#define EFI_IA32_MTRR_FIX4K_D0000 0x26A\r
115#define EFI_IA32_MTRR_FIX4K_D8000 0x26B\r
116#define EFI_IA32_MTRR_FIX4K_E0000 0x26C\r
117#define EFI_IA32_MTRR_FIX4K_E8000 0x26D\r
118#define EFI_IA32_MTRR_FIX4K_F0000 0x26E\r
119#define EFI_IA32_MTRR_FIX4K_F8000 0x26F\r
120\r
121#define EFI_IA32_MCG_CAP 0x179\r
122#define EFI_IA32_MCG_CTL 0x17B\r
123#define EFI_IA32_MC0_CTL 0x400\r
124#define EFI_IA32_MC0_STATUS 0x401\r
125\r
126#define EFI_IA32_PERF_STATUS 0x198\r
127#define EFI_IA32_PERF_CTL 0x199\r
128\r
129#define EFI_CACHE_UNCACHEABLE 0\r
130#define EFI_CACHE_WRITECOMBINING 1\r
131#define EFI_CACHE_WRITETHROUGH 4\r
132#define EFI_CACHE_WRITEPROTECTED 5\r
133#define EFI_CACHE_WRITEBACK 6\r
134\r
135//\r
136// Combine f(FamilyId), m(Model), s(SteppingId) to a single 32 bit number\r
137//\r
138#define EfiMakeCpuVersion(f, m, s) \\r
139 (((UINT32) (f) << 16) | ((UINT32) (m) << 8) | ((UINT32) (s)))\r
140\r
141VOID\r
142IA32API\r
143EfiHalt (\r
144 VOID\r
e00e1d46 145 );\r
3eb9473e 146\r
147/*++ \r
148Routine Description: \r
149 Halt the Cpu \r
150Arguments: \r
151 None \r
152Returns: \r
153 None \r
154--*/\r
155VOID\r
156IA32API\r
157EfiWbinvd (\r
158 VOID\r
e00e1d46 159 );\r
3eb9473e 160\r
161/*++ \r
162Routine Description: \r
163 Write back and invalidate the Cpu cache\r
164Arguments: \r
165 None \r
166Returns: \r
167 None \r
168--*/\r
169VOID\r
170IA32API\r
171EfiInvd (\r
172 VOID\r
e00e1d46 173 );\r
3eb9473e 174\r
175/*++ \r
176Routine Description: \r
177 Invalidate the Cpu cache\r
178Arguments: \r
179 None \r
180Returns: \r
181 None \r
182--*/\r
183VOID\r
184IA32API\r
185EfiCpuid (\r
186 IN UINT32 RegisterInEax,\r
187 OUT EFI_CPUID_REGISTER *Regs\r
e00e1d46 188 );\r
3eb9473e 189\r
190/*++ \r
191Routine Description: \r
192 Get the Cpu info by excute the CPUID instruction\r
193Arguments: \r
194 RegisterInEax: -The input value to put into register EAX\r
195 Regs: -The Output value \r
196Returns: \r
197 None \r
198--*/\r
199\r
200VOID\r
201IA32API\r
202EfiCpuidExt (\r
203 IN UINT32 RegisterInEax,\r
204 IN UINT32 CacheLevel,\r
205 OUT EFI_CPUID_REGISTER *Regs\r
206 )\r
207/*++ \r
208Routine Description: \r
209 When RegisterInEax != 4, the functionality is the same as EfiCpuid.\r
210 When RegisterInEax == 4, the function return the deterministic cache\r
211 parameters by excuting the CPUID instruction\r
212Arguments: \r
213 RegisterInEax: - The input value to put into register EAX\r
214 CacheLevel: - The deterministic cache level\r
215 Regs: - The Output value \r
216Returns: \r
217 None \r
218--*/\r
219;\r
220\r
221UINT64\r
222IA32API\r
223EfiReadMsr (\r
224 IN UINT32 Index\r
e00e1d46 225 );\r
3eb9473e 226\r
227/*++ \r
228Routine Description: \r
229 Read Cpu MSR\r
230Arguments: \r
231 Index: -The index value to select the register\r
232 \r
233Returns: \r
234 Return the read data \r
235--*/\r
236VOID\r
237IA32API\r
238EfiWriteMsr (\r
239 IN UINT32 Index,\r
240 IN UINT64 Value\r
e00e1d46 241 );\r
3eb9473e 242\r
243/*++ \r
244Routine Description: \r
245 Write Cpu MSR\r
246Arguments: \r
247 Index: -The index value to select the register\r
248 Value: -The value to write to the selected register \r
249Returns: \r
250 None \r
251--*/\r
252UINT64\r
253IA32API\r
254EfiReadTsc (\r
255 VOID\r
e00e1d46 256 );\r
3eb9473e 257\r
258/*++ \r
259Routine Description: \r
260 Read Time stamp\r
261Arguments: \r
262 None \r
263Returns: \r
264 Return the read data \r
265--*/\r
266VOID\r
267IA32API\r
268EfiDisableCache (\r
269 VOID\r
e00e1d46 270 );\r
3eb9473e 271\r
272/*++ \r
273Routine Description: \r
274 Writing back and invalidate the cache,then diable it\r
275Arguments: \r
276 None \r
277Returns: \r
278 None \r
279--*/\r
280VOID\r
281IA32API\r
282EfiEnableCache (\r
283 VOID\r
e00e1d46 284 );\r
3eb9473e 285\r
286/*++ \r
287Routine Description: \r
288 Invalidate the cache,then Enable it\r
289Arguments: \r
290 None \r
291Returns: \r
292 None \r
293--*/\r
294UINT32\r
295IA32API\r
296EfiGetEflags (\r
297 VOID\r
e00e1d46 298 );\r
3eb9473e 299\r
300/*++ \r
301Routine Description: \r
302 Get Eflags\r
303Arguments: \r
304 None \r
305Returns: \r
306 Return the Eflags value \r
307--*/\r
308VOID\r
309IA32API\r
310EfiDisableInterrupts (\r
311 VOID\r
e00e1d46 312 );\r
3eb9473e 313\r
314/*++ \r
315Routine Description: \r
316 Disable Interrupts\r
317Arguments: \r
318 None \r
319Returns: \r
320 None\r
321--*/\r
322VOID\r
323IA32API\r
324EfiEnableInterrupts (\r
325 VOID\r
e00e1d46 326 );\r
3eb9473e 327\r
328/*++ \r
329Routine Description: \r
330 Enable Interrupts\r
331Arguments: \r
332 None \r
333Returns: \r
334 None \r
335--*/\r
336\r
337\r
338VOID\r
339IA32API\r
340EfiCpuVersion (\r
341 IN UINT16 *FamilyId, OPTIONAL\r
342 IN UINT8 *Model, OPTIONAL\r
343 IN UINT8 *SteppingId, OPTIONAL\r
344 IN UINT8 *Processor OPTIONAL\r
345 )\r
346/*++\r
347\r
348Routine Description:\r
349 Extract CPU detail version infomation\r
350\r
351Arguments:\r
352 FamilyId - FamilyId, including ExtendedFamilyId\r
353 Model - Model, including ExtendedModel\r
354 SteppingId - SteppingId\r
355 Processor - Processor\r
356\r
357--*/\r
358;\r
359\r
360#endif\r