macOS Catalina 10.15安装中常见的问题及解决方法

随着macOS Catalina(卡塔利娜) 10.15发行正式版本的临近,各种安装常见问题也需要同步更新,本篇文章就是针对10.15的常见问题的汇总,我会持续不间断更新,敬请期待

关于Clover Bootloader的版本

想要正确地安装macOS Catalina 10.15,它要求你的Clover Bootloader版本不低于r4940,截止到目前为止[6-4-2019],Clover Bootloader的版本已经更新为v2.4k r4940,支持安装macOS Catalina 10.15。Clover Bootloader最新版本下载

注意事项

  • 在HFS +上安装macOS Catalina时,通过系统偏好设置自动更新系统的功能会消失。

    解决方案:使用脚本下载10.15Beta更新包,原帖:https://github.com/Gengik84/MacOS_Updater

    1
    curl -O https://raw.githubusercontent.com/Gengik84/MacOS_Updater/master/MacOS_Updater && chmod +x ./MacOS_Updater && sh ./MacOS_Updater
  • 从第三方来源安装程序:

    1
    sudo spctl --master-disable
  • 关闭Thunderbolt更新:

    1
    sudo softwareupdate --ignore ThunderboltFirmwareUpdate1.2
  • 为第三方SSD启用TRIM

    1
    sudo trimforce enable

取消4位数密码限制

1
2
pwpolicy -clearaccountpolicies
passwd

10.15 Beta5无法更新/安装的解决方法

1
2
3
Comment: change EC0 to EC
Find: 4543305F
Replace: 45435F5F

另一种格式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<dict>
<key>Comment</key>
<string>change EC0 to EC</string>
<key>Disabled</key>
<false/>
<key>Find</key>
<data>
RUMwXw==
</data>
<key>Replace</key>
<data>
RUNfXw==
</data>
</dict>

安装卡在最后2分钟的解决方法

  • 断开网络

  • 使用OsxAptioFixDrv-64.efi或者OsxAptioFixDrv3-64.efi替换AptioMemoryFix.efi,每次只可以用一个驱动

  • 抹盘直接选择APFS格式,减少HFS+转换成APFS的过程

    APFS

z390主板安装卡在apfs_module_start的解决方法

请于Acpi - DSDT - Patches中添加:

1
2
3
Comment: 	Fix AsRock Z390 BIOS DSDT Device(RTC) bug
Find: A00A9353 54415301
Replace: A00A910A FF0BFFFF

找不到安装器资源的解决方法

  • 断网
  • 删除drivers64UEFI目录下的EmuVariableUefi-64.efi
  • 修改机型为最近三年,比如MacBootPro13,1 MacBookPro14,1 iMac17,1 等等
  • 如果是双硬盘,拔掉那个不安装的,待安装完后再插回去
  • 检查镜像的md5值

关于HD3000平台

macOS Catalina 10.15已经不支持Sandy Bridge平台的安装使用,解决方法有两个:

  • 在引导标志(boot args)添加-no_compat_check跳过兼容性检查
  • 修改SMBIOS为:MacBookAir5,1

Kaby Lake UHD 620显卡特别说明

部分基于类似AAPL GfxYTile的注入参数在macOS Catalina 10.15中会失效,它要求将Clover Bootloader版本至少更新到r4587或以上,Clover Bootloader最新版本下载

关于声卡注入的ID

Apple已从macOS Catalina 10.15上的AppleHDA.kext中删除了大量的Layouts,因此很多人需要修改/修补当前的AppleHDA.kext / AudioInjector才能使音频恢复到工作状态。
Apple在macOS Catalina上删除的布局ID为:
Layout1,3,8,9,11,12,13,18,22,23,24,25,26,27,28,29,30,31,32,34,36,37,38,39,41, 42,43,44,45,46,47,48,49,50等
要查看已删除的布局的完整列表以及可用于替换已删除的布局的列表,下面是一张可以使用并可在macOS Catalina 10.15上使用的可用布局的图片:

10.14_layoutid

好消息是vit9696通过更新他的AppleALC解决了影响去除布局的问题。AppleALC最新版本的下载:https://github.com/acidanthera/AppleALC/releases

minStolenSize新补丁,用于Broadwell, Skylake 以及Kabylake

  • Kaby Lake

    1
    2
    3
    4
    Comment: Disable minStolenSize less or equal fStolenMemorySize assertion, 10.14 Credits (Sniki)
    Name: com.apple.driver.AppleIntelKBLGraphicsFramebuffer
    Find: 764648FF 05
    Replace: EB4648FF 05
  • Sky Lake

    1
    2
    3
    4
    Comment: Disable minStolenSize less or equal fStolenMemorySize assertion, 10.14 Credits (Sniki)
    Name: com.apple.driver.AppleIntelSKLGraphicsFramebuffer
    Find: 764048FF 05
    Replace: EB4048FF 05
  • Broadwall

    1
    2
    3
    4
    Comment: Disable minStolenSize less or equal fStolenMemorySize assertion, 10.14 Credits (Sniki)
    Name: com.apple.driver.AppleIntelBDWGraphicsFramebuffer
    Find: 764048FF 05
    Replace: EB4048FF 05

