mntmn b986ab8dc6 disk writing (fat) works; pixel editor demo 9 rokov pred
..
rpi-boot-tools 62ade15fbd complete move 9 rokov pred
test_kernel 62ade15fbd complete move 9 rokov pred
MULTIBOOT-ARM 62ade15fbd complete move 9 rokov pred
Makefile 62ade15fbd complete move 9 rokov pred
Makefile.rpi-boot.in 62ade15fbd complete move 9 rokov pred
README 62ade15fbd complete move 9 rokov pred
assert.c 62ade15fbd complete move 9 rokov pred
assert.h 62ade15fbd complete move 9 rokov pred
atag.c 62ade15fbd complete move 9 rokov pred
atag.h 62ade15fbd complete move 9 rokov pred
block.c b986ab8dc6 disk writing (fat) works; pixel editor demo 9 rokov pred
block.h 62ade15fbd complete move 9 rokov pred
block_cache.c 91fb33499c soundfs initial version; new fatfs with experimental writing support 9 rokov pred
boot.s 62ade15fbd complete move 9 rokov pred
config.h 62ade15fbd complete move 9 rokov pred
console.c 62ade15fbd complete move 9 rokov pred
console.h 62ade15fbd complete move 9 rokov pred
crc32.c 62ade15fbd complete move 9 rokov pred
crc32.h 62ade15fbd complete move 9 rokov pred
ctype.c 62ade15fbd complete move 9 rokov pred
ctype.h 62ade15fbd complete move 9 rokov pred
dirent.h 62ade15fbd complete move 9 rokov pred
dwc_usb.c 62ade15fbd complete move 9 rokov pred
dwc_usb.h 62ade15fbd complete move 9 rokov pred
elf.c 62ade15fbd complete move 9 rokov pred
elf.h 62ade15fbd complete move 9 rokov pred
emmc.c b986ab8dc6 disk writing (fat) works; pixel editor demo 9 rokov pred
errno.h 62ade15fbd complete move 9 rokov pred
ext2.c 62ade15fbd complete move 9 rokov pred
fat.c f3c8e9a6b4 uartkeys fs, crash fix in reader, arm shifting fixes 9 rokov pred
fb.c 62ade15fbd complete move 9 rokov pred
fb.h 62ade15fbd complete move 9 rokov pred
font.c 62ade15fbd complete move 9 rokov pred
fs.h 07ec8c3a07 device changes brought back; rpi fs + eval working 9 rokov pred
heap.c 62ade15fbd complete move 9 rokov pred
libfs.c 07ec8c3a07 device changes brought back; rpi fs + eval working 9 rokov pred
linker-qemu.ld 62ade15fbd complete move 9 rokov pred
linker.ld 62ade15fbd complete move 9 rokov pred
log.c 62ade15fbd complete move 9 rokov pred
log.h 62ade15fbd complete move 9 rokov pred
main.c 62ade15fbd complete move 9 rokov pred
mbox.c 62ade15fbd complete move 9 rokov pred
mbox.h 07ec8c3a07 device changes brought back; rpi fs + eval working 9 rokov pred
mbr.c 07ec8c3a07 device changes brought back; rpi fs + eval working 9 rokov pred
memchunk.c 62ade15fbd complete move 9 rokov pred
memchunk.h 62ade15fbd complete move 9 rokov pred
mksdimg.sh 62ade15fbd complete move 9 rokov pred
mmio.c 62ade15fbd complete move 9 rokov pred
mmio.h 62ade15fbd complete move 9 rokov pred
multiboot.c 62ade15fbd complete move 9 rokov pred
multiboot.h 62ade15fbd complete move 9 rokov pred
nofs.c 62ade15fbd complete move 9 rokov pred
output.c 62ade15fbd complete move 9 rokov pred
output.h 62ade15fbd complete move 9 rokov pred
printf.c 62ade15fbd complete move 9 rokov pred
ramdisk.c 62ade15fbd complete move 9 rokov pred
raspbootin-server.c 62ade15fbd complete move 9 rokov pred
raspbootin.c 62ade15fbd complete move 9 rokov pred
raspbootin.h 62ade15fbd complete move 9 rokov pred
stdio.c 62ade15fbd complete move 9 rokov pred
stdio.h 62ade15fbd complete move 9 rokov pred
stdlib.c 62ade15fbd complete move 9 rokov pred
stdlib.h 62ade15fbd complete move 9 rokov pred
stream.c 62ade15fbd complete move 9 rokov pred
string.h 62ade15fbd complete move 9 rokov pred
strtol.c 62ade15fbd complete move 9 rokov pred
strtoll.c 62ade15fbd complete move 9 rokov pred
timer.c 62ade15fbd complete move 9 rokov pred
timer.h 62ade15fbd complete move 9 rokov pred
uart.c 62ade15fbd complete move 9 rokov pred
uart.h 62ade15fbd complete move 9 rokov pred
usb.h 62ade15fbd complete move 9 rokov pred
util.h 62ade15fbd complete move 9 rokov pred
vfs.c 62ade15fbd complete move 9 rokov pred
vfs.h 07ec8c3a07 device changes brought back; rpi fs + eval working 9 rokov pred

