1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/zsl588-OpenCorePkg

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
OpenCoreAcpi.c 6.4 КБ
Копировать Редактировать Исходные данные Просмотреть построчно История
Marvin Häuser Отправлено 4 лет назад 6b27ad1
/** @file
OpenCore driver.
Copyright (c) 2019, vit9696. All rights reserved.<BR>
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.
**/
#include <Library/OcMainLib.h>
#include <Library/BaseLib.h>
#include <Library/DebugLib.h>
#include <Library/MemoryAllocationLib.h>
#include <Library/OcAcpiLib.h>
#include <Library/OcMiscLib.h>
#include <Library/OcStringLib.h>
#include <Library/PrintLib.h>
#include <Library/UefiBootServicesTableLib.h>
STATIC
VOID
OcAcpiAddTables (
IN OC_GLOBAL_CONFIG *Config,
IN OC_STORAGE_CONTEXT *Storage,
IN OC_ACPI_CONTEXT *Context
)
{
EFI_STATUS Status;
UINT8 *TableData;
UINT32 TableDataLength;
UINT32 Index;
OC_ACPI_ADD_ENTRY *Table;
CONST CHAR8 *TablePath;
CHAR16 FullPath[OC_STORAGE_SAFE_PATH_MAX];
for (Index = 0; Index < Config->Acpi.Add.Count; ++Index) {
Table = Config->Acpi.Add.Values[Index];
TablePath = OC_BLOB_GET (&Table->Path);
if (!Table->Enabled || TablePath[0] == '\0') {
DEBUG ((DEBUG_INFO, "OC: Skipping add ACPI %a (%d)\n", TablePath, Table->Enabled));
continue;
}
Status = OcUnicodeSafeSPrint (FullPath, sizeof (FullPath), OPEN_CORE_ACPI_PATH "%a", TablePath);
if (EFI_ERROR (Status)) {
DEBUG ((
DEBUG_WARN,
"OC: Failed to fit ACPI path %s%a",
OPEN_CORE_ACPI_PATH,
TablePath
));
continue;
}
UnicodeUefiSlashes (FullPath);
TableData = OcStorageReadFileUnicode (Storage, FullPath, &TableDataLength);
if (TableData == NULL) {
DEBUG ((
DEBUG_WARN,
"OC: Failed to find ACPI %a\n",
TablePath
));
continue;
}
Status = AcpiInsertTable (Context, TableData, TableDataLength);
if (EFI_ERROR (Status)) {
DEBUG ((
DEBUG_WARN,
"OC: Failed to add ACPI %a - %r\n",
TablePath,
Status
));
}
}
}
STATIC
VOID
OcAcpiDeleteTables (
IN OC_GLOBAL_CONFIG *Config,
IN OC_ACPI_CONTEXT *Context
)
{
EFI_STATUS Status;
UINT32 Index;
UINT32 Signature;
UINT64 OemTableId;
OC_ACPI_DELETE_ENTRY *Table;
for (Index = 0; Index < Config->Acpi.Delete.Count; ++Index) {
Table = Config->Acpi.Delete.Values[Index];
if (!Table->Enabled) {
continue;
}
CopyMem (&Signature, Table->TableSignature, sizeof (Table->TableSignature));
CopyMem (&OemTableId, Table->OemTableId, sizeof (Table->OemTableId));
Status = AcpiDeleteTable (
Context,
Signature,
Table->TableLength,
OemTableId,
Table->All
);
if (EFI_ERROR (Status)) {
DEBUG ((
DEBUG_WARN,
"OC: Failed to drop ACPI %08X %016LX %u (%d) - %r\n",
Signature,
OemTableId,
Table->TableLength,
Table->All,
Status
));
}
}
}
STATIC
VOID
OcAcpiPatchTables (
IN OC_GLOBAL_CONFIG *Config,
IN OC_ACPI_CONTEXT *Context
)
{
EFI_STATUS Status;
UINT32 Index;
OC_ACPI_PATCH_ENTRY *UserPatch;
OC_ACPI_PATCH Patch;
for (Index = 0; Index < Config->Acpi.Patch.Count; ++Index) {
UserPatch = Config->Acpi.Patch.Values[Index];
if (!UserPatch->Enabled) {
continue;
}
//
// Ignore patch if:
// - There is nothing to replace.
// - Find and replace mismatch in size.
// - Mask and ReplaceMask mismatch in size when are available.
//
if (UserPatch->Replace.Size == 0
|| (UserPatch->Find.Size > 0 && UserPatch->Find.Size != UserPatch->Replace.Size)
|| (UserPatch->Find.Size == 0 && OC_BLOB_GET (&UserPatch->Base)[0] == '\0')
|| (UserPatch->Mask.Size > 0 && UserPatch->Find.Size != UserPatch->Mask.Size)
|| (UserPatch->ReplaceMask.Size > 0 && UserPatch->Replace.Size != UserPatch->ReplaceMask.Size)) {
DEBUG ((DEBUG_ERROR, "OC: ACPI patch %u is borked\n", Index));
continue;
}
ZeroMem (&Patch, sizeof (Patch));
Patch.Find = OC_BLOB_GET (&UserPatch->Find);
Patch.Replace = OC_BLOB_GET (&UserPatch->Replace);
if (UserPatch->Mask.Size > 0) {
Patch.Mask = OC_BLOB_GET (&UserPatch->Mask);
}
if (UserPatch->ReplaceMask.Size > 0) {
Patch.ReplaceMask = OC_BLOB_GET (&UserPatch->ReplaceMask);
}
Patch.Base = OC_BLOB_GET (&UserPatch->Base);
Patch.BaseSkip = UserPatch->BaseSkip;
Patch.Size = UserPatch->Replace.Size;
Patch.Count = UserPatch->Count;
Patch.Skip = UserPatch->Skip;
Patch.Limit = UserPatch->Limit;
CopyMem (&Patch.TableSignature, UserPatch->TableSignature, sizeof (UserPatch->TableSignature));
Patch.TableLength = UserPatch->TableLength;
CopyMem (&Patch.OemTableId, UserPatch->OemTableId, sizeof (UserPatch->OemTableId));
Status = AcpiApplyPatch (Context, &Patch);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_WARN, "OC: ACPI patcher failed %u - %r\n", Index, Status));
}
}
}
VOID
OcLoadAcpiSupport (
IN OC_STORAGE_CONTEXT *Storage,
IN OC_GLOBAL_CONFIG *Config
)
{
EFI_STATUS Status;
OC_ACPI_CONTEXT Context;
Status = AcpiInitContext (&Context);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "OC: Failed to initialize ACPI support - %r\n", Status));
return;
}
if (Config->Acpi.Quirks.RebaseRegions) {
AcpiLoadRegions (&Context);
}
OcAcpiPatchTables (Config, &Context);
OcAcpiDeleteTables (Config, &Context);
OcAcpiAddTables (Config, Storage, &Context);
if (Config->Acpi.Quirks.FadtEnableReset) {
AcpiFadtEnableReset (&Context);
}
if (Config->Acpi.Quirks.ResetLogoStatus) {
AcpiResetLogoStatus (&Context);
}
//
// Log hardware signature.
//
AcpiHandleHardwareSignature (&Context, Config->Acpi.Quirks.ResetHwSig);
if (Config->Acpi.Quirks.RebaseRegions) {
AcpiRelocateRegions (&Context);
}
if (Config->Acpi.Quirks.NormalizeHeaders) {
AcpiNormalizeHeaders (&Context);
}
if (Config->Acpi.Quirks.SyncTableIds) {
AcpiSyncTableIds (&Context);
}
AcpiApplyContext (&Context);
AcpiFreeContext (&Context);
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/zsl588-OpenCorePkg.git
git@gitlife.ru:oschina-mirror/zsl588-OpenCorePkg.git
oschina-mirror
zsl588-OpenCorePkg
zsl588-OpenCorePkg
0.7.7