10.15.x解除USB端口限制补丁 [6-5-2019更新]

经和PMHeart求证后,精简成2条补丁

1
2
3
4
5
6
7
8
9
Comment: USB port limit patch #1 10.15.x modify by DalianSky(credit ydeng)
Name: com.apple.iokit.IOUSBHostFamily
Find: 83FB0F0F
Replace: 83FB3F0F

Comment: USB Port limit patch #2 10.15.x modify by DalianSky
Name: com.apple.driver.usb.AppleUSBXHCI
Find: 83F90F0F
Replace: 83F93F0F

Intel HD3000显卡驱动

由于macOS Catalina 10.15中已经将AppleIntelHD3000Graphics.kext等相关驱动移除,一个折衷的解决方案是复制一份macOS Sierra 10.12.x的驱动到/System/Library/Extensions,重建缓存后重启即可享用。详见https://www.tonymacx86.com/threads/success-lenovo-b570e.255129/page-2#post-1770059

找回丢失的DW1560/Brcm94352Z驱动

Mojave系统下的蓝牙会失效,截止到目前的解决方法是:将文件BrcmFirmwareData.kextBrcmPatchRAM2.kext复制到/Library/Extensions目录下。联想版请使用BrcmFirmwareRepo.kext

当然,在重启前,还要重建一下系统的缓存,命令为:

1
sudo kextcache -i /

如果嫌输入命令麻烦,也可以使用应用Kext Utility重建缓存。

重启你的系统,检查WIFI/蓝牙是否工作正常。

关于10.15高通无线失效无法驱动的问题的解决方案[来自套路]

升级到Mojave的大家应该都看到了,14的驱动删掉了好多,最惹人注意的就是A卡的一堆、hd3000的几个、N卡的几个加上高通的无线网卡驱动,用了很久也琢磨了好久后,终于找到了解决高通无线挂的解决方案,下面是方法:

由于14系统内删除了Airport40的驱动,而ath9k插件又正是对其起的作用,因此前提条件是我们需要将13的这个kext拿来用,后面我会给出附件,ath9k插件的作者很久没有维护了,目前为止,作者源码只支持到10.13,因此需要我们手动修改源码使其能够支持到10.15,这里不做过多介绍,有兴趣的可以在下面评论,我会尽量解答,这里只把需要的附件做简要说明,大家也就不用再去clone源码修改编译了,附件主要包括3个,第一个是AtherosAirport40驱动,是我从13.6beta4中提取出来的,大家直接将其安装到/Library/Extensions/即可,然后就是我基于作者源码修改后的ath9k插件和最新的lilu(也是最新源码修改的),将这两个插件放到CLOVER,最后,为了保险起见,在config加上两个boot参数,分别是-lilubetaall-ath9565,当然这是9565的参数,其余参数参见ath9k的说明文档,下面有链接,然后重建缓存、修复权限重启就可以了。详见:http://bbs.pcbeta.com/viewthread-1790406-1-1.html 感谢套路athlonreg

APFS转换解决方法

Apple已经删除了我们必须避免APFS转换的选项,常规的方法已经无法避免安装过程中自动将分区转换为APFS格式,包括在硬盘上安装以及SSD上面安装。
以下是一些目前已知的替代品:
1.使用Carbon Copy Cloner(CCC)应用程序格式驱动器备份到HFS + J并恢复备份。
2.使用此应用程序将APFS分区转换为HFS + J:https://www.paragon-software.com/home/apfs-hfs-converter/
3.使用USB转SATA电缆从外部卸下HDD / SSD并安装macOS(似乎避免了APFS转换)。
4.修补安装程序,由你来找到这个方法。

安装中出现的IOConsoleUsers: time(0) 0->0, lin 0, llk 1, IOConsoleUsers: gIOScreenLockState 3, hs 0, bs 0, nov 0, sm 0x0错误的临时解决方法

群里最常见的安装过程中出现的一个错误是:

1
2
IOConsoleUsers: time(0) 0->0, lin 0, llk 1,
IOConsoleUsers: gIOScreenLockState 3, hs 0, bs 0, nov 0, sm 0x0

原因是系统无法识别出你的显卡驱动,临时的解决方法是:

  • 取消勾选Inject Intel
  • 或者将platform-id修改为0x12345678
  • 两种方法二选一,不知道如何操作的请移步Clover使用教程