README

rpi-boot
--------

A simple second stage boot loader for the Raspberry Pi to assist in the
development of hobby kernels.


Features
--------

* Supports booting flat binary files, ELF executables and ELF and a.out
executables with a Multiboot header. Linux kernels are currently not
supported (but support is planned for a future version).

* Supports FAT(16/32) and ext2 filesystems.

* Supports loading additional modules when in Multiboot mode.

* Proviedes functions to the loaded kernel to allow it to easily
access the framebuffer (via a printf() interface) and the filesystem
(via fopen/fread/fclose/opendir/readdir/closedir).


Installation
------------

Edit config.h to your needs to enable/disable certain functionality.

Run make in the source directory and copy the kernel.img file to the SD card
containing your Raspian distribution. You are recommended to backup your
original kernel.img file first.


Usage
-----

The rpi-boot bootloader will initially search for files called
/boot/rpi_boot.cfg, /boot/rpi-boot.cfg and /boot/grub/grub.cfg (in that order)
on the first partition of the SD card. If one is not found, it searches for
those files on each filesystem known to the system.

It understands the following commands:

multiboot [cmdline]
- Load a multiboot compliant kernel

module [name]
- Load an additional Multiboot module

kernel
- Load a non-multiboot compliant kernel

boot
- Boot the kernel

binary_load_addr
- Set the load address for a flat binary file subsequently loaded by the
'kernel' command

entry_addr
- Set the entry point that is jumped to by a subsequent 'boot' command

console_log [+] [buffer_size]
- Copy the console log to a file. If '+' is specified after the file name
then append to the file instead of overwriting it. If 'buffer_size'
is specified then it is the number of bytes to buffer before writing
to the file. This prevents the log quickly using up all the write
cycles on solid state media, but runs the risk of some messages being
lost on a kernel crash. Call fflush(get_log_file()) from the guest
OS to manually flush the buffer. Support for console_log requires
that ENABLE_CONSOLE_LOGFILE be enabled in config.h


System state on kernel start
----------------------------

For Multiboot kernels, the system state is defined in MULTIBOOT-ARM, otherwise:

r0 will be 0
r1 will be the ARM machine type
r2 will be the address of the ATAGs

(the above 3 are identical to the ARM Linux boot protocol)

r3 will be the address of the multiboot_arm_functions structure as defined in
MULTIBOOT-ARM.

See the test-kernel directory for an example.


Caveats
-------

rpi-boot occupies the first 1 MiB of memory for itself. If you wish to make
use of the multiboot_arm_functions functions you need to preserve this. If
not you can overwrite it from within your kernel. If you do overwrite it,
you should make sure you have already obtained all the information you need
from the various Multiboot structures (or copied them elsewhere).

Because of this, rpi-boot will not boot kernels which are linked below 1 MiB.