Booting Windows using coreboot: Difference between revisions
No edit summary |
|||
Line 55: | Line 55: | ||
== Building ADLO payload == | == Building ADLO payload == | ||
'''IMPORTANT: This step is necessary only if using LinuxBIOSv2. If using LinuxBIOSv3 go to section ''Building LinuxBIOSv3''''' | |||
First, download ADLO's source code. | First, download ADLO's source code. | ||
$ svn co svn://linuxbios.org/repos/trunk/LinuxBIOSv2/ | $ svn co svn://linuxbios.org/repos/trunk/LinuxBIOSv2/ | ||
Line 65: | Line 67: | ||
Check the [http://tracker.linuxbios.org/trac/LinuxBIOS/browser/trunk/LinuxBIOSv2/util/ADLO/README README] file to see some information about installing as86 + patch in order to compile bochs' bios. You can also get a [http://www.cix.co.uk/~mayday/ prepatched version] of as86. I downloaded the newest version and patched it. | Check the [http://tracker.linuxbios.org/trac/LinuxBIOS/browser/trunk/LinuxBIOSv2/util/ADLO/README README] file to see some information about installing as86 + patch in order to compile bochs' bios. You can also get a [http://www.cix.co.uk/~mayday/ prepatched version] of as86. I downloaded the newest version and patched it. | ||
After running ''make'', a file named ''payload'' will be generated. | After running ''make'', a file named ''payload'' will be generated. | ||
== Building LinuxBIOSv2 == | |||
Now it is time to build linuxBIOS. | |||
$ cd LinuxBIOSv2/targets/emulation/qemu-i386 | |||
You should edit the Config.lb file, where it says payload put the path of the file generated by ADLO. It should look like this: | |||
* payload path/to/adlo/payload | |||
Return to targets directory and execute: | |||
$ ./buildtarget emulation/qemu-i386 | |||
Go to targets/emulation/qemu-i386/qemu-i386 and execute: | |||
$ make | |||
This creates the LinuxBIOS image (qemu-bios.rom). Copy this file to a specific folder and rename it to bios.bin. | |||
== Building LinuxBIOSv3 == | == Building LinuxBIOSv3 == | ||
Line 71: | Line 85: | ||
$ svn co svn://linuxbios.org/repository/LinuxBIOSv3 | $ svn co svn://linuxbios.org/repository/LinuxBIOSv3 | ||
$ cd LinuxBIOSv3/ | $ cd LinuxBIOSv3/ | ||
$ Apply patch that puts ADLO into LinuxBIOSv3 | |||
$ make menuconfig | $ make menuconfig | ||
There are few options that should be enabled: | There are few options that should be enabled: | ||
Mainboard->Mainboard vendor->Emulated Systems | Mainboard->Mainboard vendor->Emulated Systems | ||
Mainboard->Mainboard model->QEMU x86 | Mainboard->Mainboard model->QEMU x86 | ||
Payload->An | Payload->An ADLO payload file | ||
Exit and when asked to generate a config file say yes. After, execute: | Exit and when asked to generate a config file say yes. After, execute: | ||
$ make | $ make | ||
Line 89: | Line 104: | ||
$ qemu-img create -f qcow /path/to/win.cow 2000M | $ qemu-img create -f qcow /path/to/win.cow 2000M | ||
Insert the installation CD, and install Windows 2000/XP in the QEMU image. During the installation process you can choose whether ACPI support is desired. This is done pressing F7 or F5 during the screen with the message "press F6 if you need to install a SCSI or RAID controller" on the bottom. F7 lets windows choose the most appropriate option. F5 shows all the available options so the user can choose. I have tested a win2k | Insert the installation CD, and install Windows 2000/XP in the QEMU image. During the installation process you can choose whether ACPI support is desired. This is done pressing F7 or F5 during the screen with the message "press F6 if you need to install a SCSI or RAID controller" on the bottom. F7 lets windows choose the most appropriate option. F5 shows all the available options so the user can choose. I have successfully tested a win2k and a winXP images with and without ACPI support on. | ||
Revision as of 18:11, 15 August 2007
This file is licensed under the Creative Commons Attribution ShareAlike 3.0 License. In short: you are free to share and make derivative works of the file under the conditions that you appropriately attribute it, and that you distribute it only under a license identical to this one. |
Why Windows?
LinuxBIOS itself has many positive aspects that should be made widely available. In order to make LinuxBIOS a very strong alternative firmware for PC's we cannot afford not considering support for windows since it owns about 90% in the PC market.
Project Overview
This project was accepted for the Google Summer Of Code 2007 and its main goal is to figure out how to boot Windows Vista/XP/2003. There is not a chosen approach to achieve that. Having a dedicated LinuxBIOS loader is the most desired solution but since some success has been reported using ADLO, it has been chosen in this phase of understanding better the problem.
Instead of a real hardware, QEMU emulator will be used since it is easily available for anyone who wishes to contribute.
I intend to describe in detailed all the steps taken up to now and some of the problems faced. My first goal is to repeat the stages to boot windows 2000 described in the paper entitled Flexibility in ROM: A Stackable Open Source BIOS. After that, we will focus on windows XP and Vista that require a more complicated support.
Any suggestion is welcome, please use the LinuxBIOS mailing list or email Augusto Pedroza.
Requirements
The following software packages are needed:
- LinuxBIOSv3
- ADLO
- QEMU 0.9.0 or greater
- as86 80x86 assembler
plus a working development environment (make, gcc, etc.). gcc verions 4.0.x and 4.1.x work fine except for QEMU, which requires gcc 3.x.
Installing Qemu
In order to build QEMU from source gcc 3.x. is required. If you use a different version of gcc, take a look at the following section.
Building gcc 3.x
$ wget ftp://ftp.mirrorservice.org/sites/sources.redhat.com/pub/gcc/releases/gcc-3.4.6/gcc-3.4.6.tar.gz $ tar zxvf gcc-3.4.6.tar.gz $ cd gcc-3.4.6/ $ ./configure --prefix=/opt/gcc34 $ make bootstrap $ make install (as root)
Building QEMU
Download QEMU source code (I used qemu-0.9.0.tar.gz) and extract it.
$ tar -xzvf qemu-0.9.0.tar.gz $ cd qemu-0.9.0/
Configure and make QEMU (use the --cc option if your default gcc is newer than version 3.4):
If you need some bios debug messages from qemu add --extra-cflags="-DDEBUG_BIOS" to the configuration line below. Since LinuxBIOS already outputs debug messages without this option, turning it on will mess Qemu output error messages. It is useful for some situations though.
$ ./configure --cc=/opt/gcc34/bin/gcc --target-list=i386-softmmu && make $ make install
The QEMU binary is stored in the i386-softmmu directory.
Building ADLO payload
IMPORTANT: This step is necessary only if using LinuxBIOSv2. If using LinuxBIOSv3 go to section Building LinuxBIOSv3
First, download ADLO's source code.
$ svn co svn://linuxbios.org/repos/trunk/LinuxBIOSv2/
APPLY PATCH SENT TO LINUXBIOS MAILING LIST!
Go to LinuxBIOSv2 directory:
$ cd LinuxBIOSv2/ $ patch -p1 < xpboot.diff $ make
Check the README file to see some information about installing as86 + patch in order to compile bochs' bios. You can also get a prepatched version of as86. I downloaded the newest version and patched it. After running make, a file named payload will be generated.
Building LinuxBIOSv2
Now it is time to build linuxBIOS.
$ cd LinuxBIOSv2/targets/emulation/qemu-i386
You should edit the Config.lb file, where it says payload put the path of the file generated by ADLO. It should look like this:
- payload path/to/adlo/payload
Return to targets directory and execute:
$ ./buildtarget emulation/qemu-i386
Go to targets/emulation/qemu-i386/qemu-i386 and execute:
$ make
This creates the LinuxBIOS image (qemu-bios.rom). Copy this file to a specific folder and rename it to bios.bin.
Building LinuxBIOSv3
Now it is time to build linuxBIOSv3. You should first download it:
$ svn co svn://linuxbios.org/repository/LinuxBIOSv3 $ cd LinuxBIOSv3/ $ Apply patch that puts ADLO into LinuxBIOSv3 $ make menuconfig
There are few options that should be enabled:
Mainboard->Mainboard vendor->Emulated Systems Mainboard->Mainboard model->QEMU x86 Payload->An ADLO payload file
Exit and when asked to generate a config file say yes. After, execute:
$ make
This creates a LinuxBIOS image named /build/bios.bin. Copy this file to a specific folder. I will call this folder 'LinuxBIOS_bios/'
Creating an Appropriate Disk Image
Installing Windows
There are few options to create an image, I chose to use the qemu-img tool. Create an image no smaller than 1.2GB to avoid any kind of problems during windows installation. The qcow format is very appropriate because will only take up as much space as is really needed. Since I wanted to install a small version of linux, I created an image of 2GB.
$ qemu-img create -f qcow /path/to/win.cow 2000M
Insert the installation CD, and install Windows 2000/XP in the QEMU image. During the installation process you can choose whether ACPI support is desired. This is done pressing F7 or F5 during the screen with the message "press F6 if you need to install a SCSI or RAID controller" on the bottom. F7 lets windows choose the most appropriate option. F5 shows all the available options so the user can choose. I have successfully tested a win2k and a winXP images with and without ACPI support on.
Windows seems to be very sensitive to BIOS changes. I got the following error when installing windows with QEMU default BIOS and later trying to run it using LinuxBIOS:
*** STOP: 0x0000007B (0xF781B84C,0xC0000034,0x00000000,0x00000000) INACCESSIBLE_BOOT_DEVICE [1].
So, the BIOS used during windows installation should be the same as the one that will be used to run windows.
Before executing the next command, copy a file named vgabios-cirrus.bin to the same folder where the bios.bin file is, in my case, LinuxBIOS_bios/. This file can be found in the qemu directory at qemu-0.9.0/pc-bios.
Then run:
$ qemu -L path/to/LinuxBIOS_bios/ -hda /path/to/win.cow -boot d -cdrom /dev/cdrom -m 384 -localtime
The -L option allows us to inform the path for BIOS, VGA BIOS. This step takes a lot longer than installing windows on a Hard Disk.
Booting Windows
Just execute this:
$ qemu -L path/to/LinuxBIOS_bios/ -hda win.cow
I get the following errors due to interrupt calls:
int13_harddisk: function 41, unmapped device for ELDL=81 int13_harddisk: function 08, unmapped device for ELDL=81 *** int 15h function AX=00C0, BX=0000 not yet supported! *** int 15h function AX=5300, BX=0000 not yet supported!
int13 function 41 -> (with BX = 55AAh) is a check for the "Installation of the INT 13 BIOS Extensions" in Memory. int13 function 08 -> Get Drive Parameters
Even though some keyboard error messages are displayed, the keyboard works correctly with LinuxBIOSv3 (It has a wrong behavior with LinuxBIOSv2):
KBD: int09h_handler(): unknown scancode read: 0x72! KBD: int09h_handler(): unknown scancode read: 0x75! KBD: int09h_handler(): unknown scancode read: 0x74!
Just wait the boot process and ... enjoy it!!
Debugging using GDB
Recompile qemu with this patch in order to disable timer interrupts.
qemu-0.9.0$ patch -p0 <../qemu-20061108-debug-on-linux.patch qemu-0.9.0$ ./configure --cc=/opt/gcc34/bin/gcc --target-list=i386-softmmu && make qemu-0.9.0/i386-softmmu$ gdb qemu (gdb) set args -L path/to/LinuxBIOS_bios/ -hda path/to/win2k.cow (gdb) break main (gdb) run
Now that we are able to boot windows 2000 and XP, we will work hard on getting windows Vista soon.