-
Notifications
You must be signed in to change notification settings - Fork 5.1k
Upstreaming
This document details the effort to move to ARCH_BCM2835 and get drivers upstream.
ARCH_BCM2835
Mailing list: http://lists.infradead.org/mailman/listinfo/linux-rpi-kernel
Maintainer: Stephen Warren
Lubomir Rintel is doing work on several drivers: https://github.com/hackerspace/rpi-linux/commits/lr-vchiq-new-mailbox
Discussion: Issue #627
If you have knowledge in this area, please contribute. Consider using strikethrough instead of deleting things you regard as wrong/outdated.
Status Table
Component | Status | Assigned To | Comments | Meta Comments |
---|---|---|---|---|
Audio | Depends on DMA and/or Mailbox - codec/digi/dac | Which one(s) | ||
Framebuffer | replace with DRM eventually | Depends on Mailbox | ||
GPU (DRM) | execution ready soon, modesetting will take longer | anholt | Depends on Mailbox until modesetting is ready | |
HWMON | Depends on DMA and/or Mailbox | Which one(s) | ||
VCHIQ | Depends on DMA and/or Mailbox and/or vchiq | Which one(s) | ||
Power (?) | More info req'd | Depends on DMA and/or Mailbox | Which one(s) | |
CPUFreq | WIP | lkundrak | Depends on DMA and/or Mailbox | Which one(s) |
Mailbox | WIP | lkundrak | Depends on Mailbox API | bcm2708_vcio |
Thermal | WIP | lkundrak | Depends on DMA and/or Mailbox | Which one(s) |
MMC | Semi-Upstreamed | drivers/mmc/host/sdhci-bcm2835.c | Which one(s) | |
Clock Source | Upstreamed | drivers/clocksource/bcm2835_timer.c | ||
Common Clk | Upstreamed | drivers/clk/clk-bcm2835.c | ||
DMA | Upstreamed | drivers/dma/bcm2835-dma.c - less FIQ sup't | ||
I2C | Upstreamed | drivers/i2c/busses/i2c-bcm2835.c | ||
IRQ | Upstreamed | drivers/irqchip/irq-bcm2835.c | ||
I2S (Audio) | Upstreamed | sound/soc/bcm/bcm2835-i2s.c | ||
Pinctrl | Upstreamed | drivers/pinctrl/pinctrl-bcm2835.c | ||
Random NG | Upstreamed | drivers/char/hw_random/bcm2835-rng.c | ||
SPI | Upstreamed | drivers/spi/spi-bcm2835.c | ||
Watchdog | Upstreamed | drivers/watchdog/bcm2835_wdt.c | ||
LEDs | Pre-Upstreamed | drivers/leds/leds-gpio.c | ||
Serial | Pre-Upstreamed | drivers/tty/serial/amba-pl011.c |
DMA
bcm2835-dma (bcm2708-dmaengine OK)
Mailbox
bcm2835-mbox (work in progress)
Waiting for the Mailbox API to be included (now in linux-next).
Drivers depending on DMA and/or Mailbox
bcm2708_fb
bcm2835-mmc (OK)
bcm2835_hwmon (this is not upstream)
bcm2835-thermal (work in progress)
bcm2835-cpufreq (work in progress)
vchiq (a DT hack exists)
sound/arm/bcm2835.c (a DT hack exists, depends on vchiq)
drivers/gpu/drm/vc4 (rebase to upstream 2835+mailbox in progress) status of userspace
Drivers already upstream
irq-bcm2835 (no FIQ support)
pinctrl-bcm2835
spi-bcm2835
i2c-bcm2835
bcm2835_wdt
bcm2835-rng
bcm2835-i2s
Work is ongoing to get the bootloader to boot the vanilla kernel.
Several features that would make life easier regarding runtime editing of the DTB are not yet implemented. Currently, VC4 bootloader cannot:
- Add nodes to the DTB
- Remove nodes from the DTB
- Resize the DTB in-place (requires that padding is used in the devicetree.dtb file).
The Videocore bootloader now supports the GPIOMAN configuration interface. This is the initial setup of GPIO pins done on boot by VC prior to booting the ARM: necessary for compute module implementations.
This is a devicetree-based videocore-only setup that is parsed independently of the elements that the ARM cares about. Details to be released in due course.
Role: Interrupt driver
BCM2708: armctrl
BCM2835: irq-bcm2835
irq-bcm2835 lacks FIQ support (PM33).
Role: BCM2708 clock implementation
BCM2708: clock
BCM2835: clk-bcm2835.c
BCM2708 is now using the Common Clock Framework: PR #630
Role: DMA driver
BCM2708: bcm2708_dma
BCM2835: bcm2835-dma
How does bcm2708_dma relate to bcm2708-dmaengine?
- bcm2708_dma is an allocate-release driver to prevent trampling on Videocore channels. Becomes obsolete if the dma channels are passed in via the devicetree and parsed by bcm2835-dmaengine - a "status" property would mark which channels are reserved for VC4 use.
Role: Power driver
BCM2708: bcm2708_power
BCM2835: NYI
Chip power and clocking are currently under the exclusive control of Videocore. There is no documentation released for the power/clock domain management engines.
This driver provides a mailbox interface to power up/down the domains that notionally belong to the ARM, however currently this is not used by any of the peripheral drivers.
Role:
BCM2708: vc-mem
- Userspace helper to get videocore mem addresses. What uses this?
Role: Mailbox driver
BCM2708: bcm2708_vcio
BCM2835:
WIP: bcm2835-mbox
This is waiting for the Mailbox API to be included:
- [linux-next] mailbox: Introduce framework for mailbox (2014-09-16)
- [PATCHv10 0/4] Common Mailbox Framework (2014-08-01)
Role: SPI master driver
BCM2708: spi-bcm2708
BCM2835: spi-bcm2835
spi-bcm2708 has 9-bit support implemented with the LoSSI mode. spi-bcm2835 doesn't have this. LoSSI mode isn't a general purpose 9-bit SPI, because some values triggers an automatic read by the controller. It is used with MIPI DBI type C interface compatible LCD controllers.
Role: I2C bus driver
BCM2708: i2c-bcm2708
BCM2835: i2c-bcm2835
Role: DMA Engine
BCM2708: bcm2708-dmaengine
BCM2835: bcm2835-dma
Both drivers are the work of Florian Meier and are probably similar.
This driver only supports cyclic DMA transfers, which is mainly for sound cards?
It seems slave_sg support is needed for MMC/FBDEV etc. (notro)
Alternative dmaengine driver: https://github.com/lp0/linux/blob/986c15594ae813839189a3cf9fde9da2511ca1c3/drivers/dma/bcm2708_dma.c
Internally, we have expanded the upstream dmaengine driver to include slave_sg support. To be submitted to the kernel mailing lists. (P33M)
slave_sg support added to bcm2708-dmaengine: dmaengine: expand functionality by supporting scatter/gather transfers
Role: Kernel to VideoCore communication interface
BCM2708: vchiq
Hack: vchiq
Role: MMC driver
BCM2708: sdhci-bcm2708
BCM2835: sdhci-bcm2835
My brief testing of sdhci-bcm2835, gave write speeds around 700 kB/s. (notro)
sdhci-bcm2708 uses DMA.
Upstream sdhci-bcm2835 is limited to PIO mode. There is no inherent support for using "platform DMA" to perform block transfers. To implement DMA mode in the upstream version, a mmc-layer driver needs to be created (several other platforms have this and use DMA in a similar fashion) mmc-bcm2835 work underway. Depends on slave_sg support in bcm2835-dmaengine.
- Internally we have implemented an mmc-bcm2835 driver. This seems to be the preferred method of implementing drivers for hardware that have varying (read: broken) implementations of the SD specification. The driver is working well with performance substantially superior to PIO mode, though it hasn't had the 2 years of testing that the bcm2708 driver has. To be submitted to the kernel mailing lists. (P33M)
bcm2835-mmc added: MMC: added alternative MMC driver
Role: GPIO driver
BCM2708: bcm2708_gpio
BCM2835: pinctrl-bcm2835
Role: Framebuffer driver
BCM2708: bcm2708_fb
BCM2835:
bcm2708_fb uses DMA. To implement on mach-bcm2835, slave_sg support (also possibly DMA memcpy) required in bcm2835-dmaengine.
- With the updates to bcm2835-dmaengine, bcm2835-fb has a dependency only on the mailbox interface. (P33M)
Role: Watchdog driver
BCM2708: bcm2708_wdog
BCM2835: bcm2835_wdt
Role: Random Number Generator driver
BCM2708: bcm2708-rng
BCM2835: bcm2835-rng
Role: Hardware Monitoring
BCM2708: bcm2835_hwmon
Adding DT support is trivial.
Dependency on an upstreamed mailbox interface (P33M).
Role: Thermal Management
BCM2708: bcm2835_thermal
BCM2835:
WIP: bcm2835-thermal
Adding DT support is trivial.
Dependency on an upstreamed mailbox interface (P33M).
Role: Audio
BCM2708: sound/arm/bcm2835.c
Hack: bcm2835-audio
Adding DT support is trivial.
Dependency on an upstreamed mailbox interface (and vchiq) (P33M).
Role: Audio I2S module
BCM2708: bcm2708-i2s
BCM2835: bcm2835-i2s
Role: Audio
BCM2708: hifiberry_dac
Also adds device: pcm5102a-codec
Not a device associated with the platform. Can be added to the DT if attached (P33M).
Role: Audio BCM2708: hifiberry_digi
Has this as well in bcm2708.c
I2C_BOARD_INFO("wm8804", 0x3b)
Not a device associated with the platform. Can be added to the DT if attached (P33M).
Role: Audio
BCM2708: rpi-dac
Also adds device: pcm1794a-codec
Not a device associated with the platform. Can be added to the DT if attached (P33M).
Role: Audio
BCM2708: iqaudio-dac
Has this as well in bcm2708.c
I2C_BOARD_INFO("pcm5122", 0x4c)
Source: arch/arm/mach-bcm2708/bcm2708.c
Driver: w1-gpio
Device Tree: yes (bindings)
Using bcmrpi_defconfig, a w1_device is added on GPIO4 with no pullup enable pin.
Module parameters:
module_param(w1_gpio_pin, uint, 0644);
module_param(w1_gpio_pullup, uint, 0644);
Role: Serial console
Device: dev:f1
Device Tree: yes (see bcm2835.dtsi)
Module parameter:
module_param(uart_clock, uint, 0644);
Device: serial8250
Driver: 8250
bcmrpi_defconfig doesn't include CONFIG_SERIAL_8250
Driver: leds-gpio
Device Tree: yes (see bcm2835-rpi-b.dts)
ACT led
Trigger: mmc0
Module parameters:
module_param(disk_led_gpio, uint, 0644);
module_param(disk_led_active_low, uint, 0644);
Module parameters:
module_param(boardrev, uint, 0644);
module_param(serial, uint, 0644);
$ cat /proc/cpuinfo
Revision : 000e
Serial : 000000004939788f
Used on poweroff to tell the bootloader to halt.
Module parameter:
module_param(reboot_part, uint, 0644);
Fork this repo, make your changes, then send us a pull request
One caveat. If you are making changes to upstream code (i.e. with no changes specific to Raspberry Pi devices), then it's best to submit your changes upstream, then when they are accepted, we can cherry-pick them back to our branches here.
- Shortcuts to other Raspberry Pi pages
- Official Website
- Official Forum
- Official Website Documentation
- Documentation Repository
-
Firmware Repository
- For reporting issues with the Raspberry Pi VC4/6 firmware.
-
Userland Repository
- For reporting issues with the Raspberry Pi supplied userland apps.
-
Raspbian distro Repository
- For reporting issues with the Raspbian distribution and desktop.