232 lines
5.6 KiB
Text
232 lines
5.6 KiB
Text
|
==========================================
|
||
|
$Id: README,v 1.1 2002/11/25 02:07:53 rminnich Exp $
|
||
|
==========================================
|
||
|
|
||
|
ADLO
|
||
|
|
||
|
A project to combine LinuxBIOS and BOCHS BIOS to add support
|
||
|
for booting legacy applications, such as Microsoft Windows.
|
||
|
|
||
|
==========================================
|
||
|
|
||
|
Boot Overvew:
|
||
|
|
||
|
ADLO requires an boot loader with ELF support.
|
||
|
In our case it is either LinuxBIOS or EtherBOOT.
|
||
|
|
||
|
Sample execution paths:
|
||
|
|
||
|
LinuxBIOS -> ADLO -> LILO -> LINUX
|
||
|
|
||
|
LinuxBIOS -> EtherBOOT -> ADLO -> LILO -> LINUX
|
||
|
|
||
|
Then it can start any real mode application.
|
||
|
In our case it could be LILO or GRUB, but
|
||
|
choices are not limited to this.
|
||
|
|
||
|
==========================================
|
||
|
|
||
|
ADLO overview:
|
||
|
|
||
|
-Elf header
|
||
|
-mainteance routines
|
||
|
-bochs bios
|
||
|
-vga bios
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
Elf header
|
||
|
|
||
|
hand crafted binary. Currently there are 3 diff binaries
|
||
|
for three different sizes of payload (65kb,113kb,129kb).
|
||
|
|
||
|
they are catted at beginning of file
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
mainteance routines
|
||
|
|
||
|
this is the loader.s file which gets compiled into loader.o binary
|
||
|
|
||
|
it is catted 2nd right after elf header and it is where
|
||
|
control is being transfered when the elf is executed.
|
||
|
|
||
|
it consist of :
|
||
|
-tuneups:
|
||
|
select device to boot
|
||
|
set memory for Int15/EAX=E820
|
||
|
enable LBA
|
||
|
copy LinuxBIOS table [TODO]
|
||
|
-shadow :
|
||
|
enable/write/read
|
||
|
-copy:
|
||
|
bochs @ 0xF00000
|
||
|
video bios (binary only) @ 0xC00000
|
||
|
-switch
|
||
|
from Real to Protected Mode
|
||
|
-jump
|
||
|
jmp to the bios at 0xFFFF:0x0000
|
||
|
|
||
|
we must have bios payload always at 1kb
|
||
|
offset from start of ELF payload so loader.o
|
||
|
must be always 1024 bytes.
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
BOCHS BIOS
|
||
|
|
||
|
we have taken the boch's project and just extracted
|
||
|
its bios from it only. it took us (so far) only
|
||
|
minor modifications in order to make it work.
|
||
|
|
||
|
basically it is the following directory in the
|
||
|
bochs sources
|
||
|
|
||
|
bochs-cvs/bochs/bios
|
||
|
|
||
|
of all files there the rombios.c is the key file.
|
||
|
Most of the times our patches are against current
|
||
|
version of the rombios.c file. We try to feed back
|
||
|
the patches to bochs maintainers so that's possible
|
||
|
to use the bochs bios as is.
|
||
|
|
||
|
the boch's related stuff are in bochs subdirectory.
|
||
|
|
||
|
building boch's bios is as simple as
|
||
|
|
||
|
cd bochs/bochs-cvs/bochs/bios
|
||
|
make
|
||
|
|
||
|
the resulting file rombios.bin is our bios image.
|
||
|
|
||
|
-----
|
||
|
At present time, it is recommended to use
|
||
|
dev86-0.16.3 + my patch in order to compile
|
||
|
bochs' bios. The dev86 package can be found
|
||
|
at:
|
||
|
|
||
|
http://www.cix.co.uk/~mayday/
|
||
|
|
||
|
prepatched sources at:
|
||
|
|
||
|
http://www.missl.cs.umd.edu/~adam/dev86-0.16.3-MSR.tgz
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
Video BIOS
|
||
|
|
||
|
Video BIOS we use is binary only, so far.
|
||
|
|
||
|
At the present time we are using the original
|
||
|
Video BIOS as supplied from the system.
|
||
|
|
||
|
To get the image simply type:
|
||
|
|
||
|
make makevideobios
|
||
|
|
||
|
The right thing will happen. For refernece the
|
||
|
magic line in the Makefile is:
|
||
|
|
||
|
videobios:
|
||
|
dd if=/proc/kcore \
|
||
|
of=./video.bios.bin \
|
||
|
bs=1 count=65536 skip=790528
|
||
|
|
||
|
---------------
|
||
|
|
||
|
We assume it is located at 0xC00000-0xE00000
|
||
|
and we use 'dd and /proc/kcore to extract it
|
||
|
(obviously it works as root only).
|
||
|
|
||
|
Obviously it needs to be done with original
|
||
|
(as shipped by manufactuer bios) so it should
|
||
|
be done as the first step of the ADLO setup.
|
||
|
|
||
|
---------------
|
||
|
|
||
|
The /proc/kcore is in ELF format (linux kernel
|
||
|
2.4.x and later) so if we want to get accurate
|
||
|
image of ram we must skip the ELF header.
|
||
|
The magic command is :
|
||
|
|
||
|
readelf -a /proc/kcore
|
||
|
|
||
|
Program Headers:
|
||
|
Type Offset VirtAddr PhysAddr FileSiz MemSiz
|
||
|
NOTE 0x0007d4 0x00000000 0x00000000 0x005b0 0x00000
|
||
|
LOAD 0x001000 0xc0000000 0x00000000 0xff60000 0xff60000
|
||
|
^^^^^^^^
|
||
|
|
||
|
There we look for the first LOAD section, and see what
|
||
|
is its offset (for us it is 0x1000)
|
||
|
|
||
|
---------------
|
||
|
|
||
|
64KiB = 65536
|
||
|
|
||
|
0x0C 00 00 + 0x10 00 = 790528
|
||
|
|
||
|
---------------
|
||
|
|
||
|
On technical note in our case video bios
|
||
|
is just 48kb, but for paranoia sake we copy
|
||
|
64kb.
|
||
|
|
||
|
==========================================
|
||
|
|
||
|
Environment overview
|
||
|
|
||
|
ADLO is an ELF file and thus can be loaded either directly from 1)
|
||
|
LinuxBIOS, or 2) via EtherBOOT, or 3) via EtherBOOT+ AA patch for FS
|
||
|
support.
|
||
|
|
||
|
1)
|
||
|
Both LinuxBIOS and ADLO are on the same EEPROM chip. From end-user
|
||
|
viewpoint it is probably the most similar to the bios classic.
|
||
|
(computer boots up and just loads whatever is in MBR).
|
||
|
|
||
|
2)
|
||
|
Set it up in /tftpboot directory on dhcp/tftp server and have it served
|
||
|
from there. (this is how we did the development)
|
||
|
|
||
|
3)
|
||
|
Use AA patch and put it as /kernel file and it will be then loaded by
|
||
|
etherboot from local hard disk.
|
||
|
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
Before ADLO starts.
|
||
|
|
||
|
ADLO requires an boot loader with ELF support.
|
||
|
In our case it is:
|
||
|
|
||
|
-LinuxBIOS
|
||
|
-LinuxBIOS and EtherBOOT
|
||
|
-LinuxBIOS and EtherBOOT + AA polled I/O patch (w/ FS support).
|
||
|
|
||
|
As little as LinuxBIOS only is required to get ADLO
|
||
|
up and running.
|
||
|
|
||
|
For development purposes it is recommended full set of
|
||
|
LinuxBIOS + EtherBOOT and boot via DHCP/TFTP.
|
||
|
|
||
|
------------------------------------------
|
||
|
|
||
|
After ADLO finish.
|
||
|
|
||
|
ADLO will attempt to locate the first hard disk
|
||
|
and read MBR from it and execute.
|
||
|
|
||
|
Then it can start any real mode application.
|
||
|
In our case it could be LILO or GRUB
|
||
|
but choices are not limited to this.
|
||
|
|
||
|
In our case it would cause LILO to load
|
||
|
(fully usable) and from there it was able to
|
||
|
execute simple programs. so far the list
|
||
|
of the program is limited to linux which
|
||
|
runs somewhat. More to come in future.
|
||
|
|
||
|
==========================================
|