跳转至

OC 文件结构

原始文件结构

OpenCore 引导的官方项目地址为:https://github.com/acidanthera/OpenCorePkg

查看最新版本的下载地址为:https://github.com/acidanthera/OpenCorePkg/releases

截止写文章的时间 2021 年 09 月 17 日,最新的 OC 引导为 0.7.3 的版本,所以我们下载 OpenCore-0.7.3-RELEASE.zip 并解压,这样就得到 OC 的最原始的文件了。

下面分别大概说明一下这些目录的作用:

  • Docs:存放 OC 最新的配置文档、版本更新变化、ACPI 示例文件以及 Sample.list 配置文件模板
  • IA32:里面放着 32 位老机器使用的 EFI 引导文件
  • Utilities:OC 官方集成的小工具都放在这里
  • X64: 里面放着 64 位目前主流机器使用的 EFI 引导文件

知道了大概的目录结果的话,下面来详细的介绍一下这些目录里面的文件详细情况。

Docs

~/Downloads/OpenCore-0.7.3-RELEASE/Docs
.
├── AcpiSamples          # ACPI 示例文件   ├── Binaries         # 编译好的 ACPI 文件      ├── SSDT-ALS0.aml
│      ├── SSDT-AWAC-DISABLE.aml
│      ...
│   └── Source           # ACPI 原始文件       ├── SSDT-ALS0.dsl
│       ├── SSDT-AWAC-DISABLE.dsl
│       ...
├── Changelog.md         # 版本更新日志
├── Configuration.pdf    # 当期版本的官方配置文档
├── Differences.pdf      # 和上一个版本的改变部分
├── Sample.plist         # 当期版本的配置文件模板
└── SampleCustom.plist   # 当期版本的配置文件模板

这里面文件都比较好理解,除了发现貌似 2 个配置文件模板,分别是 Sample.plist 和 SampleCustom.plist,但是国光我对比了一下,发现二者基本上没有差别,理论上都是可使用的,我们普遍使用 Sample.plist 这个配置文件比较多。

Utilities

这个目录下放着一些 OC 官方的小工具,下面来分别介绍一下这些小工具的作用

  • acdtinfo:检测当前机器的 kexts 安装情况
  • ACPIe:产生有用的 ACPI 查找跟踪排错使用
  • CreateVault:里面包含了 RSA 秘钥生成工具和用来创建 Valut 的脚本
  • disklabel:标签生成小工具,一般也用不到
  • icnspack:icns 合成制作小工具,想要自己自定义主题的时候可以用得上
  • kpdescribe:调式 Debug 排错使用,用于恢复堆栈跟踪
  • LegacyBoot:在旧电脑中模拟 UEFI 环境的工具和脚本
  • LogoutHook:用于模拟 NVRAM 保存的增强脚本
  • macrecovery:启动盘制作脚本
  • macserial:序列号生成工具
  • ocpasswordgen:OpenCore 密码数据生成工具
  • ocvalidate:检测 config.list 语法的正确与否

EFI

最后来到了我们的重头戏 EFI 部分,下面是 EFI 主要文件夹的作用讲解:

~/Downloads/OpenCore-0.7.3-RELEASE/X64/EFI
.
├── BOOT                          # 引导文件夹   └── BOOTx64.efi               # 引导文件
└── OC                            # OC 文件夹
    ├── ACPI                    # ACPI 存放的文件夹
       ├── SSDT-EC.aml
       ├── SSDT-PLUG.aml
       │── SSDT-PNLF.aml
           ...
    ├── Drivers                   # OC 驱动的文件夹
       ├── AudioDxe.efi
       ├── CrScreenshotDxe.efi
       ├── HiiDatabase.efi
           ...
    ├── Kexts                     # 存放内核拓展 kexts 的文件夹
       ├── AppleALC.kext
       ├── Lilu.kext
       ├── WhateverGreen.kext
           ...
    ├── OpenCore.efi              # OC 的核心文件
    ├── Resources                 # OC 的主题样式
       ├── Audio
       ├── Font
       ├── Image
       └── Label
    └── Tools                     # OC 小工具文件夹
        ├── BootKicker.efi
        ├── ChipTune.efi
        ├── CleanNvram.efi
            ...