platform-id_0x12345678

安装完成后再通过Clover Configurator设置正确的FakeIDig-plaform-id驱动你的显卡。

去掉Lilu的输出信息,还原10.13/10.14 内核崩溃(kernel pance)的真相

原文出处:https://applelife.ru/threads/ustanovka-macos-high-sierra-10-13-na-intel-pc.2210706/page-358#post-686953

**方法1:**使用文本编辑器,在KernelToPatch段落添加内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<key>KernelToPatch</key>
<array>
<dict>
<key>Comment</key>
<string>Disable panic kext logging on Release kernel</string>
<key>Disabled</key>
<false/>
<key>Find</key>
<data>
AIoChMB0
</data>
<key>MatchOS</key>
<string>10.14.4,10.14.5</string>
<key>Replace</key>
<data>
AIoChMDr
</data>
</dict>
</dict>
</array>

**方法2:**使用Clover Configurator打开config.plist - Kernel and Kext Patches - kernelToPatch,新添加:

1
2
3
4
Comment:    Disable panic kext logging on 10.15.4 Release kernel
Find: 008a0284c074
Replace: 008a0284c0eb
MatchOS: 10.14.4,10.14.5

其它的内核补丁备用,请自行食用:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
XCPM patches 10.15

_cpuid_set_info
Find: 72 3c d0 77 50 0f b6 c0
Repl: xx 3c d0 77 50 0f b6 c0

_xcpm_bootstrap
Find: 8D 43 C4 3C 22 77 22
Repl: 8D 43 xx 3C 22 77 22

_xcpm_SMT_scope_msrs #1
Find: BE060000005DE908000000
Repl: BE060000005DC390909090

_xcpm_SMT_scope_msrs #2
Find: 31 D2 E8 3E FD FF FF
Repl: 31 D2 90 90 90 90 90

_xcpm_core_scope_msrs
Find: 31 D2 E8 51 FD FF FF
Repl: 31 D2 90 90 90 90 90

_xcpm_pkg_scope_msrs
Find: 31 D2 E8 74 FD FF FF
Repl: 31 D2 90 90 90 90 90

disable all msrs above
Find: BE 06 00 00 00 5D E9 08 00 00 00 0F 1F 84 00 00 00 00 00 55
Repl: BE 06 00 00 00 5D E9 08 00 00 00 0F 1F 84 00 00 00 00 00 C3

Performance patch (credit to @vit9696)
Find: C1E3084863D389D048C1EA20
Repl: C1E308B800FF000031D29090

引用链接:https://www.insanelymac.com/forum/topic/339035-pre-release-macos-catalina/?page=2&tab=comments#comment-2676147

Block injected kexts 禁用无效的、未知的驱动程序

当你面对这么一堆驱动的时候,如何让它们有条不紊地正常工作呢?万一出现问题的时候又如何让这些驱动在Clover引导的时候禁用它们呢?这个时候 Block injected kexts 就派上用场了。新版的 Clover Bootloader 已经将 Block injected kexts 放到了 macOS 系统分区的图标下面了。

  • 操作方法:
    • 开机进入clover引导界面,要引导的分区卷标上按 空格 即可进入
      1-main
    • 光标移动到 Block injected kexts 回车进入
      kim
    • 选择当前系统加载的驱动程序目录
      kimselect
    • 勾选禁用的驱动程序
      kimoptions
    • ESC 退出该子菜单

选择-v时出现Attempting system restart...MACH Reboot的解决方法

在安装High Sierra启动过程中,选择-v跑时会出现

1
Attempting system restart...MACH Reboot

而不用-v图跑直接显示苹果标志时则不会出现。

解决方法

config.plist配置文件DropTables下添加以下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<key>ACPI</key>
<key>DropTables</key>
<array>
<dict>
<key>Signature</key>
<string>MATS</string>
</dict>
<dict>
<key>Signature</key>
<string>DMAR</string>
</dict>
<dict>
<key>Signature</key>
<string>BGRT</string>
</dict>
</array>

抹盘时提示"MediaKit报告设备上的空间不足以执行请求的操作"的原因及解决方法

群里遇到最多的问题就是抹盘时提示"MediaKit报告设备上的空间不足以执行请求的操作",一直想就此写个解决方法

原因

出现该提示最根本的原因就是你之前的磁盘分区中ESP分区的尺寸小于200MB

解决方法

  • Windows下使用diskgenius删除掉MSR分区,将多出来的分区合并到ESP,正好凑成200MB,以满足安装macOS的基本需求.
  • macOS下可以直接使用磁盘工具进行抹盘,它会自动生成一个200MB的EFI分区,当然前提条件是你需要先备份好磁盘里的数据,否则会造成全盘数据的丢失,请谨慎操作.

关于macOS Catalina 10.15下修改显存以及帧缓存、显示接口

请移步另一篇教程:Coffee Lake帧缓冲区补丁及UHD630 Coffee Lake ig-platform-id数据整理

教你将U盘上的EFI复制到磁盘的EFI分区,脱离USB运行[macOS篇]

新的系统安装成功后,EFI还位于U盘里,总不能一直挂着U盘使用系统吧。这个时候如果你想将U盘里的EFI复制到磁盘的EFI分区里,却苦于找不到看不见EFI分区,这个时候是该让diskutil登场了。

diskutil命令的基本用法:

查看磁盘分区表

1
diskutil list

/dev/disk0(internal, physical):

#:TYPENAMESIZEIDENTIFIER
0:GUID_partition_scheme256 GBdisk0
1:EFIEFI200 MBdisk0s1
2:Apple_HFSMAC128 GBdisk0s2
3:Microsoft Basic DataWIN10127.7 GBdisk0s3

/dev/disk1(internal, physical):

#:TYPENAMESIZEIDENTIFIER
0:GUID_partition_scheme16 GBdisk1
1:EFIEFI200 MBdisk1s1
2:Apple_HFSInstall macOS Sierra15.8 GBdisk1s2

挂载磁盘EFI分区

1
sudo diskutil mount disk0s1

挂载U盘EFI分区

1
sudo diskutil mount disk1s1

打开Finder,注意后面有个.

1
open .

左侧会显示挂载了两个EFI分区,将U盘EFI目录全部复制到磁盘的EFI分区即可。

合并EFI分区

这里有一点需要注意:如果之前安装过Windows系统的话,会存在EFI的目录,只是EFI的目录下面只有BOOT和Microsoft这两个目录,如果希望添加macOS的Clover引导的话,可以将USB的EFI分区里面的EFI目录下面的CLOVER复制到磁盘里的EFI目录下,也就是执行的是**合并**的操作,让EFI同时支持WINDOWS和macOS的引导.千万不要全部复制,否则有可能造成EFI无法启动Windows.

复制EFI分区

如果磁盘上的EFI分区里为空的,可以直接将USB的EFI分区下面的EFI目录直接复制到磁盘上的EFI分区里.

教你将U盘上的EFI复制到磁盘的EFI分区,脱离USB运行[Windows篇]

挂载EFI分区

Windows操作系统下面,打开cmd窗口,输入命令:

1
2
3
4
5
6
7
diskpart
list disk # 磁盘列表
select disk n # 选择EFI分区所在的磁盘,n为磁盘号
list partition # 磁盘分区列表
select partition n # 选择EFI分区,n为EFI分区号
set id="ebd0a0a2-b9e5-4433-87c0-68b6b72699c7" # 设置为EFI分区
assign letter=X # x为EFI分区盘符

您可以重复输入命令同时挂载USB的EFI分区和磁盘的EFI分区
打开资源管理器,会出现一个盘符为X的磁盘,格式化为fat32格式,将USB的EFI分区下面的EFI目录复制到安装磁盘的EFI分区下

合并EFI分区

这里有一点需要注意:如果之前安装过Windows系统的话,会存在EFI的目录,只是EFI的目录下面只有BOOT和Microsoft这两个目录,如果希望添加macOS的Clover引导的话,可以将USB的EFI分区里面的EFI目录下面的CLOVER复制到磁盘里的EFI目录下,也就是执行的是**合并**的操作,让EFI同时支持WINDOWS和macOS的引导.千万不要全部复制,否则有可能造成EFI无法启动Windows.

复制EFI分区

如果磁盘上的EFI分区里为空的,可以直接将USB的EFI分区下面的EFI目录直接复制到磁盘上的EFI分区里.

添加UEFI引导选项

使用工具:BOOTICE

操作过程:

  1. 打开BOOTICE软件,选择物理磁盘,选择欲操作的目标磁盘,点击分区管理,弹出分区管理的窗口,点击分配盘符,为ESP分区分配一个盘符,点击确定
    BOOTICE1
  2. 选择UEFI,点击修改启动序列,点击添加按钮,菜单标题填写:CLOVER,选择启动文件,在打开的窗口里选择ESP分区下的目录\EFI\CLOVER\CLOVERX64.EFI,点击保存当前启动项设置
    BOOTICE2

重建缓存的命令

打开终端,输入命令:

1
sudo kextcache -i /

关于打赏

您的支持就是我更新的动力!
如果不希望看到博主停更的话,请点击下方的 打赏 支持一下,有钱的捧个钱场,没钱的捧个人场,谢谢大家!

更新日期更新日期2019-09-082019-09-08
-------------本文结束感谢您的阅读-------------
如果文章对您有帮助,就请站长喝杯咖啡吧 ´◡`
0%