diff options
| author | David Oberhollenzer <goliath@infraroot.at> | 2020-01-11 01:05:11 +0100 | 
|---|---|---|
| committer | David Oberhollenzer <goliath@infraroot.at> | 2020-01-11 01:05:11 +0100 | 
| commit | 4e2beb47ce388e5556cd1bb4644a02c61fd80a64 (patch) | |
| tree | 0458ed57261705c2213e3eba28aa73cc1e8ae633 | |
| parent | 39d809917699f6ad9bf218b32efd43aa15da6677 (diff) | |
Add writeup on kernel boot and add the firmware blobs
Signed-off-by: David Oberhollenzer <goliath@infraroot.at>
| -rw-r--r-- | firmware/LICENCE.broadcom | 30 | ||||
| -rw-r--r-- | firmware/bootcode.bin | bin | 0 -> 52296 bytes | |||
| -rw-r--r-- | firmware/cmdline.txt | 1 | ||||
| -rw-r--r-- | firmware/config.txt | 3 | ||||
| -rw-r--r-- | firmware/fixup.dat | bin | 0 -> 6694 bytes | |||
| -rw-r--r-- | firmware/start.elf | bin | 0 -> 2869348 bytes | |||
| -rw-r--r-- | kernel.md | 80 | 
7 files changed, 114 insertions, 0 deletions
| diff --git a/firmware/LICENCE.broadcom b/firmware/LICENCE.broadcom new file mode 100644 index 0000000..89b5c0c --- /dev/null +++ b/firmware/LICENCE.broadcom @@ -0,0 +1,30 @@ +Copyright (c) 2006, Broadcom Corporation. +Copyright (c) 2015, Raspberry Pi (Trading) Ltd +All rights reserved. + +Redistribution.  Redistribution and use in binary form, without +modification, are permitted provided that the following conditions are +met: + +* This software may only be used for the purposes of developing for,  +  running or using a Raspberry Pi device. +* Redistributions must reproduce the above copyright notice and the +  following disclaimer in the documentation and/or other materials +  provided with the distribution. +* Neither the name of Broadcom Corporation nor the names of its suppliers +  may be used to endorse or promote products derived from this software +  without specific prior written permission. + +DISCLAIMER.  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND +CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, +BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS +OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR +TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE +USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH +DAMAGE. + diff --git a/firmware/bootcode.bin b/firmware/bootcode.binBinary files differ new file mode 100644 index 0000000..72c6225 --- /dev/null +++ b/firmware/bootcode.bin diff --git a/firmware/cmdline.txt b/firmware/cmdline.txt new file mode 100644 index 0000000..235f637 --- /dev/null +++ b/firmware/cmdline.txt @@ -0,0 +1 @@ +console=tty0 diff --git a/firmware/config.txt b/firmware/config.txt new file mode 100644 index 0000000..16c1ceb --- /dev/null +++ b/firmware/config.txt @@ -0,0 +1,3 @@ +dtparam= +kernel=zImage +initramfs initrd.xz followkernel diff --git a/firmware/fixup.dat b/firmware/fixup.datBinary files differ new file mode 100644 index 0000000..46d088c --- /dev/null +++ b/firmware/fixup.dat diff --git a/firmware/start.elf b/firmware/start.elfBinary files differ new file mode 100644 index 0000000..904c0d9 --- /dev/null +++ b/firmware/start.elf @@ -333,3 +333,83 @@ instead of using sha256. This is necessary, because the kernel built in  xz library cannot do sha256, will refuse to unpack the image otherwise and the  system won't boot. + +## Putting everything on the Raspberry Pi and Booting it + +Remember how I mentioned earlier that the last step of our boot loader chain +would involve something sane, like U-Boot or BareBox? Well, not on the +Raspberry Pi. + +In addition to the already bizarro hardware, the Raspberry Pi has a lot of +proprietary magic baked directly into the hardware. The boot process is +controlled by the GPU, since the SoC is basically a GPU with an ARM CPU slapped +on to it. + +The GPU loads a binary called `bootcode.bin` from the SD card, which contains a +proprietary boot loader blob for GPU. It does some initialization and chain +loads `start.elf` which contains a firmware blob for the GPU. The GPU is running +an RTOS called [ThreadX OS](https://en.wikipedia.org/wiki/ThreadX) and somewhere +around [1M lines](https://www.raspberrypi.org/forums/viewtopic.php?t=53007#p406247) +worth of firmware code. + +There are different versions of `start.elf`. The one called `start_x.elf` +contains an additional driver for the camera interface, `start_db.elf` is a +debug version and `start_cd.elf` is a version with a cut-down memory layout. + +In the end, the GPU firmware loads and parses a file called `config.txt` from +the SD card, which contains configuration parameters, and `cmdline.txt` which +contains the kernel command line. After parsing the configuration, it finally +loads the kernel, the initrd, the device tree binaries and runs the kernel. + +### Copying the Files Over + +First, we need a micro SD card with a FAT32 partition on it. How to create the +partition is left as an exercise to the reader. + +Onto this partition, we copy the proprietary boot loader blobs: + +* [bootcode.bin](firmware/bootcode.bin) +* [fixup.dat](firmware/fixup.data) +* [start.elf](firmware/start.elf) + +We create a minimal [config.txt](firmware/config.txt) in the root directory: + +	dtparam= +	kernel=zImage +	initramfs initrd.xz followkernel + +The first line makes sure the boot loader doesn't mangle the device tree. The +second one specifies the kernel binary that should be loaded and the last one +specifies the initrd image. Note that there is no `=` sign in the last +line. This field has a different format and the boot loader will ignore it if +there is an `=` sign. The `followkernel` attribute tells the boot loader to put +the initrd into memory right after the kernel binary. + +Then, we'll put the [cmdline.txt](firmware/cmdline.txt) onto the SD card: + +	console=tty0 + +The `console` parameter tells the kernel what to use as a console device. We +tell it to use the first video console which is what we will get at the HDMI +output of the Raspberry Pi. + +Whats left is the device tree binaries and lastly the kernel and initrd: + +    mkdir -p overlays +    cp $SYSROOT/boot/dts/*-rpi-3-*.dtb . +    cp $SYSROOT/boot/dts/overlays/*.dtbo overlays/ + +    cp $SYSROOT/boot/initrd.xz . +    cp $SYSROOT/boot/zImage . + +If you are done, unmount the micro SD card and plug it into your Raspberr Pi. + + +### Booting It Up + +If you connect the HDMI port and power up the Raspberry Pi, it should boot +directly into the initrd and you should get a BusyBox shell. + +The PATH is propperly set and the most common shell commands should be there, so +you can poke around the root filesystem which is in memory and has been unpacked +from the `initrd.xz`. | 
