GRUB Legacy
GRUB Legacy は GNU プロジェクトによってメンテナンスされていた マルチブート ブートローダーです。Erich Stefan Boleyn によって設計・実装された GRUB (GRand Unified Bootloader) から由来しています。
ブートローダーとはコンピューターが起動した時に最初に走るプログラムです。Linux カーネルをロードして制御を移行する役割を担っています。バトンを受け取ったカーネルは、オペレーティングシステムを初期化します。
目次
- 1 インストール
- 2 GRUB2 へのアップグレード
- 3 設定
- 4 Bootloader installation
- 5 Tips and tricks
- 6 トラブルシューティング
- 7 参照
インストール
GRUB Legacy は GRUB バージョン 2.x のために公式リポジトリから落とされましたが、依然として grub-legacyAUR パッケージでインストールできます。
また、GRUB をブートローダーとして使うにはドライブやパーティションのブートセクタにインストールする必要があります。これについてはブートローダーのインストールセクションで説明しています。
GRUB2 へのアップグレード
アップグレードは必須なのか?
答えはノーです。GRUB Legacy がシステムから削除されることはなく、完全に機能する状態であり続けます。
ただし、サポートされない他のパッケージと同じように、バグは修正されなくなります。したがって、GRUB バージョン 2.x にアップグレードするか他のブートローダーに変えるほうが良いでしょう。
GRUB Legacy は GPT ディスク, Btrfs ファイルシステム, UEFI ファームウェアをサポートしていません。
アップグレード方法
GRUB Legacy から GRUB バージョン 2.x にアップグレードするのは Arch Linux に GRUB を新規インストールするのと同じです。GRUB#インストール を見て下さい。
相違点
- GRUB Legacy と GRUB ではコマンドが異なります。先に進む前に GRUB commands を確認してください (例: "find" は "search" に置き換わっています)。
- 今の GRUB はモジュール式であり "stage 1.5" を必要としません。そのため、ブートローダー自体の機能は限定的です -- 拡張機能の必要に応じてハードドライブからモジュールがロードされます (例: RAID や LVM のサポート)。
- デバイスの命名規則が GRUB Legacy と GRUB で変わっています。パーティションは0ではなく1から番号付けされ、ドライブは0から番号が始まり、パーティションテーブルのタイプが前に付きます。例えば、
/dev/sda1
は(hd0,msdos1)
(MBR) や(hd0,gpt1)
(GPT) と表記されます。 - GRUB は GRUB Legacy よりもかなり大きくなっています (
/boot
に ~13 MB は占領します)。分割された/boot
パーティションから起動している状態で、このパーティションが 32MB よりも小さい場合、ディスク容量の問題が起こったり、pacman が新しいカーネルのインストールを拒否したりします。
重要なデータのバックアップ
GRUB のインストールはスムーズに行われるべきですが、GRUB v2 にアップグレードする前に GRUB Legacy のファイルを保持しておくことを強く推奨します。
# mv /boot/grub /boot/grub-legacy
ブートコードやパーティションテーブルを含んでいる MBR をバックアップするには (/dev/sdX
は実際のディスクパスに置き換えてください):
# dd if=/dev/sdX of=/path/to/backup/mbr_backup bs=512 count=1
MBR の446バイトにはブートコードが含まれていて、次の64バイトにはパーティションテーブルが含まれています。リストアする際にパーティションテーブルを上書きしたくない場合は、MBR ブートコードだけをバックアップすることを推奨します:
# dd if=/dev/sdX of=/path/to/backup/bootcode_backup bs=446 count=1
GRUB2 を正しくインストールできないときは、#GRUB Legacy のリストア を見て下さい。
GRUB Legacy の設定ファイルを新しいフォーマットに変換する
grub-mkconfig
が失敗する場合、次のコマンドで /boot/grub/menu.lst
ファイルを /boot/grub/grub.cfg
に変換してください:
# grub-menulst2cfg /boot/grub/menu.lst /boot/grub/grub.cfg
例えば:
/boot/grub/menu.lst
default=0 timeout=5 title Arch Linux Stock Kernel root (hd0,0) kernel /vmlinuz-linux root=/dev/sda2 ro initrd /initramfs-linux.img title Arch Linux Stock Kernel Fallback root (hd0,0) kernel /vmlinuz-linux root=/dev/sda2 ro initrd /initramfs-linux-fallback.img
/boot/grub/grub.cfg
set default='0'; if [ x"$default" = xsaved ]; then load_env; set default="$saved_entry"; fi set timeout=5 menuentry 'Arch Linux Stock Kernel' { set root='(hd0,1)'; set legacy_hdbias='0' legacy_kernel '/vmlinuz-linux' '/vmlinuz-linux' 'root=/dev/sda2' 'ro' legacy_initrd '/initramfs-linux.img' '/initramfs-linux.img' } menuentry 'Arch Linux Stock Kernel Fallback' { set root='(hd0,1)'; set legacy_hdbias='0' legacy_kernel '/vmlinuz-linux' '/vmlinuz-linux' 'root=/dev/sda2' 'ro' legacy_initrd '/initramfs-linux-fallback.img' '/initramfs-linux-fallback.img' }
GRUB の /boot/grub/grub.cfg
設定ファイルを作るのを忘れて、再起動したら GRUB のコマンドシェルが表示された場合、以下を入力してください:
sh:grub> insmod legacycfg sh:grub> legacy_configfile ${prefix}/menu.lst
Arch で起動して正しい GRUB /boot/grub/grub.cfg
設定ファイルを再生成してください。
GRUB Legacy のリストア
- GRUB v2 のファイルをどけてください:
# mv /boot/grub /boot/grub.nonfunctional
- GRUB Legacy を
/boot
にコピーしてください:
# cp -af /boot/grub-legacy /boot/grub
- MBR と sda の次の 62 セクタをバックアップしたコピーで置き換えて下さい:
# dd if=/path/to/backup/first-sectors of=/dev/sdX bs=512 count=1
MBR のブートコードだけをリストアするとより安全です:
# dd if=/path/to/backup/mbr-boot-code of=/dev/sdX bs=446 count=1
設定
設定ファイルは /boot/grub/menu.lst
です。必要に応じてこのファイルを編集してください。
timeout #
--default
オペレーティングシステムが自動的にロードされるまで待機する時間 (秒数)。default #
--timeout
がつきたときに選択されるデフォルトのブートエントリ。
設定例 (/boot
が別パーティションにある場合):
/boot/grub/menu.lst
# Config file for GRUB - The GNU GRand Unified Bootloader # /boot/grub/menu.lst # DEVICE NAME CONVERSIONS # # Linux GRUB # ------------------------- # /dev/fd0 (fd0) # /dev/sda (hd0) # /dev/sdb2 (hd1,1) # /dev/sda3 (hd0,2) # # FRAMEBUFFER RESOLUTION SETTINGS # +-------------------------------------------------+ # | 640x480 800x600 1024x768 1280x1024 # ----+-------------------------------------------- # 256 | 0x301=769 0x303=771 0x305=773 0x307=775 # 32K | 0x310=784 0x313=787 0x316=790 0x319=793 # 64K | 0x311=785 0x314=788 0x317=791 0x31A=794 # 16M | 0x312=786 0x315=789 0x318=792 0x31B=795 # +-------------------------------------------------+ # for more details and different resolutions see # https://wiki.archlinux.org/index.php/GRUB#Framebuffer_Resolution # general configuration: timeout 5 default 0 color light-blue/black light-cyan/blue # boot sections follow # each is implicitly numbered from 0 in the order of appearance below # # TIP: If you want a 1024x768 framebuffer, add "vga=773" to your kernel line. # #-* # (0) Arch Linux title Arch Linux root (hd0,0) kernel /vmlinuz-linux root=/dev/sda3 ro initrd /initramfs-linux.img # (1) Windows #title Windows #rootnoverify (hd0,0) #makeactive #chainloader +1
Finding GRUB's root
GRUB must be told where its files reside on the system, since multiple instances may exist (i.e., in multi-boot environments). GRUB files always reside under /boot
, which may be on a dedicated partition.
If you are unaware of the the location of /boot
, use the GRUB shell find
command to locate the GRUB files. Enter the GRUB shell as root by:
# grub
The following example is for systems without a separate /boot
partition, wherein /boot
is merely a directory under /
:
grub> find /boot/grub/stage1
The following example is for systems with a separate /boot
partition:
grub> find /grub/stage1
GRUB will find the file, and output the location of the stage1
file. For example:
grub> find /grub/stage1
(hd0,0)
This value should be entered on the root
line in your configuration file. Type quit
to exit the shell.
Dual booting with Windows
Add the following to the end of your /boot/grub/menu.lst
(assuming that your Windows partition is on the first partition of the first drive):
/boot/grub/menu.lst
title Windows rootnoverify (hd0,0) makeactive chainloader +1
If Windows is located on another hard disk, the map
command must be used. This will make your Windows install think it is actually on the first drive. Assuming that your Windows partition is on the first partition of the second drive:
/boot/grub/menu.lst
title Windows map (hd0) (hd1) map (hd1) (hd0) rootnoverify (hd1,0) makeactive chainloader +1
Dual booting with GNU/Linux
This can be done the same way that an Arch Linux install is defined. For example:
/boot/grub/menu.lst
title Other Linux root (hd0,2) kernel /path/to/kernel root=/dev/sda3 ro initrd /path/to/initrd
chainloader and configfile
To facilitate system maintenance, the chainloader
or configfile
command should be used to boot another Linux distribution that provides an "automagic" GRUB configuration mechanism (e.g. Debian, Ubuntu, openSUSE). This allows the distribution to manage its own menu.lst
and boot options.
- The
chainloader
command will load another bootloader (rather than a kernel image); useful if another bootloader is installed in a partition's boot sector (GRUB, for example). This allows one to install a "main" instance of GRUB to the MBR and distribution-specific instances of GRUB to each partition boot record (PBR).
- The
configfile
command will instruct the currently running GRUB instance to load the specified configuration file. This can be used to load another distribution'smenu.lst
without a separate GRUB installation. The caveat of this approach is that othermenu.lst
may not be compatible with the installed version of GRUB; some distributions heavily patch their versions of GRUB.
For example, GRUB is to be installed to the MBR and some other bootloader (be it GRUB or LILO) is already installed to the boot sector of (hd0,2)
.
--------------------------------------------- | | | | % | | M | | | B % | | B | (hd0,0) | (hd0,1) | L % (hd0,2) | | R | | | % | | | | | % | --------------------------------------------- | ^ | chainloading | -----------------------------
One can simply include in menu.lst
:
title Other Linux root (hd0,2) chainloader +1
Or, if the bootloader on (hd0,2)
is GRUB:
title Other Linux root (hd0,2) configfile /boot/grub/menu.lst
The chainloader
command can also be used to load the MBR of a second drive:
title Other drive rootnoverify (hd1) chainloader +1
Dual booting with GNU/Linux (GRUB2)
If the other Linux distribution uses GRUB2 (e.g. Ubuntu 9.10+), and you installed its boot loader to its root partition, you can add an entry like this one to your /boot/grub/menu.lst
:
/boot/grub/menu.lst
# other Linux using GRUB2 title Ubuntu root (hd0,2) kernel /boot/grub/core.img
Selecting this entry at boot will load the other distribution's GRUB2 menu assuming that the distribution is installed on /dev/sda3
.
Bootloader installation
Manual recovery of GRUB libs
The *stage*
files are expected to be in /boot/grub
, which may not be the case if the bootloader was not installed during system installation or if the partition/filesystem was damaged, accidentally deleted, etc.
Manually copy the GRUB libs like so:
# cp -a /usr/lib/grub/i386-pc/* /boot/grub
General notes about bootloader installation
GRUB may be installed from a separate medium (e.g. a LiveCD), or directly from a running Arch install. The GRUB bootloader is seldom required to be reinstalled and installation is not necessary when:
- The configuration file is updated.
- The grub-legacyAUR package is updated.
Installation is necessary when:
- A bootloader is not already installed.
- Another operating system overwrites the Linux bootloader.
- The bootloader fails for some unknown reason.
Before continuing, a few notes:
- Be sure that your GRUB configuration is correct (
/boot/grub/menu.lst
) before proceeding. Refer to Finding GRUB's root to ensure your devices are defined correctly. - GRUB must be installed on the MBR (first sector of the hard disk), or the first partition of the first storage device to be recognized by most BIOSes. To allow individual distributions the ability to manage their own GRUB menus, multiple instances of GRUB can be used, see chainloader and configfile.
- Installing the GRUB bootloader may need to be done from within a
chroot
ed environment (i.e. from installed environment via a separate medium) for cases like RAID configurations or if you forgot/broke your GRUB installation. You will need to Change root from a LiveCD or another Linux installation to do so.
First, enter the GRUB shell:
# grub
Use the root
command with the output from the find
command (see Finding GRUB's root) to instruct GRUB which partition contains stage1 (and therefore, /boot
):
grub> root (hd1,0)
Installing to the MBR
The following example installs GRUB to the MBR of the first drive:
grub> setup (hd0)
Installing to a partition
The following example installs GRUB to the first partition of the first drive:
grub> setup (hd0,0)
After running setup
, enter quit
to exit the shell. If you chrooted, exit your chroot and unmount partitions. Now reboot to test.
Alternate method (grub-install)
Use the grub-install
command followed by the location to install the bootloader. For example to install the GRUB bootloader to the MBR of the first drive:
# grub-install /dev/sda
GRUB will indicate whether it successfully installs. If it does not, you will have to use the GRUB shell method.
Tips and tricks
Additional configuration notes.
Graphical boot
For those desiring eye candy, see grub-gfx. GRUB also offers enhanced graphical capabilities, such as background images and bitmap fonts.
Framebuffer resolution
One can use the resolution given in the menu.lst
, but you might want to use your LCD wide-screen at its full native resolution. Here is what you can do to achieve this:
On Wikipedia, there is a list of extended framebuffer resolutions (i.e. beyond the ones in the VBE standard). But, for example, the one I want to use for 1440x900 (vga=867
) does not work. This is because the graphic card manufacturers are free to choose any number they wish, as this is not part of the VBE 3 standard. This is why these codes change from one card to the other (possibly even for the same manufacturer).
So instead of using that table, you can use one of the tools mentioned below to get the correct code:
GRUB recognized value
This is an easy way to find the resolution code using only GRUB itself.
On the kernel line, specify that the kernel should ask you which mode to use.
kernel /vmlinuz-linux root=/dev/sda1 ro vga=ask
Now reboot. GRUB will now present a list of suitable codes to use and the option to scan for even more.
You can pick the code you would like to use (do not forget it, it is needed for the next step) and boot using it.
Now replace ask
in the kernel line with the correct one you have picked.
e.g. the kernel line for [369] 1680x1050x32
would be:
kernel /vmlinuz-linux root=/dev/sda1 ro vga=0x369
hwinfo
- Install the hwinfo package.
- Run
hwinfo --framebuffer
as root. - Pick up the code corresponding to the desired resolution.
- Use the 6 digit code with 0x prefix in
vga=
kernel option inmenu.lst
. Or convert it to decimal to avoid the use of 0x prefix.
Example output of hwinfo:
Mode 0x0364: 1440x900 (+1440), 8 bits Mode 0x0365: 1440x900 (+5760), 24 bits
And the kernel line:
kernel /vmlinuz-linux root=/dev/sda1 ro vga=0x0365
vbetest
- Install lrmiAUR[リンク切れ: アーカイブ: aur-mirror] which contains the vbetest tool (x86_64 users will need to use hwinfo).
- Run
vbetest
as root - Then note the number in [ ] corresponding to your desired resolution.
- Press
q
to quit vbetest interactive prompt.- As an option, in a console as root, you can test the mode you just picked up by running
vbetest -m <yourcode>
and see a pattern like this one
- As an option, in a console as root, you can test the mode you just picked up by running
- Add 512 to the discovered value picked up above and use the total value to define the
vga=
parameter in the kernel options ofmenu.lst
. - Reboot to enjoy the result
For example vbetest on one computer:
[356] 1440x900 (256 color palette) [357] 1440x900 (8:8:8)
So here the number you want is 357. Then, 357 + 512 = 869, so you will use vga=869. Add your value to the end of the kernel line in menu.lst
as shown below:
kernel /vmlinuz-linux root=/dev/sda1 ro vga=869
Naming partitions
By Label
If you alter (or plan to alter) partition sizes from time to time, you might want to consider defining your drive/partitions by a label. You can label ext2, ext3, ext4 partitions by:
e2label /dev/drive|partition label
The label name can be up to 16 characters long but cannot have spaces for GRUB to understand it. Then define it in your menu.lst
:
kernel /boot/vmlinuz-linux root=/dev/disk/by-label/Arch_Linux ro
By UUID
The UUID (Universally Unique IDentifier) of a partition may be discovered with blkid
or ls -l /dev/disk/by-uuid
. It is defined in menu.lst
with either:
kernel /boot/vmlinuz-linux root=/dev/disk/by-uuid/uuid_number
or:
kernel /boot/vmlinuz-linux root=UUID=uuid_number
Boot as root (single-user mode)
At the boot loader, select an entry and edit it (e
key). Append the following parameters to the kernel options:
[...] single init=/bin/bash
This will start in single-user mode (init 1), i.e. you will end up to a root prompt without being asked for password. This may be useful for recovery features, like resetting the root password. However, this is a huge security flaw if you have not set any password protection for grub.
Password protection
You can enable password protection in the GRUB configuration file for operating systems you wish to have protected. Bootloader password protection may be desired if your BIOS lacks such functionality and you need the extra security.
First, choose a password you can remember and then encrypt it:
# grub-md5-crypt
Password: Retype password: $1$ZOGor$GABXUQ/hnzns/d5JYqqjw
Then add your password to the beginning of the GRUB configuration file at /boot/grub/menu.lst
(the password must be at the beginning of the configuration file for GRUB to be able to recognize it):
# general configuration timeout 5 default 0 color light-blue/black light-cyan/blue password --md5 $1$ZOGor$GABXUQ/hnzns/d5JYqqjw
Then for each operating system you wish to protect, add the lock
command:
# (0) Arch Linux title Arch Linux lock root (hd0,1) kernel /boot/vmlinuz-linux root=/dev/disk/by-label/Arch_Linux ro initrd /boot/initramfs-linux.img
It is always possible to reset your BIOS settings by setting the appropriate jumper on the motherboard (see your motherboard's manual, as it is specific to every model). So in case other have access to the hardware, there is basically no way to prevent boot breakthroughs.
Restart with named boot choice
If you realize that you often need to switch to some other non-default OS (e.g. Windows) having to reboot and wait for the GRUB menu to appear is tedious. GRUB offers a way to record your OS choice when restarting instead of waiting for the menu, by designating a temporary new default which will be reset as soon as it has been used.
Supposing a simple menu.lst
setup like this:
/boot/grub/menu.lst
# general configuration: timeout 10 default 0 color light-blue/black light-cyan/blue # (0) Arch title Arch Linux root (hd0,1) kernel /boot/vmlinuz-linux root=/dev/disk/by-label/ARCH ro initrd /boot/initramfs-linux.img # (1) Windows title Windows XP rootnoverify (hd0,0) makeactive chainloader +1
Arch is the default (0). We want to restart in to Windows. Change default 0
to default saved
-- this will record the current default in a default
file in the GRUB directory whenever the savedefault command is used. Now add the line savedefault 0
to the bottom of the Windows entry. Whenever Windows is booted, it will reset the default to Arch, thus making changing the default to Windows temporary.
Now all that is needed is a way to easily change the default manually. This can be accomplished using the command grub-set-default
. So, to reboot into Windows, enter the following command:
# grub-set-default 1 && sudo shutdown -r now
For ease of use, you might to wish to implement the "Allow users to shutdown fix" (including /sbin/grub-set-default
amongst the commands the user is allowed to issue without supplying a password).
LILO and GRUB interaction
If the LILO package is installed on your system, remove it. As some tasks (e.g. kernel compilation using make all
) will make a LILO call, and LILO will then be installed over GRUB. LILO may have been included in your base system, depending on your installer media version and whether you selected/deselected it during the package selection stage.
GRUB ブートディスク
まず、フロッピーディスクをフォーマット:
# fdformat /dev/fd0 # mke2fs /dev/fd0
次にディスクをマウント:
# mount -t ext2 /dev/fd0 /mnt/fl
GRUB をディスクにインストール:
# grub-install --root-directory=/mnt/fl '(fd0)'
menu.lst
ファイルをディスクにコピー:
# cp /boot/grub/menu.lst /mnt/fl/boot/grub/menu.lst
フロッピーをアンマウント:
# umount /mnt/fl
Now you should be able to restart your computer with the disk in the drive and it should boot to GRUB. Make sure that your floppy disk is set to have higher priority than your hard drive when booting in your BIOS first, of course.
参照: Super GRUB Disk。
GRUB のメニューを非表示にする
The hiddenmenu
option can be used in order to hide the menu by default. That way no menu is displayed and the default option is going to be automatically selected after the timeout passes.
Still, you are able to press Esc
and the menu shows up. To use it, just add to your /boot/grub/menu.lst
:
hiddenmenu
トラブルシューティング
GRUB Error 17
The first check to do is to unplug any external drive. Seems obvious, but sometimes we get tired ;)
If your partition table gets messed up, an unpleasant "GRUB error 17" message might be the only thing that greets you on your next reboot. There are a number of reasons why the partition table could get messed up. Commonly, users who manipulate their partitions with GParted -- particularly logical drives -- can cause the order of the partitions to change. For example, you delete /dev/sda6
and resize /dev/sda7
, then finally re-create what used to be /dev/sda6
only now it appears at the bottom of the list, /dev/sda9
for example. Although the physical order of the partitions/logical drives has not changed, the order in which they are recognized has changed.
Fixing the partition table is easy. Boot from your Arch CD/DVD/USB, login as root and fix the partition table:
# fdisk /dev/sda
Once in disk, enter e[x]tra/expert mode, [f]ix the partition order, then [w]rite the table and exit.
You can verify that the partition table was indeed fixed by issuing an fdisk -l
. Now you just need to fix GRUB. See the Bootloader installation section.
Basically you need to tell GRUB the correct location of your /boot
then re-write GRUB to the MBR on the disk.
For example:
# grub
grub> root (hd0,6) grub> setup (hd0) grub> quit
See [this page] for a more in-depth summary of this section.
/boot/grub/stage1 not read correctly
If you see this error message while trying to set up GRUB, and you are not using a fresh partition table, it is worth checking it.
# fdisk -l /dev/sda
This will show you the partition table for /dev/sda
. So check here, whether the "Id" values of your partitions are correct.
The "System" column will show you the description of the "Id" values.
If your boot partition is marked as being "HPFS/NTFS", for example, then you have to change it to "Linux". To do this, go to fdisk,
# fdisk /dev/sda
change a partition's system id with t
, select you partition number and type in the new system id (Linux = 83).
You can also list all available system ids by typing L
instead of a system id.
If you have changed a partitions system id, you should [v]erify your partition table and then [w]rite it.
Now try to set up GRUB again.
[Here] is the forum post reporting this problem.
Accidental install to a Windows partition
If you accidentally install GRUB to a Windows partition, GRUB will write some information to the boot sector of the partition, erasing the reference to the Windows bootloader. (This is true for NTLDR the bootloader for Windows XP and earlier, unsure about later versions).
To fix this you will need to use the Windows Recovery Console for your Windows release. Because many computer manufacturers do not include this with their product (many choose to use a recovery partition) Microsoft has made them available for download. If you use XP, look at this page to be able to turn the floppy disks to a Recovery CD. Boot the Recovery CD (or enable Windows Recovery mode) and run fixboot
to repair the partition boot sector. After this, you will have to install GRUB again---this time, to the MBR, not to the Windows partition---to boot Linux.
Once you have selected and entry in the boot menu, you can edit it by pressing key e
. Use tab-completion if you need to to discover devices then Esc
to exit. Then you can try to boot by pressing b
.
device.map error
If an error is raised mentioning /boot/grub/device.map
during installation or boot, run:
# grub-install --recheck /dev/sda
to force GRUB to recheck the device map, even if it already exists. This may be necessary after resizing partitions or adding/removing drives.
If you have opened a sub-menu with the list of all operating systems configured in GRUB, selected one, and upon restart, you still booted your default OS, then you might want to check if you have the line:
default saved
in /boot/grub/menu.lst
.
GRUB fails to find or install to any virtio /dev/vd* or other non-BIOS devices
I had trouble installing GRUB while installing Arch Linux in an virtual KVM machine using a virtio device for hard drive. To install GRUB, I figured out the following:
Enter a virtual console by typing Ctrl+Alt+F2
or any other F-key for a free virtual console.
This assumes that your root file system is mounted in the folder /mnt
and the boot file system is either mounted or stored in the folder /mnt/boot
.
1. Assure that all needed GRUB files is present in your boot directory (assuming it is mounted in /mnt/boot
folder), by issuing the command:
# ls /mnt/boot/grub
2. If the /mnt/boot/grub
folder already contains all the needed files, jump to step 3. Otherwise, do the following commands (replacing /mnt
, your_kernel
and your_initrd
with the real paths and file names). You should also have the menu.lst
file written to this folder:
# mkdir -p /mnt/boot/grub # if the folder is not yet present # cp -r /boot/grub/stage1 /boot/grub/stage2 /mnt/boot/grub # cp -r your_kernel your_initrd /mnt/boot
3. Start the GRUB shell with the following command:
# grub --device-map=/dev/null
4. Enter the following commands. Replace /dev/vda
, and (hd0,0)
with the correct device and partition corresponding to your setup.
device (hd0) /dev/vda root (hd0,0) setup (hd0) quit
5. If GRUB reports no error messages, then you probably are done. You also need to add appropriate modules to the ramdisk. For more information, please refer to QEMU#Preparing an (Arch) Linux guest.