Shell中手动加载grub bootaa64.efi
2024.05.04
Shell> map
Mapping table
FS1: Alias(s):HD1b:;BLK4:
VenHw(100C2CFA-B586-4198-9B4C-1683D195B1DA)/HD(1,GPT,809A75D3-E97F-4F9
F-9E15-C4EB053E8AB3,0x800,0x32000)
FS0: Alias(s):HD0b:;BLK1:
PcieRoot(0x0)/Pci(0x0,0x0)/Pci(0x0,0x0)/NVMe(0x1,32-03-00-00-00-00-00-
00)/HD(1,GPT,9DD431F3-1E15-584E-987D-827DD40C2E49,0xF000,0x200000)
BLK3: Alias(s):
VenHw(100C2CFA-B586-4198-9B4C-1683D195B1DA)
BLK5: Alias(s):
VenHw(100C2CFA-B586-4198-9B4C-1683D195B1DA)/HD(2,GPT,836136C3-A854-4F1
2-8FCD-3F5BCE5C9F24,0x32800,0x8000)
BLK6: Alias(s):
VenHw(100C2CFA-B586-4198-9B4C-1683D195B1DA)/HD(3,GPT,8B6032D1-3641-44F
6-B489-C48D195AC17E,0x3A800,0xE543000)
BLK7: Alias(s):
VenHw(100C2CFA-B586-4198-9B4C-1683D195B1DA)/HD(4,GPT,96CA6224-A52D-464
1-A947-AA3CCBA8DC8C,0xE57D800,0xFA000)
BLK0: Alias(s):
PcieRoot(0x0)/Pci(0x0,0x0)/Pci(0x0,0x0)/NVMe(0x1,32-03-00-00-00-00-00-
00)
BLK2: Alias(s):
PcieRoot(0x0)/Pci(0x0,0x0)/Pci(0x0,0x0)/NVMe(0x1,32-03-00-00-00-00-00-
00)/HD(2,GPT,8DEE4DA3-BB01-D348-8C62-188B9C031AC1,0x20F000,0x389AB019)
Shell> fs0:
FSOpen: Open '\' Success
FS0:\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '\grub' Success
FSOpen: Open '\Image' Success
FSOpen: Open '\System.map-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\config-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\initrd.img-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\vmlinuz-5.10.110-rockchip-rk3588' Success
GDDBG get base: FEAA0000
Directory of: FS0:\
01/09/2024 02:45 209,823 config-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
12/04/2023 07:24 <DIR> 4,096 EFI
GDDBG get base: FEAA0000
01/09/2024 03:10 <DIR> 4,096 grub
GDDBG get base: FEAA0000
01/09/2024 03:09 56,613,376 Image
GDDBG get base: FEAA0000
01/09/2024 03:12 9,159,168 initrd.img-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 8,108,572 System.map-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 21,284,899 vmlinuz-5.10.110-rockchip-rk3588
5 File(s) 95,375,838 bytes
2 Dir(s)
FSOpen: Open '\' Success
FS0:\> cd EFFSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
EFI
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FS0:\EFI\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\' Success
FSOpen: Open '\' Success
FSOpen: Open '\EFI\BOOT' Success
GDDBG get base: FEAA0000
Directory of: FS0:\EFI\
01/09/2024 03:11 <DIR> 4,096 .
GDDBG get base: FEAA0000
01/09/2024 03:11 <DIR> 0 ..
GDDBG get base: FEAA0000
12/04/2023 07:24 <DIR> 4,096 BOOT
0 File(s) 0 bytes
3 Dir(s)
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FS0:\EFI\> cd BOOT
FSOpen: Open '\EFI\BOOT' Success
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FS0:\EFI\BOOT\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT\' Success
FSOpen: Open '\EFI\' Success
FSOpen: Open '\EFI\BOOT\bootaa64.efi' Success
GDDBG get base: FEAA0000
Directory of: FS0:\EFI\BOOT\
01/09/2024 03:11 <DIR> 4,096 .
GDDBG get base: FEAA0000
01/09/2024 03:11 <DIR> 4,096 ..
GDDBG get base: FEAA0000
01/09/2024 03:09 679,936 bootaa64.efi
1 File(s) 679,936 bytes
2 Dir(s)
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FS0:\EFI\BOOT\> cd ..
FSOpen: Open '\EFI\' Success
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FS0:\EFI\> cd ..
FSOpen: Open '\' Success
FSOpen: Open '\' Success
FS0:\> cd ..
FSOpen: Open '\' Success
FSOpen: Open '\' Success
FS0:\> tree .
'tree' is not recognized as an internal or external command, operable program, o
r script file.
FSOpen: Open '\' Success
FS0:\> help
acpiview - Display ACPI Table information.
alias - Displays, creates, or deletes UEFI Shell aliases.
attrib - Displays or modifies the attributes of files or directories.
bcfg - Manages the boot and driver options that are stored in NVRAM.
cd - Displays or changes the current directory.
cls - Clears the console output and optionally changes the background
and foreground color.
comp - Compares the contents of two files on a byte-for-byte basis.
connect - Binds a driver to a specific device and starts the driver.
cp - Copies one or more files or directories to another location.
date - Displays and sets the current date for the system.
dblk - Displays one or more blocks from a block device.
devices - Displays the list of devices managed by UEFI drivers.
devtree - Displays the UEFI Driver Model compliant device tree.
dh - Displays the device handles in the UEFI environment.
disconnect - Disconnects one or more drivers from the specified devices.
dmem - Displays the contents of system or device memory.
dmpstore - Manages all UEFI variables.
drivers - Displays the UEFI driver list.
drvcfg - Invokes the driver configuration.
drvdiag - Invokes the Driver Diagnostics Protocol.
echo - Controls script file command echoing or displays a message.
edit - Provides a full screen text editor for ASCII or UCS-2 files.
eficompress - Compresses a file using UEFI Compression Algorithm.
efidecompress - Decompresses a file using UEFI Decompression Algorithm.
else - Identifies the code executed when 'if' is FALSE.
endfor - Ends a 'for' loop.
endif - Ends the block of a script controlled by an 'if' statement.
exit - Exits the UEFI Shell or the current script.
for - Starts a loop based on 'for' syntax.
getmtc - Gets the MTC from BootServices and displays it.
goto - Moves around the point of execution in a script.
help - Displays the UEFI Shell command list or verbose command help.
hexedit - Provides a full screen hex editor for files, block devices, or m
emory.
i2cdemo - Read/write data from/into I2cDemo Device memory
if - Executes commands in specified conditions.
ifconfig - Modifies the default IP address of the UEFI IPv4 Network Stack.
load - Loads a UEFI driver into memory.
loadpcirom - Loads a PCI Option ROM.
ls - Lists the contents of a directory or file information.
map - Displays or defines file system mappings.
memmap - Displays the memory map maintained by the UEFI environment.
mkdir - Creates one or more new directories.
mm - Displays or modifies MEM/MMIO/IO/PCI/PCIE address space.
mode - Displays or changes the console output device mode.
mv - Moves one or more files to a destination within or between file
systems.
openinfo - Displays the protocols and agents associated with a handle.
parse - Retrieves a value from a standard format output file.
pause - Pauses a script and waits for an operator to press a key.
pci - Displays PCI device list or PCI function configuration space and
PCIe extended
configuration space.
ping - Ping the target host with an IPv4 stack.
reconnect - Reconnects drivers to the specific device.
reset - Resets the system.
rm - Deletes one or more files or directories.
sermode - Sets serial port attributes.
set - Displays or modifies UEFI Shell environment variables.
setsize - Adjusts the size of a file.
setvar - Displays or modifies a UEFI variable.
sf - Read/write data from/into SPI flash.
shift - Shifts in-script parameter positions.
smbiosview - Displays SMBIOS information.
stall - Stalls the operation for a specified number of microseconds.
time - Displays or sets the current time for the system.
timezone - Displays or sets time zone information.
touch - Updates the filename timestamp with the current system date and
time.
type - Sends the contents of a file to the standard output device.
unload - Unloads a driver image that was already loaded.
ver - Displays UEFI Firmware version information.
vol - Displays or modifies information about a disk volume.
Help usage:help [cmd|pattern|special] [-usage] [-verbose] [-section name][-b]
FSOpen: Open '\' Success
FS0:\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '\grub' Success
FSOpen: Open '\Image' Success
FSOpen: Open '\System.map-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\config-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\initrd.img-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\vmlinuz-5.10.110-rockchip-rk3588' Success
GDDBG get base: FEAA0000
Directory of: FS0:\
01/09/2024 02:45 209,823 config-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
12/04/2023 07:24 <DIR> 4,096 EFI
GDDBG get base: FEAA0000
01/09/2024 03:10 <DIR> 4,096 grub
GDDBG get base: FEAA0000
01/09/2024 03:09 56,613,376 Image
GDDBG get base: FEAA0000
01/09/2024 03:12 9,159,168 initrd.img-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 8,108,572 System.map-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 21,284,899 vmlinuz-5.10.110-rockchip-rk3588
5 File(s) 95,375,838 bytes
2 Dir(s)
FSOpen: Open '\' Success
FS0:\> cd gruFSOpen: Open '.' Success
FSOpen: Open '\grub' Success
grub
FSOpen: Open '\grub' Success
FSOpen: Open '.' Success
FSOpen: Open '\grub' Success
FS0:\grub\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\grub' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\grub\' Success
FSOpen: Open '\' Success
FSOpen: Open '\grub\grub.cfg' Success
GDDBG get base: FEAA0000
Directory of: FS0:\grub\
01/09/2024 03:11 <DIR> 4,096 .
GDDBG get base: FEAA0000
01/09/2024 03:11 <DIR> 0 ..
GDDBG get base: FEAA0000
01/09/2024 03:10 382 grub.cfg
1 File(s) 382 bytes
2 Dir(s)
FSOpen: Open '.' Success
FSOpen: Open '\grub' Success
FS0:\grub\> cat grub.cfg
FSOpen: Open '.' Success
FSOpen: Open '\grub' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\grub\grub.cfg' Success
set debug="loader,mm"
set term="vt100"
set default="0"
set timeout="1"
search --set=root --fs-uuid 91F3-6896
menuentry 'Boot YourLand from NVME' {
linux /Image resume=UUID=8550cf7b-fb7e-475d-b7ca-e0140b91284c root=PARTU
UID=8dee4da3-bb01-d348-8c62-188b9c031ac1 noresume psi=1 splash label=debug rootw
ait verbose debug nokaslr
.initrd /initrd.img-5.10.110-rockchip-rk3588
}
FSOpen: Open '.' Success
FSOpen: Open '\grub' Success
FS0:\grub\> cd ..
FSOpen: Open '\' Success
FSOpen: Open '\' Success
FS0:\> cd ..
FSOpen: Open '\' Success
FSOpen: Open '\' Success
FS0:\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '\grub' Success
FSOpen: Open '\Image' Success
FSOpen: Open '\System.map-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\config-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\initrd.img-5.10.110-rockchip-rk3588' Success
FSOpen: Open '\vmlinuz-5.10.110-rockchip-rk3588' Success
GDDBG get base: FEAA0000
Directory of: FS0:\
01/09/2024 02:45 209,823 config-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
12/04/2023 07:24 <DIR> 4,096 EFI
GDDBG get base: FEAA0000
01/09/2024 03:10 <DIR> 4,096 grub
GDDBG get base: FEAA0000
01/09/2024 03:09 56,613,376 Image
GDDBG get base: FEAA0000
01/09/2024 03:12 9,159,168 initrd.img-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 8,108,572 System.map-5.10.110-rockchip-rk3588
GDDBG get base: FEAA0000
01/09/2024 02:45 21,284,899 vmlinuz-5.10.110-rockchip-rk3588
5 File(s) 95,375,838 bytes
2 Dir(s)
FSOpen: Open '\' Success
FS0:\> cd EFFSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
EFI
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FS0:\EFI\> LS
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\' Success
FSOpen: Open '\' Success
FSOpen: Open '\EFI\BOOT' Success
GDDBG get base: FEAA0000
Directory of: FS0:\EFI\
01/09/2024 03:11 <DIR> 4,096 .
GDDBG get base: FEAA0000
01/09/2024 03:11 <DIR> 0 ..
GDDBG get base: FEAA0000
12/04/2023 07:24 <DIR> 4,096 BOOT
0 File(s) 0 bytes
3 Dir(s)
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FS0:\EFI\> cd boot
FSOpen: Open '\EFI\boot' Success
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FS0:\EFI\boot\> ls
GDDBG get base: FEAA0000
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT\' Success
FSOpen: Open '\EFI\' Success
FSOpen: Open '\EFI\BOOT\bootaa64.efi' Success
GDDBG get base: FEAA0000
Directory of: FS0:\EFI\boot\
01/09/2024 03:11 <DIR> 4,096 .
GDDBG get base: FEAA0000
01/09/2024 03:11 <DIR> 4,096 ..
GDDBG get base: FEAA0000
01/09/2024 03:09 679,936 bootaa64.efi
1 File(s) 679,936 bytes
2 Dir(s)
FSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FS0:\EFI\boot\> ./bootFSOpen: Open '.' Success
FSOpen: Open '\EFI' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '\EFI\BOOT' Success
FSOpen: Open '.' Success
FSOpen: Open '..' Success
FSOpen: Open '..' Success
bootaa64.efi
FSOpen: Open '\EFI\boot\bootaa64.efi' Success
FSOpen: Open '\EFI\boot\bootaa64.efi' Success
FSOpen: Open '\EFI\boot\bootaa64.efi' Success
FSOpen: Open '\EFI\boot\bootaa64.efi' Success
[Security] 3rd party image[0] can be loaded after EndOfDxe: PcieRoot(0x0)/Pci(0x0,0x0)/Pci(0x0,0x0)/NVMe(0x1,32-03-00-00-00-00-00-00)/HD(1,GPT,9DD431F3-1E15-584E-987D-827DD40C2E49,0xF000,0x200000)/\EFI\boot\bootaa64.efi.
Loading driver at 0x000E9DCE000 EntryPoint=0x000E9DCF000
Loading driver at 0x000E9DCE000 EntryPoint=0x000E9DCF000
Welcome to GRUB!
GNU GRUB version 2.04
/----------------------------------------------------------------------------\
|*Boot YourLand from NVME |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
\----------------------------------------------------------------------------/
Use the ^ and v keys to select which entry is highlighted.
Press enter to boot the selected OS, `e' to edit the commands
before booting or `c' for a command-line.
https://www.gnu.org/software/grub/manual/grub-dev/html_node/Debugging.html
GRUB2 can be difficult to debug because it runs on the bare-metal and thus does not have the debugging facilities normally provided by an operating system.
调试对GRUB2来说,已经是自然而然的事。
[Security] 3rd party image[0] can be loaded after EndOfDxe: PcieRoot(0x0)/Pci(0x0,0x0)/Pci(0x0,0x0)/NVMe(0x1,32-03-00-00-00-00-00-00)/HD(1,GPT,9DD431F3-1E15-584E-987D-827DD40C2E49,0xF000,0x200000)/\EFI\boot\bootaa64.efi.
Loading driver at 0x000E9DCE000 EntryPoint=0x000E9DCF000
因为GRUB2,对于UEFI来说,也就是个被加载的Module,NDB真的已经很赞,可以期待更美好。
作者:朱博渊 创建时间:2024-05-04 15:35
最后编辑:朱博渊 更新时间:2025-01-20 10:44
最后编辑:朱博渊 更新时间:2025-01-20 10:44