|
本帖最后由 極限驅動 于 2014-10-12 22:22 编辑
都知道Grub2的安装和定制大多都要在Linux环境下进行,但是很多地方都没怎么提到Windows下能否定制以及具体细节
在以前看到这个帖子
http://bbs.wuyou.net/forum.php?mod=viewthread&tid=334058
知道在Windows下是可以安装Grub2,但是没提到定制
这是有关Grub2定制的,但是却是在Ubuntu的环境下定制,实际上在Windows系统下的一旦需要定制或是修改就安装Ubuntu,有点不方便
http://bbs.wuyou.net/forum.php?mod=viewthread&tid=310626
這是也是有關Grub2定制的,不過同樣也是Ubuntu的环境下定制
http://forum.ubuntu.org.cn/viewtopic.php?t=324418
后面就自己琢磨这着怎么定制。还好吧,Ubuntu环境和Windows环境下的定制命令几乎没差别,所以命令基本可以参照。
首先,下载Grub2和bootice基本就只用到这两个小东东
Windows下的Grub2 版本是2.02 Beta2
http://alpha.gnu.org/gnu/grub/grub-2.02~beta2-for-windows.zip
【BOOTICE: 启动维护工具】用于安装Grub2
http://bbs.wuyou.net/forum.php?mod=viewthread&tid=57675
下载Windows下的Grub2包,放在哪裡無所謂,为了简洁点我就直接解压到C盘,解压后我的路径是C:\grub-2.02~beta2-for-windows 解壓後在能看到
其中,方便點較為重要的我都用鼠標選中了,下面我簡單解釋下
i386-pc文件夾是BIOS模式的所需要的
i386-efi文件夾是UEFI模式的32Bit
x86_64-efi文件夾是UEFI模式的64Bit
unicode.pf2是Grub2的字體,支持简体、繁體漢字
grub-mkimage.exe自然就是grub-mkimage命令,用於定制Grub2
locale文件夾是語言文件,打開後看裏面文件夾名稱,就能知道有很多由各種語言簡稱命名的文件夾,不過每個文件夾裏面都是相同的名稱grub.mo,後面要自己改壹下,基本只要zh_CN、zh_TW這兩個文件夾
分別把裏面的grub.mo改成和文件夾相對應的名稱
zh_CN文件夾裏面的grub.mo改名為zh_CN.mo
zh_TW文件夾裏面的grub.mo改名為zh_TW.mo
基本就只用到grub-mkimage命令来定制,至于更深层次的,我就没怎么了解,在Windows下可以通过命令 -?或 --help 來獲取其他參數。
需要同時支持BIOS和UEFI模式,然後把Grub2安裝到U盤,(這個U盤只有壹個分區)這是定制目的,下面就開始重點了。
(支持BIOS和UEFI、定制路徑)
先在U盤根目錄基礎上建立些文件夾,先看下面:
EFI>Boot
Grub2>BIOS
Grub2>UEFI_i386-efi
Grub2>UEFI_x86_64-efi
在根目錄建立EFI目的是為了支持UEFI啟動,裏面再建立Boot目錄,用於放置EFI啟動文件,32Bit默認啟動文件名為Bootia32.EFI、64Bit默認啟動文件名為Bootx64.EFI
同樣也在根目錄建立個Grub2文件夾,裏面再分別建立BIOS、UEFI_i386-efi、UEFI_x86_64-efi這叁個目錄,分別用於支持啟動BIOS模式、32Bit的UEFI模式、64Bit的UEFI模式。
以BIOS目錄為例子,不過先看看完成BIOS目錄裏面的結構(這裡標識加粗的文字表示裏面的Fonts目錄、Locale目錄可以直接複製到UEFI_i386-efi文件夾、UEFI_x86_64-efi文件夾):
Grub2>BIOS>I386-PC
Grub2>BIOS>Fonts>unicode.pf2
Grub2>BIOS>Locale>zh_CN.mo
Grub2>BIOS>Locale>zh_TW.mo
下面就來開始手動建立
①
找到解壓到C盤的Grub2包,把裏面的i386-pc文件夾整個複製到這個BIOS目錄中(裏面有很多模塊)
這樣就完成了這第壹步
Grub2>BIOS>I386-PC
把Grub2包裏的i386-efi文件夾複製到UEFI_i386-efi文件夾
把Grub2包裏的x86_64-efi文件夾複製到UEFI_x86_64-efi文件夾
自然就完成
Grub2>UEFI_i386-efi>i386-efi
Grub2>UEFI_x86_64-efi>x86_64-efi
②
BIOS目錄中建立Fonts文件夾,然後把unicode.pf2字體複製到Fonts文件夾裏面
第貳步也完成了
Grub2>BIOS>Fonts>unicode.pf2
③
BIOS目錄中建立Locale文件夾,然後把Grub2其中的語言文件zh_CN.mo、zh_TW.mo複製到Locale文件夾中(在上面有提到Grub2的locale文件夾裏面的zh_CN文件夾、zh_TW文件夾以及zh_CN.mo、zh_TW.mo)
第叁部也完成了
Grub2>BIOS>Locale>zh_CN.mo
Grub2>BIOS>Locale>zh_TW.mo
這叁步就完成了Grub2的路徑定制
④
最後就是用grub-mkimage命令定制
這裡我再詳細點
BIOS模式定制的是內核文件Core.img,後面會用到啟動文件Boot.img,用這兩個文件以二進制合并成G2ldr
UEFI模式定制的是EFI啟動文件,有點不同的是UEFI是分64Bit啟動文件和32Bit啟動文件
同樣的,這裡我先直接給出定制的命令(基本可以照搬),後面我再解釋
BIOS模式定制:
注意了,BIOS模式對應的是MBR分區表,那麼啟動扇區的扇區數量為63
因為啟動扇區數量為63,有時定制BIOS模式時定制的模塊可以不要太多,基本上取biosdisk part_msdos fat exfat ntfs這些模塊就可以了,還有下面給出的定制命令,其實也能直接用的,原因後面再講
grub-mkimage.exe -d I386-PC -p (hd0,1)/Grub2/BIOS -o Core.img -O i386-pc biosdisk part_msdos fat exfat ext2 ntfs normal iso9660 search_fs_file
UEFI模式的32Bit定制:
grub-mkimage.exe -d i386-efi -p (hd0,1)/Grub2/UEFI_i386-efi -o I386-EFI.EFI -O i386-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
UEFI模式的64Bit定制:
grub-mkimage.exe -d x86_64-efi -p (hd0,1)/Grub2/UEFI_x86_64-efi -o X86_64-EFI.EFI -O x86_64-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
grub-mkimage命令參數解釋(注意,大小寫,不能搞混,以及路徑用的是正斜杠 / ):
-d 表示在定制的模式時需要用到的文件所在的路徑,壹般不用給完整路徑,直接給出和模式對應的文件夾名稱就行了,在定制時會默認的路徑,在Windows下,我的Grub2包放在C盤,那麼路徑是C:\grub-2.02~beta2-for-windows,模式對應的路徑默認自然就是C:\grub-2.02~beta2-for-windows\i386-pc
-p 定制後對應的路徑,因為涉及Grub2的prefix变量值以及Grub2啟動路勁,所以這裡才是基本完成路徑定制,不過還有些問題我後面再講
-o (這裡是小o) 表示定制後輸出的文件名稱以及路徑,壹般只寫文件名稱就行,在Windows下,會直接輸出到Grub2包所在的路徑中
-O (這裡是大O)表示定制模式,後面接的自然就是包含的模塊,可以自己在模式對應的目錄裏面查找并選需要的模塊
最後,就可以打開Windows下的命令行,開始執行定制命令了,不過命令行的路徑壹般的默認路徑大多是C:\Windows\System32,還不能直接執行定制命令。
要轉到Grub2包的路徑中,我的在C盤,執行如下命令:
cd /d c:\grub-2.02~beta2-for-windows
轉後如如下:
現在可以開始執行定制的命令了,先把BIOS模式定制的命令照搬
grub-mkimage.exe -d I386-PC -p (hd0,1)/Grub2/BIOS -o Core.img -O i386-pc biosdisk part_msdos fat exfat ext2 ntfs normal iso9660 search_fs_file
命令執行完後,會在我的C:\grub-2.02~beta2-for-windows路徑中生成個Core.img,文件 86.5 KB大小,後面會詳細講下這個文件
當然,如果是UEFI模式定制,就簡單了,定制命令直接照搬,直接生成EFI啟動文件就徹底完成了。
在執行完定制UEFI模式的32Bit和64Bit命令後,會看到於Grub2包裏面的I386-EFI.EFI和X86_64-EFI.EFI兩個EFI啟動文件,大小無所謂
I386-EFI.EFI 更名為Bootia32.EFI
X86_64-EFI.EFI更名為Bootx64.EFI
注意:默認下UEFI模式是按照EFI啟動文件的名稱來引導啟動的,32Bit默認引導Bootia32.EFI、64Bit默認引導Bootx64.EFI
更名完後直接放置到前面提到的用於EFI啟動的目錄
EFI>Boot
放置完,UEFI模式的定制就徹底完成。BIOS模式還有個步驟要完成
⑤
在這裡就主要講BIOS模式的最後壹步
在④步驟中,已經生成BIOS模式所需的內核文件Core.img,其大小是86.5 KB
生成的只是單單BIOS模式的內核文件,還無法引導Grub2,還需要個啟動文件Boot.img,該文件很小,只有512Byte,位於i386-pc文件夾,該文件的作用是啟動Grub2,然後加載內核文件Core.img
所以這裡的最後壹步就是把啟動文件Boot.img和內核文件Core.img以二進制形式合并,合并後的文件我個人稱呼為扇區文件G2ldr(不知道這個文件有沒標準的名稱),因為可以直接導入到扇區,來引導啟動Grub2,也可以由GRUB4DOS直接加載這個扇區文件來啟動Grub2。
老樣子,先給出命令(如果命令行的路徑不是Grub2包所在的路徑,就先要修改命令行的路徑,前面有提到)
Copy /B i386-pc\Boot.img+Core.img G2ldr
Copy是Windows下的複製命令,自帶了個二進制的參數 /B ,加上去就表示二進制,文件在命令行中已經轉入到Grub2包所在的路徑,啟動文件Boot.img位於Grub2包裏的i386-pc文件夾,加上前面生成的內核文件Core.img,在後面只有壹個名稱G2ldr,表示兩個文件以二進制形式合并,其實名稱不一定非要取名G2ldr喜歡可以自己改。
注意:合并時必須以二進制方式,并且時啟動文件Boot.img必須放在內核文件Core.img前面才能進行合并,也就是說內核文件Core.img壹但放在啟動文件Boot.img前面,就會出現無法引導Grub2的情況,為了防止錯物的命令被複製,我就上圖了
合并後能看到扇區文件G2ldr,大小是87.0 KB
合并完了也就基本完成BIOS模式的,這個文件能夠可以導入到扇區,也可以由GRUB4DOS加載啟動。
順便把定制出的內核文件Core.img複製到Grub2>BIOS>I386-PC這個文件夾裏面,扇區文件G2ldr複製到Grub2>BIOS文件夾中
那現在就來導入到扇區,前面提到過【BOOTICE: 启动维护工具】是用來安裝Grub2的,安裝方式我就上圖解說:
在目标磁盘選擇U盤,不要選錯了,然後選擇主引导记录(M)
在主引导记录介面選擇恢复MBR(R)
最後就可以選擇前面合并好的扇區文件G2ldr,請注意下打扇區文件G2ldr後的圖
看到沒有,在恢复扇区数:的數字框中可以看到扇區數量為175,徹底大於前面說的63,其實也無所謂了,在数字框中手動填入63就可以,Grub2還是可以啟動的
如果不修改為63,而是直接把175扇區數量寫入的話,Grub2會無法啟動,其他問題嘛(┬_┬)。。。。可能會把U盤的其他數據損壞
另外我這裡再給出個不超過63扇區的定制命令:
grub-mkimage.exe -d I386-PC -p (hd0,1)/Grub2/BIOS -o Core.img -O i386-pc biosdisk part_msdos fat exfat ntfs
內核文件Core.img,大小30.5 KB
合并后的扇区文件G2ldr,大小是31.0 KB
用bootice打開後會看到扇區大小剛好是63
这壹步完成后就基本完成了(BIOS和UEFI、自定義Grub2路徑)基本上就能啟動了。
不過還差個Grub.CFG文件,是個文本文件,改個後綴名就行了,編碼是UTF8,文件放置在和模式對應自定義的文件夾裏面,我這裡放置在Grub2>BIOS裏面,Grub.CFG文件配置大多都通用,只是注意路徑用的都是正斜杠 /
在論壇裏面有很多例子可以用,基本上只要拿過來後,只要自己修改路徑
BIOS模式的Grub.CFG文件配置
set pager=1
insmod all_video
insmod vbe
insmod vga
insmod video_bochs
insmod video_cirrus
insmod font
insmod gfxterm
insmod gfxmenu
insmod gettext
insmod jpeg
insmod png
#加载unicode字体显示中文
loadfont /Grub2/BIOS/Fonts/unicode.pf2
set locale_dir=/Grub2/BIOS/Locale
set lang=zh_CN
#设置分辨率
set gfxmode=auto
terminal_output gfxterm
#设置背景图片
background_image /
#倒计时
set timeout=300
#颜色
set color_normal=green/black
set color_highlight=white/cyan
UEFI模式的Grub.CFG文件配置(這個注意了,因為有32Bit和64Bit,對應的路徑需要自己改壹下)
set pager=1
insmod all_video
insmod video_bochs
insmod video_cirrus
insmod efi_gop
insmod efi_uga
insmod font
insmod gfxterm
insmod gfxmenu
insmod gettext
insmod jpeg
insmod png
#加载unicode字体显示中文
loadfont /Grub2/UEFI_i386-efi/Fonts/unicode.pf2
set locale_dir=/Grub2/UEFI_i386-efi/Locale
set lang=zh_CN
#设置分辨率
set gfxmode=auto
terminal_output gfxterm
#设置背景图片
#background_image /
#倒计时
set timeout=300
#颜色
set color_normal=green/black
set color_highlight=white/cyan
⑥
這裡最後我說壹下關於路徑的問題
目前GRUB4DOS和Grub2中(hdX,Y)表示第幾個硬碟第幾個分區
X表示第幾個硬碟
Y表示第幾個分區,不過
在GRUB4DOS中第壹塊硬碟的第壹分區的表示(hd0,0)
在Grub2裏第壹塊硬碟的第壹分區改變成(hd0,1)(我自己有點不明白為什麼要這樣改變,這個表達方式明明可以延續下來)
在Grub2啟動時是以Grub2自身為中心,來確定第幾個硬碟至於第幾個分區會按照分區是否隱藏來確定,所以在grub-mkimage命令定制時 -p 這個參數用(hd0,1)來表示U盤是第壹個硬碟上的壹個分區,如果有兩個分區,并且Grub2安裝到第貳個分區可以用(hd0,2)表示
U盤如果有特別結構帶多個分區的注意了
如果U盤做成啟動盤,并且有特別結構帶有多個分區,同時在隱藏和顯示分區之前來回切換U盤的分區時,在使用基於Qemu的啟動器來測試時會發現有時無法啟動Grub2,原因在於把U盤上哪個分區顯示出來哪個就是(hd0,1)有可能導致Grub2基本啟動後找不到相對應的路徑
如果說第壹個分區是正常使用的也就是平時看得到的,它是(hd0,1),第貳個分區是隱藏的,安裝了Grub2,它是(hd0,2),平時能夠正常啟動是因為Grub2所在的分區是隱藏的正常順序位於(hd0,2)
但是在修改時,把第壹分區隱藏了,把第貳分區顯示了,那它們之前的分區順序就反過來了,變成正常使用的是(hd0,2),安裝Grub2的的是(hd0,1),在用Qemu測試時自然就因為Grub2找不到自己的路徑從而無法正常啟動
決解方法是,在定制路徑時可以不要(hd0,1)、(hd0,2)。。。這些來表示位置,老樣子,直接給出定制命令:
BIOS模式定制:
grub-mkimage.exe -d I386-PC -p /Grub2/BIOS -o Core.img -O i386-pc biosdisk part_msdos fat exfat ext2 ntfs normal iso9660 search_fs_file
UEFI模式的32Bit定制:
grub-mkimage.exe -d i386-efi -p /Grub2/UEFI_i386-efi -o I386-EFI.EFI -O i386-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
UEFI模式的64Bit定制:
grub-mkimage.exe -d x86_64-efi -p /Grub2/UEFI_x86_64-efi -o X86_64-EFI.EFI -O x86_64-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
其實就是把路徑中的(hd0,1)這些去掉,讓Grub2啟動時模糊查找,自然就能正常啟動,不會受到U盤分區隱藏顯示的影響。
上面的东西就是我自己在Windows下完成的Grub2定制时发现的错误以及解决的,最後我自己是成功启动了,不过我自己没有UEFI环境,用的都是Qemu测试的,都成功启动了。
我自己也是搞了很久才成功的,上面有些地方講的方面可能有點多餘,也不清楚哪些地方出錯,如果知道的話,那麼各位請指出來。
希望上面東西對各位在Windows定制Grub2有幫助,不知道講的夠不夠詳細
小更新:
最後我要特別感謝Qemu启动器的作者:阿弥陀佛
能同時支持BIOS和UEFI 32Bit、64Bit,要是沒這個Qemu启动器,定制時的測試,真是的個大問題
[原创] 【14.7.31最后更新+源代码】Qemu启动测试器增强版,支持64位,支持EFI,linux内核调试
http://bbs.wuyou.net/forum.php?mod=viewthread&tid=335197
下面是我按照我這個帖子做的定制的Grub2
Grub2目錄中的扇區文件G2ldr,大小31.0 KB,扇區數量63
Grub2>BIOS目錄的扇區文件G2ldr,大小87.0 KB,扇區數量175
Grub2>BIOS>I386-PC目錄的內核文件Core.img,大小86.5 KB,和啟動文件Boot.img合并後就是Grub2>BIOS目錄的扇區文件G2ldr
我分割壓縮了,把下面的最後面的7Z後綴名去掉,就能一起解壓了
Windows定制Grub2(包括BIOS和UEFI、自定义Grub2路徑).7z.001.7Z
(1 MB, 下载次数: 3561)
Windows定制Grub2(包括BIOS和UEFI、自定义Grub2路徑).7z.002.7Z
(1 MB, 下载次数: 2533)
Windows定制Grub2(包括BIOS和UEFI、自定义Grub2路徑).7z.003.7Z
(305.19 KB, 下载次数: 2104)
2014年 10月2日 更新:(自定义Grub2路徑)
在前面的grub-mkimage定制命令有個參數 -p 是Grub2的prefix變量,可以用來定制自己設定的Grub2路徑,但是有時候在U盤上,會因為(hdx,y)不確定時發生無法啟動的問題,雖然在上面提到可以不加(hdx,y)來啟動U盤上的Grub2,但是這樣有時候安裝在硬碟上的設備卻會出現無法啟動的情況。這樣壹來Grub2在定制後,變得U盤能啟動,硬碟無法啟動,不那麼通用,需要修改重新定制,很不靈活。還好後面找到了解決辦法
[原创] Grub2启动盘的制作,支持BIOS和UEFI哦..... (帖子開頭有提到)
http://bbs.wuyou.net/forum.php?mod=viewthread&tid=310626
在重新查找資料時看到帖子中有提到壹個bootconfig.cfg的文件,它的參數 -c (小寫c),發現這個bootconfig.cfg文件可以很好解決上面的路徑問題。有點粗心,自己在摸索的時候不瞭解具體細節,到後面就被我徹底忽略了,造成有時候Grub2在啟動時找不到自己的路徑,形成在U盤能啟動,硬碟無法啟動的情況,還好,在及時發現并大致瞭解後我就再來更新下,以便解決Gurb2在定制時啟動後找不到路徑
我自己在上面提到的參數變量 -p 是設置變量prefix直接設定路徑的,太直接了,這樣有時Grub2在啟動時是無法定位到自己的路徑,帖子中的提到的bootconfig.cfg文件是grub-mkimage命令參數 -c (小寫c)有搜索功能,可以定制prefix變量來自定义Grub2路徑,也就是說,可以通過搜索來確定Grub2的準確路徑,這樣Grub2在啟動是就不會出現無法找到自己路徑的問題,帖子的Grub2就是定制的。
grub-mkimage命令參數 -c (小寫c)是調用壹個配置,文件名稱無所謂,在這裡我就標準點,就用Config.CFG文件名,帖子中是bootconfig.cfg,編碼不清楚,不過我用的是UTF8,在創建後的文件都放在Grub2包裏面,這樣壹來執行定制命令時只要給出文件名就能直接調用到了
先給出文件內容(下面3選1):
#搜索文件名来定位,定制时需要 search_fs_file 模块 (推荐使用这个方式定位)
search.file /Grub2/BIOS/Grub.CFG root
set prefix=/Grub2/BIOS
#搜索盘符名称(分区标签),会区分大小写,不支持中文名,定制时需要 search_label 模块
search.fs_label Grub2 root
set prefix=/Grub2/BIOS
#搜索分区UUID,要事先获取,好处是具有唯一性,但有点不好获取,定制时需要 search_fs_uuid 模块
search.fs_uuid 01234567-89ab-cdef-0123-456789abcdef root
set prefix=/Grub2/BIOS
下面是設定路徑
set prefix=/Grub2/BIOS
這部份是表示Grub2的路徑和grub-mkimage定制命令的參數 -p 是壹個意思的。只要寫上相對的Grub2路徑,不需要具體到(hdx,y),至於具體的(hdx,y)會通過上面的搜索來定位,它們後面尾部都會有個root表示搜索到了,就選定為根設備,可以避免不确定(hdx,y)的情况,上面有叁个Config.CFG的定位方式,推薦用第壹種,如下:
search.file /Grub2/BIOS/Grub.CFG root
set prefix=/Grub2/BIOS
如上面說明的通过搜索相對路徑/Grub2/BIOS下面的Grub.CFG文件名来確定根設備,接著就引導啟動被選定為根設備下Grub2的相對路徑。另外其它兩種搜索定位方式我感覺不是很好用,至少我個人是怎麼覺得的,修改的話只要修改紅色的部分,這個方式表示的是路徑,路徑和我的貼上前面自定義的路徑壹樣。
注意了:除了搜索分區UUID的方式能保證搜索到的是唯一不衝突,其它方式在搜索的時候是有可能會出現被搜索到相同的,如:可能會出現多個在相對路徑下有相同的文件名和多個相同的盤符名稱(分區標籤),為了避免搜索時可能會出現的衝突,壹般在設定搜索的內容時,需要考慮到衝突的情況,如:通過搜索文件名,不要選定那些常見的通用名稱和路徑,選那些衝突的可能性很小的文件名,就像選定自己定制路徑下的文件來定位位置,或者設定壹個就自己知道的文件名,也能避免衝突,基本上不會出現這樣的巧合;在搜索盤符名稱(分區標籤)時,名稱的設定和設定文件名是壹樣設定個就自己知道的名稱就行了
在grub-mkimage定制命令中使用參數 -c (小寫c)時就不要 -p 參數,(雖然加上去無所謂,但是已經沒這個必要了)下面我再重新給出BIOS和UEFI的定制命令,另外為了Config.CFG文件好辨認些下面會改名:
BIOS模式定制(Config.CFG文件改成I386-PC.CFG):
grub-mkimage.exe -d I386-PC -c I386-PC.CFG -o Core.img -O i386-pc biosdisk part_msdos fat exfat ext2 ntfs normal iso9660 search_fs_file
I386-PC.CFG文件內容:
search.file /Grub2/BIOS/Grub.CFG root
set prefix=/Grub2/BIOS
UEFI模式的32Bit定制(Config.CFG文件改成I386-EFI.CFG):
grub-mkimage.exe -d i386-efi -c I386-EFI.CFG -o I386-EFI.EFI -O i386-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
I386-EFI.CFG文件內容:
search.file /Grub2/UEFI_i386-efi/Grub.CFG root
set prefix=/Grub2/UEFI_i386-efi
UEFI模式的64Bit定制:(Config.CFG文件改成X86_64-EFI.CFG)
grub-mkimage.exe -d x86_64-efi -c X86_64-EFI.CFG -o X86_64-EFI.EFI -O x86_64-efi part_gpt part_msdos disk fat exfat ext2 ntfs appleldr hfs iso9660 normal search_fs_file
X86_64-EFI.CFG文件內容:
search.file /Grub2/UEFI_x86_64-efi/Grub.CFG root
set prefix=/Grub2/UEFI_x86_64-efi
這次基本就沒問題了,理論上,Grub2在啟動時會搜索相應路徑下的Grub.CFG文件,然後設定為啟動的分區,基本不用太在乎(hdx,y)的位置了,只是記得在每個模塊目錄裏面創建個Grub.CFG文件,因為搜索的就是Grub.CFG文件。
小更新:快捷鍵
覺得還是方便壹下大家,同時在這裡我回復:qq5274202的快捷鍵 --hotkey 設置,順便說壹下菜單中的 --class 怎麼用
先看看下官方的快捷鍵說明,還有注意下Name和Key
http://www.gnu.org/software/grub/manual/grub.html#sendkey
Name 是說明
Key 是按鍵
其實看 Key 就好了,因為這才是自己要設定的快捷鍵
注意了:Grub2中已經設定好了壹些內部的快捷鍵比如:c 不過是小寫,我們就不要用快捷鍵 --hotkey 設置成和小寫的內部快捷鍵相同,注意是不要相同的小寫按鍵因為設置後快捷鍵 --hotkey 是不會生效的,但是呢,可以設置個大寫,另外在不衝突的情況下快捷鍵是不分大小寫的
先給例子:
menuentry "重启计算机" --hotkey=+ {
reboot
}
menuentry "关机计算机" --hotkey=- {
halt
}
菜單參數 --hotkey=快捷鍵
如上面的,按下 + 就會計算機就會重啟;按下 - 就會計算機就會關鍵
Grub2內部設定的快捷鍵
c (小寫)是Grub2的命令行快捷鍵
先看例子:
menuentry "重启计算机" --hotkey=c {
reboot
}
menuentry "关机计算机" --hotkey=C {
halt
}
在 重启计算机 的這個菜單快捷鍵是不會生效,也不會提示有問題,因為用 c (小寫)這是Grub2內部設定的快捷鍵
在 关机计算机 的這個菜單快捷鍵是會生效,因為用 C(大寫)不是Grub2內部設定的快捷鍵
這是我自己試驗過的
現在來說說菜單參數 --class
菜單參數 --class 名稱
其實這個參數 --class 是配合Grub2主題來用的,在使用主題後Grub2的菜單畫面會有所變化。在編輯菜單時根據每個菜單選項內容大概的標識,給參數 --class 後面加個合適的名稱,到時候在啟動主題時每個菜單前面就會有個小圖標,會好看些,具體說明看下面。
我使用主題後,比如:
大多時候菜單的是沒有加參數 --class 的
menuentry "重启计算机" {
reboot
}
啟動后如下圖:
菜單參數 -class windows
菜單參數後面的 windows 是個標識,也可以說是個標籤,Grub2在使用主題並且啟動時會根據 windows 找出叫 windows 的ico圖標文件名,然後給菜單選項前面加上這個圖標。
menuentry "重启计算机" --class windows {
reboot
}
注意了:在參數 -class 有效時只使用從左邊開始的第壹個參數 -class ,並且只使用壹個,第壹個,無效時使用第貳個,以此類推
在Grub2主題使用時如下圖:注意下 菜單 重启计算机 前面小圖標
|
评分
-
查看全部评分
|