windwos11 更新 BIOS 覆盖了 endevaourOS linux 的启动引导 grub 重建修复
windwos11 更新 BIOS 覆盖了 endevaourOS linux 的启动引导 grub 重建修复
- date: 2022-10-30
- lastmod: 2022-10-30
问题为什么发生
我在 windows11 从官网下载并更新了 BIOS 固件,发现大部分 BIOS 设置被重置了(BIOS密码没有被重置),需要重新设置安全按启动、UMA size等。启动项里边看不到 endevaourOS 了,只剩下 windows 了,开始直接进入 win,之前设置的开机 log(OEM log)也被重置了。
怎么办
在 forum搜索了一波,发现 Restore grub after window 8 installation 2021-10 中的回答还蛮仔细
efibootmgr -v
看 en 启动项还在不在,在就调整顺序即可。我的无拉- 第一步不在就需要从新生成引导。关键在于分清楚根分区在那个盘块
工具
- 硬件:U盘(存放系统镜像)
- 软件:Ventory(给 U 盘加上装系统的功能)、系统镜像(liveCD 急救)
livsCD 重建 grub
插上 u盘,从 u 盘进入 endevaourOS 的 liveCD. 查看en引导已不在、查看分区重建引导
$ efibootmgr # 查看启动项, en 已经不见了
BootCurrent: 0017
Timeout: 0 seconds
BootOrder: 0000,0013,0014,0015,0016,0017,0018,0019
Boot0000* Windows Boot Manager HD(1,GPT,171ffb3e-6c37-4801-8b11-3ba3cea2e27a,0x800,0x82000)/File(\EFI\Microsoft\Boot\bootmgfw.efi)
Boot0010 Setup FvFile(721c8b66-426c-4e86-8e99-3457c46ab0b9)
Boot0011 Boot Menu FvFile(86488440-41bb-42c7-93ac-450fbf7766bf)
Boot0012 UEFI Diagnostics FvFile(f8397897-e203-4a62-b977-9e7e5d94d91b)
Boot0013* NVMe: WDC PC SN730 SDBPNTY-512G-1101 PciRoot(0x0)/Pci(0x2,0x4)/Pci(0x0,0x0)/NVMe(0x1,00-1B-44-8B-46-3A-AB-8F){99191c00-d932-4e4c-ae9a-a0b6e98eb8a4}
Boot0017* USB HDD: SMI USB DISK PciRoot(0x0)/Pci(0x8,0x1)/Pci(0x0,0x3)/USB(5,0){aa21e833-33af-47bc-89bd-419f88c50803}$ sudo su # 切换到 root
# parted -l
Model: SMI USB DISK (scsi)
Disk /dev/sda: 31.5GB
Sector size (logical/physical): 512B/512B
Partition Table: msdos
Disk Flags: Number Start End Size Type File system Flags1 1049kB 31.4GB 31.4GB primary boot2 31.4GB 31.5GB 33.6MB primary fat16 espModel: WDC PC SN730 SDBPNTY-512G-1101 (nvme)
Disk /dev/nvme0n1: 512GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Disk Flags: Number Start End Size File system Name Flags1 1049kB 274MB 273MB fat32 EFI System Partition boot, esp3 316MB 253GB 253GB ext4 extra4 253GB 339GB 85.9GB ext4 home2 339GB 382GB 42.9GB ext4 root5 382GB 441GB 59.1GB ntfs Basic data partition msftdata6 441GB 512GB 70.8GB ntfs Basic data partition msftdata
Boot0019* USB CD: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,86701296aa5a7848b66cd49dd3ba6a55)# df -h
Filesystem Size Used Avail Use% Mounted on
dev 5.8G 0 5.8G 0% /dev
run 5.8G 9.6M 5.8G 1% /run
/dev/mapper/ventoy 1.9G 1.9G 0 100% /run/archiso/bootmnt
cowspace 10G 3.6M 10G 1% /run/archiso/cowspace
/dev/loop0 1.7G 1.7G 0 100% /run/archiso/airootfs
airootfs 10G 3.6M 10G 1% /
tmpfs 5.8G 0 5.8G 0% /dev/shm
tmpfs 5.8G 24K 5.8G 1% /tmp
tmpfs 1.2G 84K 1.2G 1% /run/user/1000
/dev/nvme0n1p4 79G 33G 42G 44% /run/media/liveuser/a3a2ba69-8213-4723-ba8d-b4b8470dd7eb
/dev/nvme0n1p6 66G 33G 34G 50% /run/media/liveuser/D
/dev/nvme0n1p5 55G 28G 28G 51% /run/media/liveuser/C
/dev/nvme0n1p3 232G 179G 41G 82% /run/media/liveuser/a
/dev/nvme0n1p2 40G 18G 20G 49% /run/media/liveuser/ff0d5e61-82bc-425b-b4dd-2fed5ad072bc# mount /dev/nvme0n1p2 /mnt # 挂载系统根分区到 /mnt
# mount /dev/nvme0n1p1 /mnt/boot/efi # 挂载 efi 分区到 /mnt/boot/efi# arch-chroot /mnt # 不是很懂,大概就是把这个挂载点认为是根分区
# grub-install --target=x86_64-efi --efi-directory=/boot/efi --bootloader-id=EnOS # 将 grub 安装为 bootloader
Installing for x86_64-efi platform.
Installation finished. No error reported.
# grub-mkconfig -o /boot/grub/grub.cfg # 生成配置文件
Generating grub configuration file ...
Found background: /usr/share/endeavouros/splash.png
Found linux image: /boot/vmlinuz-linux-lts
Found initrd image: /boot/amd-ucode.img /boot/initramfs-linux-lts.img
Found fallback initrd image(s) in /boot: amd-ucode.img initramfs-linux-lts-fallback.img
Found linux image: /boot/vmlinuz-linux
Found initrd image: /boot/amd-ucode.img /boot/initramfs-linux.img
Found fallback initrd image(s) in /boot: amd-ucode.img initramfs-linux-fallback.img
Warning: os-prober will be executed to detect other bootable partitions.
Its output will be used to detect bootable binaries on them and create new boot entries.
ERROR: mkdir /var/lock/dmraid
Adding boot menu entry for UEFI Firmware Settings ...
done# lsblk -fs
NAME FSTYPE FSVER LABEL UUID FSAVAIL FSUSE% MOUNTPOINTS
loop0
sda2
└─sda
ventoy
└─sda1 └─sda
nvme0n1p1 152.2M 41% /boot/efi
└─nvme0n1
nvme0n1p2 19.2G 46% /
└─nvme0n1
nvme0n1p3
└─nvme0n1
nvme0n1p4
└─nvme0n1
nvme0n1p5
└─nvme0n1
nvme0n1p6
└─nvme0n1# efibootmgr # 有 en 并且是第一启动项
BootCurrent: 0017
Timeout: 0 seconds
BootOrder: 0001,0000,0013,0014,0015,0016,0017,0018,0019
Boot0000* Windows Boot Manager HD(1,GPT,171ffb3e-6c37-4801-8b11-3ba3cea2e27a,0x800,0x82000)/File(\EFI\Microsoft\Boot\bootmgfw.efi)57494e444f5753000100000088000000780000004200430044004f0042004a004500430054003d007b00390064006500610038003600320063002d0035006300640064002d0034006500370030002d0061006300630031002d006600330032006200330034003400640034003700390035007d00000000000100000010000000040000007fff0400
Boot0001* EnOS HD(1,GPT,171ffb3e-6c37-4801-8b11-3ba3cea2e27a,0x800,0x82000)/File(\EFI\EnOS\grubx64.efi)
Boot0010 Setup FvFile(721c8b66-426c-4e86-8e99-3457c46ab0b9)
Boot0011 Boot Menu FvFile(86488440-41bb-42c7-93ac-450fbf7766bf)
Boot0012 UEFI Diagnostics FvFile(f8397897-e203-4a62-b977-9e7e5d94d91b)
Boot0013* NVMe: WDC PC SN730 SDBPNTY-512G-1101 PciRoot(0x0)/Pci(0x2,0x4)/Pci(0x0,0x0)/NVMe(0x1,00-1B-44-8B-46-3A-AB-8F){99191c00-d932-4e4c-ae9a-a0b6e98eb8a4}
Boot0014* ATA HDD: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,91af625956449f41a7b91f4f892ab0f600)
Boot0015* ATA HDD1: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,91af625956449f41a7b91f4f892ab0f601)
Boot0016* ATAPI CD: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,aea2090adfde214e8b3a5e471856a354)
Boot0017* USB HDD: SMI USB DISK PciRoot(0x0)/Pci(0x8,0x1)/Pci(0x0,0x3)/USB(5,0){aa21e833-33af-47bc-89bd-419f88c50803}
Boot0018* USB FDD: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,6ff015a28830b543a8b8641009461e49)
Boot0019* USB CD: VenMsg(bc7838d2-0f82-4d60-8316-c068ee79d25b,86701296aa5a7848b66cd49dd3ba6a55)# cat /etc/fstab
# <file system> <mount point> <type> <options> <dump> <pass>
UUID=92C4-DD2F /boot/efi vfat defaults,noatime 0 2
UUID=a3a2ba69-8213-4723-ba8d-b4b8470dd7eb /home ext4 defaults,noatime 0 2
UUID=ff0d5e61-82bc-425b-b4dd-2fed5ad072bc / ext4 defaults,noatime 0 1
最后成功进入了原来的 manjaro,又重新生成了一次 grub,这次就找到了 win11。
os 探测 与 log 修改
现在启动会进入 en,但是没有 win11了,还有连线狗头图标。
启动之后不行,进入了 win11 并开始了 windows 的自动修复。。。晒晒我的 grub 配置()
$ sudo nano /etc/default/grubGRUB_DEFAULT=0
GRUB_TIMEOUT=1
GRUB_TIMEOUT_STYLE=hidden
GRUB_DISTRIBUTOR="EndeavourOS"
#GRUB_CMDLINE_LINUX_DEFAULT="loglevel=3 nowatchdog nvme_load=YES"
GRUB_CMDLINE_LINUX_DEFAULT="quiet splash"
GRUB_CMDLINE_LINUX=""
GRUB_DISABLE_OS_PROBER=false # 加上这一句$ sudo grub-mkconfig -o /boot/grub/grub.cfg # 从新生成配置
修改开机 logo: Customize Lenovo PC boot logo (screen) without installing “Lenovo PC Manager”.,不需要装管家,tnnd 管家卸载了背景就重置了
Q&A
怎么确定分区的 uuid 和 efibootmgr 中一致?
删除 efi 下的旧配置是否安全?
我这里有如下几个,endeavouros 是修复之前的,修复之后应该只用 EnOS了,Lenovo这个是修改 OEM log用的,Manjaro 是卸载残留。
$ ls /boot/efi/EFI/ Boot endeavouros EnOS Lenovo Manjaro Microsoft
参考
Chroot
[Succeed]rEFind安装之在Deepin上的一番折腾怀疑联想Could not prepare Boot variable: No space left on device. Kearney. 2021-02-19
windwos11 更新 BIOS 覆盖了 endevaourOS linux 的启动引导 grub 重建修复相关推荐
- Linux的启动引导讲解
一.前言 "不畏浮云遮望眼,自缘身在最高层" "不以规矩,无以成方园" "采得百花成蜜后,为谁辛苦为谁甜" "仓廪实则知礼节,衣食 ...
- linux开机启动遇到grub启动_Linux如何跳过grub启动
1 一:LINUX启动方法: 第一步:(如果知道linux具体在哪个分区,则可以略过第一步) 查找/boot/grub/grub.conf分区所在的目录: 输入以下命令: grub> find ...
- Linux启动阶段Grub损坏修复
文章目录 一.GRUB试验(试验环境:VMware-Centos6-基于分区) (试验一)破坏GRUB第1阶段,系统无法正常启动,修复之! 总结步骤: 试验步骤如下: (实验二)破坏GRUB第2阶段, ...
- HP Proliant DL388 Gen9 服务器 BIOS 设置丢失,win2008 r2启动引导文件修复
HP Proliant DL388 Gen9 服务器 因电源断电发生故障 服务器的启动界面一直是上图的模样,不断在重启中... 排查后,发现win2008 r2系统引导丢失.HP服务器BIOS设置丢失 ...
- linux 11Gasm启动crs,11GR2重建CRS
1.停止crs [root@node1 ~]# /u01/app/grid/11.2.0/bin/crsctl stop crs -f [root@node2 ~]# /u01/app/grid/11 ...
- Linux启动故障排查和修复技巧
一个执着于技术的公众号 我发现Linux系统在启动过程中会出现一些故障,导致系统无法正常启动,我在这里写了几个应对单用户模式.GRUB命令操作.Linux救援模式的故障修复案例帮助大家了解此类问题的解 ...
- 计算机从加电到系统(Linux)启动完成
0x0 背景 在我参加的面试和我面试别人.或者参加别人对别人的面试的事后经常遇到的一个问题就是:请从计算机加电开始描述一下计算机启动到操作系统正式启动起来的全过程.这是一个考验对计算机体系结构和基本知 ...
- 双linux grub rescue,Grub Rescue修复方法
症状: 开机显示:GRUB loading error:unknow filesystem grub rescue> 原因: 已经发现下面几种操作会导致这种问题: 1,想删除ubuntu,于是直 ...
- 卸载linux grub rescue,Grub Rescue 修复方法
症状: 开机显示:GRUB loading error:unknow filesystem grub rescue> 原因: 由于操作者不知道grub2分为两部分,一部分(一般情况下)写在了mb ...
最新文章
- (C++)202012-2 期末预测之最佳阈值 满分
- try catch语句 java_深入剖析java的try…catch…finally语句
- equals 与==的不同
- Python学习笔记(五) Python高级特性
- 学习并整理windows下编译nginx的步骤
- rails中weill_paginate的paginate方法中不能使用额外参数的解决办法
- 【ArcGIS风暴】ArcGIS 10.2栅格计算器实用公式大全(经典珍藏版)
- ds18b20c语言显示小数位,DS18B20多点测温(读序列,匹配序列,51单片机C程序,1602显示)...
- android uri db,Android ContentProvider封装数据库和文件读写总结
- 【树】Unique Binary Search Trees II
- 企业仓库管理软件免费版要把处理好三个问题 利用凌云仓库管理软件免费版的智能补货功能可以快速的指定采购策略,这里面就需要及时了解每一张采购订单的执行情况,不但要防止遗漏订单情况的发生,更要防止情绪化采购
- PCB布局布线注意事项
- WinDbg 符号下载错误解决方案
- 华视电子vue身份证读取
- 无感FOC滑膜观测器学习
- (二)进程管理之进程状态及组织方式
- 逻辑综合重点解析(Design Compiler篇)
- 511遇见易语言乐玩插件FindPicEx找图扩展找多图
- Cesium鼠标事件汇总
- 如何修改知乎绑定的手机号(2021)