AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1277828
Accepted
Chris Williamson
Chris Williamson
Asked: 2020-09-26 15:00:16 +0800 CST2020-09-26 15:00:16 +0800 CST 2020-09-26 15:00:16 +0800 CST

如何在 shim 更新后修复损坏的启动?

  • 772

我有一台运行 Kubuntu 20.04 的 MacBook Pro(15 英寸,2008 年末),直到昨天。

系统提示我有可用的软件更新。据我所知,更新的软件包是 shim、shim-(某种东西),也许还有一个。我等待软件更新程序和单独的 grub 更新程序完成并在我这样做之前提示我重新启动。现在当我尝试启动时,我得到一个黑屏,上面写着:

设置 MokListRT 失败:参数无效
无法创建 MokListRT:参数无效
导入 MOK 状态失败:import_mok_state() failed
: 无效的参数
由于安全模式被禁用而继续引导_

但引导不会继续。

我今天花了很多时间寻找可能的解决方案。对我来说最有希望的是这个关于 Ubuntu grub2 包错误的评论。评论说要删除“shim/shim-signed/mokutil”,我认为评论者的意思是删除所有这三个包。它们似乎与 UEFI 安全启动有关,这是我的老式 MacBook Pro 不支持的。我不知道为什么我的系统首先会有这些软件包,然后提示我更新它们。

但我无法启动到 Kubuntu 来删除它们。引导过程甚至没有向我显示 grub 菜单,在提示输入加密密钥之前,我通常会短暂看到它。我假设磁盘加密不是这里的问题,因为这个过程似乎没有那么远。

我还有一个 OS X 分区,我可以通过按住option键进入 Mac 引导加载程序(并且它不会显示我的 Kubuntu 分区作为选项)来启动它。在 OS X 中,我下载了最新的 Kubuntu .iso 文件,验证了它的 SHA256 哈希值,并仔细按照 Ubuntu在 macOS 上创建可启动 U 盘教程中的说明进行操作。

当我重新启动时,按住option键进入 Mac 引导加载程序并选择我创建的这个所谓的可引导 USB 记忆棒,我确实得到了 grub 菜单。当我选择默认的 Kubuntu 或安全图形模式选项时,我得到:

[1.142769] Initramfs 解包失败:解码失败
[61.214455] rcu:信息:rcp_sched 检测到 CPU/任务的停顿:
[61.214508] rcu: o1-...!: (0 ticks this GP) idle=894/0/0x0 softirq=355/355 fqs=0
[61.215558] rcu:rcp_sched kthread 急需 15002 个 jiffies!g=835 f0x0 RCU_GP_WAIT_FQS(5)->状态=0x402->cpu=1
[61.215620] rcu:RCU 宽限期线程堆栈转储:

最后四行每隔几分钟重复一次,直到我断电。

所以我无法启动常规的 Kubuntu 分区,也无法启动 U 盘。

如何重新启动到我的 Kubuntu 系统?

grub2 boot mac uefi secure-boot
  • 1 1 个回答
  • 7413 Views

1 个回答

  • Voted
  1. Best Answer
    Chris Williamson
    2020-09-27T06:20:09+08:002020-09-27T06:20:09+08:00

    仔细撰写和发布我的问题的过程一定让我的大脑产生了一些震动,这让我真正看到了昨天多次出现在搜索结果中的东西:

    0015522:使用较旧的 uefi fw 的机器无法使用较新的 shim 启动(就像在 Apple 2008 iMac 上一样) - CentOS Bug Tracker

    具体来说,我做了本质上是他的解决方法#2,除了我必须修改它以启动到我的 OS X 分区,然后作为 root 创建 /Volumes/efi,使用 diskutil 来识别 EFI 分区,挂载它并 cd 到/卷/efi/EFI/ubuntu。正如他所写的那样,我没有将 grub64x.efi 复制到 shimx64.efi 上,而是首先将 shimx64.efi 移动到我的桌面目录以进行临时保管,以防万一我想恢复我所做的更改。然后我将 grub64x.efi 复制到 shimx64.efi。然后 umount 给了我一些错误,但建议我尝试 diskutil unmount,我做了,并且有效。然后我重新启动并获得了通常的(对我而言)grub 菜单、加密密码提示,最后回到 Kubuntu,我现在已经删除了 shim 和 shim-signed 包。

    似乎删除 shim 包并没有删除它放在 /boot/efi/EFI/ubuntu/ 和 /boot/efi/EFI/Boot-backup/ 中的文件。我现在要离开他们。

    我还将对我在问题中链接到的 Ubuntu 错误发表评论。我称它为 grub2 包错误,但我现在看到它的状态在 grub2 中已更改为无效,同时在 shim 中的状态为不完整并在 shim-signed 中确认。有很多评论,但似乎仍然有很多混乱,似乎还没有人与 CentOS 错误报告者发现的修复建立联系。因此,我会将我的经验发布到 Ubuntu 错误中,他们肯定会为其他所有人修复它。

    • 5

相关问题

  • 更改 Wubi 的启动顺序

  • 如何在 Ubuntu 启动时显示或隐藏启动消息?

  • 如何避免启动时出现“S to Skip”消息?

  • 如何使用 Mac 创建 Ubuntu live USB?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve