]> git.proxmox.com Git - mirror_edk2.git/blame - Vlv2TbltDevicePkg/AcpiPlatform/AcpiPlatform.c
Vlv2DeviceRefCodePkg&Vlv2TbltDevicePkg:Add setup option of LPE Audio.
[mirror_edk2.git] / Vlv2TbltDevicePkg / AcpiPlatform / AcpiPlatform.c
CommitLineData
3cbfba02
DW
1/** @file\r
2\r
aa44e98d 3 Copyright (c) 2004 - 2016, Intel Corporation. All rights reserved.<BR>\r
a0f3b028 4\r
3cbfba02
DW
5\r
6 This program and the accompanying materials are licensed and made available under\r
7\r
a0f3b028
LS
8 the terms and conditions of the BSD License that accompanies this distribution.\r
9\r
10 The full text of the license may be found at\r
3cbfba02 11\r
a0f3b028 12 http://opensource.org/licenses/bsd-license.php.\r
3cbfba02 13\r
3cbfba02 14\r
3cbfba02 15\r
a0f3b028
LS
16 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
17\r
18 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
3cbfba02 19\r
3cbfba02 20\r
3cbfba02
DW
21\r
22\r
23\r
24\r
25Module Name:\r
26\r
27 AcpiPlatform.c\r
28\r
29Abstract:\r
30\r
31 ACPI Platform Driver\r
32\r
33\r
a0f3b028 34**/\r
3cbfba02
DW
35\r
36#include <PiDxe.h>\r
37#include <Protocol/TcgService.h>\r
38#include <Protocol/FirmwareVolume.h>\r
39#include "AcpiPlatform.h"\r
40#include "AcpiPlatformHooks.h"\r
41#include "AcpiPlatformHooksLib.h"\r
42#include "Platform.h"\r
43#include <Hpet.h>\r
44#include <Mcfg.h>\r
45#include "Osfr.h"\r
46#include <Guid/GlobalVariable.h>\r
47#include <Guid/SetupVariable.h>\r
48#include <Guid/PlatformInfo.h>\r
49#include <Protocol/CpuIo.h>\r
50#include <Guid/BoardFeatures.h>\r
51#include <Protocol/AcpiSupport.h>\r
52#include <Protocol/AcpiS3Save.h>\r
53#include <Protocol/Ps2Policy.h>\r
54#include <Library/CpuIA32.h>\r
55#include <SetupMode.h>\r
56#include <Guid/AcpiTableStorage.h>\r
57#include <Guid/EfiVpdData.h>\r
58#include <PchAccess.h>\r
59#include <Guid/Vlv2Variable.h>\r
60#include <Guid/PlatformCpuInfo.h>\r
61\r
62\r
63CHAR16 EfiPlatformCpuInfoVariable[] = L"PlatformCpuInfo";\r
64CHAR16 gACPIOSFRModelStringVariableName[] = ACPI_OSFR_MODEL_STRING_VARIABLE_NAME;\r
65CHAR16 gACPIOSFRRefDataBlockVariableName[] = ACPI_OSFR_REF_DATA_BLOCK_VARIABLE_NAME;\r
66CHAR16 gACPIOSFRMfgStringVariableName[] = ACPI_OSFR_MFG_STRING_VARIABLE_NAME;\r
67\r
68EFI_CPU_IO_PROTOCOL *mCpuIo;\r
69#ifndef __GNUC__\r
70#pragma optimize("", off)\r
71#endif\r
72BOOLEAN mFirstNotify;\r
73EFI_PLATFORM_INFO_HOB *mPlatformInfo;\r
74EFI_GUID mSystemConfigurationGuid = SYSTEM_CONFIGURATION_GUID;\r
75SYSTEM_CONFIGURATION mSystemConfiguration;\r
76SYSTEM_CONFIGURATION mSystemConfig;\r
77\r
78UINT8 mSmbusRsvdAddresses[] = PLATFORM_SMBUS_RSVD_ADDRESSES;\r
79UINT8 mNumberSmbusAddress = sizeof( mSmbusRsvdAddresses ) / sizeof( mSmbusRsvdAddresses[0] );\r
80\r
81/**\r
82 Locate the first instance of a protocol. If the protocol requested is an\r
83 FV protocol, then it will return the first FV that contains the ACPI table\r
84 storage file.\r
85\r
86 @param[in] Protocol The protocol to find.\r
87 @param[in] Instance Return pointer to the first instance of the protocol.\r
88 @param[in] Type The type of protocol to locate.\r
89\r
90 @retval EFI_SUCCESS The function completed successfully.\r
91 @retval EFI_NOT_FOUND The protocol could not be located.\r
92 @retval EFI_OUT_OF_RESOURCES There are not enough resources to find the protocol.\r
93\r
94**/\r
95EFI_STATUS\r
96LocateSupportProtocol (\r
97 IN EFI_GUID *Protocol,\r
98 OUT VOID **Instance,\r
99 IN UINT32 Type\r
100 )\r
101{\r
102 EFI_STATUS Status;\r
103 EFI_HANDLE *HandleBuffer;\r
104 UINTN NumberOfHandles;\r
105 EFI_FV_FILETYPE FileType;\r
106 UINT32 FvStatus;\r
107 EFI_FV_FILE_ATTRIBUTES Attributes;\r
108 UINTN Size;\r
109 UINTN Index;\r
110\r
111 FvStatus = 0;\r
112\r
113 //\r
114 // Locate protocol.\r
115 //\r
116 Status = gBS->LocateHandleBuffer (\r
117 ByProtocol,\r
118 Protocol,\r
119 NULL,\r
120 &NumberOfHandles,\r
121 &HandleBuffer\r
122 );\r
123 if (EFI_ERROR (Status)) {\r
124 //\r
125 // Defined errors at this time are not found and out of resources.\r
126 //\r
127 return Status;\r
128 }\r
129\r
130 //\r
131 // Looking for FV with ACPI storage file.\r
132 //\r
133 for (Index = 0; Index < NumberOfHandles; Index++) {\r
134 //\r
135 // Get the protocol on this handle.\r
136 // This should not fail because of LocateHandleBuffer.\r
137 //\r
138 Status = gBS->HandleProtocol (\r
139 HandleBuffer[Index],\r
140 Protocol,\r
141 Instance\r
142 );\r
143 ASSERT (!EFI_ERROR (Status));\r
144\r
145 if (!Type) {\r
146 //\r
147 // Not looking for the FV protocol, so find the first instance of the\r
148 // protocol. There should not be any errors because our handle buffer\r
149 // should always contain at least one or LocateHandleBuffer would have\r
150 // returned not found.\r
151 //\r
152 break;\r
153 }\r
154\r
155 //\r
156 // See if it has the ACPI storage file.\r
157 //\r
158 Status = ((EFI_FIRMWARE_VOLUME_PROTOCOL *) (*Instance))->ReadFile (\r
159 *Instance,\r
160 &gEfiAcpiTableStorageGuid,\r
161 NULL,\r
162 &Size,\r
163 &FileType,\r
164 &Attributes,\r
165 &FvStatus\r
166 );\r
167\r
168 //\r
169 // If we found it, then we are done.\r
170 //\r
171 if (!EFI_ERROR (Status)) {\r
172 break;\r
173 }\r
174 }\r
175\r
176 //\r
177 // Our exit status is determined by the success of the previous operations.\r
178 // If the protocol was found, Instance already points to it.\r
179 //\r
180 //\r
181 // Free any allocated buffers.\r
182 //\r
183 gBS->FreePool (HandleBuffer);\r
184\r
185 return Status;\r
186}\r
187\r
188/**\r
189 This function will update any runtime platform specific information.\r
190 This currently includes:\r
191 Setting OEM table values, ID, table ID, creator ID and creator revision.\r
192 Enabling the proper processor entries in the APIC tables.\r
193\r
194 @param[in] Table The table to update.\r
195\r
196 @retval EFI_SUCCESS The function completed successfully.\r
197\r
198**/\r
199EFI_STATUS\r
200PlatformUpdateTables (\r
201 IN OUT EFI_ACPI_COMMON_HEADER *Table\r
202 )\r
203{\r
204 EFI_ACPI_DESCRIPTION_HEADER *TableHeader;\r
205 UINT8 *CurrPtr;\r
206 UINT8 *EndPtr;\r
207 ACPI_APIC_STRUCTURE_PTR *ApicPtr;\r
208 UINT8 CurrProcessor;\r
209 EFI_STATUS Status;\r
210 EFI_MP_SERVICES_PROTOCOL *MpService;\r
211 UINTN MaximumNumberOfCPUs;\r
212 UINTN NumberOfEnabledCPUs;\r
213 UINTN BufferSize;\r
214 ACPI_APIC_STRUCTURE_PTR *ProcessorLocalApicEntry;\r
215 UINTN BspIndex;\r
216 EFI_ACPI_1_0_ASF_DESCRIPTION_TABLE *AsfEntry;\r
217 EFI_ACPI_HIGH_PRECISION_EVENT_TIMER_TABLE_HEADER *HpetTbl;\r
218 UINT64 OemIdValue;\r
219 UINT8 Index;\r
220 EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE *Facp;\r
221 EFI_ACPI_OSFR_TABLE *OsfrTable;\r
222 EFI_ACPI_OSFR_OCUR_OBJECT *pOcurObject;\r
223 EFI_ACPI_OSFR_OCUR_OBJECT OcurObject = {{0xB46F133D, 0x235F, 0x4634, 0x9F, 0x03, 0xB1, 0xC0, 0x1C, 0x54, 0x78, 0x5B}, 0, 0, 0, 0, 0};\r
224 CHAR16 *OcurMfgStringBuffer = NULL;\r
225 CHAR16 *OcurModelStringBuffer = NULL;\r
226 UINT8 *OcurRefDataBlockBuffer = NULL;\r
227 UINTN OcurMfgStringBufferSize;\r
228 UINTN OcurModelStringBufferSize;\r
229 UINTN OcurRefDataBlockBufferSize;\r
230#if defined (IDCC2_SUPPORTED) && IDCC2_SUPPORTED\r
231 EFI_ACPI_ASPT_TABLE *pSpttTable;\r
232#endif\r
233 UINT16 NumberOfHpets;\r
234 UINT16 HpetCapIdValue;\r
235 UINT32 HpetBlockID;\r
236 UINTN LocalApicCounter;\r
237 EFI_PROCESSOR_INFORMATION ProcessorInfoBuffer;\r
238 UINT8 TempVal;\r
239 EFI_ACPI_3_0_IO_APIC_STRUCTURE *IOApicType;\r
240 EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER *APICTableHeader;\r
241\r
242 CurrPtr = NULL;\r
243 EndPtr = NULL;\r
244 ApicPtr = NULL;\r
245 LocalApicCounter = 0;\r
246 CurrProcessor = 0;\r
247 ProcessorLocalApicEntry = NULL;\r
248\r
249\r
250 if (Table->Signature != EFI_ACPI_1_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_SIGNATURE) {\r
251 TableHeader = (EFI_ACPI_DESCRIPTION_HEADER *) Table;\r
252 //\r
253 // Update the OEMID.\r
254 //\r
255 OemIdValue = mPlatformInfo->AcpiOemId;\r
256\r
257 *(UINT32 *)(TableHeader->OemId) = (UINT32)OemIdValue;\r
258 *(UINT16 *)(TableHeader->OemId + 4) = *(UINT16*)(((UINT8 *)&OemIdValue) + 4);\r
259\r
260 if ((Table->Signature != EFI_ACPI_2_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE)) {\r
261 //\r
262 // Update the OEM Table ID.\r
263 //\r
264 TableHeader->OemTableId = mPlatformInfo->AcpiOemTableId;\r
265 }\r
266\r
267 //\r
268 // Update the OEM Table ID.\r
269 //\r
270 TableHeader->OemRevision = EFI_ACPI_OEM_REVISION;\r
271\r
272 //\r
273 // Update the creator ID.\r
274 //\r
275 TableHeader->CreatorId = EFI_ACPI_CREATOR_ID;\r
276\r
277 //\r
278 // Update the creator revision.\r
279 //\r
280 TableHeader->CreatorRevision = EFI_ACPI_CREATOR_REVISION;\r
281 }\r
282\r
283 //\r
284 // Complete this function.\r
285 //\r
286 //\r
287 // Locate the MP services protocol.\r
288 //\r
289 //\r
290 // Find the MP Protocol. This is an MP platform, so MP protocol must be\r
291 // there.\r
292 //\r
293 Status = gBS->LocateProtocol (\r
294 &gEfiMpServiceProtocolGuid,\r
295 NULL,\r
296 (VOID **) &MpService\r
297 );\r
298 if (EFI_ERROR (Status)) {\r
299 return Status;\r
300 }\r
301\r
302 //\r
303 // Determine the number of processors.\r
304 //\r
305 MpService->GetNumberOfProcessors (\r
306 MpService,\r
307 &MaximumNumberOfCPUs,\r
308 &NumberOfEnabledCPUs\r
309 );\r
310\r
311 ASSERT (MaximumNumberOfCPUs <= MAX_CPU_NUM && NumberOfEnabledCPUs >= 1);\r
312\r
313\r
314 //\r
315 // Assign a invalid intial value for update.\r
316 //\r
317 //\r
318 // Update the processors in the APIC table.\r
319 //\r
320 switch (Table->Signature) {\r
321 case EFI_ACPI_1_0_ASF_DESCRIPTION_TABLE_SIGNATURE:\r
322 //\r
323 // Update the table if ASF is enabled. Otherwise, return error so caller will not install.\r
324 //\r
325 if (mSystemConfig.Asf == 1) {\r
326 return EFI_UNSUPPORTED;\r
327 }\r
328 AsfEntry = (EFI_ACPI_1_0_ASF_DESCRIPTION_TABLE *) Table;\r
329 TempVal = (mNumberSmbusAddress < ASF_ADDR_DEVICE_ARRAY_LENGTH)? mNumberSmbusAddress : ASF_ADDR_DEVICE_ARRAY_LENGTH;\r
330 for (Index = 0; Index < TempVal; Index++) {\r
331 AsfEntry->AsfAddr.FixedSmbusAddresses[Index] = mSmbusRsvdAddresses[Index];\r
332 }\r
333 break;\r
334\r
335 case EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_SIGNATURE:\r
336\r
337 Status = MpService->WhoAmI (\r
338 MpService,\r
339 &BspIndex\r
340 );\r
341\r
342 //\r
343 // PCAT_COMPAT Set to 1 indicate 8259 vectors should be disabled.\r
344 //\r
345 APICTableHeader = (EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER *)Table;\r
346 APICTableHeader->Flags |= EFI_ACPI_3_0_PCAT_COMPAT;\r
347\r
348 CurrPtr = (UINT8 *) &((EFI_ACPI_DESCRIPTION_HEADER *) Table)[1];\r
349 CurrPtr = CurrPtr + 8;\r
350\r
351 //\r
352 // Size of Local APIC Address & Flag.\r
353 //\r
354 EndPtr = (UINT8 *) Table;\r
355 EndPtr = EndPtr + Table->Length;\r
356 while (CurrPtr < EndPtr) {\r
357 ApicPtr = (ACPI_APIC_STRUCTURE_PTR *) CurrPtr;\r
358 switch (ApicPtr->AcpiApicCommon.Type) {\r
359 case EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC:\r
360 //\r
361 // ESS override\r
362 // Fix for Ordering of MADT to be maintained as it is in MADT table.\r
363 //\r
364 // Update processor enabled or disabled and keep the local APIC\r
365 // order in MADT intact.\r
366 //\r
367 // Sanity check to make sure proc-id is not arbitrary.\r
368 //\r
369 DEBUG ((EFI_D_ERROR, "ApicPtr->AcpiLocalApic.AcpiProcessorId = %x, MaximumNumberOfCPUs = %x\n", \\r
370 ApicPtr->AcpiLocalApic.AcpiProcessorId, MaximumNumberOfCPUs));\r
371 if(ApicPtr->AcpiLocalApic.AcpiProcessorId > MaximumNumberOfCPUs) {\r
372 ApicPtr->AcpiLocalApic.AcpiProcessorId = (UINT8)MaximumNumberOfCPUs;\r
373 }\r
374\r
375 BufferSize = 0;\r
376 ApicPtr->AcpiLocalApic.Flags = 0;\r
377\r
378 for (CurrProcessor = 0; CurrProcessor < MaximumNumberOfCPUs; CurrProcessor++) {\r
379 Status = MpService->GetProcessorInfo (\r
380 MpService,\r
381 CurrProcessor,\r
382 &ProcessorInfoBuffer\r
383 );\r
384\r
385 if (Status == EFI_SUCCESS && ProcessorInfoBuffer.ProcessorId == ApicPtr->AcpiLocalApic.ApicId) {\r
386 //\r
387 // Check to see whether or not a processor (or thread) is enabled.\r
388 //\r
389 if ((BspIndex == CurrProcessor) || ((ProcessorInfoBuffer.StatusFlag & PROCESSOR_ENABLED_BIT) != 0)) {\r
390 //\r
391 // Go on and check if Hyper Threading is enabled. If HT not enabled\r
392 // hide this thread from OS by not setting the flag to 1. This is the\r
393 // software way to disable Hyper Threading. Basically we just hide it\r
394 // from the OS.\r
395 //\r
396 ApicPtr->AcpiLocalApic.Flags = EFI_ACPI_1_0_LOCAL_APIC_ENABLED;\r
397\r
398\r
399 if(ProcessorInfoBuffer.Location.Thread != 0) {\r
400 ApicPtr->AcpiLocalApic.Flags = 0;\r
401 }\r
402\r
403 AppendCpuMapTableEntry (&(ApicPtr->AcpiLocalApic));\r
404 }\r
405 break;\r
406 }\r
407 }\r
408\r
409 //\r
410 // If no APIC-ID match, the cpu may not be populated.\r
411 //\r
412 break;\r
413\r
414 case EFI_ACPI_3_0_IO_APIC:\r
415\r
416 IOApicType = (EFI_ACPI_3_0_IO_APIC_STRUCTURE *)CurrPtr;\r
417 IOApicType->IoApicId = 0x02;\r
418 //\r
419 // IO APIC entries can be patched here.\r
420 //\r
421 break;\r
422 }\r
423\r
424 CurrPtr = CurrPtr + ApicPtr->AcpiApicCommon.Length;\r
425 }\r
426 break;\r
427\r
428 case EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE:\r
429\r
430 Facp = (EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE *) Table;\r
431 Facp->Flags &= (UINT32)(~(3<<2));\r
432\r
433 break;\r
434\r
435 case EFI_ACPI_3_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE:\r
436 //\r
437 // Patch the memory resource.\r
438 //\r
439 PatchDsdtTable ((EFI_ACPI_DESCRIPTION_HEADER *) Table);\r
440 break;\r
441\r
442 case EFI_ACPI_3_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE:\r
443 //\r
444 // Gv3 support\r
445 //\r
446 // TBD: Need re-design based on the ValleyTrail platform.\r
447 //\r
448 break;\r
449\r
450 case EFI_ACPI_3_0_HIGH_PRECISION_EVENT_TIMER_TABLE_SIGNATURE:\r
451 //\r
452 // Adjust HPET Table to correct the Base Address.\r
453 //\r
454 // Enable HPET always as Hpet.asi always indicates that Hpet is enabled.\r
455 //\r
456 MmioOr8 (R_PCH_PCH_HPET + R_PCH_PCH_HPET_GCFG, B_PCH_PCH_HPET_GCFG_EN);\r
457\r
458\r
459 HpetTbl = (EFI_ACPI_HIGH_PRECISION_EVENT_TIMER_TABLE_HEADER *) Table;\r
460 HpetTbl->BaseAddressLower32Bit.Address = HPET_BASE_ADDRESS;\r
461 HpetTbl->EventTimerBlockId = *((UINT32*)(UINTN)HPET_BASE_ADDRESS);\r
462\r
463 HpetCapIdValue = *(UINT16 *)(UINTN)(HPET_BASE_ADDRESS);\r
464 NumberOfHpets = HpetCapIdValue & B_PCH_PCH_HPET_GCID_NT; // Bits [8:12] contains the number of Hpets\r
465 HpetBlockID = EFI_ACPI_EVENT_TIMER_BLOCK_ID;\r
466\r
467 if((NumberOfHpets) && (NumberOfHpets & B_PCH_PCH_HPET_GCID_NT)) {\r
468 HpetBlockID |= (NumberOfHpets);\r
469 }\r
470 HpetTbl->EventTimerBlockId = HpetBlockID;\r
471\r
472 break;\r
473\r
474 case EFI_ACPI_3_0_PCI_EXPRESS_MEMORY_MAPPED_CONFIGURATION_SPACE_BASE_ADDRESS_DESCRIPTION_TABLE_SIGNATURE:\r
475 //\r
476 // Update MCFG base and end bus number.\r
477 //\r
478 ((EFI_ACPI_MEMORY_MAPPED_CONFIGURATION_BASE_ADDRESS_TABLE *) Table)->Segment[0].BaseAddress\r
479 = mPlatformInfo->PciData.PciExpressBase;\r
480 ((EFI_ACPI_MEMORY_MAPPED_CONFIGURATION_BASE_ADDRESS_TABLE *) Table)->Segment[0].EndBusNumber\r
481 = (UINT8)RShiftU64 (mPlatformInfo->PciData.PciExpressSize, 20) - 1;\r
482 break;\r
483\r
484\r
485 case EFI_ACPI_OSFR_TABLE_SIGNATURE:\r
486 //\r
487 // Get size of OSFR variable.\r
488 //\r
489 OcurMfgStringBufferSize = 0;\r
490 Status = gRT->GetVariable (\r
491 gACPIOSFRMfgStringVariableName,\r
492 &gACPIOSFRMfgStringVariableGuid,\r
493 NULL,\r
494 &OcurMfgStringBufferSize,\r
495 NULL\r
496 );\r
497 if (Status != EFI_BUFFER_TOO_SMALL) {\r
498 //\r
499 // Variable must not be present on the system.\r
500 //\r
501 return EFI_UNSUPPORTED;\r
502 }\r
503\r
504 //\r
505 // Allocate memory for variable data.\r
506 //\r
507 OcurMfgStringBuffer = AllocatePool (OcurMfgStringBufferSize);\r
508 Status = gRT->GetVariable (\r
509 gACPIOSFRMfgStringVariableName,\r
510 &gACPIOSFRMfgStringVariableGuid,\r
511 NULL,\r
512 &OcurMfgStringBufferSize,\r
513 OcurMfgStringBuffer\r
514 );\r
515 if (!EFI_ERROR (Status)) {\r
516 OcurModelStringBufferSize = 0;\r
517 Status = gRT->GetVariable (\r
518 gACPIOSFRModelStringVariableName,\r
519 &gACPIOSFRModelStringVariableGuid,\r
520 NULL,\r
521 &OcurModelStringBufferSize,\r
522 NULL\r
523 );\r
524 if (Status != EFI_BUFFER_TOO_SMALL) {\r
525 //\r
526 // Variable must not be present on the system.\r
527 //\r
528 return EFI_UNSUPPORTED;\r
529 }\r
530\r
531 //\r
532 // Allocate memory for variable data.\r
533 //\r
534 OcurModelStringBuffer = AllocatePool (OcurModelStringBufferSize);\r
535 Status = gRT->GetVariable (\r
536 gACPIOSFRModelStringVariableName,\r
537 &gACPIOSFRModelStringVariableGuid,\r
538 NULL,\r
539 &OcurModelStringBufferSize,\r
540 OcurModelStringBuffer\r
541 );\r
542 if (!EFI_ERROR (Status)) {\r
543 OcurRefDataBlockBufferSize = 0;\r
544 Status = gRT->GetVariable (\r
545 gACPIOSFRRefDataBlockVariableName,\r
546 &gACPIOSFRRefDataBlockVariableGuid,\r
547 NULL,\r
548 &OcurRefDataBlockBufferSize,\r
549 NULL\r
550 );\r
551 if (Status == EFI_BUFFER_TOO_SMALL) {\r
552 //\r
553 // Allocate memory for variable data.\r
554 //\r
555 OcurRefDataBlockBuffer = AllocatePool (OcurRefDataBlockBufferSize);\r
556 Status = gRT->GetVariable (\r
557 gACPIOSFRRefDataBlockVariableName,\r
558 &gACPIOSFRRefDataBlockVariableGuid,\r
559 NULL,\r
560 &OcurRefDataBlockBufferSize,\r
561 OcurRefDataBlockBuffer\r
562 );\r
563 }\r
564 OsfrTable = (EFI_ACPI_OSFR_TABLE *) Table;\r
565 //\r
566 // Currently only one object is defined: OCUR_OSFR_TABLE.\r
567 //\r
568 OsfrTable->ObjectCount = 1;\r
569 //\r
570 // Initialize table length to fixed portion of the ACPI OSFR table.\r
571 //\r
572 OsfrTable->Header.Length = sizeof (EFI_ACPI_OSFR_TABLE_FIXED_PORTION);\r
573 *(UINT32 *)((UINTN) OsfrTable + sizeof (EFI_ACPI_OSFR_TABLE_FIXED_PORTION)) = \\r
574 (UINT32) (sizeof (EFI_ACPI_OSFR_TABLE_FIXED_PORTION) + sizeof (UINT32));\r
575 pOcurObject = (EFI_ACPI_OSFR_OCUR_OBJECT *)((UINTN) OsfrTable + sizeof (EFI_ACPI_OSFR_TABLE_FIXED_PORTION) + \\r
576 sizeof (UINT32));\r
577 CopyMem (pOcurObject, &OcurObject, sizeof (EFI_ACPI_OSFR_OCUR_OBJECT));\r
578 pOcurObject->ManufacturerNameStringOffset = (UINT32)((UINTN) pOcurObject - (UINTN) OsfrTable + \\r
579 sizeof (EFI_ACPI_OSFR_OCUR_OBJECT));\r
580 pOcurObject->ModelNameStringOffset = (UINT32)((UINTN) pOcurObject - (UINTN) OsfrTable + \\r
581 sizeof (EFI_ACPI_OSFR_OCUR_OBJECT) + OcurMfgStringBufferSize);\r
582 if (OcurRefDataBlockBufferSize > 0) {\r
583 pOcurObject->MicrosoftReferenceOffset = (UINT32)((UINTN) pOcurObject - (UINTN) OsfrTable + \\r
584 sizeof (EFI_ACPI_OSFR_OCUR_OBJECT) + OcurMfgStringBufferSize + OcurModelStringBufferSize);\r
585 }\r
586 CopyMem ((UINTN *)((UINTN) pOcurObject + sizeof (EFI_ACPI_OSFR_OCUR_OBJECT)), OcurMfgStringBuffer, \\r
587 OcurMfgStringBufferSize);\r
588 CopyMem ((UINTN *)((UINTN) pOcurObject + sizeof (EFI_ACPI_OSFR_OCUR_OBJECT) + OcurMfgStringBufferSize), \\r
589 OcurModelStringBuffer, OcurModelStringBufferSize);\r
590 if (OcurRefDataBlockBufferSize > 0) {\r
591 CopyMem ((UINTN *)((UINTN) pOcurObject + sizeof (EFI_ACPI_OSFR_OCUR_OBJECT) + OcurMfgStringBufferSize + \\r
592 OcurModelStringBufferSize),OcurRefDataBlockBuffer, OcurRefDataBlockBufferSize);\r
593 }\r
594 OsfrTable->Header.Length += (UINT32)(OcurMfgStringBufferSize + OcurModelStringBufferSize + OcurRefDataBlockBufferSize);\r
595 OsfrTable->Header.Length += sizeof (EFI_ACPI_OSFR_OCUR_OBJECT) + sizeof (UINT32);\r
596 }\r
597 }\r
598 gBS->FreePool (OcurMfgStringBuffer);\r
599 gBS->FreePool (OcurModelStringBuffer);\r
600 gBS->FreePool (OcurRefDataBlockBuffer);\r
601 break;\r
602 default:\r
603 break;\r
604 }\r
605\r
606 //\r
607 //\r
608 // Update the hardware signature in the FACS structure.\r
609 //\r
610 //\r
611 // Locate the SPCR table and update based on current settings.\r
612 // The user may change CR settings via setup or other methods.\r
613 // The SPCR table must match.\r
614 //\r
615 return EFI_SUCCESS;\r
616}\r
617\r
618/**\r
619\r
620Routine Description:\r
621\r
622 GC_TODO: Add function description.\r
623\r
624Arguments:\r
625\r
626 Event - GC_TODO: add argument description\r
627 Context - GC_TODO: add argument description\r
628\r
629Returns:\r
630\r
631 GC_TODO: add return values\r
632\r
633**/\r
634STATIC\r
635VOID\r
636EFIAPI\r
637OnReadyToBoot (\r
638 IN EFI_EVENT Event,\r
639 IN VOID *Context\r
640 )\r
641{\r
642 EFI_STATUS Status;\r
643 EFI_ACPI_TABLE_VERSION TableVersion;\r
644 EFI_ACPI_SUPPORT_PROTOCOL *AcpiSupport;\r
645 EFI_ACPI_S3_SAVE_PROTOCOL *AcpiS3Save;\r
646 SYSTEM_CONFIGURATION SetupVarBuffer;\r
647 UINTN VariableSize;\r
648 EFI_PLATFORM_CPU_INFO *PlatformCpuInfoPtr = NULL;\r
649 EFI_PLATFORM_CPU_INFO PlatformCpuInfo;\r
650 EFI_PEI_HOB_POINTERS GuidHob;\r
651\r
652 if (mFirstNotify) {\r
653 return;\r
654 }\r
655\r
656 mFirstNotify = TRUE;\r
657\r
658 //\r
659 // To avoid compiler warning of "C4701: potentially uninitialized local variable 'PlatformCpuInfo' used".\r
660 //\r
661 PlatformCpuInfo.CpuVersion.FullCpuId = 0;\r
662\r
663 //\r
664 // Get Platform CPU Info HOB.\r
665 //\r
666 PlatformCpuInfoPtr = NULL;\r
667 ZeroMem (&PlatformCpuInfo, sizeof(EFI_PLATFORM_CPU_INFO));\r
668 VariableSize = sizeof(EFI_PLATFORM_CPU_INFO);\r
669 Status = gRT->GetVariable(\r
670 EfiPlatformCpuInfoVariable,\r
671 &gEfiVlv2VariableGuid,\r
672 NULL,\r
673 &VariableSize,\r
674 PlatformCpuInfoPtr\r
675 );\r
676 if (EFI_ERROR(Status)) {\r
677 GuidHob.Raw = GetHobList ();\r
678 if (GuidHob.Raw != NULL) {\r
679 if ((GuidHob.Raw = GetNextGuidHob (&gEfiPlatformCpuInfoGuid, GuidHob.Raw)) != NULL) {\r
680 PlatformCpuInfoPtr = GET_GUID_HOB_DATA (GuidHob.Guid);\r
681 }\r
682 }\r
683 }\r
684\r
685 if ((PlatformCpuInfoPtr != NULL)) {\r
686 CopyMem(&PlatformCpuInfo, PlatformCpuInfoPtr, sizeof(EFI_PLATFORM_CPU_INFO));\r
687 }\r
688\r
689 //\r
690 // Update the ACPI parameter blocks finally.\r
691 //\r
692 VariableSize = sizeof (SYSTEM_CONFIGURATION);\r
693 Status = gRT->GetVariable (\r
694 L"Setup",\r
695 &mSystemConfigurationGuid,\r
696 NULL,\r
697 &VariableSize,\r
698 &SetupVarBuffer\r
699 );\r
620f2891
TH
700 if (EFI_ERROR (Status) || VariableSize != sizeof(SYSTEM_CONFIGURATION)) {\r
701 //The setup variable is corrupted\r
702 VariableSize = sizeof(SYSTEM_CONFIGURATION);\r
703 Status = gRT->GetVariable(\r
704 L"SetupRecovery",\r
705 &mSystemConfigurationGuid,\r
706 NULL,\r
707 &VariableSize,\r
708 &SetupVarBuffer\r
709 );\r
710 ASSERT_EFI_ERROR (Status);\r
a0f3b028 711 }\r
3cbfba02
DW
712\r
713 //\r
714 // Find the AcpiSupport protocol.\r
715 //\r
716 Status = LocateSupportProtocol (&gEfiAcpiSupportProtocolGuid, (VOID **) &AcpiSupport, 0);\r
717 ASSERT_EFI_ERROR (Status);\r
718\r
719 TableVersion = EFI_ACPI_TABLE_VERSION_2_0;\r
720\r
721 //\r
722 // Publish ACPI 1.0 or 2.0 Tables.\r
723 //\r
724 Status = AcpiSupport->PublishTables (\r
725 AcpiSupport,\r
726 TableVersion\r
727 );\r
728 ASSERT_EFI_ERROR (Status);\r
729\r
730 //\r
731 // S3 script save.\r
732 //\r
733 Status = gBS->LocateProtocol (&gEfiAcpiS3SaveProtocolGuid, NULL, (VOID **) &AcpiS3Save);\r
734 if (!EFI_ERROR (Status)) {\r
735 AcpiS3Save->S3Save (AcpiS3Save, NULL);\r
736 }\r
737\r
738}\r
739\r
740VOID\r
741PR1FSASetting (\r
742 IN VOID\r
743 )\r
744{\r
745 //\r
746 // for FSA on PR1.\r
747 //\r
748 if (mPlatformInfo->BoardId == BOARD_ID_BL_FFRD && mPlatformInfo->BoardRev >= PR1) {\r
749 DEBUG((EFI_D_ERROR, "Set FSA status = 1 for FFRD PR1\n"));\r
750 mGlobalNvsArea.Area->FsaStatus = mSystemConfiguration.PchFSAOn;\r
751 }\r
752 if (mPlatformInfo->BoardId == BOARD_ID_BL_FFRD8) {\r
753 DEBUG((EFI_D_ERROR, "Set FSA status = 1 for FFRD8\n"));\r
754 mGlobalNvsArea.Area->FsaStatus = mSystemConfiguration.PchFSAOn;\r
755 }\r
756\r
757}\r
758\r
759/**\r
760 Entry point for Acpi platform driver.\r
761\r
762 @param[in] ImageHandle A handle for the image that is initializing this driver.\r
763 @param[in] SystemTable A pointer to the EFI system table.\r
764\r
765 @retval EFI_SUCCESS Driver initialized successfully.\r
766 @retval EFI_LOAD_ERROR Failed to Initialize or has been loaded.\r
767 @retval EFI_OUT_OF_RESOURCES Could not allocate needed resources.\r
768\r
769**/\r
770EFI_STATUS\r
771EFIAPI\r
772AcpiPlatformEntryPoint (\r
773 IN EFI_HANDLE ImageHandle,\r
774 IN EFI_SYSTEM_TABLE *SystemTable\r
775 )\r
776{\r
777 EFI_STATUS Status;\r
778 EFI_STATUS AcpiStatus;\r
779 EFI_ACPI_SUPPORT_PROTOCOL *AcpiSupport;\r
780 EFI_FIRMWARE_VOLUME_PROTOCOL *FwVol;\r
781 INTN Instance;\r
782 EFI_ACPI_COMMON_HEADER *CurrentTable;\r
783 UINTN TableHandle;\r
784 UINT32 FvStatus;\r
785 UINT32 Size;\r
786 EFI_EVENT Event;\r
787 EFI_ACPI_TABLE_VERSION TableVersion;\r
788 UINTN VarSize;\r
789 UINTN SysCfgSize;\r
790 EFI_HANDLE Handle;\r
791 EFI_PS2_POLICY_PROTOCOL *Ps2Policy;\r
792 EFI_PEI_HOB_POINTERS GuidHob;\r
793 UINT8 PortData;\r
794 EFI_MP_SERVICES_PROTOCOL *MpService;\r
795 UINTN MaximumNumberOfCPUs;\r
796 UINTN NumberOfEnabledCPUs;\r
797 UINT32 Data32;\r
798 PCH_STEPPING pchStepping;\r
799\r
800 mFirstNotify = FALSE;\r
801\r
802 TableVersion = EFI_ACPI_TABLE_VERSION_2_0;\r
803 Instance = 0;\r
804 CurrentTable = NULL;\r
805 TableHandle = 0;\r
806 Data32 = 0;\r
807\r
808 //\r
809 // Update HOB variable for PCI resource information.\r
810 // Get the HOB list. If it is not present, then ASSERT.\r
811 //\r
812 GuidHob.Raw = GetHobList ();\r
813 if (GuidHob.Raw != NULL) {\r
814 if ((GuidHob.Raw = GetNextGuidHob (&gEfiPlatformInfoGuid, GuidHob.Raw)) != NULL) {\r
815 mPlatformInfo = GET_GUID_HOB_DATA (GuidHob.Guid);\r
816 }\r
817 }\r
818\r
819 //\r
820 // Search for the Memory Configuration GUID HOB. If it is not present, then\r
821 // there's nothing we can do. It may not exist on the update path.\r
822 //\r
823 VarSize = sizeof(SYSTEM_CONFIGURATION);\r
824 Status = gRT->GetVariable(\r
825 L"Setup",\r
826 &mSystemConfigurationGuid,\r
827 NULL,\r
828 &VarSize,\r
829 &mSystemConfiguration\r
830 );\r
620f2891
TH
831 if (EFI_ERROR (Status) || VarSize != sizeof(SYSTEM_CONFIGURATION)) {\r
832 //The setup variable is corrupted\r
833 VarSize = sizeof(SYSTEM_CONFIGURATION);\r
834 Status = gRT->GetVariable(\r
835 L"SetupRecovery",\r
836 &mSystemConfigurationGuid,\r
837 NULL,\r
838 &VarSize,\r
839 &mSystemConfiguration\r
840 );\r
841 ASSERT_EFI_ERROR (Status);\r
842 }\r
3cbfba02
DW
843\r
844 //\r
845 // Find the AcpiSupport protocol.\r
846 //\r
847 Status = LocateSupportProtocol (&gEfiAcpiSupportProtocolGuid, (VOID **) &AcpiSupport, 0);\r
848 ASSERT_EFI_ERROR (Status);\r
849\r
850 //\r
851 // Locate the firmware volume protocol.\r
852 //\r
853 Status = LocateSupportProtocol (&gEfiFirmwareVolumeProtocolGuid, (VOID **) &FwVol, 1);\r
854 ASSERT_EFI_ERROR (Status);\r
855\r
856 //\r
857 // Read the current system configuration variable store.\r
858 //\r
859 SysCfgSize = sizeof(SYSTEM_CONFIGURATION);\r
860 Status = gRT->GetVariable (\r
861 L"Setup",\r
862 &gEfiNormalSetupGuid,\r
863 NULL,\r
864 &SysCfgSize,\r
865 &mSystemConfig\r
866 );\r
620f2891
TH
867 if (EFI_ERROR (Status) || SysCfgSize != sizeof(SYSTEM_CONFIGURATION)) {\r
868 //The setup variable is corrupted\r
869 SysCfgSize = sizeof(SYSTEM_CONFIGURATION);\r
870 Status = gRT->GetVariable(\r
871 L"SetupRecovery",\r
872 &gEfiNormalSetupGuid,\r
873 NULL,\r
874 &SysCfgSize,\r
875 &mSystemConfig\r
876 );\r
877 ASSERT_EFI_ERROR (Status);\r
878 }\r
879\r
3cbfba02
DW
880\r
881 Status = EFI_SUCCESS;\r
882 Instance = 0;\r
883\r
884 //\r
885 // TBD: Need re-design based on the ValleyTrail platform.\r
886 //\r
887 Status = gBS->LocateProtocol (\r
888 &gEfiMpServiceProtocolGuid,\r
889 NULL,\r
890 (VOID **) &MpService\r
891 );\r
892 if (EFI_ERROR (Status)) {\r
893 return Status;\r
894 }\r
895\r
896 //\r
897 // Determine the number of processors.\r
898 //\r
899 MpService->GetNumberOfProcessors (\r
900 MpService,\r
901 &MaximumNumberOfCPUs,\r
902 &NumberOfEnabledCPUs\r
903 );\r
904\r
905 //\r
906 // Allocate and initialize the NVS area for SMM and ASL communication.\r
907 //\r
908 Status = gBS->AllocatePool (\r
909 EfiACPIMemoryNVS,\r
910 sizeof (EFI_GLOBAL_NVS_AREA),\r
911 (void **)&mGlobalNvsArea.Area\r
912 );\r
913 ASSERT_EFI_ERROR (Status);\r
914 gBS->SetMem (\r
915 mGlobalNvsArea.Area,\r
916 sizeof (EFI_GLOBAL_NVS_AREA),\r
917 0\r
918 );\r
919 DEBUG((EFI_D_ERROR, "mGlobalNvsArea.Area is at 0x%X\n", mGlobalNvsArea.Area));\r
920\r
921 //\r
922 // Update global NVS area for ASL and SMM init code to use.\r
923 //\r
924 mGlobalNvsArea.Area->ApicEnable = 1;\r
925 mGlobalNvsArea.Area->EmaEnable = 0;\r
926\r
927 mGlobalNvsArea.Area->NumberOfBatteries = 1;\r
928 mGlobalNvsArea.Area->BatteryCapacity0 = 100;\r
929 mGlobalNvsArea.Area->BatteryStatus0 = 84;\r
930 mGlobalNvsArea.Area->OnboardCom = 1;\r
931 mGlobalNvsArea.Area->IdeMode = 0;\r
932 mGlobalNvsArea.Area->PowerState = 0;\r
933\r
934 mGlobalNvsArea.Area->LogicalProcessorCount = (UINT8)NumberOfEnabledCPUs;\r
935\r
936 mGlobalNvsArea.Area->PassiveThermalTripPoint = mSystemConfiguration.PassiveThermalTripPoint;\r
937 mGlobalNvsArea.Area->PassiveTc1Value = mSystemConfiguration.PassiveTc1Value;\r
938 mGlobalNvsArea.Area->PassiveTc2Value = mSystemConfiguration.PassiveTc2Value;\r
939 mGlobalNvsArea.Area->PassiveTspValue = mSystemConfiguration.PassiveTspValue;\r
940 mGlobalNvsArea.Area->CriticalThermalTripPoint = mSystemConfiguration.CriticalThermalTripPoint;\r
941\r
942 mGlobalNvsArea.Area->IgdPanelType = mSystemConfiguration.IgdFlatPanel;\r
943 mGlobalNvsArea.Area->IgdPanelScaling = mSystemConfiguration.PanelScaling;\r
944 mGlobalNvsArea.Area->IgdSciSmiMode = 0;\r
945 mGlobalNvsArea.Area->IgdTvFormat = 0;\r
946 mGlobalNvsArea.Area->IgdTvMinor = 0;\r
947 mGlobalNvsArea.Area->IgdSscConfig = 1;\r
948 mGlobalNvsArea.Area->IgdBiaConfig = mSystemConfiguration.IgdLcdIBia;\r
949 mGlobalNvsArea.Area->IgdBlcConfig = mSystemConfiguration.IgdLcdIGmchBlc;\r
950 mGlobalNvsArea.Area->IgdDvmtMemSize = mSystemConfiguration.IgdDvmt50TotalAlloc;\r
951 mGlobalNvsArea.Area->IgdPAVP = mSystemConfiguration.PavpMode;\r
952\r
953 mGlobalNvsArea.Area->AlsEnable = mSystemConfiguration.AlsEnable;\r
954 mGlobalNvsArea.Area->BacklightControlSupport = 2;\r
955 mGlobalNvsArea.Area->BrightnessPercentage = 100;\r
956 mGlobalNvsArea.Area->IgdState = 1;\r
957 mGlobalNvsArea.Area->LidState = 1;\r
958\r
959 mGlobalNvsArea.Area->DeviceId1 = 0x80000100 ;\r
960 mGlobalNvsArea.Area->DeviceId2 = 0x80000400 ;\r
961 mGlobalNvsArea.Area->DeviceId3 = 0x80000200 ;\r
962 mGlobalNvsArea.Area->DeviceId4 = 0x04;\r
963 mGlobalNvsArea.Area->DeviceId5 = 0x05;\r
964 mGlobalNvsArea.Area->NumberOfValidDeviceId = 4 ;\r
965 mGlobalNvsArea.Area->CurrentDeviceList = 0x0F ;\r
966 mGlobalNvsArea.Area->PreviousDeviceList = 0x0F ;\r
967\r
968 mGlobalNvsArea.Area->UartSelection = mSystemConfiguration.UartInterface;\r
969 mGlobalNvsArea.Area->PcuUart1Enable = mSystemConfiguration.PcuUart1;\r
970 mGlobalNvsArea.Area->NativePCIESupport = 1;\r
52a99493 971 mGlobalNvsArea.Area->RtcBattery = mSystemConfiguration.RtcBattery;\r
3cbfba02
DW
972\r
973\r
974\r
975\r
976\r
977 //\r
978 // Update BootMode: 0:ACPI mode; 1:PCI mode\r
979 //\r
980 mGlobalNvsArea.Area->LpssSccMode = mSystemConfiguration.LpssPciModeEnabled;\r
981 if (mSystemConfiguration.LpssMipiHsi == 0) {\r
982 mGlobalNvsArea.Area->MipiHsiAddr = 0;\r
983 mGlobalNvsArea.Area->MipiHsiLen = 0;\r
984 mGlobalNvsArea.Area->MipiHsi1Addr = 0;\r
985 mGlobalNvsArea.Area->MipiHsi1Len = 0;\r
986 }\r
987\r
988 //\r
989 // Platform Flavor\r
990 //\r
991 mGlobalNvsArea.Area->PlatformFlavor = mPlatformInfo->PlatformFlavor;\r
992\r
993 //\r
994 // Update the Platform id\r
995 //\r
996 mGlobalNvsArea.Area->BoardID = mPlatformInfo->BoardId;\r
997\r
998 //\r
999 // Update the Board Revision\r
1000 //\r
1001 mGlobalNvsArea.Area->FabID = mPlatformInfo->BoardRev;\r
1002\r
1003 //\r
1004 // Update SOC Stepping\r
1005 //\r
1006 mGlobalNvsArea.Area->SocStepping = (UINT8)(PchStepping());\r
1007\r
1008 mGlobalNvsArea.Area->OtgMode = mSystemConfiguration.PchUsbOtg;\r
1009\r
1010 pchStepping = PchStepping();\r
1011 if (mSystemConfiguration.UsbAutoMode == 1) {\r
1012 //\r
1013 // Auto mode is enabled.\r
1014 //\r
1015 if (PchA0 == pchStepping) {\r
1016 //\r
1017 // For A0, EHCI is enabled as default.\r
1018 //\r
1019 mSystemConfiguration.PchUsb20 = 1;\r
1020 mSystemConfiguration.PchUsb30Mode = 0;\r
1021 mSystemConfiguration.UsbXhciSupport = 0;\r
1022 DEBUG ((EFI_D_INFO, "EHCI is enabled as default. SOC 0x%x\n", pchStepping));\r
1023 } else {\r
1024 //\r
1025 // For A1 and later, XHCI is enabled as default.\r
1026 //\r
1027 mSystemConfiguration.PchUsb20 = 0;\r
1028 mSystemConfiguration.PchUsb30Mode = 1;\r
1029 mSystemConfiguration.UsbXhciSupport = 1;\r
1030 DEBUG ((EFI_D_INFO, "XHCI is enabled as default. SOC 0x%x\n", pchStepping));\r
1031 }\r
1032 }\r
1033\r
1034 mGlobalNvsArea.Area->XhciMode = mSystemConfiguration.PchUsb30Mode;\r
1035\r
1036 mGlobalNvsArea.Area->Stepping = mPlatformInfo->IchRevision;\r
1037\r
1038 //\r
1039 // Override invalid Pre-Boot Driver and XhciMode combination.\r
1040 //\r
1041 if ((mSystemConfiguration.UsbXhciSupport == 0) && (mSystemConfiguration.PchUsb30Mode == 3)) {\r
1042 mGlobalNvsArea.Area->XhciMode = 2;\r
1043 }\r
1044 if ((mSystemConfiguration.UsbXhciSupport == 1) && (mSystemConfiguration.PchUsb30Mode == 2)) {\r
1045 mGlobalNvsArea.Area->XhciMode = 3;\r
1046 }\r
1047\r
1048 DEBUG ((EFI_D_ERROR, "ACPI NVS XHCI:0x%x\n", mGlobalNvsArea.Area->XhciMode));\r
1049\r
1050 mGlobalNvsArea.Area->PmicEnable = GLOBAL_NVS_DEVICE_DISABLE;\r
1051 mGlobalNvsArea.Area->BatteryChargingSolution = GLOBAL_NVS_DEVICE_DISABLE;\r
1052 mGlobalNvsArea.Area->ISPDevSel = mSystemConfiguration.ISPDevSel;\r
1053 mGlobalNvsArea.Area->LpeEnable = mSystemConfiguration.Lpe;\r
aa44e98d 1054 mGlobalNvsArea.Area->LpeAudioReportedByDSDT = mSystemConfiguration.LpeAudioReportedByDSDT;\r
3cbfba02
DW
1055\r
1056 if (mSystemConfiguration.ISPEn == 0) {\r
1057 mGlobalNvsArea.Area->ISPDevSel = GLOBAL_NVS_DEVICE_DISABLE;\r
1058 }\r
1059\r
1060 mGlobalNvsArea.Area->WittEnable = mSystemConfiguration.WittEnable;\r
1061 mGlobalNvsArea.Area->UtsEnable = mSystemConfiguration.UtsEnable;\r
1062 mGlobalNvsArea.Area->SarEnable = mSystemConfiguration.SAR1;\r
1063\r
1064\r
1065 mGlobalNvsArea.Area->ReservedO = 1;\r
1066\r
1067 SettingI2CTouchAddress();\r
1068 mGlobalNvsArea.Area->IdleReserve= mSystemConfiguration.IdleReserve;\r
1069 //\r
1070 // Read BMBOUND and store it in GlobalNVS to pass into ASL.\r
1071 //\r
1072 // BUGBUG: code was moved into silicon reference code.\r
1073 //\r
1074 if (mSystemConfiguration.eMMCBootMode== 1) {\r
1075 //\r
1076 // Auto detect mode.\r
1077 //\r
1078 DEBUG ((EFI_D_ERROR, "Auto detect mode------------start\n"));\r
1079\r
1080 //\r
1081 // Silicon Steppings.\r
1082 //\r
1083 switch (PchStepping()) {\r
1084 case PchA0: // A0/A1\r
1085 case PchA1:\r
1086 DEBUG ((EFI_D_ERROR, "SOC A0/A1: eMMC 4.41 Configuration\n"));\r
1087 mSystemConfiguration.LpsseMMCEnabled = 1;\r
1088 mSystemConfiguration.LpsseMMC45Enabled = 0;\r
1089 break;\r
1090\r
1091 case PchB0: // B0 and later.\r
1092 default:\r
1093 DEBUG ((EFI_D_ERROR, "SOC B0 and later: eMMC 4.5 Configuration\n"));\r
1094 mSystemConfiguration.LpsseMMCEnabled = 0;\r
1095 mSystemConfiguration.LpsseMMC45Enabled = 1;\r
1096 break;\r
1097 }\r
1098 } else if (mSystemConfiguration.eMMCBootMode == 2) {\r
1099 //\r
1100 // eMMC 4.41\r
1101 //\r
1102 DEBUG ((EFI_D_ERROR, "Force to eMMC 4.41 Configuration\n"));\r
1103 mSystemConfiguration.LpsseMMCEnabled = 1;\r
1104 mSystemConfiguration.LpsseMMC45Enabled = 0;\r
1105 } else if (mSystemConfiguration.eMMCBootMode == 3) {\r
1106 //\r
1107 // eMMC 4.5\r
1108 //\r
1109 DEBUG ((EFI_D_ERROR, "Force to eMMC 4.5 Configuration\n"));\r
1110 mSystemConfiguration.LpsseMMCEnabled = 0;\r
1111 mSystemConfiguration.LpsseMMC45Enabled = 1;\r
1112\r
1113 } else {\r
1114 //\r
1115 // Disable eMMC controllers.\r
1116 //\r
1117 DEBUG ((EFI_D_ERROR, "Disable eMMC controllers\n"));\r
1118 mSystemConfiguration.LpsseMMCEnabled = 0;\r
1119 mSystemConfiguration.LpsseMMC45Enabled = 0;\r
1120 }\r
1121\r
1122 mGlobalNvsArea.Area->emmcVersion = 0;\r
1123 if (mSystemConfiguration.LpsseMMCEnabled) {\r
1124 DEBUG ((EFI_D_ERROR, "mGlobalNvsArea.Area->emmcVersion = 0\n"));\r
1125 mGlobalNvsArea.Area->emmcVersion = 0;\r
1126 }\r
1127\r
1128 if (mSystemConfiguration.LpsseMMC45Enabled) {\r
1129 DEBUG ((EFI_D_ERROR, "mGlobalNvsArea.Area->emmcVersion = 1\n"));\r
1130 mGlobalNvsArea.Area->emmcVersion = 1;\r
1131 }\r
1132\r
1133 mGlobalNvsArea.Area->SdCardRemovable = mSystemConfiguration.SdCardRemovable;\r
a0f3b028 1134\r
3cbfba02
DW
1135 //\r
1136 // Microsoft IOT\r
1137 //\r
1138 if ((mSystemConfiguration.LpssHsuart0FlowControlEnabled == 1) && \\r
1139 (mSystemConfiguration.LpssPwm0Enabled == 0) && \\r
1140 (mSystemConfiguration.LpssPwm1Enabled == 0)) {\r
1141 mGlobalNvsArea.Area->MicrosoftIoT = GLOBAL_NVS_DEVICE_ENABLE;\r
1142 DEBUG ((EFI_D_ERROR, "JP1 is set to be MSFT IOT configuration.\n"));\r
1143 } else {\r
1144 mGlobalNvsArea.Area->MicrosoftIoT = GLOBAL_NVS_DEVICE_DISABLE;\r
1145 DEBUG ((EFI_D_ERROR, "JP1 is not set to be MSFT IOT configuration.\n"));\r
1146 }\r
a0f3b028 1147\r
3cbfba02
DW
1148 //\r
1149 // SIO related option.\r
1150 //\r
1151 Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, (void **)&mCpuIo);\r
1152 ASSERT_EFI_ERROR (Status);\r
1153\r
1154 mGlobalNvsArea.Area->WPCN381U = GLOBAL_NVS_DEVICE_DISABLE;\r
1155\r
1156 mGlobalNvsArea.Area->DockedSioPresent = GLOBAL_NVS_DEVICE_DISABLE;\r
1157\r
1158 if (mGlobalNvsArea.Area->DockedSioPresent != GLOBAL_NVS_DEVICE_ENABLE) {\r
1159 //\r
1160 // Check ID for SIO WPCN381U.\r
1161 //\r
1162 Status = mCpuIo->Io.Read (\r
1163 mCpuIo,\r
1164 EfiCpuIoWidthUint8,\r
1165 WPCN381U_CONFIG_INDEX,\r
1166 1,\r
1167 &PortData\r
1168 );\r
1169 ASSERT_EFI_ERROR (Status);\r
1170 if (PortData != 0xFF) {\r
1171 PortData = 0x20;\r
1172 Status = mCpuIo->Io.Write (\r
1173 mCpuIo,\r
1174 EfiCpuIoWidthUint8,\r
1175 WPCN381U_CONFIG_INDEX,\r
1176 1,\r
1177 &PortData\r
1178 );\r
1179 ASSERT_EFI_ERROR (Status);\r
1180 Status = mCpuIo->Io.Read (\r
1181 mCpuIo,\r
1182 EfiCpuIoWidthUint8,\r
1183 WPCN381U_CONFIG_DATA,\r
1184 1,\r
1185 &PortData\r
1186 );\r
1187 ASSERT_EFI_ERROR (Status);\r
1188 if ((PortData == WPCN381U_CHIP_ID) || (PortData == WDCP376_CHIP_ID)) {\r
1189 mGlobalNvsArea.Area->WPCN381U = GLOBAL_NVS_DEVICE_ENABLE;\r
1190 mGlobalNvsArea.Area->OnboardCom = GLOBAL_NVS_DEVICE_ENABLE;\r
1191 mGlobalNvsArea.Area->OnboardComCir = GLOBAL_NVS_DEVICE_DISABLE;\r
1192 }\r
1193 }\r
1194 }\r
1195\r
1196\r
1197\r
1198 //\r
1199 // Get Ps2 policy to set. Will be use if present.\r
1200 //\r
1201 Status = gBS->LocateProtocol (\r
1202 &gEfiPs2PolicyProtocolGuid,\r
1203 NULL,\r
1204 (VOID **)&Ps2Policy\r
1205 );\r
1206 if (!EFI_ERROR (Status)) {\r
1207 Status = Ps2Policy->Ps2InitHardware (ImageHandle);\r
1208 }\r
1209\r
1210 mGlobalNvsArea.Area->SDIOMode = mSystemConfiguration.LpssSdioMode;\r
1211\r
1212 Handle = NULL;\r
1213 Status = gBS->InstallMultipleProtocolInterfaces (\r
1214 &Handle,\r
1215 &gEfiGlobalNvsAreaProtocolGuid,\r
1216 &mGlobalNvsArea,\r
1217 NULL\r
1218 );\r
1219\r
1220 //\r
1221 // Read tables from the storage file.\r
1222 //\r
1223 while (!EFI_ERROR (Status)) {\r
1224 CurrentTable = NULL;\r
1225\r
1226 Status = FwVol->ReadSection (\r
1227 FwVol,\r
1228 &gEfiAcpiTableStorageGuid,\r
1229 EFI_SECTION_RAW,\r
1230 Instance,\r
1231 (VOID **) &CurrentTable,\r
1232 (UINTN *) &Size,\r
1233 &FvStatus\r
1234 );\r
1235\r
1236 if (!EFI_ERROR (Status)) {\r
1237 //\r
1238 // Allow platform specific code to reject the table or update it.\r
1239 //\r
1240 AcpiStatus = AcpiPlatformHooksIsActiveTable (CurrentTable);\r
1241\r
1242 if (!EFI_ERROR (AcpiStatus)) {\r
1243 //\r
1244 // Perform any table specific updates.\r
1245 //\r
1246 AcpiStatus = PlatformUpdateTables (CurrentTable);\r
1247 if (!EFI_ERROR (AcpiStatus)) {\r
1248 //\r
1249 // Add the table.\r
1250 //\r
1251 TableHandle = 0;\r
1252 AcpiStatus = AcpiSupport->SetAcpiTable (\r
1253 AcpiSupport,\r
1254 CurrentTable,\r
1255 TRUE,\r
1256 TableVersion,\r
1257 &TableHandle\r
1258 );\r
1259 ASSERT_EFI_ERROR (AcpiStatus);\r
1260 }\r
1261 }\r
1262\r
1263 //\r
1264 // Increment the instance.\r
1265 //\r
1266 Instance++;\r
1267 }\r
1268 }\r
1269\r
1270 Status = EfiCreateEventReadyToBootEx (\r
1271 TPL_NOTIFY,\r
1272 OnReadyToBoot,\r
1273 NULL,\r
1274 &Event\r
1275 );\r
1276\r
1277 //\r
1278 // Finished.\r
1279 //\r
1280 return EFI_SUCCESS;\r
1281}\r
1282\r
1283UINT8\r
1284ReadCmosBank1Byte (\r
1285 IN UINT8 Index\r
1286 )\r
1287{\r
1288 UINT8 Data;\r
1289\r
1290 IoWrite8(0x72, Index);\r
1291 Data = IoRead8 (0x73);\r
1292 return Data;\r
1293}\r
1294\r
1295VOID\r
1296WriteCmosBank1Byte (\r
1297 IN UINT8 Index,\r
1298 IN UINT8 Data\r
1299 )\r
1300{\r
1301 IoWrite8 (0x72, Index);\r
1302 IoWrite8 (0x73, Data);\r
1303}\r
1304\r
1305\r
1306\r
1307VOID\r
1308SettingI2CTouchAddress (\r
1309 IN VOID\r
1310 )\r
1311{\r
1312 if (mSystemConfiguration.I2CTouchAd == 0) {\r
1313 //\r
1314 // If setup menu select auto set I2C Touch Address base on board id.\r
1315 //\r
1316 if (mPlatformInfo->BoardId == BOARD_ID_BL_RVP ||\r
1317 mPlatformInfo->BoardId == BOARD_ID_BL_STHI ||\r
1318 mPlatformInfo->BoardId == BOARD_ID_BL_RVP_DDR3L ) {\r
1319 //\r
1320 //RVP\r
1321 //\r
1322 mGlobalNvsArea.Area->I2CTouchAddress = 0x4B;\r
1323 } else if (mPlatformInfo->BoardId == BOARD_ID_BL_FFRD) {\r
1324 //\r
1325 //FFRD\r
1326 //\r
1327 mGlobalNvsArea.Area->I2CTouchAddress = 0x4A;\r
1328 } else if (mPlatformInfo->BoardId == BOARD_ID_BB_RVP) {\r
1329 mGlobalNvsArea.Area->I2CTouchAddress = 0x4C;\r
1330 } else if (mPlatformInfo->BoardId == BOARD_ID_CVH) {\r
1331 mGlobalNvsArea.Area->I2CTouchAddress = 0x4C;\r
1332 } else if (mPlatformInfo->BoardId == BOARD_ID_BL_FFRD8) {\r
1333 //\r
1334 //FFRD8 uses 0x4A.\r
1335 //\r
1336 mGlobalNvsArea.Area->I2CTouchAddress = 0x4A;\r
1337 }\r
1338 } else {\r
1339 mGlobalNvsArea.Area->I2CTouchAddress = mSystemConfiguration.I2CTouchAd;\r
1340 }\r
1341 DEBUG((EFI_D_ERROR, "GlobalNvsArea.Area->I2CTouchAddress: [%02x]\n", mGlobalNvsArea.Area->I2CTouchAddress));\r
1342}\r
1343\r
1344\r