Allwinner arm64 DT changes for 4.19
Some interesting changes, especially: - MMC support for the H6 - PMIC support for the PineH64 - HDMI simplefb support for the A64 - PWM support for the A64 - New board: Pinebook, Amarula A64-Relic -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEE0VqZU19dR2zEVaqr0rTAlCFNr3QFAltXJZEACgkQ0rTAlCFN r3RIsw/8DUoWIlnSocPpRkBSonV55iC0qY4JKjamm/TrhQY5k4MjpX+7/PIyGQAU uNHn6vOmRILOyQS5Zg+1uWLOPypdxI2aDcQUKYNPdNJ6RytdgH1zghUM0iupOuNb CnolLpaA5RGjDvH/MarBwBoyxrAvnhLB/d5naUjzO/zoaw5j4K9idJdneJNX/aBi nezBGxWzjF0Mu1MmFhRUZD9klZcbeUtJK4sJ4yJeKUThoi1kKynpbXvONDB5wL9L JDVdWeNYrG3ylNHyAezOMM8gezGxSGjfya8zAaOZj/Wo5uvSDG4+oFaoJU2b+uPu pdHO1pNGgw57HS6ePm/ON8J4U7v8Z99sRK3BZ+3NjxL3nRsvL5jzfZtSnza6v7gb ONLlk89entDHDmtugpYYRWyw3GECv+1+oqBTngyRK9rctcFxrCsymx9cyHX7OWPC M521xUHKL84zoFMmvXPKlMHapH+I70k+a6n5kRljQ9/lbKgnjsvenZerEUB41xvV B2GXdo4MrZS/UYiPpD585InpoXmqC44cp7SOyXtUETAQ/pOQAbqE3cXHpVLnlUX9 yZfjCK6P6tp+lP9B0pFekIlzjhuUnhCqpNsTIp57ionGYRyK7oSVMOr2bf361vXZ RBLNbQ+43G8IXPKItRLOFuYNHXQlyi7GR5LnLx/UbDcU3IKhj4w= =MH+c -----END PGP SIGNATURE----- Merge tag 'sunxi-dt64-for-4.19' of https://git.kernel.org/pub/scm/linux/kernel/git/sunxi/linux into next/dt Allwinner arm64 DT changes for 4.19 Some interesting changes, especially: - MMC support for the H6 - PMIC support for the PineH64 - HDMI simplefb support for the A64 - PWM support for the A64 - New board: Pinebook, Amarula A64-Relic * tag 'sunxi-dt64-for-4.19' of https://git.kernel.org/pub/scm/linux/kernel/git/sunxi/linux: (22 commits) arm64: allwinner: h6: enable MMC0/2 on Pine H64 arm64: allwinner: h6: add device tree nodes for MMC controllers dt-binding: mmc: sunxi: add H6 compatible (with A64 fallback) arm64: dts: allwinner: a64: Remove unused address-cells/size-cells of dwmac-sun8i arm64: dts: allwinner: h6: enable AXP805 PMIC on Pine H64 arm64: dts: allwinner: h6: Use macros for R_CCU clock and reset indices arm64: dts: allwinner: a64: add HDMI regulator to all DTs' simplefb_hdmi arm64: dts: allwinner: a64: add device tree node for HDMI simplefb arm64: dts: allwinner: a64: add necessary device tree nodes for DE2 CCU arm64: dts: allwinner: h6: Add LED device nodes for Pine H64 arm64: allwinner: a64: allow laptops to wake up from lid arm64: allwinner: a64: change TERES-I DLDO3's name to start with "vdd" arm64: allwinner: a64-sopine: Add cd-gpios to mmc0 node arm64: dts: allwinner: a64: add SRAM controller device tree node arm64: dts: allwinner: add support for Pinebook arm64: dts: allwinner: a64: Add PWM controllers arm64: dts: allwinner: a64: add R_I2C controller arm64: allwinner: a64-amarula-relic: Enable AP6330 WiFi support arm64: allwinner: a64: Add RTC clock to phandle 32kHz external oscillator arm64: allwinner: a64: Add Amarula A64-Relic initial support ... Signed-off-by: Olof Johansson <olof@lixom.net>
This commit is contained in:
commit
74e828c891
|
@ -16,6 +16,8 @@ Required properties:
|
||||||
* "allwinner,sun9i-a80-mmc"
|
* "allwinner,sun9i-a80-mmc"
|
||||||
* "allwinner,sun50i-a64-emmc"
|
* "allwinner,sun50i-a64-emmc"
|
||||||
* "allwinner,sun50i-a64-mmc"
|
* "allwinner,sun50i-a64-mmc"
|
||||||
|
* "allwinner,sun50i-h6-emmc", "allwinner.sun50i-a64-emmc"
|
||||||
|
* "allwinner,sun50i-h6-mmc", "allwinner.sun50i-a64-mmc"
|
||||||
- reg : mmc controller base registers
|
- reg : mmc controller base registers
|
||||||
- clocks : a list with 4 phandle + clock specifier pairs
|
- clocks : a list with 4 phandle + clock specifier pairs
|
||||||
- clock-names : must contain "ahb", "mmc", "output" and "sample"
|
- clock-names : must contain "ahb", "mmc", "output" and "sample"
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-amarula-relic.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-bananapi-m64.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-bananapi-m64.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-nanopi-a64.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-nanopi-a64.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-olinuxino.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-olinuxino.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-orangepi-win.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-orangepi-win.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pine64-plus.dtb sun50i-a64-pine64.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pine64-plus.dtb sun50i-a64-pine64.dtb
|
||||||
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinebook.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-sopine-baseboard.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-sopine-baseboard.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-teres-i.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-teres-i.dtb
|
||||||
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h5-libretech-all-h3-cc.dtb
|
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h5-libretech-all-h3-cc.dtb
|
||||||
|
|
|
@ -0,0 +1,219 @@
|
||||||
|
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2018 Amarula Solutions B.V.
|
||||||
|
* Author: Jagan Teki <jagan@amarulasolutions.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
#include "sun50i-a64.dtsi"
|
||||||
|
|
||||||
|
#include <dt-bindings/gpio/gpio.h>
|
||||||
|
|
||||||
|
/ {
|
||||||
|
model = "Amarula A64-Relic";
|
||||||
|
compatible = "amarula,a64-relic", "allwinner,sun50i-a64";
|
||||||
|
|
||||||
|
aliases {
|
||||||
|
serial0 = &uart0;
|
||||||
|
};
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
stdout-path = "serial0:115200n8";
|
||||||
|
};
|
||||||
|
|
||||||
|
wifi_pwrseq: wifi-pwrseq {
|
||||||
|
compatible = "mmc-pwrseq-simple";
|
||||||
|
clocks = <&rtc 1>;
|
||||||
|
clock-names = "ext_clock";
|
||||||
|
reset-gpios = <&r_pio 0 2 GPIO_ACTIVE_LOW>; /* WL-PMU-EN: PL2 */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&ehci0 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc1_pins>;
|
||||||
|
vmmc-supply = <®_dcdc1>;
|
||||||
|
/*
|
||||||
|
* Schematic shows both dldo4 and eldo1 connected for vcc-io-wifi, but
|
||||||
|
* dldo4 connection shows DNP(Do Not Populate) and eldo1 connected with
|
||||||
|
* 0Ohm register to vcc-io-wifi so eldo1 is used.
|
||||||
|
*/
|
||||||
|
vqmmc-supply = <®_eldo1>;
|
||||||
|
mmc-pwrseq = <&wifi_pwrseq>;
|
||||||
|
bus-width = <4>;
|
||||||
|
non-removable;
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
brcmf: wifi@1 {
|
||||||
|
reg = <1>;
|
||||||
|
compatible = "brcm,bcm4329-fmac";
|
||||||
|
interrupt-parent = <&r_pio>;
|
||||||
|
interrupts = <0 3 IRQ_TYPE_LEVEL_LOW>; /* WL-WAKE-AP: PL3 */
|
||||||
|
interrupt-names = "host-wake";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc2_pins>;
|
||||||
|
vmmc-supply = <®_dcdc1>;
|
||||||
|
bus-width = <8>;
|
||||||
|
non-removable;
|
||||||
|
cap-mmc-hw-reset;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&ohci0 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&r_rsb {
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
axp803: pmic@3a3 {
|
||||||
|
compatible = "x-powers,axp803";
|
||||||
|
reg = <0x3a3>;
|
||||||
|
interrupt-parent = <&r_intc>;
|
||||||
|
interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
|
||||||
|
x-powers,drive-vbus-en; /* set N_VBUSEN as output pin */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
#include "axp803.dtsi"
|
||||||
|
|
||||||
|
®_aldo1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <2800000>;
|
||||||
|
regulator-max-microvolt = <2800000>;
|
||||||
|
regulator-name = "avdd-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_aldo2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-pl";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_aldo3 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3000000>;
|
||||||
|
regulator-max-microvolt = <3000000>;
|
||||||
|
regulator-name = "vcc-pll-avcc";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-3v3";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1040000>;
|
||||||
|
regulator-max-microvolt = <1300000>;
|
||||||
|
regulator-name = "vdd-cpux";
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DCDC3 is polyphased with DCDC2 */
|
||||||
|
|
||||||
|
®_dcdc5 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1500000>;
|
||||||
|
regulator-max-microvolt = <1500000>;
|
||||||
|
regulator-name = "vcc-dram";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc6 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1100000>;
|
||||||
|
regulator-max-microvolt = <1100000>;
|
||||||
|
regulator-name = "vdd-sys";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo1 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-hdmi-dsi-sensor";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo2 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-mipi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo3 {
|
||||||
|
regulator-min-microvolt = <2800000>;
|
||||||
|
regulator-max-microvolt = <2800000>;
|
||||||
|
regulator-name = "dovdd-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo4 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-wifi-io";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_drivevbus {
|
||||||
|
regulator-name = "usb0-vbus";
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_eldo1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "cpvdd";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_eldo3 {
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "dvdd-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_fldo1 {
|
||||||
|
regulator-min-microvolt = <1200000>;
|
||||||
|
regulator-max-microvolt = <1200000>;
|
||||||
|
regulator-name = "vcc-1v2-hsic";
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The A64 chip cannot work without this regulator off, although
|
||||||
|
* it seems to be only driving the AR100 core.
|
||||||
|
* Maybe we don't still know well about CPUs domain.
|
||||||
|
*/
|
||||||
|
®_fldo2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1100000>;
|
||||||
|
regulator-max-microvolt = <1100000>;
|
||||||
|
regulator-name = "vdd-cpus";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_rtc_ldo {
|
||||||
|
regulator-name = "vcc-rtc";
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usb_otg {
|
||||||
|
dr_mode = "otg";
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphy {
|
||||||
|
usb0_id_det-gpios = <&pio 7 9 GPIO_ACTIVE_HIGH>; /* PH9 */
|
||||||
|
usb0_vbus-supply = <®_drivevbus>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
|
@ -296,6 +296,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -195,6 +195,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -214,6 +214,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -191,6 +191,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -229,6 +229,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
/* On Euler connector */
|
/* On Euler connector */
|
||||||
&spdif {
|
&spdif {
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
|
@ -0,0 +1,285 @@
|
||||||
|
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.xyz>
|
||||||
|
* Copyright (C) 2018 Vasily Khoruzhick <anarsoul@gmail.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
#include "sun50i-a64.dtsi"
|
||||||
|
|
||||||
|
#include <dt-bindings/gpio/gpio.h>
|
||||||
|
#include <dt-bindings/input/input.h>
|
||||||
|
#include <dt-bindings/pwm/pwm.h>
|
||||||
|
|
||||||
|
/ {
|
||||||
|
model = "Pinebook";
|
||||||
|
compatible = "pine64,pinebook", "allwinner,sun50i-a64";
|
||||||
|
|
||||||
|
aliases {
|
||||||
|
serial0 = &uart0;
|
||||||
|
ethernet0 = &rtl8723cs;
|
||||||
|
};
|
||||||
|
|
||||||
|
backlight: backlight {
|
||||||
|
compatible = "pwm-backlight";
|
||||||
|
pwms = <&pwm 0 50000 0>;
|
||||||
|
brightness-levels = <0 5 10 15 20 30 40 55 70 85 100>;
|
||||||
|
default-brightness-level = <2>;
|
||||||
|
enable-gpios = <&pio 3 23 GPIO_ACTIVE_HIGH>; /* PD23 */
|
||||||
|
};
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
stdout-path = "serial0:115200n8";
|
||||||
|
|
||||||
|
framebuffer-lcd {
|
||||||
|
panel-supply = <®_dc1sw>;
|
||||||
|
dvdd25-supply = <®_dldo2>;
|
||||||
|
dvdd12-supply = <®_fldo1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
gpio_keys {
|
||||||
|
compatible = "gpio-keys";
|
||||||
|
|
||||||
|
lid_switch {
|
||||||
|
label = "Lid Switch";
|
||||||
|
gpios = <&r_pio 0 12 GPIO_ACTIVE_LOW>; /* PL12 */
|
||||||
|
linux,input-type = <EV_SW>;
|
||||||
|
linux,code = <SW_LID>;
|
||||||
|
linux,can-disable;
|
||||||
|
wakeup-source;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_vcc3v3: vcc3v3 {
|
||||||
|
compatible = "regulator-fixed";
|
||||||
|
regulator-name = "vcc3v3";
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
wifi_pwrseq: wifi_pwrseq {
|
||||||
|
compatible = "mmc-pwrseq-simple";
|
||||||
|
reset-gpios = <&r_pio 0 2 GPIO_ACTIVE_LOW>; /* PL2 */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&ehci0 {
|
||||||
|
phys = <&usbphy 0>;
|
||||||
|
phy-names = "usb";
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&ehci1 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc0_pins>;
|
||||||
|
vmmc-supply = <®_dcdc1>;
|
||||||
|
cd-gpios = <&pio 5 6 GPIO_ACTIVE_HIGH>;
|
||||||
|
cd-inverted;
|
||||||
|
disable-wp;
|
||||||
|
bus-width = <4>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc1_pins>;
|
||||||
|
vmmc-supply = <®_dldo4>;
|
||||||
|
vqmmc-supply = <®_eldo1>;
|
||||||
|
mmc-pwrseq = <&wifi_pwrseq>;
|
||||||
|
bus-width = <4>;
|
||||||
|
non-removable;
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
rtl8723cs: wifi@1 {
|
||||||
|
reg = <1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc2_pins>;
|
||||||
|
vmmc-supply = <®_dcdc1>;
|
||||||
|
vqmmc-supply = <®_eldo1>;
|
||||||
|
bus-width = <8>;
|
||||||
|
non-removable;
|
||||||
|
cap-mmc-hw-reset;
|
||||||
|
mmc-hs200-1_8v;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&ohci0 {
|
||||||
|
phys = <&usbphy 0>;
|
||||||
|
phy-names = "usb";
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&ohci1 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&pwm {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&r_rsb {
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
axp803: pmic@3a3 {
|
||||||
|
compatible = "x-powers,axp803";
|
||||||
|
reg = <0x3a3>;
|
||||||
|
interrupt-parent = <&r_intc>;
|
||||||
|
interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
/* The ANX6345 eDP-bridge is on r_i2c */
|
||||||
|
&r_i2c {
|
||||||
|
clock-frequency = <100000>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&r_i2c_pins_a>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
#include "axp803.dtsi"
|
||||||
|
|
||||||
|
®_aldo1 {
|
||||||
|
regulator-min-microvolt = <2800000>;
|
||||||
|
regulator-max-microvolt = <2800000>;
|
||||||
|
regulator-name = "vcc-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_aldo2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-pl";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_aldo3 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <2700000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-pll-avcc";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dc1sw {
|
||||||
|
regulator-name = "vcc-lcd";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-3v3";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1000000>;
|
||||||
|
regulator-max-microvolt = <1300000>;
|
||||||
|
regulator-name = "vdd-cpux";
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DCDC3 is polyphased with DCDC2 */
|
||||||
|
|
||||||
|
®_dcdc5 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1200000>;
|
||||||
|
regulator-max-microvolt = <1200000>;
|
||||||
|
regulator-name = "vcc-dram";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dcdc6 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1100000>;
|
||||||
|
regulator-max-microvolt = <1100000>;
|
||||||
|
regulator-name = "vdd-sys";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo1 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-hdmi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo2 {
|
||||||
|
regulator-min-microvolt = <2500000>;
|
||||||
|
regulator-max-microvolt = <2500000>;
|
||||||
|
regulator-name = "vcc-edp";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo3 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "avdd-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_dldo4 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-wifi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_eldo1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "cpvdd";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_eldo3 {
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "vdd-1v8-csi";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_fldo1 {
|
||||||
|
regulator-min-microvolt = <1200000>;
|
||||||
|
regulator-max-microvolt = <1200000>;
|
||||||
|
regulator-name = "vcc-1v2-hsic";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_fldo2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1100000>;
|
||||||
|
regulator-max-microvolt = <1100000>;
|
||||||
|
regulator-name = "vdd-cpus";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_ldo_io0 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-usb";
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
®_rtc_ldo {
|
||||||
|
regulator-name = "vcc-rtc";
|
||||||
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usb_otg {
|
||||||
|
dr_mode = "host";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphy {
|
||||||
|
usb0_vbus-supply = <®_ldo_io0>;
|
||||||
|
usb1_vbus-supply = <®_ldo_io0>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
|
@ -134,6 +134,10 @@
|
||||||
regulator-name = "vcc-wifi";
|
regulator-name = "vcc-wifi";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -45,6 +45,8 @@
|
||||||
|
|
||||||
#include "sun50i-a64.dtsi"
|
#include "sun50i-a64.dtsi"
|
||||||
|
|
||||||
|
#include <dt-bindings/gpio/gpio.h>
|
||||||
|
|
||||||
&mmc0 {
|
&mmc0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&mmc0_pins>;
|
pinctrl-0 = <&mmc0_pins>;
|
||||||
|
@ -52,6 +54,7 @@
|
||||||
non-removable;
|
non-removable;
|
||||||
disable-wp;
|
disable-wp;
|
||||||
bus-width = <4>;
|
bus-width = <4>;
|
||||||
|
cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -66,6 +69,18 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&spi0 {
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
flash@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
compatible = "jedec,spi-nor";
|
||||||
|
reg = <0>;
|
||||||
|
spi-max-frequency = <40000000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
#include "axp803.dtsi"
|
#include "axp803.dtsi"
|
||||||
|
|
||||||
®_aldo2 {
|
®_aldo2 {
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
gpios = <&r_pio 0 8 GPIO_ACTIVE_LOW>; /* PL8 */
|
gpios = <&r_pio 0 8 GPIO_ACTIVE_LOW>; /* PL8 */
|
||||||
linux,input-type = <EV_SW>;
|
linux,input-type = <EV_SW>;
|
||||||
linux,code = <SW_LID>;
|
linux,code = <SW_LID>;
|
||||||
|
wakeup-source;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -210,7 +211,7 @@
|
||||||
®_dldo3 {
|
®_dldo3 {
|
||||||
regulator-min-microvolt = <1200000>;
|
regulator-min-microvolt = <1200000>;
|
||||||
regulator-max-microvolt = <1200000>;
|
regulator-max-microvolt = <1200000>;
|
||||||
regulator-name = "eDP12";
|
regulator-name = "vdd-edp";
|
||||||
};
|
};
|
||||||
|
|
||||||
®_dldo4 {
|
®_dldo4 {
|
||||||
|
@ -253,6 +254,10 @@
|
||||||
regulator-name = "vcc-rtc";
|
regulator-name = "vcc-rtc";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&simplefb_hdmi {
|
||||||
|
vcc-hdmi-supply = <®_dldo1>;
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -43,9 +43,12 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <dt-bindings/clock/sun50i-a64-ccu.h>
|
#include <dt-bindings/clock/sun50i-a64-ccu.h>
|
||||||
|
#include <dt-bindings/clock/sun8i-de2.h>
|
||||||
#include <dt-bindings/clock/sun8i-r-ccu.h>
|
#include <dt-bindings/clock/sun8i-r-ccu.h>
|
||||||
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
||||||
#include <dt-bindings/reset/sun50i-a64-ccu.h>
|
#include <dt-bindings/reset/sun50i-a64-ccu.h>
|
||||||
|
#include <dt-bindings/reset/sun8i-de2.h>
|
||||||
|
#include <dt-bindings/reset/sun8i-r-ccu.h>
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
interrupt-parent = <&gic>;
|
interrupt-parent = <&gic>;
|
||||||
|
@ -57,17 +60,21 @@
|
||||||
#size-cells = <1>;
|
#size-cells = <1>;
|
||||||
ranges;
|
ranges;
|
||||||
|
|
||||||
/*
|
|
||||||
* The pipeline mixer0-lcd0 depends on clock CLK_MIXER0 from DE2 CCU.
|
|
||||||
* However there is no support for this clock on A64 yet, so we depend
|
|
||||||
* on the upstream clocks here to keep them (and thus CLK_MIXER0) up.
|
|
||||||
*/
|
|
||||||
simplefb_lcd: framebuffer-lcd {
|
simplefb_lcd: framebuffer-lcd {
|
||||||
compatible = "allwinner,simple-framebuffer",
|
compatible = "allwinner,simple-framebuffer",
|
||||||
"simple-framebuffer";
|
"simple-framebuffer";
|
||||||
allwinner,pipeline = "mixer0-lcd0";
|
allwinner,pipeline = "mixer0-lcd0";
|
||||||
clocks = <&ccu CLK_TCON0>,
|
clocks = <&ccu CLK_TCON0>,
|
||||||
<&ccu CLK_DE>, <&ccu CLK_BUS_DE>;
|
<&display_clocks CLK_MIXER0>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
|
simplefb_hdmi: framebuffer-hdmi {
|
||||||
|
compatible = "allwinner,simple-framebuffer",
|
||||||
|
"simple-framebuffer";
|
||||||
|
allwinner,pipeline = "mixer1-lcd1-hdmi";
|
||||||
|
clocks = <&display_clocks CLK_MIXER1>,
|
||||||
|
<&ccu CLK_TCON1>, <&ccu CLK_HDMI>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -168,10 +175,46 @@
|
||||||
#size-cells = <1>;
|
#size-cells = <1>;
|
||||||
ranges;
|
ranges;
|
||||||
|
|
||||||
|
de2@1000000 {
|
||||||
|
compatible = "allwinner,sun50i-a64-de2";
|
||||||
|
reg = <0x1000000 0x400000>;
|
||||||
|
allwinner,sram = <&de2_sram 1>;
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
ranges = <0 0x1000000 0x400000>;
|
||||||
|
|
||||||
|
display_clocks: clock@0 {
|
||||||
|
compatible = "allwinner,sun50i-a64-de2-clk";
|
||||||
|
reg = <0x0 0x100000>;
|
||||||
|
clocks = <&ccu CLK_DE>,
|
||||||
|
<&ccu CLK_BUS_DE>;
|
||||||
|
clock-names = "mod",
|
||||||
|
"bus";
|
||||||
|
resets = <&ccu RST_BUS_DE>;
|
||||||
|
#clock-cells = <1>;
|
||||||
|
#reset-cells = <1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
syscon: syscon@1c00000 {
|
syscon: syscon@1c00000 {
|
||||||
compatible = "allwinner,sun50i-a64-system-controller",
|
compatible = "allwinner,sun50i-a64-system-control";
|
||||||
"syscon";
|
|
||||||
reg = <0x01c00000 0x1000>;
|
reg = <0x01c00000 0x1000>;
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
ranges;
|
||||||
|
|
||||||
|
sram_c: sram@18000 {
|
||||||
|
compatible = "mmio-sram";
|
||||||
|
reg = <0x00018000 0x28000>;
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
ranges = <0 0x00018000 0x28000>;
|
||||||
|
|
||||||
|
de2_sram: sram-section@0 {
|
||||||
|
compatible = "allwinner,sun50i-a64-sram-c";
|
||||||
|
reg = <0x0000 0x28000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
dma: dma-controller@1c02000 {
|
dma: dma-controller@1c02000 {
|
||||||
|
@ -364,6 +407,11 @@
|
||||||
bias-pull-up;
|
bias-pull-up;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pwm_pin: pwm_pin {
|
||||||
|
pins = "PD22";
|
||||||
|
function = "pwm";
|
||||||
|
};
|
||||||
|
|
||||||
rmii_pins: rmii_pins {
|
rmii_pins: rmii_pins {
|
||||||
pins = "PD10", "PD11", "PD13", "PD14", "PD17",
|
pins = "PD10", "PD11", "PD13", "PD14", "PD17",
|
||||||
"PD18", "PD19", "PD20", "PD22", "PD23";
|
"PD18", "PD19", "PD20", "PD22", "PD23";
|
||||||
|
@ -608,8 +656,6 @@
|
||||||
clocks = <&ccu CLK_BUS_EMAC>;
|
clocks = <&ccu CLK_BUS_EMAC>;
|
||||||
clock-names = "stmmaceth";
|
clock-names = "stmmaceth";
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
#address-cells = <1>;
|
|
||||||
#size-cells = <0>;
|
|
||||||
|
|
||||||
mdio: mdio {
|
mdio: mdio {
|
||||||
compatible = "snps,dwmac-mdio";
|
compatible = "snps,dwmac-mdio";
|
||||||
|
@ -629,11 +675,25 @@
|
||||||
#interrupt-cells = <3>;
|
#interrupt-cells = <3>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pwm: pwm@1c21400 {
|
||||||
|
compatible = "allwinner,sun50i-a64-pwm",
|
||||||
|
"allwinner,sun5i-a13-pwm";
|
||||||
|
reg = <0x01c21400 0x400>;
|
||||||
|
clocks = <&osc24M>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&pwm_pin>;
|
||||||
|
#pwm-cells = <3>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
rtc: rtc@1f00000 {
|
rtc: rtc@1f00000 {
|
||||||
compatible = "allwinner,sun6i-a31-rtc";
|
compatible = "allwinner,sun6i-a31-rtc";
|
||||||
reg = <0x01f00000 0x54>;
|
reg = <0x01f00000 0x54>;
|
||||||
interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
|
interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
|
||||||
<GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
|
<GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
clock-output-names = "rtc-osc32k", "rtc-osc32k-out";
|
||||||
|
clocks = <&osc32k>;
|
||||||
|
#clock-cells = <1>;
|
||||||
};
|
};
|
||||||
|
|
||||||
r_intc: interrupt-controller@1f00c00 {
|
r_intc: interrupt-controller@1f00c00 {
|
||||||
|
@ -655,6 +715,29 @@
|
||||||
#reset-cells = <1>;
|
#reset-cells = <1>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
r_i2c: i2c@1f02400 {
|
||||||
|
compatible = "allwinner,sun50i-a64-i2c",
|
||||||
|
"allwinner,sun6i-a31-i2c";
|
||||||
|
reg = <0x01f02400 0x400>;
|
||||||
|
interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
clocks = <&r_ccu CLK_APB0_I2C>;
|
||||||
|
resets = <&r_ccu RST_APB0_I2C>;
|
||||||
|
status = "disabled";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
r_pwm: pwm@1f03800 {
|
||||||
|
compatible = "allwinner,sun50i-a64-pwm",
|
||||||
|
"allwinner,sun5i-a13-pwm";
|
||||||
|
reg = <0x01f03800 0x400>;
|
||||||
|
clocks = <&osc24M>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&r_pwm_pin>;
|
||||||
|
#pwm-cells = <3>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
r_pio: pinctrl@1f02c00 {
|
r_pio: pinctrl@1f02c00 {
|
||||||
compatible = "allwinner,sun50i-a64-r-pinctrl";
|
compatible = "allwinner,sun50i-a64-r-pinctrl";
|
||||||
reg = <0x01f02c00 0x400>;
|
reg = <0x01f02c00 0x400>;
|
||||||
|
@ -666,6 +749,16 @@
|
||||||
interrupt-controller;
|
interrupt-controller;
|
||||||
#interrupt-cells = <3>;
|
#interrupt-cells = <3>;
|
||||||
|
|
||||||
|
r_i2c_pins_a: i2c-a {
|
||||||
|
pins = "PL8", "PL9";
|
||||||
|
function = "s_i2c";
|
||||||
|
};
|
||||||
|
|
||||||
|
r_pwm_pin: pwm {
|
||||||
|
pins = "PL10";
|
||||||
|
function = "s_pwm";
|
||||||
|
};
|
||||||
|
|
||||||
r_rsb_pins: rsb {
|
r_rsb_pins: rsb {
|
||||||
pins = "PL0", "PL1";
|
pins = "PL0", "PL1";
|
||||||
function = "s_rsb";
|
function = "s_rsb";
|
||||||
|
|
|
@ -207,6 +207,18 @@
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&spi0 {
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
flash@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
compatible = "jedec,spi-nor";
|
||||||
|
reg = <0>;
|
||||||
|
spi-max-frequency = <40000000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
&uart0 {
|
&uart0 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&uart0_pins_a>;
|
pinctrl-0 = <&uart0_pins_a>;
|
||||||
|
|
|
@ -20,11 +20,157 @@
|
||||||
chosen {
|
chosen {
|
||||||
stdout-path = "serial0:115200n8";
|
stdout-path = "serial0:115200n8";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
leds {
|
||||||
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
|
heartbeat {
|
||||||
|
label = "pine-h64:green:heartbeat";
|
||||||
|
gpios = <&r_pio 0 4 GPIO_ACTIVE_HIGH>; /* PL4 */
|
||||||
|
};
|
||||||
|
|
||||||
|
link {
|
||||||
|
label = "pine-h64:white:link";
|
||||||
|
gpios = <&r_pio 0 3 GPIO_ACTIVE_HIGH>; /* PL3 */
|
||||||
|
};
|
||||||
|
|
||||||
|
status {
|
||||||
|
label = "pine-h64:blue:status";
|
||||||
|
gpios = <&r_pio 0 7 GPIO_ACTIVE_HIGH>; /* PL7 */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc0_pins>;
|
||||||
|
vmmc-supply = <®_cldo1>;
|
||||||
|
cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc2_pins>;
|
||||||
|
vmmc-supply = <®_cldo1>;
|
||||||
|
vqmmc-supply = <®_bldo2>;
|
||||||
|
non-removable;
|
||||||
|
cap-mmc-hw-reset;
|
||||||
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
&r_i2c {
|
&r_i2c {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
|
||||||
|
axp805: pmic@36 {
|
||||||
|
compatible = "x-powers,axp805", "x-powers,axp806";
|
||||||
|
reg = <0x36>;
|
||||||
|
interrupt-parent = <&r_intc>;
|
||||||
|
interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
|
||||||
|
interrupt-controller;
|
||||||
|
#interrupt-cells = <1>;
|
||||||
|
x-powers,self-working-mode;
|
||||||
|
|
||||||
|
regulators {
|
||||||
|
reg_aldo1: aldo1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-pl";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_aldo2: aldo2 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-ac200";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_aldo3: aldo3 {
|
||||||
|
/* This regulator is connected with CLDO1 */
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-3v3-1";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_bldo1: bldo1 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "vcc-bias-pll";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_bldo2: bldo2 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "vcc-efuse-pcie-hdmi-io";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_bldo3: bldo3 {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1800000>;
|
||||||
|
regulator-max-microvolt = <1800000>;
|
||||||
|
regulator-name = "vcc-dcxoio";
|
||||||
|
};
|
||||||
|
|
||||||
|
bldo4 {
|
||||||
|
/* unused */
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_cldo1: cldo1 {
|
||||||
|
/* This regulator is connected with ALDO3 */
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-3v3-2";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_cldo2: cldo2 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-wifi-1";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_cldo3: cldo3 {
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
regulator-name = "vcc-wifi-2";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_dcdca: dcdca {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <810000>;
|
||||||
|
regulator-max-microvolt = <1080000>;
|
||||||
|
regulator-name = "vdd-cpu";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_dcdcc: dcdcc {
|
||||||
|
regulator-min-microvolt = <810000>;
|
||||||
|
regulator-max-microvolt = <1080000>;
|
||||||
|
regulator-name = "vdd-gpu";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_dcdcd: dcdcd {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <960000>;
|
||||||
|
regulator-max-microvolt = <960000>;
|
||||||
|
regulator-name = "vdd-sys";
|
||||||
|
};
|
||||||
|
|
||||||
|
reg_dcdce: dcdce {
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-min-microvolt = <1200000>;
|
||||||
|
regulator-max-microvolt = <1200000>;
|
||||||
|
regulator-name = "vcc-dram";
|
||||||
|
};
|
||||||
|
|
||||||
|
sw {
|
||||||
|
/* unused */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
pcf8563: rtc@51 {
|
pcf8563: rtc@51 {
|
||||||
compatible = "nxp,pcf8563";
|
compatible = "nxp,pcf8563";
|
||||||
reg = <0x51>;
|
reg = <0x51>;
|
||||||
|
|
|
@ -5,7 +5,9 @@
|
||||||
|
|
||||||
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
||||||
#include <dt-bindings/clock/sun50i-h6-ccu.h>
|
#include <dt-bindings/clock/sun50i-h6-ccu.h>
|
||||||
|
#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
|
||||||
#include <dt-bindings/reset/sun50i-h6-ccu.h>
|
#include <dt-bindings/reset/sun50i-h6-ccu.h>
|
||||||
|
#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
interrupt-parent = <&gic>;
|
interrupt-parent = <&gic>;
|
||||||
|
@ -124,12 +126,71 @@
|
||||||
interrupt-controller;
|
interrupt-controller;
|
||||||
#interrupt-cells = <3>;
|
#interrupt-cells = <3>;
|
||||||
|
|
||||||
|
mmc0_pins: mmc0-pins {
|
||||||
|
pins = "PF0", "PF1", "PF2", "PF3",
|
||||||
|
"PF4", "PF5";
|
||||||
|
function = "mmc0";
|
||||||
|
drive-strength = <30>;
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
|
||||||
|
mmc2_pins: mmc2-pins {
|
||||||
|
pins = "PC1", "PC4", "PC5", "PC6",
|
||||||
|
"PC7", "PC8", "PC9", "PC10",
|
||||||
|
"PC11", "PC12", "PC13", "PC14";
|
||||||
|
function = "mmc2";
|
||||||
|
drive-strength = <30>;
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
|
||||||
uart0_ph_pins: uart0-ph {
|
uart0_ph_pins: uart0-ph {
|
||||||
pins = "PH0", "PH1";
|
pins = "PH0", "PH1";
|
||||||
function = "uart0";
|
function = "uart0";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
mmc0: mmc@4020000 {
|
||||||
|
compatible = "allwinner,sun50i-h6-mmc",
|
||||||
|
"allwinner,sun50i-a64-mmc";
|
||||||
|
reg = <0x04020000 0x1000>;
|
||||||
|
clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
|
||||||
|
clock-names = "ahb", "mmc";
|
||||||
|
resets = <&ccu RST_BUS_MMC0>;
|
||||||
|
reset-names = "ahb";
|
||||||
|
interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
status = "disabled";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
mmc1: mmc@4021000 {
|
||||||
|
compatible = "allwinner,sun50i-h6-mmc",
|
||||||
|
"allwinner,sun50i-a64-mmc";
|
||||||
|
reg = <0x04021000 0x1000>;
|
||||||
|
clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
|
||||||
|
clock-names = "ahb", "mmc";
|
||||||
|
resets = <&ccu RST_BUS_MMC1>;
|
||||||
|
reset-names = "ahb";
|
||||||
|
interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
status = "disabled";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
mmc2: mmc@4022000 {
|
||||||
|
compatible = "allwinner,sun50i-h6-emmc",
|
||||||
|
"allwinner,sun50i-a64-emmc";
|
||||||
|
reg = <0x04022000 0x1000>;
|
||||||
|
clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
|
||||||
|
clock-names = "ahb", "mmc";
|
||||||
|
resets = <&ccu RST_BUS_MMC2>;
|
||||||
|
reset-names = "ahb";
|
||||||
|
interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
status = "disabled";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
uart0: serial@5000000 {
|
uart0: serial@5000000 {
|
||||||
compatible = "snps,dw-apb-uart";
|
compatible = "snps,dw-apb-uart";
|
||||||
reg = <0x05000000 0x400>;
|
reg = <0x05000000 0x400>;
|
||||||
|
@ -198,7 +259,7 @@
|
||||||
reg = <0x07022000 0x400>;
|
reg = <0x07022000 0x400>;
|
||||||
interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
|
interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
|
||||||
<GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
|
<GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
clocks = <&r_ccu 2>, <&osc24M>, <&osc32k>;
|
clocks = <&r_ccu CLK_R_APB1>, <&osc24M>, <&osc32k>;
|
||||||
clock-names = "apb", "hosc", "losc";
|
clock-names = "apb", "hosc", "losc";
|
||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <3>;
|
#gpio-cells = <3>;
|
||||||
|
@ -215,8 +276,8 @@
|
||||||
compatible = "allwinner,sun6i-a31-i2c";
|
compatible = "allwinner,sun6i-a31-i2c";
|
||||||
reg = <0x07081400 0x400>;
|
reg = <0x07081400 0x400>;
|
||||||
interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
clocks = <&r_ccu 8>;
|
clocks = <&r_ccu CLK_R_APB2_I2C>;
|
||||||
resets = <&r_ccu 4>;
|
resets = <&r_ccu RST_R_APB2_I2C>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&r_i2c_pins>;
|
pinctrl-0 = <&r_i2c_pins>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
Loading…
Reference in New Issue