BOOT

BOOT 引导文件夹,下面躺着 BOOTx64.ef 引导文件

OC/ACPI

下面存放这 SSDT 编译好的文件,格式均为 .aml 格式,关于 SSDT 详细的说明可以参考下面的章节

OC/Drivers

这里放着一些驱动文件,这些驱动均已 .efi 后缀结尾,OC 官方默认的驱动文件以及说明如下:

  • AudioDxe.efi:用与启动的时候播放 Duang 的声音,就像白苹果那样
  • CrScreenshotDxe.efi:OC 引导界面截图驱动,按 F10 会保存当前界面的截图到 EFI 分区的根目录下
  • HiiDatabase.efi:用于支持 UEFI 字体渲染,四代酷睿后一般不需要
  • NvmExpressDxe.efi:用于让老主板支持 NVME Express 设备,四代酷睿后一般不需要
  • OpenCanopy.efi:使用图形化 OC 主题必备驱动
  • OpenHfsPlus.efi:文件系统驱动,用于支持识别 HFS+ 的磁盘格式
  • OpenLinuxBoot.efi:OC 0.7.3 新增的驱动,用于引导 Linux 系统
  • OpenPartitionDxe.efi:分区管理驱动程序。用于加载旧版 macOS 的 DMG 映像
  • OpenRuntime.efi:OC 核心必备驱动,功能比较强大,大家记住这个是必备的驱动就行
  • OpenUsbKbDxe.efi:USB 键盘驱动,用于模拟苹果热键,是 KeySupport 的等效方案
  • Ps2KeyboardDxe.efi:PS/2 键盘驱动,这个 PS/2 键盘也太老了吧,我好多年没见过了
  • Ps2MouseDxe.efi:PS/2 鼠标驱动,同样也太老了,很多年没有见过了
  • UsbMouseDxe.efi:USB 鼠标驱动,有些虚拟机需要依赖改驱动才可以在引导界面使用鼠标
  • XhciDxe.efi:XHCI USB controller 驱动程序,基本上 2 代酷睿开始大多数固件都自带这个驱动程序了

OC/Kexts

这里放着一些 Kexts 内核扩展文件,格式均为 .kext 文件,关于 Kexts 详细的说明可以参考下面的章节

Resources

这里放着 OC 的第三方主题文件,实际上国光我一直用的官方主题,就挺简约的。

Tools

OC 小工具文件夹,像下面的 CleanNvram.efi 和 ResetSystem.efi 就是其中的一些小工具:

OC 官方自带的工具文件以及说明如下:

  • BootKicker.efi:调用苹果原生的引导切换 GUI, 给白苹果使用的,黑苹果不支持
  • ChipTune.efi:测试 BeepGen 协议并生成不同风格和长度的音频信号。
  • CleanNvram.efi:NVRAM 清理工具,实际上 OC 自带的 NVRAM 清理功能已经足够了
  • ControlMsrE2.efi:检查所有内核的CFG 锁定(MSR 0xE2写保护)一致性,并在更改此类隐藏选项
  • CsrUtil.efi:简单实现苹果csrutil的 SIP 相关功能
  • GopStop.efi:停止显卡 GOP,排错时使用用一个简单的场景测试 GraphicsOutput 协议
  • KeyTester.efi:在 SimpleText 模式下测试键盘输入。
  • MmapDump.efi:ProvideCustomSlide 选项的必要性
  • OpenControl.efi:为其他工具提供 NVRAM 保护,以便在从 OC 启动时能够获得完整的 NVRAM 访问权限。
  • OpenShell.efi:OpenCore 配置的 UEFI Shell
  • ResetSystem.efi:用于执行系统重置的实用程序
  • RtcRw.efi:用于读取和写入 RTC (CMOS) 存储器的实用程序。
  • TpmInfo.efi:检查平台上的英特尔 PTT(平台信任技术)功能,如果启用,则允许使用 fTPM 2.0

好了,至此 OpenCore 的文件结构就介绍的差不多了,下面开始学习下 ACPI 的相关知识。


最后更新: 2022-09-19