mirror of
https://github.com/linux-sunxi/meta-sunxi.git
synced 2024-11-16 10:18:23 +01:00
cddadc1f4b
Experimental feature to include DT overlays and custom boot args
156 lines
5.5 KiB
Markdown
156 lines
5.5 KiB
Markdown
meta-sunxi
|
|
==============
|
|
|
|
Official sunxi OpenEmbedded layer for Allwinner-based boards.
|
|
|
|
This layer depends on the additional layers:
|
|
|
|
* [meta-openembedded/meta-oe](http://git.openembedded.org/meta-openembedded/tree/meta-oe)
|
|
|
|
Tested with core-image-base.
|
|
|
|
Maintainers:
|
|
|
|
* Nicolas Aguirre <aguirre.nicolas@gmail.com>
|
|
* Enrico Butera <ebutera@users.sourceforge.net>
|
|
* Sergey Lapin <slapin@ossfans.org>
|
|
* Marek Belisko <marek.belisko@gmail.com>
|
|
|
|
Community
|
|
===========
|
|
|
|
You can reach community + ask your question on gitter: https://matrix.to/#/#meta-sunxi:gitter.im
|
|
|
|
Kernel / U-Boot Version
|
|
===========
|
|
Most Allwinner devices and hardware are supported in mainline kernel and U-Boot, so this layer builds mainline by default.
|
|
|
|
Legacy sunxi Kernel / U-Boot
|
|
-----------
|
|
|
|
There is a custom U-Boot and Kernel version for sunxi devices which includes some special drivers not mainlined.
|
|
These versions are rather old (3.4 for kernel and 2014.04 for U-Boot), but may support more functions and devices than current mainline.
|
|
|
|
If you want to switch back to sunxi versions for some reasons (no device tree available, unsupported hardware), either:
|
|
- change the file conf/machine/include/sunxi.inc to include the following block
|
|
- edit your conf/local.conf to add the following block
|
|
|
|
PREFERRED_PROVIDER_u-boot="u-boot-sunxi"
|
|
PREFERRED_PROVIDER_virtual/bootloader="u-boot-sunxi"
|
|
PREFERRED_PROVIDER_virtual/kernel="linux-sunxi"
|
|
KERNEL_DEVICETREE = ""
|
|
|
|
If you already have built the mainline versions it might be necessary to reset the build directories with:
|
|
|
|
bitbake -c clean virtual/kernel virtual/bootloader
|
|
|
|
Mainline Kernel / U-Boot
|
|
-----------
|
|
|
|
For mainline kernel we have now support for latest LTS and stable.
|
|
By default we use latest LTS. If you would like to change version please update ```PREFERRED_VERSION_linux-mainline``` in:
|
|
* [conf/machine/include/sunxi.inc](https://github.com/linux-sunxi/meta-sunxi/blob/fa0846c0eb23e3424b89acb4d5a327e921f73497/conf/machine/include/sunxi.inc#L16)
|
|
|
|
When using mainline kernel ≥ 5.2 it is now possible to use the mainline graphics drivers *lima* and *panfrost*, instead of the *mali* driver provided by ARM. To enable open source mainline graphics support add the following line in your `local.conf`:
|
|
|
|
MACHINEOVERRIDES .= ":use-mailine-graphics"
|
|
|
|
Performance
|
|
===========
|
|
The default machine settings are meant to be the lowest common denominator, maximizing generality.
|
|
Significantly better performance (2x-3x) can be achieved with the following settings:
|
|
|
|
**_Allwinner A20_**
|
|
|
|
For Allwinner A20 (Cubieboard2/CubieTruck), the following tuning options are recommended:
|
|
|
|
_Enable hardfloat, thumb2 and neon capabilities_
|
|
|
|
DEFAULTTUNE = "cortexa7hf-neon-vfpv4"
|
|
|
|
This tuning profile takes advantage of the Allwinner A20 hardfloat, neon and vfpv4 capabilities.
|
|
|
|
_Change CPU governor to ondemand, and tune settings_
|
|
|
|
echo ondemand > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
|
|
echo 336000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
|
|
echo 912000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq
|
|
#More aggressive
|
|
#echo 1008000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq
|
|
echo 40 > /sys/devices/system/cpu/cpufreq/ondemand/up_threshold
|
|
echo 200000 > /sys/devices/system/cpu/cpufreq/ondemand/sampling_rate
|
|
|
|
This code changes the default CPU governor from _fantasy_ to _ondemand_, and tunes its settings, as recommended at http://linux-sunxi.org/Cpufreq
|
|
|
|
For additional discussion, see https://github.com/linux-sunxi/meta-sunxi/issues/25
|
|
|
|
Custom boot environment & devicetree overlay suppport
|
|
=====================================================
|
|
|
|
The layer provide a basic custom enviroment for linux mainline that enables:
|
|
|
|
- Custom boot argument to be passed to the kernel.
|
|
- Basic devicetree overlay support.
|
|
|
|
By default this features are disabled and have to be activated including this the bitbake configuration (e.g. local.conf):
|
|
|
|
```
|
|
DISTRO_FEATURES:append = " sunxi-env"
|
|
```
|
|
|
|
This feature instruct the layer to deploy the file ``` /boot/sunxienv.txt ``` that is loaded during boot customize kernel boot command line.
|
|
|
|
DT Overlay support
|
|
------------------
|
|
|
|
To enable overlays the following line must be activated in bitbake configuration (e.g. local.conf):
|
|
|
|
```
|
|
SUNXI_OVERLAYS_ENABLE:append = " <space separeted list with the desired overlay names without .dts>"
|
|
```
|
|
|
|
The layer includes a common set for DT overalys organized by family. The list can be found in the
|
|
following path ```meta-sunxi/recipes-bs/sunxi-overlays/files/<socfamily>/<dts file>```
|
|
|
|
Once activated the following content will be added to yout image in the boot partition:
|
|
```
|
|
/boot/dtbo/*.dbto (all compiled overlays selected in SUNXI_OVERLAYS_ENABLE)
|
|
/boot/sunxienv.txt (uboot config file with the full list of devicetree overlays)
|
|
```
|
|
|
|
```/boot/sunxienv.txt``` can be modified after the build to activate or deactive the overlays on boot to provide
|
|
runtime flexibility or for debugging. A ```.dbto``` file can be also loaded at runtime
|
|
if the kernel supports it via sysfs interface using ```cat [dbto file] > /sys/kernel/config/device-tree/overlays/```
|
|
|
|
|
|
Adding custom DT overlays
|
|
-------------------------
|
|
It is possible to add custom overlay/s via a ```bbappend``` recipe.
|
|
|
|
```
|
|
recipies-bsp
|
|
- sunxi-overlays
|
|
- sunxi-overlays%.bbappend
|
|
- files
|
|
- <custom.dts>
|
|
|
|
Inside the .bbappend the following metadata is requried:
|
|
|
|
```
|
|
FILESEXTRAPATHS:prepend := "${THISDIR}/files:"
|
|
SRC_URI:${SOC_FAMILY}:append = " file://<custom.dts>"
|
|
```
|
|
|
|
Don't forget to add the custom overlay in your image or local configuration:
|
|
|
|
```
|
|
SUNXI_OVERLAYS_ENABLED:append = " <custom>"
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|