1
1
mirror of https://github.com/OpenVoiceOS/OpenVoiceOS synced 2025-01-23 23:32:48 +01:00
OpenVoiceOS/buildroot-external/board/raspberrypi
j1nx 470fd58d98 Switch to a voluntary kernel preemption.
The respeaker mic hats and possibly (many) others are using the
x-powers ac108 adc chip however the driver of this chip is not
compatible with 64bit PREEMPT kernels crashing the drivers with
"BUG: scheduling while atomic" spinlock issues.

PREEMPT is used for low latency desktops
PREEMPT_NONE is used for servers

As we are not a (low-latency needed) desktop however not a server
as well, the middle ground actually works perfectly fine with
the benefit of having a more stable respeaker driver.

This accounts for ALL different respeaker HATs except the 2-mic
as that one is based on the WM8960 chip which is actually already
supported mainline if you want anyway.
2022-02-09 14:15:41 +01:00
..
rootfs-overlay Forgot execute right for screencheck 2022-01-29 16:04:23 +01:00
cmdline.txt Feature/rpi3 (#98) 2022-01-19 15:50:19 +01:00
config.txt Disable TV composite out 2022-01-28 09:58:05 +01:00
genimage-raspberrypi0.cfg MycroftOS: Initial setup for rpi3 2018-10-26 19:51:01 +02:00
genimage-raspberrypi0w.cfg MycroftOS: Initial setup for rpi3 2018-10-26 19:51:01 +02:00
genimage-raspberrypi2.cfg MycroftOS: Initial setup for rpi3 2018-10-26 19:51:01 +02:00
genimage-raspberrypi3-64.cfg Feature/rpi3 (#98) 2022-01-19 15:50:19 +01:00
genimage-raspberrypi3.cfg MycroftOS: Initial setup for rpi3 2018-10-26 19:51:01 +02:00
genimage-raspberrypi4-64.cfg Increase initial boot and rootfs partition sizes 2021-03-04 13:20:54 +01:00
genimage-raspberrypi4.cfg MycroftOS: Add RPI4 support. 2019-12-10 11:13:25 +01:00
genimage-raspberrypi.cfg MycroftOS: Initial setup for rpi3 2018-10-26 19:51:01 +02:00
kernel.config Switch to a voluntary kernel preemption. 2022-02-09 14:15:41 +01:00
post-build.sh Feature/rpi3 (#98) 2022-01-19 15:50:19 +01:00
post-image.sh MycroftOS: Initial start of 64bit for RPI4 2020-04-11 16:23:59 +02:00
readme.txt MycroftOS: Add RPI4 support. 2019-12-10 11:13:25 +01:00

Raspberry Pi

Intro
=====

These instructions apply to all models of the Raspberry Pi:
  - the original models A and B,
  - the "enhanced" models A+ and B+,
  - the model B2 (aka Raspberry Pi 2)
  - the model B3 (aka Raspberry Pi 3).
  - the model B4 (aka Raspberry Pi 4).

How to build it
===============

Configure Buildroot
-------------------

There are two RaspberryPi defconfig files in Buildroot, one for each
major variant, which you should base your work on:

For models A, B, A+ or B+:

  $ make raspberrypi_defconfig

For model Zero (model A+ in smaller form factor):

  $ make raspberrypi0_defconfig

For model 2 B:

  $ make raspberrypi2_defconfig

For model 3 B and B+:

  $ make raspberrypi3_defconfig

For model 4 B:

  $ make raspberrypi4_defconfig

Build the rootfs
----------------

Note: you will need to have access to the network, since Buildroot will
download the packages' sources.

You may now build your rootfs with:

  $ make

(This may take a while, consider getting yourself a coffee ;-) )

Result of the build
-------------------

After building, you should obtain this tree:

    output/images/
    +-- bcm2708-rpi-b.dtb           [1]
    +-- bcm2708-rpi-b-plus.dtb      [1]
    +-- bcm2709-rpi-2-b.dtb         [1]
    +-- bcm2710-rpi-3-b.dtb         [1]
    +-- bcm2710-rpi-3-b-plus.dtb    [1]
    +-- bcm2711-rpi-4-b.dtb         [1]
    +-- boot.vfat
    +-- rootfs.ext4
    +-- rpi-firmware/
    |   +-- bootcode.bin
    |   +-- cmdline.txt
    |   +-- config.txt
    |   +-- fixup.dat
    |   +-- start.elf
    |   `-- overlays/               [2]
    +-- sdcard.img
    `-- zImage

[1] Not all of them will be present, depending on the RaspberryPi
    model you are using.

[2] Only for the Raspberry Pi 3/4 Models (overlay pi3-miniuart-bt is needed
    to enable the RPi3 serial console otherwise occupied by the bluetooth
    chip). Alternative would be to disable the serial console in cmdline.txt
    and /etc/inittab.

How to write the SD card
========================

Once the build process is finished you will have an image called "sdcard.img"
in the output/images/ directory.

Copy the bootable "sdcard.img" onto an SD card with "dd":

  $ sudo dd if=output/images/sdcard.img of=/dev/sdX

Insert the SDcard into your Raspberry Pi, and power it up. Your new system
should come up now and start two consoles: one on the serial port on
the P1 header, one on the HDMI output where you can login using a USB
keyboard.