Commit 8749f9f3 authored by Olof Johansson's avatar Olof Johansson

Merge tag 'sunxi-dt-for-3.20' of...

Merge tag 'sunxi-dt-for-3.20' of https://git.kernel.org/pub/scm/linux/kernel/git/mripard/linux into next/dt

Merge "Allwinner device tree changes for 3.20" from Maxime Ripard:

A lot of changes to the device tree for the 3.20 merge window, mostly with:
  - More DT license convertions, only two DTS and two DTSI are still uncertain
    and have not been converted yet
  - Use the C-preprocessor includes in the device trees.
  - Add support for the A31s SoC and improve the A80 support
  - Add IR receiver, lradc, PS/2 support
  - Add cpufreq support for all SoCs but the A23 and A80.
  - And a lot of new boards

* tag 'sunxi-dt-for-3.20' of https://git.kernel.org/pub/scm/linux/kernel/git/mripard/linux: (64 commits)
  ARM: dts: sun5i: Enable axp209 support on A13-OLinuxIno
  ARM: sunxi: dts: Add A10/A20 PS2 pin muxing options
  ARM: sunxi: dts: Add PS2 nodes to dtsi for A10,A20
  ARM: dts: sun6i: Add resistive touchscreen controller node to dtsi
  ARM: dts: sun4i: Add Hyundau A7HD board
  ARM: dts: sun4i: Add Marsboard A10 board
  ARM: dts: sun9i: Enable mmc2 on A80 Optimus Board
  ARM: dts: sun9i: Add 8 bit mmc pinmux setting for mmc2
  ARM: dts: sun9i: Enable mmc0 on A80 Optimus Board
  ARM: dts: sun9i: Convert a80 optimus board dts to label referencing
  ARM: dts: sun9i: Add mmc controller nodes to the A80 dtsi
  ARM: dts: sun9i: Add mmc config clock nodes
  ARM: dts: sunxi: Add missing mdio label
  ARM: dts: sun5i: Add mk802_a10s board
  ARM: dts: sun4i: Add mk802ii board
  ARM: dts: sun4i: Add mk802 board
  ARM: dts: sun4i: Add dts file for Chuwi V7 CW0825 tablet
  ARM: dts: sun7i: Add dts file for Bananapro board
  ARM: sun6i: Enable ARM arch timers
  ARM: dts: sun6i: Convert hummingbird a31 dts to label references
  ...
Signed-off-by: default avatarOlof Johansson <olof@lixom.net>
parents 7c83955a c121f45e
...@@ -508,13 +508,19 @@ dtb-$(CONFIG_ARCH_STI) += \ ...@@ -508,13 +508,19 @@ dtb-$(CONFIG_ARCH_STI) += \
dtb-$(CONFIG_MACH_SUN4I) += \ dtb-$(CONFIG_MACH_SUN4I) += \
sun4i-a10-a1000.dtb \ sun4i-a10-a1000.dtb \
sun4i-a10-ba10-tvbox.dtb \ sun4i-a10-ba10-tvbox.dtb \
sun4i-a10-chuwi-v7-cw0825.dtb \
sun4i-a10-cubieboard.dtb \ sun4i-a10-cubieboard.dtb \
sun4i-a10-marsboard.dtb \
sun4i-a10-mini-xplus.dtb \ sun4i-a10-mini-xplus.dtb \
sun4i-a10-mk802.dtb \
sun4i-a10-mk802ii.dtb \
sun4i-a10-hackberry.dtb \ sun4i-a10-hackberry.dtb \
sun4i-a10-hyundai-a7hd.dtb \
sun4i-a10-inet97fv2.dtb \ sun4i-a10-inet97fv2.dtb \
sun4i-a10-olinuxino-lime.dtb \ sun4i-a10-olinuxino-lime.dtb \
sun4i-a10-pcduino.dtb sun4i-a10-pcduino.dtb
dtb-$(CONFIG_MACH_SUN5I) += \ dtb-$(CONFIG_MACH_SUN5I) += \
sun5i-a10s-mk802.dtb \
sun5i-a10s-olinuxino-micro.dtb \ sun5i-a10s-olinuxino-micro.dtb \
sun5i-a10s-r7-tv-dongle.dtb \ sun5i-a10s-r7-tv-dongle.dtb \
sun5i-a13-hsg-h702.dtb \ sun5i-a13-hsg-h702.dtb \
...@@ -524,9 +530,11 @@ dtb-$(CONFIG_MACH_SUN6I) += \ ...@@ -524,9 +530,11 @@ dtb-$(CONFIG_MACH_SUN6I) += \
sun6i-a31-app4-evb1.dtb \ sun6i-a31-app4-evb1.dtb \
sun6i-a31-colombus.dtb \ sun6i-a31-colombus.dtb \
sun6i-a31-hummingbird.dtb \ sun6i-a31-hummingbird.dtb \
sun6i-a31-m9.dtb sun6i-a31-m9.dtb \
sun6i-a31s-cs908.dtb
dtb-$(CONFIG_MACH_SUN7I) += \ dtb-$(CONFIG_MACH_SUN7I) += \
sun7i-a20-bananapi.dtb \ sun7i-a20-bananapi.dtb \
sun7i-a20-bananapro.dtb \
sun7i-a20-cubieboard2.dtb \ sun7i-a20-cubieboard2.dtb \
sun7i-a20-cubietruck.dtb \ sun7i-a20-cubietruck.dtb \
sun7i-a20-hummingbird.dtb \ sun7i-a20-hummingbird.dtb \
...@@ -537,7 +545,8 @@ dtb-$(CONFIG_MACH_SUN7I) += \ ...@@ -537,7 +545,8 @@ dtb-$(CONFIG_MACH_SUN7I) += \
sun7i-a20-olinuxino-micro.dtb \ sun7i-a20-olinuxino-micro.dtb \
sun7i-a20-pcduino3.dtb sun7i-a20-pcduino3.dtb
dtb-$(CONFIG_MACH_SUN8I) += \ dtb-$(CONFIG_MACH_SUN8I) += \
sun8i-a23-ippo-q8h-v5.dtb sun8i-a23-ippo-q8h-v5.dtb \
sun8i-a23-ippo-q8h-v1.2.dtb
dtb-$(CONFIG_MACH_SUN9I) += \ dtb-$(CONFIG_MACH_SUN9I) += \
sun9i-a80-optimus.dtb sun9i-a80-optimus.dtb
dtb-$(CONFIG_ARCH_TEGRA_2x_SOC) += \ dtb-$(CONFIG_ARCH_TEGRA_2x_SOC) += \
......
/*
* Copyright 2015 Chen-Yu Tsai
*
* Chen-Yu Tsai <wens@csie.org>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/*
* AXP202/209 Integrated Power Management Chip
* http://www.x-powers.com/product/AXP20X.php
* http://dl.linux-sunxi.org/AXP/AXP209%20Datasheet%20v1.0_cn.pdf
*/
&axp209 {
compatible = "x-powers,axp209";
interrupt-controller;
#interrupt-cells = <1>;
regulators {
/* Default work frequency for buck regulators */
x-powers,dcdc-freq = <1500>;
reg_dcdc2: dcdc2 {
regulator-name = "dcdc2";
};
reg_dcdc3: dcdc3 {
regulator-name = "dcdc3";
};
reg_ldo1: ldo1 {
/* LDO1 is a fixed output regulator */
regulator-always-on;
regulator-min-microvolt = <1300000>;
regulator-max-microvolt = <1300000>;
regulator-name = "ldo1";
};
reg_ldo2: ldo2 {
regulator-name = "ldo2";
};
reg_ldo3: ldo3 {
regulator-name = "ldo3";
};
reg_ldo4: ldo4 {
regulator-name = "ldo4";
};
reg_ldo5: ldo5 {
regulator-name = "ldo5";
};
};
};
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Mele A1000"; model = "Mele A1000";
...@@ -77,7 +80,7 @@ mmc0: mmc@01c0f000 { ...@@ -77,7 +80,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -112,15 +115,15 @@ pinctrl@01c20800 { ...@@ -112,15 +115,15 @@ pinctrl@01c20800 {
emac_power_pin_a1000: emac_power_pin@0 { emac_power_pin_a1000: emac_power_pin@0 {
allwinner,pins = "PH15"; allwinner,pins = "PH15";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_a1000: led_pins@0 { led_pins_a1000: led_pins@0 {
allwinner,pins = "PH10", "PH20"; allwinner,pins = "PH10", "PH20";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -159,12 +162,12 @@ leds { ...@@ -159,12 +162,12 @@ leds {
red { red {
label = "a1000:red:usr"; label = "a1000:red:usr";
gpios = <&pio 7 10 0>; gpios = <&pio 7 10 GPIO_ACTIVE_HIGH>;
}; };
blue { blue {
label = "a1000:blue:usr"; label = "a1000:blue:usr";
gpios = <&pio 7 20 0>; gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
}; };
}; };
...@@ -176,7 +179,7 @@ reg_emac_3v3: emac-3v3 { ...@@ -176,7 +179,7 @@ reg_emac_3v3: emac-3v3 {
regulator-min-microvolt = <3300000>; regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 15 0>; gpio = <&pio 7 15 GPIO_ACTIVE_HIGH>;
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
......
...@@ -46,8 +46,10 @@ ...@@ -46,8 +46,10 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ { / {
model = "BA10 tvbox"; model = "BA10 tvbox";
...@@ -74,7 +76,7 @@ mmc0: mmc@01c0f000 { ...@@ -74,7 +76,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -140,7 +142,7 @@ reg_usb1_vbus: usb1-vbus { ...@@ -140,7 +142,7 @@ reg_usb1_vbus: usb1-vbus {
}; };
reg_usb2_vbus: usb2-vbus { reg_usb2_vbus: usb2-vbus {
gpio = <&pio 7 12 0>; gpio = <&pio 7 12 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun4i-a10.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ {
model = "Chuwi V7 CW0825";
compatible = "chuwi,v7-cw0825", "allwinner,sun4i-a10";
};
&ehci1 {
status = "okay";
};
&i2c0 {
pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>;
status = "okay";
axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>;
interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
};
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted;
status = "okay";
};
&reg_usb2_vbus {
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usbphy {
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
...@@ -47,8 +47,11 @@ ...@@ -47,8 +47,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Cubietech Cubieboard"; model = "Cubietech Cubieboard";
...@@ -75,7 +78,7 @@ mmc0: mmc@01c0f000 { ...@@ -75,7 +78,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -111,8 +114,8 @@ pinctrl@01c20800 { ...@@ -111,8 +114,8 @@ pinctrl@01c20800 {
led_pins_cubieboard: led_pins@0 { led_pins_cubieboard: led_pins@0 {
allwinner,pins = "PH20", "PH21"; allwinner,pins = "PH20", "PH21";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -134,12 +137,8 @@ i2c0: i2c@01c2ac00 { ...@@ -134,12 +137,8 @@ i2c0: i2c@01c2ac00 {
status = "okay"; status = "okay";
axp209: pmic@34 { axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupts = <0>; interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
}; };
}; };
...@@ -148,6 +147,12 @@ i2c1: i2c@01c2b000 { ...@@ -148,6 +147,12 @@ i2c1: i2c@01c2b000 {
pinctrl-0 = <&i2c1_pins_a>; pinctrl-0 = <&i2c1_pins_a>;
status = "okay"; status = "okay";
}; };
spi0: spi@01c05000 {
pinctrl-names = "default";
pinctrl-0 = <&spi0_pins_a>;
status = "okay";
};
}; };
leds { leds {
...@@ -157,12 +162,12 @@ leds { ...@@ -157,12 +162,12 @@ leds {
blue { blue {
label = "cubieboard:blue:usr"; label = "cubieboard:blue:usr";
gpios = <&pio 7 21 0>; /* LED1 */ gpios = <&pio 7 21 GPIO_ACTIVE_HIGH>; /* LED1 */
}; };
green { green {
label = "cubieboard:green:usr"; label = "cubieboard:green:usr";
gpios = <&pio 7 20 0>; /* LED2 */ gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>; /* LED2 */
linux,default-trigger = "heartbeat"; linux,default-trigger = "heartbeat";
}; };
}; };
...@@ -179,3 +184,34 @@ reg_usb2_vbus: usb2-vbus { ...@@ -179,3 +184,34 @@ reg_usb2_vbus: usb2-vbus {
status = "okay"; status = "okay";
}; };
}; };
#include "axp209.dtsi"
&cpu0 {
cpu-supply = <&reg_dcdc2>;
};
&reg_dcdc2 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1450000>;
regulator-name = "vdd-cpu";
};
&reg_dcdc3 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1400000>;
regulator-name = "vdd-int-dll";
};
&reg_ldo1 {
regulator-name = "vdd-rtc";
};
&reg_ldo2 {
regulator-always-on;
regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>;
regulator-name = "avcc";
};
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Miniand Hackberry"; model = "Miniand Hackberry";
...@@ -77,7 +80,7 @@ mmc0: mmc@01c0f000 { ...@@ -77,7 +80,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -111,15 +114,15 @@ pio: pinctrl@01c20800 { ...@@ -111,15 +114,15 @@ pio: pinctrl@01c20800 {
hackberry_hogs: hogs@0 { hackberry_hogs: hogs@0 {
allwinner,pins = "PH19"; allwinner,pins = "PH19";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb2_vbus_pin_hackberry: usb2_vbus_pin@0 { usb2_vbus_pin_hackberry: usb2_vbus_pin@0 {
allwinner,pins = "PH12"; allwinner,pins = "PH12";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -157,7 +160,7 @@ reg_emac_3v3: emac-3v3 { ...@@ -157,7 +160,7 @@ reg_emac_3v3: emac-3v3 {
regulator-min-microvolt = <3300000>; regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 19 0>; gpio = <&pio 7 19 GPIO_ACTIVE_HIGH>;
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
...@@ -166,7 +169,7 @@ reg_usb1_vbus: usb1-vbus { ...@@ -166,7 +169,7 @@ reg_usb1_vbus: usb1-vbus {
reg_usb2_vbus: usb2-vbus { reg_usb2_vbus: usb2-vbus {
pinctrl-0 = <&usb2_vbus_pin_hackberry>; pinctrl-0 = <&usb2_vbus_pin_hackberry>;
gpio = <&pio 7 12 0>; gpio = <&pio 7 12 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun4i-a10.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ {
model = "Hyundai A7HD";
compatible = "hyundai,a7hd", "allwinner,sun4i-a10";
};
&ehci1 {
status = "okay";
};
&i2c0 {
pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>;
status = "okay";
axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>;
interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
};
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted;
status = "okay";
};
&reg_usb2_vbus {
gpio = <&pio 7 6 GPIO_ACTIVE_HIGH>; /* PH6 */
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usb2_vbus_pin_a {
allwinner,pins = "PH6";
};
&usbphy {
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
...@@ -48,8 +48,10 @@ ...@@ -48,8 +48,10 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ { / {
model = "INet-97F Rev 02"; model = "INet-97F Rev 02";
...@@ -65,7 +67,7 @@ mmc0: mmc@01c0f000 { ...@@ -65,7 +67,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
......
/*
* Copyright 2015 Aleksei Mamlin
* Aleksei Mamlin <mamlinav@gmail.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun4i-a10.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ {
model = "HAOYU Electronics Marsboard A10";
compatible = "haoyu,a10-marsboard", "allwinner,sun4i-a10";
leds {
compatible = "gpio-leds";
pinctrl-names = "default";
pinctrl-0 = <&led_pins_marsboard>;
red1 {
label = "marsboard:red1:usr";
gpios = <&pio 1 5 GPIO_ACTIVE_HIGH>;
};
red2 {
label = "marsboard:red2:usr";
gpios = <&pio 1 6 GPIO_ACTIVE_HIGH>;
};
red3 {
label = "marsboard:red3:usr";
gpios = <&pio 1 7 GPIO_ACTIVE_HIGH>;
};
red4 {
label = "marsboard:red4:usr";
gpios = <&pio 1 8 GPIO_ACTIVE_HIGH>;
};
};
};
&ahci {
status = "okay";
};
&ehci0 {
status = "okay";
};
&ehci1 {
status = "okay";
};
&emac {
pinctrl-names = "default";
pinctrl-0 = <&emac_pins_a>;
phy = <&phy1>;
status = "okay";
};
&i2c0 {
pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>;
status = "okay";
};
&i2c1 {
pinctrl-names = "default";
pinctrl-0 = <&i2c1_pins_a>;
status = "okay";
};
&i2c2 {
pinctrl-names = "default";
pinctrl-0 = <&i2c2_pins_a>;
status = "okay";
};
&mdio {
status = "okay";
phy1: ethernet-phy@1 {
reg = <1>;
};
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted;
status = "okay";
};
&ohci0 {
status = "okay";
};
&ohci1 {
status = "okay";
};
&pio {
led_pins_marsboard: led_pins@0 {
allwinner,pins = "PB5", "PB6", "PB7", "PB8";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
&reg_usb1_vbus {
status = "okay";
};
&reg_usb2_vbus {
status = "okay";
};
&spi0 {
pinctrl-names = "default";
pinctrl-0 = <&spi0_pins_a>;
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "PineRiver Mini X-Plus"; model = "PineRiver Mini X-Plus";
...@@ -61,7 +64,7 @@ mmc0: mmc@01c0f000 { ...@@ -61,7 +64,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -91,7 +94,7 @@ ohci1: usb@01c1c400 { ...@@ -91,7 +94,7 @@ ohci1: usb@01c1c400 {
pinctrl@01c20800 { pinctrl@01c20800 {
ir0_pins_a: ir0@0 { ir0_pins_a: ir0@0 {
/* The ir receiver is not always populated */ /* The ir receiver is not always populated */
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
}; };
......
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun4i-a10.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ {
model = "MK802";
compatible = "allwinner,mk802", "allwinner,sun4i-a10";
};
&ehci0 {
status = "okay";
};
&ehci1 {
status = "okay";
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted;
status = "okay";
};
&ohci0 {
status = "okay";
};
&pio {
usb2_vbus_pin_mk802: usb2_vbus_pin@0 {
allwinner,pins = "PH12";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
&reg_usb1_vbus {
status = "okay";
};
&reg_usb2_vbus {
pinctrl-0 = <&usb2_vbus_pin_mk802>;
gpio = <&pio 7 12 GPIO_ACTIVE_HIGH>; /* PH12 */
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun4i-a10.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ {
model = "MK802ii";
compatible = "allwinner,mk802ii", "allwinner,sun4i-a10";
};
&ehci0 {
status = "okay";
};
&ehci1 {
status = "okay";
};
&i2c0 {
pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>;
status = "okay";
axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>;
interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
};
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted;
status = "okay";
};
&ohci0 {
status = "okay";
};
&reg_usb1_vbus {
status = "okay";
};
&reg_usb2_vbus {
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
...@@ -46,8 +46,11 @@ ...@@ -46,8 +46,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A10-OLinuXino-LIME"; model = "Olimex A10-OLinuXino-LIME";
...@@ -74,7 +77,7 @@ mmc0: mmc@01c0f000 { ...@@ -74,7 +77,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -110,15 +113,15 @@ pinctrl@01c20800 { ...@@ -110,15 +113,15 @@ pinctrl@01c20800 {
ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 { ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 {
allwinner,pins = "PC3"; allwinner,pins = "PC3";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_olinuxinolime: led_pins@0 { led_pins_olinuxinolime: led_pins@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -151,14 +154,14 @@ leds { ...@@ -151,14 +154,14 @@ leds {
green { green {
label = "a10-olinuxino-lime:green:usr"; label = "a10-olinuxino-lime:green:usr";
gpios = <&pio 7 2 0>; gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>; pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>;
gpio = <&pio 2 3 0>; gpio = <&pio 2 3 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
......
...@@ -47,8 +47,12 @@ ...@@ -47,8 +47,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun4i-a10.dtsi" #include "sun4i-a10.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "LinkSprite pcDuino"; model = "LinkSprite pcDuino";
...@@ -62,6 +66,22 @@ emac: ethernet@01c0b000 { ...@@ -62,6 +66,22 @@ emac: ethernet@01c0b000 {
status = "okay"; status = "okay";
}; };
pinctrl@01c20800 {
led_pins_pcduino: led_pins@0 {
allwinner,pins = "PH15", "PH16";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
key_pins_pcduino: key_pins@0 {
allwinner,pins = "PH17", "PH18", "PH19";
allwinner,function = "gpio_in";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
mdio@01c0b080 { mdio@01c0b080 {
status = "okay"; status = "okay";
...@@ -75,7 +95,7 @@ mmc0: mmc@01c0f000 { ...@@ -75,7 +95,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -124,6 +144,48 @@ axp209: pmic@34 { ...@@ -124,6 +144,48 @@ axp209: pmic@34 {
}; };
}; };
leds {
compatible = "gpio-leds";
pinctrl-names = "default";
pinctrl-0 = <&led_pins_pcduino>;
tx {
label = "pcduino:green:tx";
gpios = <&pio 7 15 GPIO_ACTIVE_LOW>;
};
rx {
label = "pcduino:green:rx";
gpios = <&pio 7 16 GPIO_ACTIVE_LOW>;
};
};
gpio_keys {
compatible = "gpio-keys";
pinctrl-names = "default";
pinctrl-0 = <&key_pins_pcduino>;
#address-cells = <1>;
#size-cells = <0>;
button@0 {
label = "Key Back";
linux,code = <KEY_BACK>;
gpios = <&pio 7 17 GPIO_ACTIVE_LOW>;
};
button@1 {
label = "Key Home";
linux,code = <KEY_HOME>;
gpios = <&pio 7 18 GPIO_ACTIVE_LOW>;
};
button@2 {
label = "Key Menu";
linux,code = <KEY_MENU>;
gpios = <&pio 7 19 GPIO_ACTIVE_LOW>;
};
};
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
status = "okay"; status = "okay";
}; };
......
...@@ -10,7 +10,12 @@ ...@@ -10,7 +10,12 @@
* http://www.gnu.org/copyleft/gpl.html * http://www.gnu.org/copyleft/gpl.html
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/thermal/thermal.h>
#include <dt-bindings/dma/sun4i-a10.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&intc>; interrupt-parent = <&intc>;
...@@ -39,15 +44,86 @@ framebuffer@0 { ...@@ -39,15 +44,86 @@ framebuffer@0 {
<&ahb_gates 44>; <&ahb_gates 44>;
status = "disabled"; status = "disabled";
}; };
framebuffer@1 {
compatible = "allwinner,simple-framebuffer", "simple-framebuffer";
allwinner,pipeline = "de_fe0-de_be0-lcd0-hdmi";
clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 43>,
<&ahb_gates 44>, <&ahb_gates 46>;
status = "disabled";
};
framebuffer@2 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_fe0-de_be0-lcd0";
clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 44>,
<&ahb_gates 46>;
status = "disabled";
};
framebuffer@3 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_fe0-de_be0-lcd0-tve0";
clocks = <&pll5 1>, <&ahb_gates 34>, <&ahb_gates 36>,
<&ahb_gates 44>, <&ahb_gates 46>;
status = "disabled";
};
}; };
cpus { cpus {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <0>; #size-cells = <0>;
cpu@0 { cpu0: cpu@0 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a8"; compatible = "arm,cortex-a8";
reg = <0x0>; reg = <0x0>;
clocks = <&cpu>;
clock-latency = <244144>; /* 8 32k periods */
operating-points = <
/* kHz uV */
1056000 1500000
1008000 1400000
912000 1350000
864000 1300000
624000 1250000
>;
#cooling-cells = <2>;
cooling-min-level = <0>;
cooling-max-level = <4>;
};
};
thermal-zones {
cpu_thermal {
/* milliseconds */
polling-delay-passive = <250>;
polling-delay = <1000>;
thermal-sensors = <&rtp>;
cooling-maps {
map0 {
trip = <&cpu_alert0>;
cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
};
};
trips {
cpu_alert0: cpu_alert0 {
/* milliCelsius */
temperature = <850000>;
hysteresis = <2000>;
type = "passive";
};
cpu_crit: cpu_crit {
/* milliCelsius */
temperature = <100000>;
hysteresis = <2000>;
type = "critical";
};
};
}; };
}; };
...@@ -359,7 +435,8 @@ spi0: spi@01c05000 { ...@@ -359,7 +435,8 @@ spi0: spi@01c05000 {
interrupts = <10>; interrupts = <10>;
clocks = <&ahb_gates 20>, <&spi0_clk>; clocks = <&ahb_gates 20>, <&spi0_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 27>, <&dma 1 26>; dmas = <&dma SUN4I_DMA_DEDICATED 27>,
<&dma SUN4I_DMA_DEDICATED 26>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -372,7 +449,8 @@ spi1: spi@01c06000 { ...@@ -372,7 +449,8 @@ spi1: spi@01c06000 {
interrupts = <11>; interrupts = <11>;
clocks = <&ahb_gates 21>, <&spi1_clk>; clocks = <&ahb_gates 21>, <&spi1_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 9>, <&dma 1 8>; dmas = <&dma SUN4I_DMA_DEDICATED 9>,
<&dma SUN4I_DMA_DEDICATED 8>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -387,7 +465,7 @@ emac: ethernet@01c0b000 { ...@@ -387,7 +465,7 @@ emac: ethernet@01c0b000 {
status = "disabled"; status = "disabled";
}; };
mdio@01c0b080 { mdio: mdio@01c0b080 {
compatible = "allwinner,sun4i-a10-mdio"; compatible = "allwinner,sun4i-a10-mdio";
reg = <0x01c0b080 0x14>; reg = <0x01c0b080 0x14>;
status = "disabled"; status = "disabled";
...@@ -438,8 +516,8 @@ usbphy: phy@01c13400 { ...@@ -438,8 +516,8 @@ usbphy: phy@01c13400 {
reg-names = "phy_ctrl", "pmu1", "pmu2"; reg-names = "phy_ctrl", "pmu1", "pmu2";
clocks = <&usb_clk 8>; clocks = <&usb_clk 8>;
clock-names = "usb_phy"; clock-names = "usb_phy";
resets = <&usb_clk 1>, <&usb_clk 2>; resets = <&usb_clk 0>, <&usb_clk 1>, <&usb_clk 2>;
reset-names = "usb1_reset", "usb2_reset"; reset-names = "usb0_reset", "usb1_reset", "usb2_reset";
status = "disabled"; status = "disabled";
}; };
...@@ -469,7 +547,8 @@ spi2: spi@01c17000 { ...@@ -469,7 +547,8 @@ spi2: spi@01c17000 {
interrupts = <12>; interrupts = <12>;
clocks = <&ahb_gates 22>, <&spi2_clk>; clocks = <&ahb_gates 22>, <&spi2_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 29>, <&dma 1 28>; dmas = <&dma SUN4I_DMA_DEDICATED 29>,
<&dma SUN4I_DMA_DEDICATED 28>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -510,7 +589,8 @@ spi3: spi@01c1f000 { ...@@ -510,7 +589,8 @@ spi3: spi@01c1f000 {
interrupts = <50>; interrupts = <50>;
clocks = <&ahb_gates 23>, <&spi3_clk>; clocks = <&ahb_gates 23>, <&spi3_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 31>, <&dma 1 30>; dmas = <&dma SUN4I_DMA_DEDICATED 31>,
<&dma SUN4I_DMA_DEDICATED 30>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -538,57 +618,57 @@ pio: pinctrl@01c20800 { ...@@ -538,57 +618,57 @@ pio: pinctrl@01c20800 {
pwm0_pins_a: pwm0@0 { pwm0_pins_a: pwm0@0 {
allwinner,pins = "PB2"; allwinner,pins = "PB2";
allwinner,function = "pwm"; allwinner,function = "pwm";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
pwm1_pins_a: pwm1@0 { pwm1_pins_a: pwm1@0 {
allwinner,pins = "PI3"; allwinner,pins = "PI3";
allwinner,function = "pwm"; allwinner,function = "pwm";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PB22", "PB23"; allwinner,pins = "PB22", "PB23";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart0_pins_b: uart0@1 { uart0_pins_b: uart0@1 {
allwinner,pins = "PF2", "PF4"; allwinner,pins = "PF2", "PF4";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart1_pins_a: uart1@0 { uart1_pins_a: uart1@0 {
allwinner,pins = "PA10", "PA11"; allwinner,pins = "PA10", "PA11";
allwinner,function = "uart1"; allwinner,function = "uart1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PB0", "PB1"; allwinner,pins = "PB0", "PB1";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PB18", "PB19"; allwinner,pins = "PB18", "PB19";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PB20", "PB21"; allwinner,pins = "PB20", "PB21";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
emac_pins_a: emac0@0 { emac_pins_a: emac0@0 {
...@@ -598,36 +678,78 @@ emac_pins_a: emac0@0 { ...@@ -598,36 +678,78 @@ emac_pins_a: emac0@0 {
"PA11", "PA12", "PA13", "PA14", "PA11", "PA12", "PA13", "PA14",
"PA15", "PA16"; "PA15", "PA16";
allwinner,function = "emac"; allwinner,function = "emac";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_cd_pin_reference_design: mmc0_cd_pin@0 { mmc0_cd_pin_reference_design: mmc0_cd_pin@0 {
allwinner,pins = "PH1"; allwinner,pins = "PH1";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
ir0_pins_a: ir0@0 { ir0_pins_a: ir0@0 {
allwinner,pins = "PB3","PB4"; allwinner,pins = "PB3","PB4";
allwinner,function = "ir0"; allwinner,function = "ir0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
ir1_pins_a: ir1@0 { ir1_pins_a: ir1@0 {
allwinner,pins = "PB22","PB23"; allwinner,pins = "PB22","PB23";
allwinner,function = "ir1"; allwinner,function = "ir1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
spi0_pins_a: spi0@0 {
allwinner,pins = "PI10", "PI11", "PI12", "PI13";
allwinner,function = "spi0";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
spi1_pins_a: spi1@0 {
allwinner,pins = "PI16", "PI17", "PI18", "PI19";
allwinner,function = "spi1";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
spi2_pins_a: spi2@0 {
allwinner,pins = "PB14", "PB15", "PB16", "PB17";
allwinner,function = "spi2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
spi2_pins_b: spi2@1 {
allwinner,pins = "PC19", "PC20", "PC21", "PC22";
allwinner,function = "spi2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
ps20_pins_a: ps20@0 {
allwinner,pins = "PI20", "PI21";
allwinner,function = "ps2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
ps21_pins_a: ps21@0 {
allwinner,pins = "PH12", "PH13";
allwinner,function = "ps2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -675,6 +797,13 @@ ir1: ir@01c21c00 { ...@@ -675,6 +797,13 @@ ir1: ir@01c21c00 {
status = "disabled"; status = "disabled";
}; };
lradc: lradc@01c22800 {
compatible = "allwinner,sun4i-a10-lradc-keys";
reg = <0x01c22800 0x100>;
interrupts = <31>;
status = "disabled";
};
sid: eeprom@01c23800 { sid: eeprom@01c23800 {
compatible = "allwinner,sun4i-a10-sid"; compatible = "allwinner,sun4i-a10-sid";
reg = <0x01c23800 0x10>; reg = <0x01c23800 0x10>;
...@@ -684,6 +813,7 @@ rtp: rtp@01c25000 { ...@@ -684,6 +813,7 @@ rtp: rtp@01c25000 {
compatible = "allwinner,sun4i-a10-ts"; compatible = "allwinner,sun4i-a10-ts";
reg = <0x01c25000 0x100>; reg = <0x01c25000 0x100>;
interrupts = <29>; interrupts = <29>;
#thermal-sensor-cells = <0>;
}; };
uart0: serial@01c28000 { uart0: serial@01c28000 {
...@@ -795,5 +925,21 @@ i2c2: i2c@01c2b400 { ...@@ -795,5 +925,21 @@ i2c2: i2c@01c2b400 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <0>; #size-cells = <0>;
}; };
ps20: ps2@01c2a000 {
compatible = "allwinner,sun4i-a10-ps2";
reg = <0x01c2a000 0x400>;
interrupts = <62>;
clocks = <&apb1_gates 6>;
status = "disabled";
};
ps21: ps2@01c2a400 {
compatible = "allwinner,sun4i-a10-ps2";
reg = <0x01c2a400 0x400>;
interrupts = <63>;
clocks = <&apb1_gates 7>;
status = "disabled";
};
}; };
}; };
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun5i-a10s.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ {
model = "MK802-A10s";
compatible = "allwinner,a10s-mk802", "allwinner,sun5i-a10s";
leds {
compatible = "gpio-leds";
pinctrl-names = "default";
pinctrl-0 = <&led_pins_mk802>;
red {
label = "mk802:red:usr";
gpios = <&pio 1 2 GPIO_ACTIVE_HIGH>; /* PB2 */
};
};
};
&ehci0 {
status = "okay";
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_mk802>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 6 1 GPIO_ACTIVE_HIGH>; /* PG1 */
cd-inverted;
status = "okay";
};
&ohci0 {
status = "okay";
};
&pio {
led_pins_mk802: led_pins@0 {
allwinner,pins = "PB2";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
mmc0_cd_pin_mk802: mmc0_cd_pin@0 {
allwinner,pins = "PG1";
allwinner,function = "gpio_in";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
};
usb1_vbus_pin_mk802: usb1_vbus_pin@0 {
allwinner,pins = "PB10";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
&reg_usb1_vbus {
pinctrl-0 = <&usb1_vbus_pin_mk802>;
gpio = <&pio 1 10 GPIO_ACTIVE_HIGH>; /* PB10 */
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
status = "okay";
};
...@@ -48,8 +48,12 @@ ...@@ -48,8 +48,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun5i-a10s.dtsi" #include "sun5i-a10s.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A10s-Olinuxino Micro"; model = "Olimex A10s-Olinuxino Micro";
...@@ -76,7 +80,7 @@ mmc0: mmc@01c0f000 { ...@@ -76,7 +80,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxino_micro>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxino_micro>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 1 0>; /* PG1 */ cd-gpios = <&pio 6 1 GPIO_ACTIVE_HIGH>; /* PG1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -86,7 +90,7 @@ mmc1: mmc@01c10000 { ...@@ -86,7 +90,7 @@ mmc1: mmc@01c10000 {
pinctrl-0 = <&mmc1_pins_a>, <&mmc1_cd_pin_olinuxino_micro>; pinctrl-0 = <&mmc1_pins_a>, <&mmc1_cd_pin_olinuxino_micro>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 13 0>; /* PG13 */ cd-gpios = <&pio 6 13 GPIO_ACTIVE_HIGH>; /* PG13 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -108,29 +112,69 @@ pinctrl@01c20800 { ...@@ -108,29 +112,69 @@ pinctrl@01c20800 {
mmc0_cd_pin_olinuxino_micro: mmc0_cd_pin@0 { mmc0_cd_pin_olinuxino_micro: mmc0_cd_pin@0 {
allwinner,pins = "PG1"; allwinner,pins = "PG1";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
mmc1_cd_pin_olinuxino_micro: mmc1_cd_pin@0 { mmc1_cd_pin_olinuxino_micro: mmc1_cd_pin@0 {
allwinner,pins = "PG13"; allwinner,pins = "PG13";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
led_pins_olinuxino: led_pins@0 { led_pins_olinuxino: led_pins@0 {
allwinner,pins = "PE3"; allwinner,pins = "PE3";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_olinuxino_m: usb1_vbus_pin@0 { usb1_vbus_pin_olinuxino_m: usb1_vbus_pin@0 {
allwinner,pins = "PB10"; allwinner,pins = "PB10";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
lradc: lradc@01c22800 {
vref-supply = <&reg_vcc3v0>;
status = "okay";
button@191 {
label = "Volume Up";
linux,code = <KEY_VOLUMEUP>;
channel = <0>;
voltage = <191274>;
};
button@392 {
label = "Volume Down";
linux,code = <KEY_VOLUMEDOWN>;
channel = <0>;
voltage = <392644>;
};
button@601 {
label = "Menu";
linux,code = <KEY_MENU>;
channel = <0>;
voltage = <601151>;
};
button@795 {
label = "Enter";
linux,code = <KEY_ENTER>;
channel = <0>;
voltage = <795090>;
};
button@987 {
label = "Home";
linux,code = <KEY_HOMEPAGE>;
channel = <0>;
voltage = <987387>;
}; };
}; };
...@@ -185,14 +229,14 @@ leds { ...@@ -185,14 +229,14 @@ leds {
green { green {
label = "a10s-olinuxino-micro:green:usr"; label = "a10s-olinuxino-micro:green:usr";
gpios = <&pio 4 3 0>; gpios = <&pio 4 3 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_olinuxino_m>; pinctrl-0 = <&usb1_vbus_pin_olinuxino_m>;
gpio = <&pio 1 10 0>; gpio = <&pio 1 10 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -46,8 +46,11 @@ ...@@ -46,8 +46,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun5i-a10s.dtsi" #include "sun5i-a10s.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "R7 A10s hdmi tv-stick"; model = "R7 A10s hdmi tv-stick";
...@@ -59,7 +62,7 @@ mmc0: mmc@01c0f000 { ...@@ -59,7 +62,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_r7>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_r7>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 1 0>; /* PG1 */ cd-gpios = <&pio 6 1 GPIO_ACTIVE_HIGH>; /* PG1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -90,22 +93,22 @@ pinctrl@01c20800 { ...@@ -90,22 +93,22 @@ pinctrl@01c20800 {
mmc0_cd_pin_r7: mmc0_cd_pin@0 { mmc0_cd_pin_r7: mmc0_cd_pin@0 {
allwinner,pins = "PG1"; allwinner,pins = "PG1";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
led_pins_r7: led_pins@0 { led_pins_r7: led_pins@0 {
allwinner,pins = "PB2"; allwinner,pins = "PB2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_r7: usb1_vbus_pin@0 { usb1_vbus_pin_r7: usb1_vbus_pin@0 {
allwinner,pins = "PG13"; allwinner,pins = "PG13";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -123,14 +126,14 @@ leds { ...@@ -123,14 +126,14 @@ leds {
green { green {
label = "r7-tv-dongle:green:usr"; label = "r7-tv-dongle:green:usr";
gpios = <&pio 1 2 0>; gpios = <&pio 1 2 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_r7>; pinctrl-0 = <&usb1_vbus_pin_r7>;
gpio = <&pio 6 13 0>; gpio = <&pio 6 13 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -11,7 +11,10 @@ ...@@ -11,7 +11,10 @@
* http://www.gnu.org/copyleft/gpl.html * http://www.gnu.org/copyleft/gpl.html
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/dma/sun4i-a10.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&intc>; interrupt-parent = <&intc>;
...@@ -36,6 +39,14 @@ framebuffer@0 { ...@@ -36,6 +39,14 @@ framebuffer@0 {
<&ahb_gates 44>; <&ahb_gates 44>;
status = "disabled"; status = "disabled";
}; };
framebuffer@1 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0";
clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 44>;
status = "disabled";
};
}; };
cpus { cpus {
...@@ -320,7 +331,8 @@ spi0: spi@01c05000 { ...@@ -320,7 +331,8 @@ spi0: spi@01c05000 {
interrupts = <10>; interrupts = <10>;
clocks = <&ahb_gates 20>, <&spi0_clk>; clocks = <&ahb_gates 20>, <&spi0_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 27>, <&dma 1 26>; dmas = <&dma SUN4I_DMA_DEDICATED 27>,
<&dma SUN4I_DMA_DEDICATED 26>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -333,7 +345,8 @@ spi1: spi@01c06000 { ...@@ -333,7 +345,8 @@ spi1: spi@01c06000 {
interrupts = <11>; interrupts = <11>;
clocks = <&ahb_gates 21>, <&spi1_clk>; clocks = <&ahb_gates 21>, <&spi1_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 9>, <&dma 1 8>; dmas = <&dma SUN4I_DMA_DEDICATED 9>,
<&dma SUN4I_DMA_DEDICATED 8>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -348,7 +361,7 @@ emac: ethernet@01c0b000 { ...@@ -348,7 +361,7 @@ emac: ethernet@01c0b000 {
status = "disabled"; status = "disabled";
}; };
mdio@01c0b080 { mdio: mdio@01c0b080 {
compatible = "allwinner,sun4i-a10-mdio"; compatible = "allwinner,sun4i-a10-mdio";
reg = <0x01c0b080 0x14>; reg = <0x01c0b080 0x14>;
status = "disabled"; status = "disabled";
...@@ -390,8 +403,8 @@ usbphy: phy@01c13400 { ...@@ -390,8 +403,8 @@ usbphy: phy@01c13400 {
reg-names = "phy_ctrl", "pmu1"; reg-names = "phy_ctrl", "pmu1";
clocks = <&usb_clk 8>; clocks = <&usb_clk 8>;
clock-names = "usb_phy"; clock-names = "usb_phy";
resets = <&usb_clk 1>; resets = <&usb_clk 0>, <&usb_clk 1>;
reset-names = "usb1_reset"; reset-names = "usb0_reset", "usb1_reset";
status = "disabled"; status = "disabled";
}; };
...@@ -421,7 +434,8 @@ spi2: spi@01c17000 { ...@@ -421,7 +434,8 @@ spi2: spi@01c17000 {
interrupts = <12>; interrupts = <12>;
clocks = <&ahb_gates 22>, <&spi2_clk>; clocks = <&ahb_gates 22>, <&spi2_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 29>, <&dma 1 28>; dmas = <&dma SUN4I_DMA_DEDICATED 29>,
<&dma SUN4I_DMA_DEDICATED 28>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -449,22 +463,22 @@ pio: pinctrl@01c20800 { ...@@ -449,22 +463,22 @@ pio: pinctrl@01c20800 {
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PB19", "PB20"; allwinner,pins = "PB19", "PB20";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart2_pins_a: uart2@0 { uart2_pins_a: uart2@0 {
allwinner,pins = "PC18", "PC19"; allwinner,pins = "PC18", "PC19";
allwinner,function = "uart2"; allwinner,function = "uart2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart3_pins_a: uart3@0 { uart3_pins_a: uart3@0 {
allwinner,pins = "PG9", "PG10"; allwinner,pins = "PG9", "PG10";
allwinner,function = "uart3"; allwinner,function = "uart3";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
emac_pins_a: emac0@0 { emac_pins_a: emac0@0 {
...@@ -474,43 +488,43 @@ emac_pins_a: emac0@0 { ...@@ -474,43 +488,43 @@ emac_pins_a: emac0@0 {
"PA11", "PA12", "PA13", "PA14", "PA11", "PA12", "PA13", "PA14",
"PA15", "PA16"; "PA15", "PA16";
allwinner,function = "emac"; allwinner,function = "emac";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PB0", "PB1"; allwinner,pins = "PB0", "PB1";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PB15", "PB16"; allwinner,pins = "PB15", "PB16";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PB17", "PB18"; allwinner,pins = "PB17", "PB18";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc1_pins_a: mmc1@0 { mmc1_pins_a: mmc1@0 {
allwinner,pins = "PG3","PG4","PG5","PG6","PG7","PG8"; allwinner,pins = "PG3","PG4","PG5","PG6","PG7","PG8";
allwinner,function = "mmc1"; allwinner,function = "mmc1";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -526,6 +540,13 @@ wdt: watchdog@01c20c90 { ...@@ -526,6 +540,13 @@ wdt: watchdog@01c20c90 {
reg = <0x01c20c90 0x10>; reg = <0x01c20c90 0x10>;
}; };
lradc: lradc@01c22800 {
compatible = "allwinner,sun4i-a10-lradc-keys";
reg = <0x01c22800 0x100>;
interrupts = <31>;
status = "disabled";
};
sid: eeprom@01c23800 { sid: eeprom@01c23800 {
compatible = "allwinner,sun4i-a10-sid"; compatible = "allwinner,sun4i-a10-sid";
reg = <0x01c23800 0x10>; reg = <0x01c23800 0x10>;
...@@ -535,6 +556,7 @@ rtp: rtp@01c25000 { ...@@ -535,6 +556,7 @@ rtp: rtp@01c25000 {
compatible = "allwinner,sun4i-a10-ts"; compatible = "allwinner,sun4i-a10-ts";
reg = <0x01c25000 0x100>; reg = <0x01c25000 0x100>;
interrupts = <29>; interrupts = <29>;
#thermal-sensor-cells = <0>;
}; };
uart0: serial@01c28000 { uart0: serial@01c28000 {
......
...@@ -46,8 +46,11 @@ ...@@ -46,8 +46,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun5i-a13.dtsi" #include "sun5i-a13.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "HSG H702"; model = "HSG H702";
...@@ -59,17 +62,13 @@ mmc0: mmc@01c0f000 { ...@@ -59,17 +62,13 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_h702>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_h702>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 0 0>; /* PG0 */ cd-gpios = <&pio 6 0 GPIO_ACTIVE_HIGH>; /* PG0 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
usbphy: phy@01c13400 { usbphy: phy@01c13400 {
/* usb1_vbus-supply = <&reg_ldo3>;
* There doesn't seem to be a GPIO for controlling
* usb1 vbus, despite the fex file saying otherwise.
*/
usb1_vbus-supply = <&reg_vcc5v0>;
status = "okay"; status = "okay";
}; };
...@@ -85,8 +84,8 @@ pinctrl@01c20800 { ...@@ -85,8 +84,8 @@ pinctrl@01c20800 {
mmc0_cd_pin_h702: mmc0_cd_pin@0 { mmc0_cd_pin_h702: mmc0_cd_pin@0 {
allwinner,pins = "PG0"; allwinner,pins = "PG0";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
}; };
...@@ -102,11 +101,8 @@ i2c0: i2c@01c2ac00 { ...@@ -102,11 +101,8 @@ i2c0: i2c@01c2ac00 {
status = "okay"; status = "okay";
axp209: pmic@34 { axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupts = <0>; interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
}; };
}; };
...@@ -128,3 +124,40 @@ i2c2: i2c@01c2b400 { ...@@ -128,3 +124,40 @@ i2c2: i2c@01c2b400 {
}; };
}; };
}; };
#include "axp209.dtsi"
&cpu0 {
cpu-supply = <&reg_dcdc2>;
};
&reg_dcdc2 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1500000>;
regulator-name = "vdd-cpu";
};
&reg_dcdc3 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1400000>;
regulator-name = "vdd-int-dll";
};
&reg_ldo1 {
regulator-name = "vdd-rtc";
};
&reg_ldo2 {
regulator-always-on;
regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>;
regulator-name = "avcc";
};
&reg_ldo3 {
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
regulator-name = "vcc-wifi";
};
...@@ -47,8 +47,11 @@ ...@@ -47,8 +47,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun5i-a13.dtsi" #include "sun5i-a13.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A13-Olinuxino Micro"; model = "Olimex A13-Olinuxino Micro";
...@@ -60,7 +63,7 @@ mmc0: mmc@01c0f000 { ...@@ -60,7 +63,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxinom>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxinom>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 0 0>; /* PG0 */ cd-gpios = <&pio 6 0 GPIO_ACTIVE_HIGH>; /* PG0 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -82,22 +85,22 @@ pinctrl@01c20800 { ...@@ -82,22 +85,22 @@ pinctrl@01c20800 {
mmc0_cd_pin_olinuxinom: mmc0_cd_pin@0 { mmc0_cd_pin_olinuxinom: mmc0_cd_pin@0 {
allwinner,pins = "PG0"; allwinner,pins = "PG0";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
led_pins_olinuxinom: led_pins@0 { led_pins_olinuxinom: led_pins@0 {
allwinner,pins = "PG9"; allwinner,pins = "PG9";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_olinuxinom: usb1_vbus_pin@0 { usb1_vbus_pin_olinuxinom: usb1_vbus_pin@0 {
allwinner,pins = "PG11"; allwinner,pins = "PG11";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -133,14 +136,14 @@ leds { ...@@ -133,14 +136,14 @@ leds {
power { power {
label = "a13-olinuxino-micro:green:power"; label = "a13-olinuxino-micro:green:power";
gpios = <&pio 6 9 0>; gpios = <&pio 6 9 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_olinuxinom>; pinctrl-0 = <&usb1_vbus_pin_olinuxinom>;
gpio = <&pio 6 11 0>; gpio = <&pio 6 11 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -48,8 +48,12 @@ ...@@ -48,8 +48,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun5i-a13.dtsi" #include "sun5i-a13.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A13-Olinuxino"; model = "Olimex A13-Olinuxino";
...@@ -61,7 +65,7 @@ mmc0: mmc@01c0f000 { ...@@ -61,7 +65,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxino>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_olinuxino>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 6 0 0>; /* PG0 */ cd-gpios = <&pio 6 0 GPIO_ACTIVE_HIGH>; /* PG0 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -83,22 +87,62 @@ pinctrl@01c20800 { ...@@ -83,22 +87,62 @@ pinctrl@01c20800 {
mmc0_cd_pin_olinuxino: mmc0_cd_pin@0 { mmc0_cd_pin_olinuxino: mmc0_cd_pin@0 {
allwinner,pins = "PG0"; allwinner,pins = "PG0";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
led_pins_olinuxino: led_pins@0 { led_pins_olinuxino: led_pins@0 {
allwinner,pins = "PG9"; allwinner,pins = "PG9";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_olinuxino: usb1_vbus_pin@0 { usb1_vbus_pin_olinuxino: usb1_vbus_pin@0 {
allwinner,pins = "PG11"; allwinner,pins = "PG11";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
lradc: lradc@01c22800 {
vref-supply = <&reg_vcc3v0>;
status = "okay";
button@191 {
label = "Volume Up";
linux,code = <KEY_VOLUMEUP>;
channel = <0>;
voltage = <191274>;
};
button@392 {
label = "Volume Down";
linux,code = <KEY_VOLUMEDOWN>;
channel = <0>;
voltage = <392644>;
};
button@601 {
label = "Menu";
linux,code = <KEY_MENU>;
channel = <0>;
voltage = <601151>;
};
button@795 {
label = "Enter";
linux,code = <KEY_ENTER>;
channel = <0>;
voltage = <795090>;
};
button@987 {
label = "Home";
linux,code = <KEY_HOMEPAGE>;
channel = <0>;
voltage = <987387>;
}; };
}; };
...@@ -112,6 +156,15 @@ i2c0: i2c@01c2ac00 { ...@@ -112,6 +156,15 @@ i2c0: i2c@01c2ac00 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>; pinctrl-0 = <&i2c0_pins_a>;
status = "okay"; status = "okay";
axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>;
interrupts = <0>;
interrupt-controller;
#interrupt-cells = <1>;
};
}; };
i2c1: i2c@01c2b000 { i2c1: i2c@01c2b000 {
...@@ -133,14 +186,14 @@ leds { ...@@ -133,14 +186,14 @@ leds {
pinctrl-0 = <&led_pins_olinuxino>; pinctrl-0 = <&led_pins_olinuxino>;
power { power {
gpios = <&pio 6 9 0>; gpios = <&pio 6 9 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_olinuxino>; pinctrl-0 = <&usb1_vbus_pin_olinuxino>;
gpio = <&pio 6 11 0>; gpio = <&pio 6 11 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -11,7 +11,12 @@ ...@@ -11,7 +11,12 @@
* http://www.gnu.org/copyleft/gpl.html * http://www.gnu.org/copyleft/gpl.html
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/thermal/thermal.h>
#include <dt-bindings/dma/sun4i-a10.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&intc>; interrupt-parent = <&intc>;
...@@ -21,13 +26,75 @@ aliases { ...@@ -21,13 +26,75 @@ aliases {
serial1 = &uart3; serial1 = &uart3;
}; };
chosen {
#address-cells = <1>;
#size-cells = <1>;
ranges;
framebuffer@0 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0";
clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 44>;
status = "disabled";
};
};
cpus { cpus {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <0>; #size-cells = <0>;
cpu@0 {
cpu0: cpu@0 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a8"; compatible = "arm,cortex-a8";
reg = <0x0>; reg = <0x0>;
clocks = <&cpu>;
clock-latency = <244144>; /* 8 32k periods */
operating-points = <
/* kHz uV */
1104000 1500000
1008000 1400000
912000 1350000
864000 1300000
624000 1200000
576000 1200000
432000 1200000
>;
#cooling-cells = <2>;
cooling-min-level = <0>;
cooling-max-level = <6>;
};
};
thermal-zones {
cpu_thermal {
/* milliseconds */
polling-delay-passive = <250>;
polling-delay = <1000>;
thermal-sensors = <&rtp>;
cooling-maps {
map0 {
trip = <&cpu_alert0>;
cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
};
};
trips {
cpu_alert0: cpu_alert0 {
/* milliCelsius */
temperature = <850000>;
hysteresis = <2000>;
type = "passive";
};
cpu_crit: cpu_crit {
/* milliCelsius */
temperature = <100000>;
hysteresis = <2000>;
type = "critical";
};
};
}; };
}; };
...@@ -304,7 +371,8 @@ spi0: spi@01c05000 { ...@@ -304,7 +371,8 @@ spi0: spi@01c05000 {
interrupts = <10>; interrupts = <10>;
clocks = <&ahb_gates 20>, <&spi0_clk>; clocks = <&ahb_gates 20>, <&spi0_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 27>, <&dma 1 26>; dmas = <&dma SUN4I_DMA_DEDICATED 27>,
<&dma SUN4I_DMA_DEDICATED 26>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -317,7 +385,8 @@ spi1: spi@01c06000 { ...@@ -317,7 +385,8 @@ spi1: spi@01c06000 {
interrupts = <11>; interrupts = <11>;
clocks = <&ahb_gates 21>, <&spi1_clk>; clocks = <&ahb_gates 21>, <&spi1_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 9>, <&dma 1 8>; dmas = <&dma SUN4I_DMA_DEDICATED 9>,
<&dma SUN4I_DMA_DEDICATED 8>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -349,8 +418,8 @@ usbphy: phy@01c13400 { ...@@ -349,8 +418,8 @@ usbphy: phy@01c13400 {
reg-names = "phy_ctrl", "pmu1"; reg-names = "phy_ctrl", "pmu1";
clocks = <&usb_clk 8>; clocks = <&usb_clk 8>;
clock-names = "usb_phy"; clock-names = "usb_phy";
resets = <&usb_clk 1>; resets = <&usb_clk 0>, <&usb_clk 1>;
reset-names = "usb1_reset"; reset-names = "usb0_reset", "usb1_reset";
status = "disabled"; status = "disabled";
}; };
...@@ -380,7 +449,8 @@ spi2: spi@01c17000 { ...@@ -380,7 +449,8 @@ spi2: spi@01c17000 {
interrupts = <12>; interrupts = <12>;
clocks = <&ahb_gates 22>, <&spi2_clk>; clocks = <&ahb_gates 22>, <&spi2_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 29>, <&dma 1 28>; dmas = <&dma SUN4I_DMA_DEDICATED 29>,
<&dma SUN4I_DMA_DEDICATED 28>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -408,43 +478,43 @@ pio: pinctrl@01c20800 { ...@@ -408,43 +478,43 @@ pio: pinctrl@01c20800 {
uart1_pins_a: uart1@0 { uart1_pins_a: uart1@0 {
allwinner,pins = "PE10", "PE11"; allwinner,pins = "PE10", "PE11";
allwinner,function = "uart1"; allwinner,function = "uart1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart1_pins_b: uart1@1 { uart1_pins_b: uart1@1 {
allwinner,pins = "PG3", "PG4"; allwinner,pins = "PG3", "PG4";
allwinner,function = "uart1"; allwinner,function = "uart1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PB0", "PB1"; allwinner,pins = "PB0", "PB1";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PB15", "PB16"; allwinner,pins = "PB15", "PB16";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PB17", "PB18"; allwinner,pins = "PB17", "PB18";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -460,6 +530,13 @@ wdt: watchdog@01c20c90 { ...@@ -460,6 +530,13 @@ wdt: watchdog@01c20c90 {
reg = <0x01c20c90 0x10>; reg = <0x01c20c90 0x10>;
}; };
lradc: lradc@01c22800 {
compatible = "allwinner,sun4i-a10-lradc-keys";
reg = <0x01c22800 0x100>;
interrupts = <31>;
status = "disabled";
};
sid: eeprom@01c23800 { sid: eeprom@01c23800 {
compatible = "allwinner,sun4i-a10-sid"; compatible = "allwinner,sun4i-a10-sid";
reg = <0x01c23800 0x10>; reg = <0x01c23800 0x10>;
...@@ -469,6 +546,7 @@ rtp: rtp@01c25000 { ...@@ -469,6 +546,7 @@ rtp: rtp@01c25000 {
compatible = "allwinner,sun4i-a10-ts"; compatible = "allwinner,sun4i-a10-ts";
reg = <0x01c25000 0x100>; reg = <0x01c25000 0x100>;
interrupts = <29>; interrupts = <29>;
#thermal-sensor-cells = <0>;
}; };
uart1: serial@01c28400 { uart1: serial@01c28400 {
......
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun6i-a31.dtsi" #include "sun6i-a31.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Allwinner A31 APP4 EVB1 Evaluation Board"; model = "Allwinner A31 APP4 EVB1 Evaluation Board";
...@@ -64,8 +67,8 @@ pio: pinctrl@01c20800 { ...@@ -64,8 +67,8 @@ pio: pinctrl@01c20800 {
usb1_vbus_pin_a: usb1_vbus_pin@0 { usb1_vbus_pin_a: usb1_vbus_pin@0 {
allwinner,pins = "PH27"; allwinner,pins = "PH27";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -87,7 +90,7 @@ uart0: serial@01c28000 { ...@@ -87,7 +90,7 @@ uart0: serial@01c28000 {
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_a>; pinctrl-0 = <&usb1_vbus_pin_a>;
gpio = <&pio 7 27 0>; gpio = <&pio 7 27 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun6i-a31.dtsi" #include "sun6i-a31.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "WITS A31 Colombus Evaluation Board"; model = "WITS A31 Colombus Evaluation Board";
...@@ -65,7 +68,7 @@ mmc0: mmc@01c0f000 { ...@@ -65,7 +68,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_colombus>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_colombus>;
vmmc-supply = <&reg_vcc3v0>; vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 0 8 0>; /* PA8 */ cd-gpios = <&pio 0 8 GPIO_ACTIVE_HIGH>; /* PA8 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -81,21 +84,21 @@ ehci1: usb@01c1b000 { ...@@ -81,21 +84,21 @@ ehci1: usb@01c1b000 {
pio: pinctrl@01c20800 { pio: pinctrl@01c20800 {
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
mmc0_cd_pin_colombus: mmc0_cd_pin@0 { mmc0_cd_pin_colombus: mmc0_cd_pin@0 {
allwinner,pins = "PA8"; allwinner,pins = "PA8";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
usb2_vbus_pin_colombus: usb2_vbus_pin@0 { usb2_vbus_pin_colombus: usb2_vbus_pin@0 {
allwinner,pins = "PH24"; allwinner,pins = "PH24";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -127,7 +130,7 @@ i2c2: i2c@01c2b400 { ...@@ -127,7 +130,7 @@ i2c2: i2c@01c2b400 {
reg_usb2_vbus: usb2-vbus { reg_usb2_vbus: usb2-vbus {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&usb2_vbus_pin_colombus>; pinctrl-0 = <&usb2_vbus_pin_colombus>;
gpio = <&pio 7 24 0>; gpio = <&pio 7 24 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -48,8 +48,11 @@ ...@@ -48,8 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun6i-a31.dtsi" #include "sun6i-a31.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Merrii A31 Hummingbird"; model = "Merrii A31 Hummingbird";
...@@ -58,72 +61,41 @@ / { ...@@ -58,72 +61,41 @@ / {
chosen { chosen {
bootargs = "earlyprintk console=ttyS0,115200"; bootargs = "earlyprintk console=ttyS0,115200";
}; };
};
soc@01c00000 { &ehci0 {
mmc0: mmc@01c0f000 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_hummingbird>;
vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>;
cd-gpios = <&pio 0 8 0>; /* PA8 */
cd-inverted;
status = "okay";
};
usbphy: phy@01c19400 {
usb1_vbus-supply = <&reg_usb1_vbus>;
status = "okay";
};
ehci0: usb@01c1a000 {
status = "okay";
};
ohci0: usb@01c1a400 {
status = "okay"; status = "okay";
}; };
pio: pinctrl@01c20800 {
mmc0_pins_a: mmc0@0 {
/* external pull-ups missing for some pins */
allwinner,pull = <1>;
};
mmc0_cd_pin_hummingbird: mmc0_cd_pin@0 {
allwinner,pins = "PA8";
allwinner,function = "gpio_in";
allwinner,drive = <0>;
allwinner,pull = <1>;
};
usb1_vbus_pin_a: usb1_vbus_pin@0 {
allwinner,pins = "PH24";
allwinner,function = "gpio_out";
allwinner,drive = <0>;
allwinner,pull = <0>;
};
};
uart0: serial@01c28000 { &gmac {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>; pinctrl-0 = <&gmac_pins_rgmii_a>;
phy = <&phy1>;
phy-mode = "rgmii";
snps,reset-gpio = <&pio 0 21 GPIO_ACTIVE_HIGH>;
snps,reset-active-low;
snps,reset-delays-us = <0 10000 30000>;
status = "okay"; status = "okay";
phy1: ethernet-phy@1 {
reg = <1>;
}; };
};
i2c0: i2c@01c2ac00 { &i2c0 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>; pinctrl-0 = <&i2c0_pins_a>;
/* pull-ups and devices require AXP221 DLDO3 */ /* pull-ups and devices require AXP221 DLDO3 */
status = "failed"; status = "failed";
}; };
i2c1: i2c@01c2b000 { &i2c1 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&i2c1_pins_a>; pinctrl-0 = <&i2c1_pins_a>;
status = "okay"; status = "okay";
}; };
i2c2: i2c@01c2b400 { &i2c2 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&i2c2_pins_a>; pinctrl-0 = <&i2c2_pins_a>;
status = "okay"; status = "okay";
...@@ -132,24 +104,53 @@ pcf8563: rtc@51 { ...@@ -132,24 +104,53 @@ pcf8563: rtc@51 {
compatible = "nxp,pcf8563"; compatible = "nxp,pcf8563";
reg = <0x51>; reg = <0x51>;
}; };
}; };
gmac: ethernet@01c30000 { &mmc0 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&gmac_pins_rgmii_a>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_hummingbird>;
phy = <&phy1>; vmmc-supply = <&reg_vcc3v0>;
phy-mode = "rgmii"; bus-width = <4>;
cd-gpios = <&pio 0 8 GPIO_ACTIVE_HIGH>; /* PA8 */
cd-inverted;
status = "okay"; status = "okay";
};
phy1: ethernet-phy@1 { &mmc0_pins_a {
reg = <1>; /* external pull-ups missing for some pins */
}; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
};
reg_usb1_vbus: usb1-vbus { &ohci0 {
pinctrl-0 = <&usb1_vbus_pin_a>;
gpio = <&pio 7 24 0>; /* PH24 */
status = "okay"; status = "okay";
};
&pio {
mmc0_cd_pin_hummingbird: mmc0_cd_pin@0 {
allwinner,pins = "PA8";
allwinner,function = "gpio_in";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
}; };
&reg_usb1_vbus {
gpio = <&pio 7 24 GPIO_ACTIVE_HIGH>; /* PH24 */
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&usb1_vbus_pin_a {
/* different pin from sunxi-common-regulators */
allwinner,pins = "PH24";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
status = "okay";
};
...@@ -46,8 +46,11 @@ ...@@ -46,8 +46,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun6i-a31.dtsi" #include "sun6i-a31.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Mele M9 / A1000G Quad top set box"; model = "Mele M9 / A1000G Quad top set box";
...@@ -63,7 +66,7 @@ mmc0: mmc@01c0f000 { ...@@ -63,7 +66,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_m9>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_m9>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 22 0>; /* PH22 */ cd-gpios = <&pio 7 22 GPIO_ACTIVE_HIGH>; /* PH22 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -85,22 +88,22 @@ pio: pinctrl@01c20800 { ...@@ -85,22 +88,22 @@ pio: pinctrl@01c20800 {
led_pins_m9: led_pins@0 { led_pins_m9: led_pins@0 {
allwinner,pins = "PH13"; allwinner,pins = "PH13";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_cd_pin_m9: mmc0_cd_pin@0 { mmc0_cd_pin_m9: mmc0_cd_pin@0 {
allwinner,pins = "PH22"; allwinner,pins = "PH22";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
usb1_vbus_pin_m9: usb1_vbus_pin@0 { usb1_vbus_pin_m9: usb1_vbus_pin@0 {
allwinner,pins = "PC27"; allwinner,pins = "PC27";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -121,6 +124,12 @@ phy1: ethernet-phy@1 { ...@@ -121,6 +124,12 @@ phy1: ethernet-phy@1 {
reg = <1>; reg = <1>;
}; };
}; };
ir@01f02000 {
pinctrl-names = "default";
pinctrl-0 = <&ir_pins_a>;
status = "okay";
};
}; };
leds { leds {
...@@ -130,14 +139,14 @@ leds { ...@@ -130,14 +139,14 @@ leds {
blue { blue {
label = "m9:blue:usr"; label = "m9:blue:usr";
gpios = <&pio 7 13 0>; gpios = <&pio 7 13 GPIO_ACTIVE_HIGH>;
}; };
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&usb1_vbus_pin_m9>; pinctrl-0 = <&usb1_vbus_pin_m9>;
gpio = <&pio 2 27 0>; gpio = <&pio 2 27 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -47,7 +47,11 @@ ...@@ -47,7 +47,11 @@
* OTHER DEALINGS IN THE SOFTWARE. * OTHER DEALINGS IN THE SOFTWARE.
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
...@@ -73,6 +77,24 @@ framebuffer@0 { ...@@ -73,6 +77,24 @@ framebuffer@0 {
clocks = <&pll6 0>; clocks = <&pll6 0>;
status = "disabled"; status = "disabled";
}; };
framebuffer@1 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0";
clocks = <&pll6 0>;
status = "disabled";
};
};
timer {
compatible = "arm,armv7-timer";
interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
clock-frequency = <24000000>;
arm,cpu-registers-not-fw-configured;
}; };
cpus { cpus {
...@@ -111,10 +133,10 @@ memory { ...@@ -111,10 +133,10 @@ memory {
pmu { pmu {
compatible = "arm,cortex-a7-pmu", "arm,cortex-a15-pmu"; compatible = "arm,cortex-a7-pmu", "arm,cortex-a15-pmu";
interrupts = <0 120 4>, interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
<0 121 4>, <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
<0 122 4>, <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>,
<0 123 4>; <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>;
}; };
clocks { clocks {
...@@ -361,7 +383,7 @@ soc@01c00000 { ...@@ -361,7 +383,7 @@ soc@01c00000 {
dma: dma-controller@01c02000 { dma: dma-controller@01c02000 {
compatible = "allwinner,sun6i-a31-dma"; compatible = "allwinner,sun6i-a31-dma";
reg = <0x01c02000 0x1000>; reg = <0x01c02000 0x1000>;
interrupts = <0 50 4>; interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 6>; clocks = <&ahb1_gates 6>;
resets = <&ahb1_rst 6>; resets = <&ahb1_rst 6>;
#dma-cells = <1>; #dma-cells = <1>;
...@@ -378,7 +400,7 @@ mmc0: mmc@01c0f000 { ...@@ -378,7 +400,7 @@ mmc0: mmc@01c0f000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 8>; resets = <&ahb1_rst 8>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 60 4>; interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -389,7 +411,7 @@ mmc1: mmc@01c10000 { ...@@ -389,7 +411,7 @@ mmc1: mmc@01c10000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 9>; resets = <&ahb1_rst 9>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 61 4>; interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -400,7 +422,7 @@ mmc2: mmc@01c11000 { ...@@ -400,7 +422,7 @@ mmc2: mmc@01c11000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 10>; resets = <&ahb1_rst 10>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 62 4>; interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -411,7 +433,7 @@ mmc3: mmc@01c12000 { ...@@ -411,7 +433,7 @@ mmc3: mmc@01c12000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 11>; resets = <&ahb1_rst 11>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 63 4>; interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -442,7 +464,7 @@ usbphy: phy@01c19400 { ...@@ -442,7 +464,7 @@ usbphy: phy@01c19400 {
ehci0: usb@01c1a000 { ehci0: usb@01c1a000 {
compatible = "allwinner,sun6i-a31-ehci", "generic-ehci"; compatible = "allwinner,sun6i-a31-ehci", "generic-ehci";
reg = <0x01c1a000 0x100>; reg = <0x01c1a000 0x100>;
interrupts = <0 72 4>; interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 26>; clocks = <&ahb1_gates 26>;
resets = <&ahb1_rst 26>; resets = <&ahb1_rst 26>;
phys = <&usbphy 1>; phys = <&usbphy 1>;
...@@ -453,7 +475,7 @@ ehci0: usb@01c1a000 { ...@@ -453,7 +475,7 @@ ehci0: usb@01c1a000 {
ohci0: usb@01c1a400 { ohci0: usb@01c1a400 {
compatible = "allwinner,sun6i-a31-ohci", "generic-ohci"; compatible = "allwinner,sun6i-a31-ohci", "generic-ohci";
reg = <0x01c1a400 0x100>; reg = <0x01c1a400 0x100>;
interrupts = <0 73 4>; interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 29>, <&usb_clk 16>; clocks = <&ahb1_gates 29>, <&usb_clk 16>;
resets = <&ahb1_rst 29>; resets = <&ahb1_rst 29>;
phys = <&usbphy 1>; phys = <&usbphy 1>;
...@@ -464,7 +486,7 @@ ohci0: usb@01c1a400 { ...@@ -464,7 +486,7 @@ ohci0: usb@01c1a400 {
ehci1: usb@01c1b000 { ehci1: usb@01c1b000 {
compatible = "allwinner,sun6i-a31-ehci", "generic-ehci"; compatible = "allwinner,sun6i-a31-ehci", "generic-ehci";
reg = <0x01c1b000 0x100>; reg = <0x01c1b000 0x100>;
interrupts = <0 74 4>; interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 27>; clocks = <&ahb1_gates 27>;
resets = <&ahb1_rst 27>; resets = <&ahb1_rst 27>;
phys = <&usbphy 2>; phys = <&usbphy 2>;
...@@ -475,7 +497,7 @@ ehci1: usb@01c1b000 { ...@@ -475,7 +497,7 @@ ehci1: usb@01c1b000 {
ohci1: usb@01c1b400 { ohci1: usb@01c1b400 {
compatible = "allwinner,sun6i-a31-ohci", "generic-ohci"; compatible = "allwinner,sun6i-a31-ohci", "generic-ohci";
reg = <0x01c1b400 0x100>; reg = <0x01c1b400 0x100>;
interrupts = <0 75 4>; interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 30>, <&usb_clk 17>; clocks = <&ahb1_gates 30>, <&usb_clk 17>;
resets = <&ahb1_rst 30>; resets = <&ahb1_rst 30>;
phys = <&usbphy 2>; phys = <&usbphy 2>;
...@@ -486,7 +508,7 @@ ohci1: usb@01c1b400 { ...@@ -486,7 +508,7 @@ ohci1: usb@01c1b400 {
ohci2: usb@01c1c400 { ohci2: usb@01c1c400 {
compatible = "allwinner,sun6i-a31-ohci", "generic-ohci"; compatible = "allwinner,sun6i-a31-ohci", "generic-ohci";
reg = <0x01c1c400 0x100>; reg = <0x01c1c400 0x100>;
interrupts = <0 77 4>; interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 31>, <&usb_clk 18>; clocks = <&ahb1_gates 31>, <&usb_clk 18>;
resets = <&ahb1_rst 31>; resets = <&ahb1_rst 31>;
status = "disabled"; status = "disabled";
...@@ -495,10 +517,10 @@ ohci2: usb@01c1c400 { ...@@ -495,10 +517,10 @@ ohci2: usb@01c1c400 {
pio: pinctrl@01c20800 { pio: pinctrl@01c20800 {
compatible = "allwinner,sun6i-a31-pinctrl"; compatible = "allwinner,sun6i-a31-pinctrl";
reg = <0x01c20800 0x400>; reg = <0x01c20800 0x400>;
interrupts = <0 11 4>, interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>,
<0 15 4>, <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>,
<0 16 4>, <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>,
<0 17 4>; <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 5>; clocks = <&apb1_gates 5>;
gpio-controller; gpio-controller;
interrupt-controller; interrupt-controller;
...@@ -509,36 +531,36 @@ pio: pinctrl@01c20800 { ...@@ -509,36 +531,36 @@ pio: pinctrl@01c20800 {
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PH20", "PH21"; allwinner,pins = "PH20", "PH21";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PH14", "PH15"; allwinner,pins = "PH14", "PH15";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PH16", "PH17"; allwinner,pins = "PH16", "PH17";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PH18", "PH19"; allwinner,pins = "PH18", "PH19";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_pins_mii_a: gmac_mii@0 { gmac_pins_mii_a: gmac_mii@0 {
...@@ -548,8 +570,8 @@ gmac_pins_mii_a: gmac_mii@0 { ...@@ -548,8 +570,8 @@ gmac_pins_mii_a: gmac_mii@0 {
"PA20", "PA21", "PA22", "PA23", "PA20", "PA21", "PA22", "PA23",
"PA24", "PA26", "PA27"; "PA24", "PA26", "PA27";
allwinner,function = "gmac"; allwinner,function = "gmac";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_pins_gmii_a: gmac_gmii@0 { gmac_pins_gmii_a: gmac_gmii@0 {
...@@ -565,8 +587,8 @@ gmac_pins_gmii_a: gmac_gmii@0 { ...@@ -565,8 +587,8 @@ gmac_pins_gmii_a: gmac_gmii@0 {
* data lines in GMII mode run at 125MHz and * data lines in GMII mode run at 125MHz and
* might need a higher signal drive strength * might need a higher signal drive strength
*/ */
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_pins_rgmii_a: gmac_rgmii@0 { gmac_pins_rgmii_a: gmac_rgmii@0 {
...@@ -579,8 +601,8 @@ gmac_pins_rgmii_a: gmac_rgmii@0 { ...@@ -579,8 +601,8 @@ gmac_pins_rgmii_a: gmac_rgmii@0 {
* data lines in RGMII mode use DDR mode * data lines in RGMII mode use DDR mode
* and need a higher signal drive strength * and need a higher signal drive strength
*/ */
allwinner,drive = <3>; allwinner,drive = <SUN4I_PINCTRL_40_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -605,11 +627,11 @@ apb2_rst: reset@01c202d8 { ...@@ -605,11 +627,11 @@ apb2_rst: reset@01c202d8 {
timer@01c20c00 { timer@01c20c00 {
compatible = "allwinner,sun4i-a10-timer"; compatible = "allwinner,sun4i-a10-timer";
reg = <0x01c20c00 0xa0>; reg = <0x01c20c00 0xa0>;
interrupts = <0 18 4>, interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>,
<0 19 4>, <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>,
<0 20 4>, <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>,
<0 21 4>, <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>,
<0 22 4>; <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&osc24M>; clocks = <&osc24M>;
}; };
...@@ -618,10 +640,17 @@ wdt1: watchdog@01c20ca0 { ...@@ -618,10 +640,17 @@ wdt1: watchdog@01c20ca0 {
reg = <0x01c20ca0 0x20>; reg = <0x01c20ca0 0x20>;
}; };
rtp: rtp@01c25000 {
compatible = "allwinner,sun6i-a31-ts";
reg = <0x01c25000 0x100>;
interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
#thermal-sensor-cells = <0>;
};
uart0: serial@01c28000 { uart0: serial@01c28000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28000 0x400>; reg = <0x01c28000 0x400>;
interrupts = <0 0 4>; interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 16>; clocks = <&apb2_gates 16>;
...@@ -634,7 +663,7 @@ uart0: serial@01c28000 { ...@@ -634,7 +663,7 @@ uart0: serial@01c28000 {
uart1: serial@01c28400 { uart1: serial@01c28400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28400 0x400>; reg = <0x01c28400 0x400>;
interrupts = <0 1 4>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 17>; clocks = <&apb2_gates 17>;
...@@ -647,7 +676,7 @@ uart1: serial@01c28400 { ...@@ -647,7 +676,7 @@ uart1: serial@01c28400 {
uart2: serial@01c28800 { uart2: serial@01c28800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28800 0x400>; reg = <0x01c28800 0x400>;
interrupts = <0 2 4>; interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 18>; clocks = <&apb2_gates 18>;
...@@ -660,7 +689,7 @@ uart2: serial@01c28800 { ...@@ -660,7 +689,7 @@ uart2: serial@01c28800 {
uart3: serial@01c28c00 { uart3: serial@01c28c00 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28c00 0x400>; reg = <0x01c28c00 0x400>;
interrupts = <0 3 4>; interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 19>; clocks = <&apb2_gates 19>;
...@@ -673,7 +702,7 @@ uart3: serial@01c28c00 { ...@@ -673,7 +702,7 @@ uart3: serial@01c28c00 {
uart4: serial@01c29000 { uart4: serial@01c29000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29000 0x400>; reg = <0x01c29000 0x400>;
interrupts = <0 4 4>; interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 20>; clocks = <&apb2_gates 20>;
...@@ -686,7 +715,7 @@ uart4: serial@01c29000 { ...@@ -686,7 +715,7 @@ uart4: serial@01c29000 {
uart5: serial@01c29400 { uart5: serial@01c29400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29400 0x400>; reg = <0x01c29400 0x400>;
interrupts = <0 5 4>; interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 21>; clocks = <&apb2_gates 21>;
...@@ -699,7 +728,7 @@ uart5: serial@01c29400 { ...@@ -699,7 +728,7 @@ uart5: serial@01c29400 {
i2c0: i2c@01c2ac00 { i2c0: i2c@01c2ac00 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2ac00 0x400>; reg = <0x01c2ac00 0x400>;
interrupts = <0 6 4>; interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 0>; clocks = <&apb2_gates 0>;
resets = <&apb2_rst 0>; resets = <&apb2_rst 0>;
status = "disabled"; status = "disabled";
...@@ -710,7 +739,7 @@ i2c0: i2c@01c2ac00 { ...@@ -710,7 +739,7 @@ i2c0: i2c@01c2ac00 {
i2c1: i2c@01c2b000 { i2c1: i2c@01c2b000 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2b000 0x400>; reg = <0x01c2b000 0x400>;
interrupts = <0 7 4>; interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 1>; clocks = <&apb2_gates 1>;
resets = <&apb2_rst 1>; resets = <&apb2_rst 1>;
status = "disabled"; status = "disabled";
...@@ -721,7 +750,7 @@ i2c1: i2c@01c2b000 { ...@@ -721,7 +750,7 @@ i2c1: i2c@01c2b000 {
i2c2: i2c@01c2b400 { i2c2: i2c@01c2b400 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2b400 0x400>; reg = <0x01c2b400 0x400>;
interrupts = <0 8 4>; interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 2>; clocks = <&apb2_gates 2>;
resets = <&apb2_rst 2>; resets = <&apb2_rst 2>;
status = "disabled"; status = "disabled";
...@@ -732,7 +761,7 @@ i2c2: i2c@01c2b400 { ...@@ -732,7 +761,7 @@ i2c2: i2c@01c2b400 {
i2c3: i2c@01c2b800 { i2c3: i2c@01c2b800 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2b800 0x400>; reg = <0x01c2b800 0x400>;
interrupts = <0 9 4>; interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 3>; clocks = <&apb2_gates 3>;
resets = <&apb2_rst 3>; resets = <&apb2_rst 3>;
status = "disabled"; status = "disabled";
...@@ -743,7 +772,7 @@ i2c3: i2c@01c2b800 { ...@@ -743,7 +772,7 @@ i2c3: i2c@01c2b800 {
gmac: ethernet@01c30000 { gmac: ethernet@01c30000 {
compatible = "allwinner,sun7i-a20-gmac"; compatible = "allwinner,sun7i-a20-gmac";
reg = <0x01c30000 0x1054>; reg = <0x01c30000 0x1054>;
interrupts = <0 82 4>; interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "macirq"; interrupt-names = "macirq";
clocks = <&ahb1_gates 17>, <&gmac_tx_clk>; clocks = <&ahb1_gates 17>, <&gmac_tx_clk>;
clock-names = "stmmaceth", "allwinner_gmac_tx"; clock-names = "stmmaceth", "allwinner_gmac_tx";
...@@ -760,10 +789,10 @@ gmac: ethernet@01c30000 { ...@@ -760,10 +789,10 @@ gmac: ethernet@01c30000 {
timer@01c60000 { timer@01c60000 {
compatible = "allwinner,sun6i-a31-hstimer", "allwinner,sun7i-a20-hstimer"; compatible = "allwinner,sun6i-a31-hstimer", "allwinner,sun7i-a20-hstimer";
reg = <0x01c60000 0x1000>; reg = <0x01c60000 0x1000>;
interrupts = <0 51 4>, interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
<0 52 4>, <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>,
<0 53 4>, <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
<0 54 4>; <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 19>; clocks = <&ahb1_gates 19>;
resets = <&ahb1_rst 19>; resets = <&ahb1_rst 19>;
}; };
...@@ -771,7 +800,7 @@ timer@01c60000 { ...@@ -771,7 +800,7 @@ timer@01c60000 {
spi0: spi@01c68000 { spi0: spi@01c68000 {
compatible = "allwinner,sun6i-a31-spi"; compatible = "allwinner,sun6i-a31-spi";
reg = <0x01c68000 0x1000>; reg = <0x01c68000 0x1000>;
interrupts = <0 65 4>; interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 20>, <&spi0_clk>; clocks = <&ahb1_gates 20>, <&spi0_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 23>, <&dma 23>; dmas = <&dma 23>, <&dma 23>;
...@@ -783,7 +812,7 @@ spi0: spi@01c68000 { ...@@ -783,7 +812,7 @@ spi0: spi@01c68000 {
spi1: spi@01c69000 { spi1: spi@01c69000 {
compatible = "allwinner,sun6i-a31-spi"; compatible = "allwinner,sun6i-a31-spi";
reg = <0x01c69000 0x1000>; reg = <0x01c69000 0x1000>;
interrupts = <0 66 4>; interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 21>, <&spi1_clk>; clocks = <&ahb1_gates 21>, <&spi1_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 24>, <&dma 24>; dmas = <&dma 24>, <&dma 24>;
...@@ -795,7 +824,7 @@ spi1: spi@01c69000 { ...@@ -795,7 +824,7 @@ spi1: spi@01c69000 {
spi2: spi@01c6a000 { spi2: spi@01c6a000 {
compatible = "allwinner,sun6i-a31-spi"; compatible = "allwinner,sun6i-a31-spi";
reg = <0x01c6a000 0x1000>; reg = <0x01c6a000 0x1000>;
interrupts = <0 67 4>; interrupts = <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 22>, <&spi2_clk>; clocks = <&ahb1_gates 22>, <&spi2_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 25>, <&dma 25>; dmas = <&dma 25>, <&dma 25>;
...@@ -807,7 +836,7 @@ spi2: spi@01c6a000 { ...@@ -807,7 +836,7 @@ spi2: spi@01c6a000 {
spi3: spi@01c6b000 { spi3: spi@01c6b000 {
compatible = "allwinner,sun6i-a31-spi"; compatible = "allwinner,sun6i-a31-spi";
reg = <0x01c6b000 0x1000>; reg = <0x01c6b000 0x1000>;
interrupts = <0 68 4>; interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 23>, <&spi3_clk>; clocks = <&ahb1_gates 23>, <&spi3_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 26>, <&dma 26>; dmas = <&dma 26>, <&dma 26>;
...@@ -824,13 +853,14 @@ gic: interrupt-controller@01c81000 { ...@@ -824,13 +853,14 @@ gic: interrupt-controller@01c81000 {
<0x01c86000 0x2000>; <0x01c86000 0x2000>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupts = <1 9 0xf04>; interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
}; };
rtc: rtc@01f00000 { rtc: rtc@01f00000 {
compatible = "allwinner,sun6i-a31-rtc"; compatible = "allwinner,sun6i-a31-rtc";
reg = <0x01f00000 0x54>; reg = <0x01f00000 0x54>;
interrupts = <0 40 4>, <0 41 4>; interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
}; };
nmi_intc: interrupt-controller@01f00c0c { nmi_intc: interrupt-controller@01f00c0c {
...@@ -838,7 +868,7 @@ nmi_intc: interrupt-controller@01f00c0c { ...@@ -838,7 +868,7 @@ nmi_intc: interrupt-controller@01f00c0c {
interrupt-controller; interrupt-controller;
#interrupt-cells = <2>; #interrupt-cells = <2>;
reg = <0x01f00c0c 0x38>; reg = <0x01f00c0c 0x38>;
interrupts = <0 32 4>; interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
}; };
prcm@01f01400 { prcm@01f01400 {
...@@ -878,6 +908,13 @@ apb0_gates: apb0_gates_clk { ...@@ -878,6 +908,13 @@ apb0_gates: apb0_gates_clk {
"apb0_i2c"; "apb0_i2c";
}; };
ir_clk: ir_clk {
#clock-cells = <0>;
compatible = "allwinner,sun4i-a10-mod0-clk";
clocks = <&osc32k>, <&osc24M>;
clock-output-names = "ir";
};
apb0_rst: apb0_rst { apb0_rst: apb0_rst {
compatible = "allwinner,sun6i-a31-clock-reset"; compatible = "allwinner,sun6i-a31-clock-reset";
#reset-cells = <1>; #reset-cells = <1>;
...@@ -889,11 +926,21 @@ cpucfg@01f01c00 { ...@@ -889,11 +926,21 @@ cpucfg@01f01c00 {
reg = <0x01f01c00 0x300>; reg = <0x01f01c00 0x300>;
}; };
ir: ir@01f02000 {
compatible = "allwinner,sun5i-a13-ir";
clocks = <&apb0_gates 1>, <&ir_clk>;
clock-names = "apb", "ir";
resets = <&apb0_rst 1>;
interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
reg = <0x01f02000 0x40>;
status = "disabled";
};
r_pio: pinctrl@01f02c00 { r_pio: pinctrl@01f02c00 {
compatible = "allwinner,sun6i-a31-r-pinctrl"; compatible = "allwinner,sun6i-a31-r-pinctrl";
reg = <0x01f02c00 0x400>; reg = <0x01f02c00 0x400>;
interrupts = <0 45 4>, interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>,
<0 46 4>; <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb0_gates 0>; clocks = <&apb0_gates 0>;
resets = <&apb0_rst 0>; resets = <&apb0_rst 0>;
gpio-controller; gpio-controller;
...@@ -901,6 +948,13 @@ r_pio: pinctrl@01f02c00 { ...@@ -901,6 +948,13 @@ r_pio: pinctrl@01f02c00 {
#interrupt-cells = <2>; #interrupt-cells = <2>;
#size-cells = <0>; #size-cells = <0>;
#gpio-cells = <3>; #gpio-cells = <3>;
ir_pins_a: ir@0 {
allwinner,pins = "PL4";
allwinner,function = "s_ir";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
}; };
}; };
}; };
/*
* Copyright 2014 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun6i-a31s.dtsi"
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ {
model = "CSQ CS908 top set box";
compatible = "csq,cs908", "allwinner,sun6i-a31s";
};
&usbphy {
status = "okay";
};
&ehci0 {
status = "okay";
};
&ehci1 {
status = "okay";
};
&ohci1 {
status = "okay";
};
&pio {
usb1_vbus_pin_csq908: usb1_vbus_pin@0 {
allwinner,pins = "PC27";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&gmac {
pinctrl-names = "default";
pinctrl-0 = <&gmac_pins_mii_a>;
phy = <&phy1>;
phy-mode = "mii";
status = "okay";
phy1: ethernet-phy@1 {
reg = <1>;
};
};
&ir {
pinctrl-names = "default";
pinctrl-0 = <&ir_pins_a>;
status = "okay";
};
/*
* Copyright 2014 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/*
* The A31s is the same die as the A31 in a different package, this is
* reflected by it having different pinctrl compatible everything else is
* identical.
*/
#include "sun6i-a31.dtsi"
&pio {
compatible = "allwinner,sun6i-a31s-pinctrl";
};
...@@ -48,8 +48,12 @@ ...@@ -48,8 +48,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "LeMaker Banana Pi"; model = "LeMaker Banana Pi";
...@@ -67,7 +71,7 @@ mmc0: mmc@01c0f000 { ...@@ -67,7 +71,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_bananapi>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_bananapi>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 10 0>; /* PH10 */ cd-gpios = <&pio 7 10 GPIO_ACTIVE_HIGH>; /* PH10 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -102,22 +106,22 @@ pinctrl@01c20800 { ...@@ -102,22 +106,22 @@ pinctrl@01c20800 {
mmc0_cd_pin_bananapi: mmc0_cd_pin@0 { mmc0_cd_pin_bananapi: mmc0_cd_pin@0 {
allwinner,pins = "PH10"; allwinner,pins = "PH10";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
gmac_power_pin_bananapi: gmac_power_pin@0 { gmac_power_pin_bananapi: gmac_power_pin@0 {
allwinner,pins = "PH23"; allwinner,pins = "PH23";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_bananapi: led_pins@0 { led_pins_bananapi: led_pins@0 {
allwinner,pins = "PH24"; allwinner,pins = "PH24";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -154,7 +158,7 @@ axp209: pmic@34 { ...@@ -154,7 +158,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -188,7 +192,7 @@ leds { ...@@ -188,7 +192,7 @@ leds {
green { green {
label = "bananapi:green:usr"; label = "bananapi:green:usr";
gpios = <&pio 7 24 0>; gpios = <&pio 7 24 GPIO_ACTIVE_HIGH>;
}; };
}; };
...@@ -209,6 +213,6 @@ reg_gmac_3v3: gmac-3v3 { ...@@ -209,6 +213,6 @@ reg_gmac_3v3: gmac-3v3 {
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
startup-delay-us = <100000>; startup-delay-us = <100000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 23 0>; gpio = <&pio 7 23 GPIO_ACTIVE_HIGH>;
}; };
}; };
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/dts-v1/;
#include "sun7i-a20.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/arm-gic.h>
/ {
model = "LeMaker Banana Pro";
compatible = "lemaker,bananapro", "allwinner,sun7i-a20";
leds {
compatible = "gpio-leds";
pinctrl-names = "default";
pinctrl-0 = <&led_pins_bananapro>;
blue {
label = "bananapro:blue:usr";
gpios = <&pio 6 2 GPIO_ACTIVE_HIGH>;
};
green {
label = "bananapro:green:usr";
gpios = <&pio 7 24 GPIO_ACTIVE_HIGH>;
};
};
reg_gmac_3v3: gmac-3v3 {
compatible = "regulator-fixed";
pinctrl-names = "default";
pinctrl-0 = <&gmac_power_pin_bananapro>;
regulator-name = "gmac-3v3";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
startup-delay-us = <100000>;
enable-active-high;
gpio = <&pio 7 23 GPIO_ACTIVE_HIGH>;
};
reg_vmmc3: vmmc3 {
compatible = "regulator-fixed";
pinctrl-names = "default";
pinctrl-0 = <&vmmc3_pin_bananapro>;
regulator-name = "vmmc3";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
enable-active-high;
gpio = <&pio 7 22 GPIO_ACTIVE_HIGH>;
};
};
&ahci {
status = "okay";
};
&ehci0 {
status = "okay";
};
&ehci1 {
status = "okay";
};
&gmac {
pinctrl-names = "default";
pinctrl-0 = <&gmac_pins_rgmii_a>;
phy = <&phy1>;
phy-mode = "rgmii";
phy-supply = <&reg_gmac_3v3>;
status = "okay";
phy1: ethernet-phy@1 {
reg = <1>;
};
};
&i2c0 {
pinctrl-names = "default";
pinctrl-0 = <&i2c0_pins_a>;
status = "okay";
axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>;
interrupt-parent = <&nmi_intc>;
interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller;
#interrupt-cells = <1>;
};
};
&i2c2 {
pinctrl-names = "default";
pinctrl-0 = <&i2c2_pins_a>;
status = "okay";
};
&ir0 {
pinctrl-names = "default";
pinctrl-0 = <&ir0_pins_a>;
status = "okay";
};
&mmc0 {
pinctrl-names = "default";
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_bananapro>;
vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>;
cd-gpios = <&pio 7 10 GPIO_ACTIVE_HIGH>; /* PH10 */
cd-inverted;
status = "okay";
};
&mmc3 {
pinctrl-names = "default";
pinctrl-0 = <&mmc3_pins_a>;
vmmc-supply = <&reg_vmmc3>;
bus-width = <4>;
non-removable;
status = "okay";
};
&ohci0 {
status = "okay";
};
&ohci1 {
status = "okay";
};
&pio {
gmac_power_pin_bananapro: gmac_power_pin@0 {
allwinner,pins = "PH23";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
led_pins_bananapro: led_pins@0 {
allwinner,pins = "PH24", "PG2";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
mmc0_cd_pin_bananapro: mmc0_cd_pin@0 {
allwinner,pins = "PH10";
allwinner,function = "gpio_in";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
};
usb1_vbus_pin_bananapro: usb1_vbus_pin@0 {
allwinner,pins = "PH0";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
usb2_vbus_pin_bananapro: usb2_vbus_pin@0 {
allwinner,pins = "PH1";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
vmmc3_pin_bananapro: vmmc3_pin@0 {
allwinner,pins = "PH22";
allwinner,function = "gpio_out";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
&reg_usb1_vbus {
pinctrl-0 = <&usb1_vbus_pin_bananapro>;
gpio = <&pio 7 0 GPIO_ACTIVE_HIGH>; /* PH0 */
status = "okay";
};
&reg_usb2_vbus {
pinctrl-0 = <&usb2_vbus_pin_bananapro>;
gpio = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
status = "okay";
};
&spi0 {
pinctrl-names = "default";
pinctrl-0 = <&spi0_pins_a>;
status = "okay";
};
&uart0 {
pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>;
status = "okay";
};
&uart2 {
pinctrl-names = "default";
pinctrl-0 = <&uart2_pins_a>;
status = "okay";
};
&uart7 {
pinctrl-names = "default";
pinctrl-0 = <&uart7_pins_a>;
status = "okay";
};
&usbphy {
usb1_vbus-supply = <&reg_usb1_vbus>;
usb2_vbus-supply = <&reg_usb2_vbus>;
status = "okay";
};
...@@ -3,17 +3,57 @@ ...@@ -3,17 +3,57 @@
* *
* Maxime Ripard <maxime.ripard@free-electrons.com> * Maxime Ripard <maxime.ripard@free-electrons.com>
* *
* The code contained herein is licensed under the GNU General Public * This file is dual-licensed: you can use it either under the terms
* License. You may obtain a copy of the GNU General Public License * of the GPL or the X11 license, at your option. Note that this dual
* Version 2 or later at the following locations: * licensing only applies to this file, and not this project as a
* whole.
* *
* http://www.opensource.org/licenses/gpl-license.html * a) This file is free software; you can redistribute it and/or
* http://www.gnu.org/copyleft/gpl.html * modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Cubietech Cubieboard2"; model = "Cubietech Cubieboard2";
...@@ -25,7 +65,7 @@ mmc0: mmc@01c0f000 { ...@@ -25,7 +65,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -61,8 +101,8 @@ pinctrl@01c20800 { ...@@ -61,8 +101,8 @@ pinctrl@01c20800 {
led_pins_cubieboard2: led_pins@0 { led_pins_cubieboard2: led_pins@0 {
allwinner,pins = "PH20", "PH21"; allwinner,pins = "PH20", "PH21";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -84,13 +124,9 @@ i2c0: i2c@01c2ac00 { ...@@ -84,13 +124,9 @@ i2c0: i2c@01c2ac00 {
status = "okay"; status = "okay";
axp209: pmic@34 { axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller;
#interrupt-cells = <1>;
}; };
}; };
...@@ -120,12 +156,12 @@ leds { ...@@ -120,12 +156,12 @@ leds {
blue { blue {
label = "cubieboard2:blue:usr"; label = "cubieboard2:blue:usr";
gpios = <&pio 7 21 0>; gpios = <&pio 7 21 GPIO_ACTIVE_HIGH>;
}; };
green { green {
label = "cubieboard2:green:usr"; label = "cubieboard2:green:usr";
gpios = <&pio 7 20 0>; gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
}; };
}; };
...@@ -141,3 +177,34 @@ reg_usb2_vbus: usb2-vbus { ...@@ -141,3 +177,34 @@ reg_usb2_vbus: usb2-vbus {
status = "okay"; status = "okay";
}; };
}; };
#include "axp209.dtsi"
&cpu0 {
cpu-supply = <&reg_dcdc2>;
};
&reg_dcdc2 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1450000>;
regulator-name = "vdd-cpu";
};
&reg_dcdc3 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1400000>;
regulator-name = "vdd-int-dll";
};
&reg_ldo1 {
regulator-name = "vdd-rtc";
};
&reg_ldo2 {
regulator-always-on;
regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>;
regulator-name = "avcc";
};
...@@ -3,17 +3,57 @@ ...@@ -3,17 +3,57 @@
* *
* Oliver Schinagl <oliver@schinagl.nl> * Oliver Schinagl <oliver@schinagl.nl>
* *
* The code contained herein is licensed under the GNU General Public * This file is dual-licensed: you can use it either under the terms
* License. You may obtain a copy of the GNU General Public License * of the GPL or the X11 license, at your option. Note that this dual
* Version 2 or later at the following locations: * licensing only applies to this file, and not this project as a
* whole.
* *
* http://www.opensource.org/licenses/gpl-license.html * a) This file is free software; you can redistribute it and/or
* http://www.gnu.org/copyleft/gpl.html * modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Cubietech Cubietruck"; model = "Cubietech Cubietruck";
...@@ -25,7 +65,7 @@ mmc0: mmc@01c0f000 { ...@@ -25,7 +65,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -70,35 +110,35 @@ ohci1: usb@01c1c400 { ...@@ -70,35 +110,35 @@ ohci1: usb@01c1c400 {
pinctrl@01c20800 { pinctrl@01c20800 {
mmc3_pins_a: mmc3@0 { mmc3_pins_a: mmc3@0 {
/* AP6210 requires pull-up */ /* AP6210 requires pull-up */
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
vmmc3_pin_cubietruck: vmmc3_pin@0 { vmmc3_pin_cubietruck: vmmc3_pin@0 {
allwinner,pins = "PH9"; allwinner,pins = "PH9";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
ahci_pwr_pin_cubietruck: ahci_pwr_pin@1 { ahci_pwr_pin_cubietruck: ahci_pwr_pin@1 {
allwinner,pins = "PH12"; allwinner,pins = "PH12";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_cubietruck: led_pins@0 { led_pins_cubietruck: led_pins@0 {
allwinner,pins = "PH7", "PH11", "PH20", "PH21"; allwinner,pins = "PH7", "PH11", "PH20", "PH21";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb0_vbus_pin_a: usb0_vbus_pin@0 { usb0_vbus_pin_a: usb0_vbus_pin@0 {
allwinner,pins = "PH17"; allwinner,pins = "PH17";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -126,13 +166,9 @@ i2c0: i2c@01c2ac00 { ...@@ -126,13 +166,9 @@ i2c0: i2c@01c2ac00 {
status = "okay"; status = "okay";
axp209: pmic@34 { axp209: pmic@34 {
compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller;
#interrupt-cells = <1>;
}; };
}; };
...@@ -168,34 +204,34 @@ leds { ...@@ -168,34 +204,34 @@ leds {
blue { blue {
label = "cubietruck:blue:usr"; label = "cubietruck:blue:usr";
gpios = <&pio 7 21 0>; gpios = <&pio 7 21 GPIO_ACTIVE_HIGH>;
}; };
orange { orange {
label = "cubietruck:orange:usr"; label = "cubietruck:orange:usr";
gpios = <&pio 7 20 0>; gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
}; };
white { white {
label = "cubietruck:white:usr"; label = "cubietruck:white:usr";
gpios = <&pio 7 11 0>; gpios = <&pio 7 11 GPIO_ACTIVE_HIGH>;
}; };
green { green {
label = "cubietruck:green:usr"; label = "cubietruck:green:usr";
gpios = <&pio 7 7 0>; gpios = <&pio 7 7 GPIO_ACTIVE_HIGH>;
}; };
}; };
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
pinctrl-0 = <&ahci_pwr_pin_cubietruck>; pinctrl-0 = <&ahci_pwr_pin_cubietruck>;
gpio = <&pio 7 12 0>; gpio = <&pio 7 12 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
reg_usb0_vbus: usb0-vbus { reg_usb0_vbus: usb0-vbus {
pinctrl-0 = <&usb0_vbus_pin_a>; pinctrl-0 = <&usb0_vbus_pin_a>;
gpio = <&pio 7 17 0>; gpio = <&pio 7 17 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
...@@ -215,6 +251,37 @@ reg_vmmc3: vmmc3 { ...@@ -215,6 +251,37 @@ reg_vmmc3: vmmc3 {
regulator-min-microvolt = <3300000>; regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 9 0>; gpio = <&pio 7 9 GPIO_ACTIVE_HIGH>;
}; };
}; };
#include "axp209.dtsi"
&cpu0 {
cpu-supply = <&reg_dcdc2>;
};
&reg_dcdc2 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1450000>;
regulator-name = "vdd-cpu";
};
&reg_dcdc3 {
regulator-always-on;
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1400000>;
regulator-name = "vdd-int-dll";
};
&reg_ldo1 {
regulator-name = "vdd-rtc";
};
&reg_ldo2 {
regulator-always-on;
regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>;
regulator-name = "avcc";
};
...@@ -12,8 +12,12 @@ ...@@ -12,8 +12,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Merrii A20 Hummingbird"; model = "Merrii A20 Hummingbird";
...@@ -25,7 +29,7 @@ mmc0: mmc@01c0f000 { ...@@ -25,7 +29,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v0>; vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -70,29 +74,29 @@ pio: pinctrl@01c20800 { ...@@ -70,29 +74,29 @@ pio: pinctrl@01c20800 {
ahci_pwr_pin_a20_hummingbird: ahci_pwr_pin@0 { ahci_pwr_pin_a20_hummingbird: ahci_pwr_pin@0 {
allwinner,pins = "PH15"; allwinner,pins = "PH15";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_a20_hummingbird: usb1_vbus_pin@0 { usb1_vbus_pin_a20_hummingbird: usb1_vbus_pin@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc3_vdd_pin_a20_hummingbird: mmc3_vdd_pin@0 { mmc3_vdd_pin_a20_hummingbird: mmc3_vdd_pin@0 {
allwinner,pins = "PH9"; allwinner,pins = "PH9";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_vdd_pin_a20_hummingbird: gmac_vdd_pin@0 { gmac_vdd_pin_a20_hummingbird: gmac_vdd_pin@0 {
allwinner,pins = "PH16"; allwinner,pins = "PH16";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -147,7 +151,7 @@ axp209: pmic@34 { ...@@ -147,7 +151,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
}; };
...@@ -184,7 +188,7 @@ gmac: ethernet@01c50000 { ...@@ -184,7 +188,7 @@ gmac: ethernet@01c50000 {
phy-mode = "rgmii"; phy-mode = "rgmii";
phy-supply = <&reg_gmac_vdd>; phy-supply = <&reg_gmac_vdd>;
/* phy reset config */ /* phy reset config */
snps,reset-gpio = <&pio 0 17 0>; /* PA17 */ snps,reset-gpio = <&pio 0 17 GPIO_ACTIVE_HIGH>; /* PA17 */
snps,reset-active-low; snps,reset-active-low;
/* wait 1s after reset, otherwise fail to read phy id */ /* wait 1s after reset, otherwise fail to read phy id */
snps,reset-delays-us = <0 10000 1000000>; snps,reset-delays-us = <0 10000 1000000>;
...@@ -198,13 +202,13 @@ phy1: ethernet-phy@1 { ...@@ -198,13 +202,13 @@ phy1: ethernet-phy@1 {
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
pinctrl-0 = <&ahci_pwr_pin_a20_hummingbird>; pinctrl-0 = <&ahci_pwr_pin_a20_hummingbird>;
gpio = <&pio 7 15 0>; /* PH15 */ gpio = <&pio 7 15 GPIO_ACTIVE_HIGH>; /* PH15 */
status = "okay"; status = "okay";
}; };
reg_usb1_vbus: usb1-vbus { reg_usb1_vbus: usb1-vbus {
pinctrl-0 = <&usb1_vbus_pin_a20_hummingbird>; pinctrl-0 = <&usb1_vbus_pin_a20_hummingbird>;
gpio = <&pio 7 2 0>; /* PH2 */ gpio = <&pio 7 2 GPIO_ACTIVE_HIGH>; /* PH2 */
status = "okay"; status = "okay";
}; };
...@@ -220,7 +224,7 @@ reg_mmc3_vdd: mmc3_vdd { ...@@ -220,7 +224,7 @@ reg_mmc3_vdd: mmc3_vdd {
regulator-min-microvolt = <3000000>; regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>; regulator-max-microvolt = <3000000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 9 0>; /* PH9 */ gpio = <&pio 7 9 GPIO_ACTIVE_HIGH>; /* PH9 */
}; };
reg_gmac_vdd: gmac_vdd { reg_gmac_vdd: gmac_vdd {
...@@ -231,6 +235,6 @@ reg_gmac_vdd: gmac_vdd { ...@@ -231,6 +235,6 @@ reg_gmac_vdd: gmac_vdd {
regulator-min-microvolt = <3000000>; regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3000000>; regulator-max-microvolt = <3000000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 16 0>; /* PH16 */ gpio = <&pio 7 16 GPIO_ACTIVE_HIGH>; /* PH16 */
}; };
}; };
...@@ -46,8 +46,12 @@ ...@@ -46,8 +46,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "I12 / Q5 / QT840A A20 tvbox"; model = "I12 / Q5 / QT840A A20 tvbox";
...@@ -59,7 +63,7 @@ mmc0: mmc@01c0f000 { ...@@ -59,7 +63,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -98,35 +102,35 @@ ohci1: usb@01c1c400 { ...@@ -98,35 +102,35 @@ ohci1: usb@01c1c400 {
pinctrl@01c20800 { pinctrl@01c20800 {
mmc3_pins_a: mmc3@0 { mmc3_pins_a: mmc3@0 {
/* AP6210 / AP6330 requires pull-up */ /* AP6210 / AP6330 requires pull-up */
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
vmmc3_pin_i12_tvbox: vmmc3_pin@0 { vmmc3_pin_i12_tvbox: vmmc3_pin@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
vmmc3_io_pin_i12_tvbox: vmmc3_io_pin@0 { vmmc3_io_pin_i12_tvbox: vmmc3_io_pin@0 {
allwinner,pins = "PH12"; allwinner,pins = "PH12";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_power_pin_i12_tvbox: gmac_power_pin@0 { gmac_power_pin_i12_tvbox: gmac_power_pin@0 {
allwinner,pins = "PH21"; allwinner,pins = "PH21";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_i12_tvbox: led_pins@0 { led_pins_i12_tvbox: led_pins@0 {
allwinner,pins = "PH9", "PH20"; allwinner,pins = "PH9", "PH20";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -151,7 +155,7 @@ axp209: pmic@34 { ...@@ -151,7 +155,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -179,12 +183,12 @@ leds { ...@@ -179,12 +183,12 @@ leds {
red { red {
label = "i12_tvbox:red:usr"; label = "i12_tvbox:red:usr";
gpios = <&pio 7 9 1>; gpios = <&pio 7 9 GPIO_ACTIVE_LOW>;
}; };
blue { blue {
label = "i12_tvbox:blue:usr"; label = "i12_tvbox:blue:usr";
gpios = <&pio 7 20 0>; gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
}; };
}; };
...@@ -204,7 +208,7 @@ reg_vmmc3: vmmc3 { ...@@ -204,7 +208,7 @@ reg_vmmc3: vmmc3 {
regulator-min-microvolt = <3300000>; regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 2 0>; gpio = <&pio 7 2 GPIO_ACTIVE_HIGH>;
}; };
reg_vmmc3_io: vmmc3-io { reg_vmmc3_io: vmmc3-io {
...@@ -217,7 +221,7 @@ reg_vmmc3_io: vmmc3-io { ...@@ -217,7 +221,7 @@ reg_vmmc3_io: vmmc3-io {
/* This controls VCC-PI, must be always on! */ /* This controls VCC-PI, must be always on! */
regulator-always-on; regulator-always-on;
enable-active-high; enable-active-high;
gpio = <&pio 7 12 0>; gpio = <&pio 7 12 GPIO_ACTIVE_HIGH>;
}; };
reg_gmac_3v3: gmac-3v3 { reg_gmac_3v3: gmac-3v3 {
...@@ -229,6 +233,6 @@ reg_gmac_3v3: gmac-3v3 { ...@@ -229,6 +233,6 @@ reg_gmac_3v3: gmac-3v3 {
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
startup-delay-us = <50000>; startup-delay-us = <50000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 21 0>; gpio = <&pio 7 21 GPIO_ACTIVE_HIGH>;
}; };
}; };
...@@ -48,8 +48,12 @@ ...@@ -48,8 +48,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Mele M3"; model = "Mele M3";
...@@ -61,7 +65,7 @@ mmc0: mmc@01c0f000 { ...@@ -61,7 +65,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -101,8 +105,8 @@ pinctrl@01c20800 { ...@@ -101,8 +105,8 @@ pinctrl@01c20800 {
led_pins_m3: led_pins@0 { led_pins_m3: led_pins@0 {
allwinner,pins = "PH20"; allwinner,pins = "PH20";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -127,7 +131,7 @@ axp209: pmic@34 { ...@@ -127,7 +131,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -154,7 +158,7 @@ leds { ...@@ -154,7 +158,7 @@ leds {
blue { blue {
label = "m3:blue:usr"; label = "m3:blue:usr";
gpios = <&pio 7 20 0>; gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
}; };
}; };
......
...@@ -49,8 +49,12 @@ ...@@ -49,8 +49,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A20-OLinuXino-LIME"; model = "Olimex A20-OLinuXino-LIME";
...@@ -62,7 +66,7 @@ mmc0: mmc@01c0f000 { ...@@ -62,7 +66,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -98,15 +102,15 @@ pinctrl@01c20800 { ...@@ -98,15 +102,15 @@ pinctrl@01c20800 {
ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 { ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 {
allwinner,pins = "PC3"; allwinner,pins = "PC3";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_olinuxinolime: led_pins@0 { led_pins_olinuxinolime: led_pins@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -125,7 +129,7 @@ axp209: pmic@34 { ...@@ -125,7 +129,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -152,14 +156,14 @@ leds { ...@@ -152,14 +156,14 @@ leds {
green { green {
label = "a20-olinuxino-lime:green:usr"; label = "a20-olinuxino-lime:green:usr";
gpios = <&pio 7 2 0>; gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>; pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>;
gpio = <&pio 2 3 0>; gpio = <&pio 2 3 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
......
...@@ -46,8 +46,12 @@ ...@@ -46,8 +46,12 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A20-OLinuXino-LIME2"; model = "Olimex A20-OLinuXino-LIME2";
...@@ -59,7 +63,7 @@ mmc0: mmc@01c0f000 { ...@@ -59,7 +63,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -95,15 +99,15 @@ pinctrl@01c20800 { ...@@ -95,15 +99,15 @@ pinctrl@01c20800 {
ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 { ahci_pwr_pin_olinuxinolime: ahci_pwr_pin@1 {
allwinner,pins = "PC3"; allwinner,pins = "PC3";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
led_pins_olinuxinolime: led_pins@0 { led_pins_olinuxinolime: led_pins@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -122,7 +126,7 @@ axp209: pmic@34 { ...@@ -122,7 +126,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -199,14 +203,14 @@ leds { ...@@ -199,14 +203,14 @@ leds {
green { green {
label = "a20-olinuxino-lime2:green:usr"; label = "a20-olinuxino-lime2:green:usr";
gpios = <&pio 7 2 0>; gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>; pinctrl-0 = <&ahci_pwr_pin_olinuxinolime>;
gpio = <&pio 2 3 0>; gpio = <&pio 2 3 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
......
...@@ -12,8 +12,13 @@ ...@@ -12,8 +12,13 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Olimex A20-Olinuxino Micro"; model = "Olimex A20-Olinuxino Micro";
...@@ -36,7 +41,7 @@ mmc0: mmc@01c0f000 { ...@@ -36,7 +41,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -46,7 +51,7 @@ mmc3: mmc@01c12000 { ...@@ -46,7 +51,7 @@ mmc3: mmc@01c12000 {
pinctrl-0 = <&mmc3_pins_a>, <&mmc3_cd_pin_olinuxinom>; pinctrl-0 = <&mmc3_pins_a>, <&mmc3_cd_pin_olinuxinom>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 11 0>; /* PH11 */ cd-gpios = <&pio 7 11 GPIO_ACTIVE_HIGH>; /* PH11 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -88,15 +93,69 @@ pinctrl@01c20800 { ...@@ -88,15 +93,69 @@ pinctrl@01c20800 {
mmc3_cd_pin_olinuxinom: mmc3_cd_pin@0 { mmc3_cd_pin_olinuxinom: mmc3_cd_pin@0 {
allwinner,pins = "PH11"; allwinner,pins = "PH11";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
led_pins_olinuxino: led_pins@0 { led_pins_olinuxino: led_pins@0 {
allwinner,pins = "PH2"; allwinner,pins = "PH2";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <1>; allwinner,drive = <SUN4I_PINCTRL_20_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
lradc: lradc@01c22800 {
vref-supply = <&reg_vcc3v0>;
status = "okay";
button@191 {
label = "Volume Up";
linux,code = <KEY_VOLUMEUP>;
channel = <0>;
voltage = <191274>;
};
button@392 {
label = "Volume Down";
linux,code = <KEY_VOLUMEDOWN>;
channel = <0>;
voltage = <392644>;
};
button@601 {
label = "Menu";
linux,code = <KEY_MENU>;
channel = <0>;
voltage = <601151>;
};
button@795 {
label = "Search";
linux,code = <KEY_SEARCH>;
channel = <0>;
voltage = <795090>;
};
button@987 {
label = "Home";
linux,code = <KEY_HOMEPAGE>;
channel = <0>;
voltage = <987387>;
};
button@1184 {
label = "Esc";
linux,code = <KEY_ESC>;
channel = <0>;
voltage = <1184678>;
};
button@1398 {
label = "Enter";
linux,code = <KEY_ENTER>;
channel = <0>;
voltage = <1398804>;
}; };
}; };
...@@ -127,7 +186,7 @@ axp209: pmic@34 { ...@@ -127,7 +186,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -166,7 +225,7 @@ leds { ...@@ -166,7 +225,7 @@ leds {
green { green {
label = "a20-olinuxino-micro:green:usr"; label = "a20-olinuxino-micro:green:usr";
gpios = <&pio 7 2 0>; gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>;
default-state = "on"; default-state = "on";
}; };
}; };
......
...@@ -47,10 +47,13 @@ ...@@ -47,10 +47,13 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun7i-a20.dtsi" #include "sun7i-a20.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h> #include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h> #include <dt-bindings/input/input.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "LinkSprite pcDuino3"; model = "LinkSprite pcDuino3";
...@@ -62,7 +65,7 @@ mmc0: mmc@01c0f000 { ...@@ -62,7 +65,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>;
vmmc-supply = <&reg_vcc3v3>; vmmc-supply = <&reg_vcc3v3>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 7 1 0>; /* PH1 */ cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -102,15 +105,15 @@ ahci_pwr_pin_a: ahci_pwr_pin@0 { ...@@ -102,15 +105,15 @@ ahci_pwr_pin_a: ahci_pwr_pin@0 {
led_pins_pcduino3: led_pins@0 { led_pins_pcduino3: led_pins@0 {
allwinner,pins = "PH15", "PH16"; allwinner,pins = "PH15", "PH16";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
key_pins_pcduino3: key_pins@0 { key_pins_pcduino3: key_pins@0 {
allwinner,pins = "PH17", "PH18", "PH19"; allwinner,pins = "PH17", "PH18", "PH19";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -135,7 +138,7 @@ axp209: pmic@34 { ...@@ -135,7 +138,7 @@ axp209: pmic@34 {
compatible = "x-powers,axp209"; compatible = "x-powers,axp209";
reg = <0x34>; reg = <0x34>;
interrupt-parent = <&nmi_intc>; interrupt-parent = <&nmi_intc>;
interrupts = <0 8>; interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <1>; #interrupt-cells = <1>;
...@@ -203,7 +206,7 @@ reg_usb2_vbus: usb2-vbus { ...@@ -203,7 +206,7 @@ reg_usb2_vbus: usb2-vbus {
}; };
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
gpio = <&pio 7 2 0>; gpio = <&pio 7 2 GPIO_ACTIVE_HIGH>;
status = "okay"; status = "okay";
}; };
}; };
...@@ -47,7 +47,13 @@ ...@@ -47,7 +47,13 @@
* OTHER DEALINGS IN THE SOFTWARE. * OTHER DEALINGS IN THE SOFTWARE.
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/thermal/thermal.h>
#include <dt-bindings/dma/sun4i-a10.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
...@@ -76,16 +82,49 @@ framebuffer@0 { ...@@ -76,16 +82,49 @@ framebuffer@0 {
<&ahb_gates 44>; <&ahb_gates 44>;
status = "disabled"; status = "disabled";
}; };
framebuffer@1 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0";
clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 44>;
status = "disabled";
};
framebuffer@2 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0-tve0";
clocks = <&pll5 1>, <&ahb_gates 34>, <&ahb_gates 36>,
<&ahb_gates 44>;
status = "disabled";
};
}; };
cpus { cpus {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <0>; #size-cells = <0>;
cpu@0 { cpu0: cpu@0 {
compatible = "arm,cortex-a7"; compatible = "arm,cortex-a7";
device_type = "cpu"; device_type = "cpu";
reg = <0>; reg = <0>;
clocks = <&cpu>;
clock-latency = <244144>; /* 8 32k periods */
operating-points = <
/* kHz uV */
1008000 1450000
960000 1400000
912000 1400000
864000 1300000
720000 1200000
528000 1100000
312000 1000000
144000 900000
>;
#cooling-cells = <2>;
cooling-min-level = <0>;
cooling-max-level = <7>;
}; };
cpu@1 { cpu@1 {
...@@ -95,22 +134,54 @@ cpu@1 { ...@@ -95,22 +134,54 @@ cpu@1 {
}; };
}; };
thermal-zones {
cpu_thermal {
/* milliseconds */
polling-delay-passive = <250>;
polling-delay = <1000>;
thermal-sensors = <&rtp>;
cooling-maps {
map0 {
trip = <&cpu_alert0>;
cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
};
};
trips {
cpu_alert0: cpu_alert0 {
/* milliCelsius */
temperature = <75000>;
hysteresis = <2000>;
type = "passive";
};
cpu_crit: cpu_crit {
/* milliCelsius */
temperature = <100000>;
hysteresis = <2000>;
type = "critical";
};
};
};
};
memory { memory {
reg = <0x40000000 0x80000000>; reg = <0x40000000 0x80000000>;
}; };
timer { timer {
compatible = "arm,armv7-timer"; compatible = "arm,armv7-timer";
interrupts = <1 13 0xf08>, interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<1 14 0xf08>, <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<1 11 0xf08>, <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
<1 10 0xf08>; <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
}; };
pmu { pmu {
compatible = "arm,cortex-a7-pmu", "arm,cortex-a15-pmu"; compatible = "arm,cortex-a7-pmu", "arm,cortex-a15-pmu";
interrupts = <0 120 4>, interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
<0 121 4>; <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>;
}; };
clocks { clocks {
...@@ -462,13 +533,13 @@ nmi_intc: interrupt-controller@01c00030 { ...@@ -462,13 +533,13 @@ nmi_intc: interrupt-controller@01c00030 {
interrupt-controller; interrupt-controller;
#interrupt-cells = <2>; #interrupt-cells = <2>;
reg = <0x01c00030 0x0c>; reg = <0x01c00030 0x0c>;
interrupts = <0 0 4>; interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
}; };
dma: dma-controller@01c02000 { dma: dma-controller@01c02000 {
compatible = "allwinner,sun4i-a10-dma"; compatible = "allwinner,sun4i-a10-dma";
reg = <0x01c02000 0x1000>; reg = <0x01c02000 0x1000>;
interrupts = <0 27 4>; interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 6>; clocks = <&ahb_gates 6>;
#dma-cells = <2>; #dma-cells = <2>;
}; };
...@@ -476,10 +547,11 @@ dma: dma-controller@01c02000 { ...@@ -476,10 +547,11 @@ dma: dma-controller@01c02000 {
spi0: spi@01c05000 { spi0: spi@01c05000 {
compatible = "allwinner,sun4i-a10-spi"; compatible = "allwinner,sun4i-a10-spi";
reg = <0x01c05000 0x1000>; reg = <0x01c05000 0x1000>;
interrupts = <0 10 4>; interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 20>, <&spi0_clk>; clocks = <&ahb_gates 20>, <&spi0_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 27>, <&dma 1 26>; dmas = <&dma SUN4I_DMA_DEDICATED 27>,
<&dma SUN4I_DMA_DEDICATED 26>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -489,10 +561,11 @@ spi0: spi@01c05000 { ...@@ -489,10 +561,11 @@ spi0: spi@01c05000 {
spi1: spi@01c06000 { spi1: spi@01c06000 {
compatible = "allwinner,sun4i-a10-spi"; compatible = "allwinner,sun4i-a10-spi";
reg = <0x01c06000 0x1000>; reg = <0x01c06000 0x1000>;
interrupts = <0 11 4>; interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 21>, <&spi1_clk>; clocks = <&ahb_gates 21>, <&spi1_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 9>, <&dma 1 8>; dmas = <&dma SUN4I_DMA_DEDICATED 9>,
<&dma SUN4I_DMA_DEDICATED 8>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -502,12 +575,12 @@ spi1: spi@01c06000 { ...@@ -502,12 +575,12 @@ spi1: spi@01c06000 {
emac: ethernet@01c0b000 { emac: ethernet@01c0b000 {
compatible = "allwinner,sun4i-a10-emac"; compatible = "allwinner,sun4i-a10-emac";
reg = <0x01c0b000 0x1000>; reg = <0x01c0b000 0x1000>;
interrupts = <0 55 4>; interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 17>; clocks = <&ahb_gates 17>;
status = "disabled"; status = "disabled";
}; };
mdio@01c0b080 { mdio: mdio@01c0b080 {
compatible = "allwinner,sun4i-a10-mdio"; compatible = "allwinner,sun4i-a10-mdio";
reg = <0x01c0b080 0x14>; reg = <0x01c0b080 0x14>;
status = "disabled"; status = "disabled";
...@@ -520,7 +593,7 @@ mmc0: mmc@01c0f000 { ...@@ -520,7 +593,7 @@ mmc0: mmc@01c0f000 {
reg = <0x01c0f000 0x1000>; reg = <0x01c0f000 0x1000>;
clocks = <&ahb_gates 8>, <&mmc0_clk>; clocks = <&ahb_gates 8>, <&mmc0_clk>;
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
interrupts = <0 32 4>; interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -529,7 +602,7 @@ mmc1: mmc@01c10000 { ...@@ -529,7 +602,7 @@ mmc1: mmc@01c10000 {
reg = <0x01c10000 0x1000>; reg = <0x01c10000 0x1000>;
clocks = <&ahb_gates 9>, <&mmc1_clk>; clocks = <&ahb_gates 9>, <&mmc1_clk>;
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
interrupts = <0 33 4>; interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -538,7 +611,7 @@ mmc2: mmc@01c11000 { ...@@ -538,7 +611,7 @@ mmc2: mmc@01c11000 {
reg = <0x01c11000 0x1000>; reg = <0x01c11000 0x1000>;
clocks = <&ahb_gates 10>, <&mmc2_clk>; clocks = <&ahb_gates 10>, <&mmc2_clk>;
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
interrupts = <0 34 4>; interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -547,7 +620,7 @@ mmc3: mmc@01c12000 { ...@@ -547,7 +620,7 @@ mmc3: mmc@01c12000 {
reg = <0x01c12000 0x1000>; reg = <0x01c12000 0x1000>;
clocks = <&ahb_gates 11>, <&mmc3_clk>; clocks = <&ahb_gates 11>, <&mmc3_clk>;
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
interrupts = <0 35 4>; interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -566,7 +639,7 @@ usbphy: phy@01c13400 { ...@@ -566,7 +639,7 @@ usbphy: phy@01c13400 {
ehci0: usb@01c14000 { ehci0: usb@01c14000 {
compatible = "allwinner,sun7i-a20-ehci", "generic-ehci"; compatible = "allwinner,sun7i-a20-ehci", "generic-ehci";
reg = <0x01c14000 0x100>; reg = <0x01c14000 0x100>;
interrupts = <0 39 4>; interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 1>; clocks = <&ahb_gates 1>;
phys = <&usbphy 1>; phys = <&usbphy 1>;
phy-names = "usb"; phy-names = "usb";
...@@ -576,7 +649,7 @@ ehci0: usb@01c14000 { ...@@ -576,7 +649,7 @@ ehci0: usb@01c14000 {
ohci0: usb@01c14400 { ohci0: usb@01c14400 {
compatible = "allwinner,sun7i-a20-ohci", "generic-ohci"; compatible = "allwinner,sun7i-a20-ohci", "generic-ohci";
reg = <0x01c14400 0x100>; reg = <0x01c14400 0x100>;
interrupts = <0 64 4>; interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&usb_clk 6>, <&ahb_gates 2>; clocks = <&usb_clk 6>, <&ahb_gates 2>;
phys = <&usbphy 1>; phys = <&usbphy 1>;
phy-names = "usb"; phy-names = "usb";
...@@ -586,10 +659,11 @@ ohci0: usb@01c14400 { ...@@ -586,10 +659,11 @@ ohci0: usb@01c14400 {
spi2: spi@01c17000 { spi2: spi@01c17000 {
compatible = "allwinner,sun4i-a10-spi"; compatible = "allwinner,sun4i-a10-spi";
reg = <0x01c17000 0x1000>; reg = <0x01c17000 0x1000>;
interrupts = <0 12 4>; interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 22>, <&spi2_clk>; clocks = <&ahb_gates 22>, <&spi2_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 29>, <&dma 1 28>; dmas = <&dma SUN4I_DMA_DEDICATED 29>,
<&dma SUN4I_DMA_DEDICATED 28>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -599,7 +673,7 @@ spi2: spi@01c17000 { ...@@ -599,7 +673,7 @@ spi2: spi@01c17000 {
ahci: sata@01c18000 { ahci: sata@01c18000 {
compatible = "allwinner,sun4i-a10-ahci"; compatible = "allwinner,sun4i-a10-ahci";
reg = <0x01c18000 0x1000>; reg = <0x01c18000 0x1000>;
interrupts = <0 56 4>; interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&pll6 0>, <&ahb_gates 25>; clocks = <&pll6 0>, <&ahb_gates 25>;
status = "disabled"; status = "disabled";
}; };
...@@ -607,7 +681,7 @@ ahci: sata@01c18000 { ...@@ -607,7 +681,7 @@ ahci: sata@01c18000 {
ehci1: usb@01c1c000 { ehci1: usb@01c1c000 {
compatible = "allwinner,sun7i-a20-ehci", "generic-ehci"; compatible = "allwinner,sun7i-a20-ehci", "generic-ehci";
reg = <0x01c1c000 0x100>; reg = <0x01c1c000 0x100>;
interrupts = <0 40 4>; interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 3>; clocks = <&ahb_gates 3>;
phys = <&usbphy 2>; phys = <&usbphy 2>;
phy-names = "usb"; phy-names = "usb";
...@@ -617,7 +691,7 @@ ehci1: usb@01c1c000 { ...@@ -617,7 +691,7 @@ ehci1: usb@01c1c000 {
ohci1: usb@01c1c400 { ohci1: usb@01c1c400 {
compatible = "allwinner,sun7i-a20-ohci", "generic-ohci"; compatible = "allwinner,sun7i-a20-ohci", "generic-ohci";
reg = <0x01c1c400 0x100>; reg = <0x01c1c400 0x100>;
interrupts = <0 65 4>; interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&usb_clk 7>, <&ahb_gates 4>; clocks = <&usb_clk 7>, <&ahb_gates 4>;
phys = <&usbphy 2>; phys = <&usbphy 2>;
phy-names = "usb"; phy-names = "usb";
...@@ -627,10 +701,11 @@ ohci1: usb@01c1c400 { ...@@ -627,10 +701,11 @@ ohci1: usb@01c1c400 {
spi3: spi@01c1f000 { spi3: spi@01c1f000 {
compatible = "allwinner,sun4i-a10-spi"; compatible = "allwinner,sun4i-a10-spi";
reg = <0x01c1f000 0x1000>; reg = <0x01c1f000 0x1000>;
interrupts = <0 50 4>; interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 23>, <&spi3_clk>; clocks = <&ahb_gates 23>, <&spi3_clk>;
clock-names = "ahb", "mod"; clock-names = "ahb", "mod";
dmas = <&dma 1 31>, <&dma 1 30>; dmas = <&dma SUN4I_DMA_DEDICATED 31>,
<&dma SUN4I_DMA_DEDICATED 30>;
dma-names = "rx", "tx"; dma-names = "rx", "tx";
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -640,7 +715,7 @@ spi3: spi@01c1f000 { ...@@ -640,7 +715,7 @@ spi3: spi@01c1f000 {
pio: pinctrl@01c20800 { pio: pinctrl@01c20800 {
compatible = "allwinner,sun7i-a20-pinctrl"; compatible = "allwinner,sun7i-a20-pinctrl";
reg = <0x01c20800 0x400>; reg = <0x01c20800 0x400>;
interrupts = <0 28 4>; interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb0_gates 5>; clocks = <&apb0_gates 5>;
gpio-controller; gpio-controller;
interrupt-controller; interrupt-controller;
...@@ -651,99 +726,99 @@ pio: pinctrl@01c20800 { ...@@ -651,99 +726,99 @@ pio: pinctrl@01c20800 {
pwm0_pins_a: pwm0@0 { pwm0_pins_a: pwm0@0 {
allwinner,pins = "PB2"; allwinner,pins = "PB2";
allwinner,function = "pwm"; allwinner,function = "pwm";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
pwm1_pins_a: pwm1@0 { pwm1_pins_a: pwm1@0 {
allwinner,pins = "PI3"; allwinner,pins = "PI3";
allwinner,function = "pwm"; allwinner,function = "pwm";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PB22", "PB23"; allwinner,pins = "PB22", "PB23";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart2_pins_a: uart2@0 { uart2_pins_a: uart2@0 {
allwinner,pins = "PI16", "PI17", "PI18", "PI19"; allwinner,pins = "PI16", "PI17", "PI18", "PI19";
allwinner,function = "uart2"; allwinner,function = "uart2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart3_pins_a: uart3@0 { uart3_pins_a: uart3@0 {
allwinner,pins = "PG6", "PG7", "PG8", "PG9"; allwinner,pins = "PG6", "PG7", "PG8", "PG9";
allwinner,function = "uart3"; allwinner,function = "uart3";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart3_pins_b: uart3@1 { uart3_pins_b: uart3@1 {
allwinner,pins = "PH0", "PH1"; allwinner,pins = "PH0", "PH1";
allwinner,function = "uart3"; allwinner,function = "uart3";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart4_pins_a: uart4@0 { uart4_pins_a: uart4@0 {
allwinner,pins = "PG10", "PG11"; allwinner,pins = "PG10", "PG11";
allwinner,function = "uart4"; allwinner,function = "uart4";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart5_pins_a: uart5@0 { uart5_pins_a: uart5@0 {
allwinner,pins = "PI10", "PI11"; allwinner,pins = "PI10", "PI11";
allwinner,function = "uart5"; allwinner,function = "uart5";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart6_pins_a: uart6@0 { uart6_pins_a: uart6@0 {
allwinner,pins = "PI12", "PI13"; allwinner,pins = "PI12", "PI13";
allwinner,function = "uart6"; allwinner,function = "uart6";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart7_pins_a: uart7@0 { uart7_pins_a: uart7@0 {
allwinner,pins = "PI20", "PI21"; allwinner,pins = "PI20", "PI21";
allwinner,function = "uart7"; allwinner,function = "uart7";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PB0", "PB1"; allwinner,pins = "PB0", "PB1";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PB18", "PB19"; allwinner,pins = "PB18", "PB19";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PB20", "PB21"; allwinner,pins = "PB20", "PB21";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c3_pins_a: i2c3@0 { i2c3_pins_a: i2c3@0 {
allwinner,pins = "PI0", "PI1"; allwinner,pins = "PI0", "PI1";
allwinner,function = "i2c3"; allwinner,function = "i2c3";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
emac_pins_a: emac0@0 { emac_pins_a: emac0@0 {
...@@ -753,22 +828,22 @@ emac_pins_a: emac0@0 { ...@@ -753,22 +828,22 @@ emac_pins_a: emac0@0 {
"PA11", "PA12", "PA13", "PA14", "PA11", "PA12", "PA13", "PA14",
"PA15", "PA16"; "PA15", "PA16";
allwinner,function = "emac"; allwinner,function = "emac";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
clk_out_a_pins_a: clk_out_a@0 { clk_out_a_pins_a: clk_out_a@0 {
allwinner,pins = "PI12"; allwinner,pins = "PI12";
allwinner,function = "clk_out_a"; allwinner,function = "clk_out_a";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
clk_out_b_pins_a: clk_out_b@0 { clk_out_b_pins_a: clk_out_b@0 {
allwinner,pins = "PI13"; allwinner,pins = "PI13";
allwinner,function = "clk_out_b"; allwinner,function = "clk_out_b";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_pins_mii_a: gmac_mii@0 { gmac_pins_mii_a: gmac_mii@0 {
...@@ -778,8 +853,8 @@ gmac_pins_mii_a: gmac_mii@0 { ...@@ -778,8 +853,8 @@ gmac_pins_mii_a: gmac_mii@0 {
"PA11", "PA12", "PA13", "PA14", "PA11", "PA12", "PA13", "PA14",
"PA15", "PA16"; "PA15", "PA16";
allwinner,function = "gmac"; allwinner,function = "gmac";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
gmac_pins_rgmii_a: gmac_rgmii@0 { gmac_pins_rgmii_a: gmac_rgmii@0 {
...@@ -793,90 +868,104 @@ gmac_pins_rgmii_a: gmac_rgmii@0 { ...@@ -793,90 +868,104 @@ gmac_pins_rgmii_a: gmac_rgmii@0 {
* data lines in RGMII mode use DDR mode * data lines in RGMII mode use DDR mode
* and need a higher signal drive strength * and need a higher signal drive strength
*/ */
allwinner,drive = <3>; allwinner,drive = <SUN4I_PINCTRL_40_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
spi0_pins_a: spi0@0 { spi0_pins_a: spi0@0 {
allwinner,pins = "PI10", "PI11", "PI12", "PI13", "PI14"; allwinner,pins = "PI10", "PI11", "PI12", "PI13", "PI14";
allwinner,function = "spi0"; allwinner,function = "spi0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
spi1_pins_a: spi1@0 { spi1_pins_a: spi1@0 {
allwinner,pins = "PI16", "PI17", "PI18", "PI19"; allwinner,pins = "PI16", "PI17", "PI18", "PI19";
allwinner,function = "spi1"; allwinner,function = "spi1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
spi2_pins_a: spi2@0 { spi2_pins_a: spi2@0 {
allwinner,pins = "PC19", "PC20", "PC21", "PC22"; allwinner,pins = "PC19", "PC20", "PC21", "PC22";
allwinner,function = "spi2"; allwinner,function = "spi2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
spi2_pins_b: spi2@1 { spi2_pins_b: spi2@1 {
allwinner,pins = "PB14", "PB15", "PB16", "PB17"; allwinner,pins = "PB14", "PB15", "PB16", "PB17";
allwinner,function = "spi2"; allwinner,function = "spi2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_cd_pin_reference_design: mmc0_cd_pin@0 { mmc0_cd_pin_reference_design: mmc0_cd_pin@0 {
allwinner,pins = "PH1"; allwinner,pins = "PH1";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
mmc2_pins_a: mmc2@0 { mmc2_pins_a: mmc2@0 {
allwinner,pins = "PC6","PC7","PC8","PC9","PC10","PC11"; allwinner,pins = "PC6","PC7","PC8","PC9","PC10","PC11";
allwinner,function = "mmc2"; allwinner,function = "mmc2";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
mmc3_pins_a: mmc3@0 { mmc3_pins_a: mmc3@0 {
allwinner,pins = "PI4","PI5","PI6","PI7","PI8","PI9"; allwinner,pins = "PI4","PI5","PI6","PI7","PI8","PI9";
allwinner,function = "mmc3"; allwinner,function = "mmc3";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
ir0_pins_a: ir0@0 { ir0_pins_a: ir0@0 {
allwinner,pins = "PB3","PB4"; allwinner,pins = "PB3","PB4";
allwinner,function = "ir0"; allwinner,function = "ir0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
ir1_pins_a: ir1@0 { ir1_pins_a: ir1@0 {
allwinner,pins = "PB22","PB23"; allwinner,pins = "PB22","PB23";
allwinner,function = "ir1"; allwinner,function = "ir1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
ps20_pins_a: ps20@0 {
allwinner,pins = "PI20", "PI21";
allwinner,function = "ps2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
ps21_pins_a: ps21@0 {
allwinner,pins = "PH12", "PH13";
allwinner,function = "ps2";
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
timer@01c20c00 { timer@01c20c00 {
compatible = "allwinner,sun4i-a10-timer"; compatible = "allwinner,sun4i-a10-timer";
reg = <0x01c20c00 0x90>; reg = <0x01c20c00 0x90>;
interrupts = <0 22 4>, interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>,
<0 23 4>, <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>,
<0 24 4>, <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>,
<0 25 4>, <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>,
<0 67 4>, <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>,
<0 68 4>; <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&osc24M>; clocks = <&osc24M>;
}; };
...@@ -888,7 +977,7 @@ wdt: watchdog@01c20c90 { ...@@ -888,7 +977,7 @@ wdt: watchdog@01c20c90 {
rtc: rtc@01c20d00 { rtc: rtc@01c20d00 {
compatible = "allwinner,sun7i-a20-rtc"; compatible = "allwinner,sun7i-a20-rtc";
reg = <0x01c20d00 0x20>; reg = <0x01c20d00 0x20>;
interrupts = <0 24 4>; interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
}; };
pwm: pwm@01c20e00 { pwm: pwm@01c20e00 {
...@@ -903,7 +992,7 @@ ir0: ir@01c21800 { ...@@ -903,7 +992,7 @@ ir0: ir@01c21800 {
compatible = "allwinner,sun4i-a10-ir"; compatible = "allwinner,sun4i-a10-ir";
clocks = <&apb0_gates 6>, <&ir0_clk>; clocks = <&apb0_gates 6>, <&ir0_clk>;
clock-names = "apb", "ir"; clock-names = "apb", "ir";
interrupts = <0 5 4>; interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
reg = <0x01c21800 0x40>; reg = <0x01c21800 0x40>;
status = "disabled"; status = "disabled";
}; };
...@@ -912,11 +1001,18 @@ ir1: ir@01c21c00 { ...@@ -912,11 +1001,18 @@ ir1: ir@01c21c00 {
compatible = "allwinner,sun4i-a10-ir"; compatible = "allwinner,sun4i-a10-ir";
clocks = <&apb0_gates 7>, <&ir1_clk>; clocks = <&apb0_gates 7>, <&ir1_clk>;
clock-names = "apb", "ir"; clock-names = "apb", "ir";
interrupts = <0 6 4>; interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
reg = <0x01c21c00 0x40>; reg = <0x01c21c00 0x40>;
status = "disabled"; status = "disabled";
}; };
lradc: lradc@01c22800 {
compatible = "allwinner,sun4i-a10-lradc-keys";
reg = <0x01c22800 0x100>;
interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
};
sid: eeprom@01c23800 { sid: eeprom@01c23800 {
compatible = "allwinner,sun7i-a20-sid"; compatible = "allwinner,sun7i-a20-sid";
reg = <0x01c23800 0x200>; reg = <0x01c23800 0x200>;
...@@ -925,13 +1021,14 @@ sid: eeprom@01c23800 { ...@@ -925,13 +1021,14 @@ sid: eeprom@01c23800 {
rtp: rtp@01c25000 { rtp: rtp@01c25000 {
compatible = "allwinner,sun4i-a10-ts"; compatible = "allwinner,sun4i-a10-ts";
reg = <0x01c25000 0x100>; reg = <0x01c25000 0x100>;
interrupts = <0 29 4>; interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
#thermal-sensor-cells = <0>;
}; };
uart0: serial@01c28000 { uart0: serial@01c28000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28000 0x400>; reg = <0x01c28000 0x400>;
interrupts = <0 1 4>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 16>; clocks = <&apb1_gates 16>;
...@@ -941,7 +1038,7 @@ uart0: serial@01c28000 { ...@@ -941,7 +1038,7 @@ uart0: serial@01c28000 {
uart1: serial@01c28400 { uart1: serial@01c28400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28400 0x400>; reg = <0x01c28400 0x400>;
interrupts = <0 2 4>; interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 17>; clocks = <&apb1_gates 17>;
...@@ -951,7 +1048,7 @@ uart1: serial@01c28400 { ...@@ -951,7 +1048,7 @@ uart1: serial@01c28400 {
uart2: serial@01c28800 { uart2: serial@01c28800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28800 0x400>; reg = <0x01c28800 0x400>;
interrupts = <0 3 4>; interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 18>; clocks = <&apb1_gates 18>;
...@@ -961,7 +1058,7 @@ uart2: serial@01c28800 { ...@@ -961,7 +1058,7 @@ uart2: serial@01c28800 {
uart3: serial@01c28c00 { uart3: serial@01c28c00 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28c00 0x400>; reg = <0x01c28c00 0x400>;
interrupts = <0 4 4>; interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 19>; clocks = <&apb1_gates 19>;
...@@ -971,7 +1068,7 @@ uart3: serial@01c28c00 { ...@@ -971,7 +1068,7 @@ uart3: serial@01c28c00 {
uart4: serial@01c29000 { uart4: serial@01c29000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29000 0x400>; reg = <0x01c29000 0x400>;
interrupts = <0 17 4>; interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 20>; clocks = <&apb1_gates 20>;
...@@ -981,7 +1078,7 @@ uart4: serial@01c29000 { ...@@ -981,7 +1078,7 @@ uart4: serial@01c29000 {
uart5: serial@01c29400 { uart5: serial@01c29400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29400 0x400>; reg = <0x01c29400 0x400>;
interrupts = <0 18 4>; interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 21>; clocks = <&apb1_gates 21>;
...@@ -991,7 +1088,7 @@ uart5: serial@01c29400 { ...@@ -991,7 +1088,7 @@ uart5: serial@01c29400 {
uart6: serial@01c29800 { uart6: serial@01c29800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29800 0x400>; reg = <0x01c29800 0x400>;
interrupts = <0 19 4>; interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 22>; clocks = <&apb1_gates 22>;
...@@ -1001,7 +1098,7 @@ uart6: serial@01c29800 { ...@@ -1001,7 +1098,7 @@ uart6: serial@01c29800 {
uart7: serial@01c29c00 { uart7: serial@01c29c00 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29c00 0x400>; reg = <0x01c29c00 0x400>;
interrupts = <0 20 4>; interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 23>; clocks = <&apb1_gates 23>;
...@@ -1011,7 +1108,7 @@ uart7: serial@01c29c00 { ...@@ -1011,7 +1108,7 @@ uart7: serial@01c29c00 {
i2c0: i2c@01c2ac00 { i2c0: i2c@01c2ac00 {
compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c";
reg = <0x01c2ac00 0x400>; reg = <0x01c2ac00 0x400>;
interrupts = <0 7 4>; interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 0>; clocks = <&apb1_gates 0>;
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -1021,7 +1118,7 @@ i2c0: i2c@01c2ac00 { ...@@ -1021,7 +1118,7 @@ i2c0: i2c@01c2ac00 {
i2c1: i2c@01c2b000 { i2c1: i2c@01c2b000 {
compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c";
reg = <0x01c2b000 0x400>; reg = <0x01c2b000 0x400>;
interrupts = <0 8 4>; interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 1>; clocks = <&apb1_gates 1>;
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -1031,7 +1128,7 @@ i2c1: i2c@01c2b000 { ...@@ -1031,7 +1128,7 @@ i2c1: i2c@01c2b000 {
i2c2: i2c@01c2b400 { i2c2: i2c@01c2b400 {
compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c";
reg = <0x01c2b400 0x400>; reg = <0x01c2b400 0x400>;
interrupts = <0 9 4>; interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 2>; clocks = <&apb1_gates 2>;
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -1041,7 +1138,7 @@ i2c2: i2c@01c2b400 { ...@@ -1041,7 +1138,7 @@ i2c2: i2c@01c2b400 {
i2c3: i2c@01c2b800 { i2c3: i2c@01c2b800 {
compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c";
reg = <0x01c2b800 0x400>; reg = <0x01c2b800 0x400>;
interrupts = <0 88 4>; interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 3>; clocks = <&apb1_gates 3>;
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -1051,7 +1148,7 @@ i2c3: i2c@01c2b800 { ...@@ -1051,7 +1148,7 @@ i2c3: i2c@01c2b800 {
i2c4: i2c@01c2c000 { i2c4: i2c@01c2c000 {
compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c";
reg = <0x01c2c000 0x400>; reg = <0x01c2c000 0x400>;
interrupts = <0 89 4>; interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 15>; clocks = <&apb1_gates 15>;
status = "disabled"; status = "disabled";
#address-cells = <1>; #address-cells = <1>;
...@@ -1061,7 +1158,7 @@ i2c4: i2c@01c2c000 { ...@@ -1061,7 +1158,7 @@ i2c4: i2c@01c2c000 {
gmac: ethernet@01c50000 { gmac: ethernet@01c50000 {
compatible = "allwinner,sun7i-a20-gmac"; compatible = "allwinner,sun7i-a20-gmac";
reg = <0x01c50000 0x10000>; reg = <0x01c50000 0x10000>;
interrupts = <0 85 4>; interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "macirq"; interrupt-names = "macirq";
clocks = <&ahb_gates 49>, <&gmac_tx_clk>; clocks = <&ahb_gates 49>, <&gmac_tx_clk>;
clock-names = "stmmaceth", "allwinner_gmac_tx"; clock-names = "stmmaceth", "allwinner_gmac_tx";
...@@ -1076,10 +1173,10 @@ gmac: ethernet@01c50000 { ...@@ -1076,10 +1173,10 @@ gmac: ethernet@01c50000 {
hstimer@01c60000 { hstimer@01c60000 {
compatible = "allwinner,sun7i-a20-hstimer"; compatible = "allwinner,sun7i-a20-hstimer";
reg = <0x01c60000 0x1000>; reg = <0x01c60000 0x1000>;
interrupts = <0 81 4>, interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>,
<0 82 4>, <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>,
<0 83 4>, <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>,
<0 84 4>; <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb_gates 28>; clocks = <&ahb_gates 28>;
}; };
...@@ -1091,7 +1188,23 @@ gic: interrupt-controller@01c81000 { ...@@ -1091,7 +1188,23 @@ gic: interrupt-controller@01c81000 {
<0x01c86000 0x2000>; <0x01c86000 0x2000>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupts = <1 9 0xf04>; interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
};
ps20: ps2@01c2a000 {
compatible = "allwinner,sun4i-a10-ps2";
reg = <0x01c2a000 0x400>;
interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 6>;
status = "disabled";
};
ps21: ps2@01c2a400 {
compatible = "allwinner,sun4i-a10-ps2";
reg = <0x01c2a400 0x400>;
interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 7>;
status = "disabled";
}; };
}; };
}; };
/*
* Copyright 2015 Hans de Goede <hdegoede@redhat.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
/*
* The Ippo Q8H v1.2 is almost identical to the v5, still it needs a separate
* dtb file since some gpio-s surrounding the wlan/bluetooth are different,
* and it uses different camera sensors.
*/
#include "sun8i-a23-ippo-q8h-v5.dts"
/ {
model = "Ippo Q8H Dual Core Tablet (v1.2)";
compatible = "ippo,q8h-v1.2", "allwinner,sun8i-a23";
};
...@@ -48,13 +48,21 @@ ...@@ -48,13 +48,21 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun8i-a23.dtsi" #include "sun8i-a23.dtsi"
/include/ "sunxi-common-regulators.dtsi" #include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Ippo Q8H Dual Core Tablet (v5)"; model = "Ippo Q8H Dual Core Tablet (v5)";
compatible = "ippo,q8h-v5", "allwinner,sun8i-a23"; compatible = "ippo,q8h-v5", "allwinner,sun8i-a23";
aliases {
serial0 = &r_uart;
};
chosen { chosen {
bootargs = "earlyprintk console=ttyS0,115200"; bootargs = "earlyprintk console=ttyS0,115200";
}; };
...@@ -65,7 +73,7 @@ mmc0: mmc@01c0f000 { ...@@ -65,7 +73,7 @@ mmc0: mmc@01c0f000 {
pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_q8h>; pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_q8h>;
vmmc-supply = <&reg_vcc3v0>; vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>; bus-width = <4>;
cd-gpios = <&pio 1 4 0>; /* PB4 */ cd-gpios = <&pio 1 4 GPIO_ACTIVE_HIGH>; /* PB4 */
cd-inverted; cd-inverted;
status = "okay"; status = "okay";
}; };
...@@ -74,8 +82,27 @@ pinctrl@01c20800 { ...@@ -74,8 +82,27 @@ pinctrl@01c20800 {
mmc0_cd_pin_q8h: mmc0_cd_pin@0 { mmc0_cd_pin_q8h: mmc0_cd_pin@0 {
allwinner,pins = "PB4"; allwinner,pins = "PB4";
allwinner,function = "gpio_in"; allwinner,function = "gpio_in";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <1>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
};
};
lradc: lradc@01c22800 {
vref-supply = <&reg_vcc3v0>;
status = "okay";
button@200 {
label = "Volume Up";
linux,code = <KEY_VOLUMEUP>;
channel = <0>;
voltage = <200000>;
};
button@400 {
label = "Volume Down";
linux,code = <KEY_VOLUMEDOWN>;
channel = <0>;
voltage = <400000>;
}; };
}; };
......
...@@ -47,7 +47,11 @@ ...@@ -47,7 +47,11 @@
* OTHER DEALINGS IN THE SOFTWARE. * OTHER DEALINGS IN THE SOFTWARE.
*/ */
/include/ "skeleton.dtsi" #include "skeleton.dtsi"
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
...@@ -61,6 +65,20 @@ aliases { ...@@ -61,6 +65,20 @@ aliases {
serial5 = &r_uart; serial5 = &r_uart;
}; };
chosen {
#address-cells = <1>;
#size-cells = <1>;
ranges;
framebuffer@0 {
compatible = "allwinner,simple-framebuffer",
"simple-framebuffer";
allwinner,pipeline = "de_be0-lcd0";
clocks = <&pll6 0>;
status = "disabled";
};
};
cpus { cpus {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <0>; #size-cells = <0>;
...@@ -242,7 +260,7 @@ soc@01c00000 { ...@@ -242,7 +260,7 @@ soc@01c00000 {
dma: dma-controller@01c02000 { dma: dma-controller@01c02000 {
compatible = "allwinner,sun8i-a23-dma"; compatible = "allwinner,sun8i-a23-dma";
reg = <0x01c02000 0x1000>; reg = <0x01c02000 0x1000>;
interrupts = <0 50 4>; interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&ahb1_gates 6>; clocks = <&ahb1_gates 6>;
resets = <&ahb1_rst 6>; resets = <&ahb1_rst 6>;
#dma-cells = <1>; #dma-cells = <1>;
...@@ -255,7 +273,7 @@ mmc0: mmc@01c0f000 { ...@@ -255,7 +273,7 @@ mmc0: mmc@01c0f000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 8>; resets = <&ahb1_rst 8>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 60 4>; interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -266,7 +284,7 @@ mmc1: mmc@01c10000 { ...@@ -266,7 +284,7 @@ mmc1: mmc@01c10000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 9>; resets = <&ahb1_rst 9>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 61 4>; interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -277,16 +295,16 @@ mmc2: mmc@01c11000 { ...@@ -277,16 +295,16 @@ mmc2: mmc@01c11000 {
clock-names = "ahb", "mmc"; clock-names = "ahb", "mmc";
resets = <&ahb1_rst 10>; resets = <&ahb1_rst 10>;
reset-names = "ahb"; reset-names = "ahb";
interrupts = <0 62 4>; interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled"; status = "disabled";
}; };
pio: pinctrl@01c20800 { pio: pinctrl@01c20800 {
compatible = "allwinner,sun8i-a23-pinctrl"; compatible = "allwinner,sun8i-a23-pinctrl";
reg = <0x01c20800 0x400>; reg = <0x01c20800 0x400>;
interrupts = <0 11 4>, interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>,
<0 15 4>, <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>,
<0 17 4>; <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 5>; clocks = <&apb1_gates 5>;
gpio-controller; gpio-controller;
interrupt-controller; interrupt-controller;
...@@ -297,43 +315,43 @@ pio: pinctrl@01c20800 { ...@@ -297,43 +315,43 @@ pio: pinctrl@01c20800 {
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PF2", "PF4"; allwinner,pins = "PF2", "PF4";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc0_pins_a: mmc0@0 { mmc0_pins_a: mmc0@0 {
allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5";
allwinner,function = "mmc0"; allwinner,function = "mmc0";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
mmc1_pins_a: mmc1@0 { mmc1_pins_a: mmc1@0 {
allwinner,pins = "PG0","PG1","PG2","PG3","PG4","PG5"; allwinner,pins = "PG0","PG1","PG2","PG3","PG4","PG5";
allwinner,function = "mmc1"; allwinner,function = "mmc1";
allwinner,drive = <2>; allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c0_pins_a: i2c0@0 { i2c0_pins_a: i2c0@0 {
allwinner,pins = "PH2", "PH3"; allwinner,pins = "PH2", "PH3";
allwinner,function = "i2c0"; allwinner,function = "i2c0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c1_pins_a: i2c1@0 { i2c1_pins_a: i2c1@0 {
allwinner,pins = "PH4", "PH5"; allwinner,pins = "PH4", "PH5";
allwinner,function = "i2c1"; allwinner,function = "i2c1";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
i2c2_pins_a: i2c2@0 { i2c2_pins_a: i2c2@0 {
allwinner,pins = "PE12", "PE13"; allwinner,pins = "PE12", "PE13";
allwinner,function = "i2c2"; allwinner,function = "i2c2";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
...@@ -358,21 +376,28 @@ apb2_rst: reset@01c202d8 { ...@@ -358,21 +376,28 @@ apb2_rst: reset@01c202d8 {
timer@01c20c00 { timer@01c20c00 {
compatible = "allwinner,sun4i-a10-timer"; compatible = "allwinner,sun4i-a10-timer";
reg = <0x01c20c00 0xa0>; reg = <0x01c20c00 0xa0>;
interrupts = <0 18 4>, interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>,
<0 19 4>; <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&osc24M>; clocks = <&osc24M>;
}; };
wdt0: watchdog@01c20ca0 { wdt0: watchdog@01c20ca0 {
compatible = "allwinner,sun6i-a31-wdt"; compatible = "allwinner,sun6i-a31-wdt";
reg = <0x01c20ca0 0x20>; reg = <0x01c20ca0 0x20>;
interrupts = <0 25 4>; interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
};
lradc: lradc@01c22800 {
compatible = "allwinner,sun4i-a10-lradc-keys";
reg = <0x01c22800 0x100>;
interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
}; };
uart0: serial@01c28000 { uart0: serial@01c28000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28000 0x400>; reg = <0x01c28000 0x400>;
interrupts = <0 0 4>; interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 16>; clocks = <&apb2_gates 16>;
...@@ -385,7 +410,7 @@ uart0: serial@01c28000 { ...@@ -385,7 +410,7 @@ uart0: serial@01c28000 {
uart1: serial@01c28400 { uart1: serial@01c28400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28400 0x400>; reg = <0x01c28400 0x400>;
interrupts = <0 1 4>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 17>; clocks = <&apb2_gates 17>;
...@@ -398,7 +423,7 @@ uart1: serial@01c28400 { ...@@ -398,7 +423,7 @@ uart1: serial@01c28400 {
uart2: serial@01c28800 { uart2: serial@01c28800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28800 0x400>; reg = <0x01c28800 0x400>;
interrupts = <0 2 4>; interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 18>; clocks = <&apb2_gates 18>;
...@@ -411,7 +436,7 @@ uart2: serial@01c28800 { ...@@ -411,7 +436,7 @@ uart2: serial@01c28800 {
uart3: serial@01c28c00 { uart3: serial@01c28c00 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c28c00 0x400>; reg = <0x01c28c00 0x400>;
interrupts = <0 3 4>; interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 19>; clocks = <&apb2_gates 19>;
...@@ -424,7 +449,7 @@ uart3: serial@01c28c00 { ...@@ -424,7 +449,7 @@ uart3: serial@01c28c00 {
uart4: serial@01c29000 { uart4: serial@01c29000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01c29000 0x400>; reg = <0x01c29000 0x400>;
interrupts = <0 4 4>; interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb2_gates 20>; clocks = <&apb2_gates 20>;
...@@ -437,7 +462,7 @@ uart4: serial@01c29000 { ...@@ -437,7 +462,7 @@ uart4: serial@01c29000 {
i2c0: i2c@01c2ac00 { i2c0: i2c@01c2ac00 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2ac00 0x400>; reg = <0x01c2ac00 0x400>;
interrupts = <0 6 4>; interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 0>; clocks = <&apb2_gates 0>;
resets = <&apb2_rst 0>; resets = <&apb2_rst 0>;
status = "disabled"; status = "disabled";
...@@ -448,7 +473,7 @@ i2c0: i2c@01c2ac00 { ...@@ -448,7 +473,7 @@ i2c0: i2c@01c2ac00 {
i2c1: i2c@01c2b000 { i2c1: i2c@01c2b000 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2b000 0x400>; reg = <0x01c2b000 0x400>;
interrupts = <0 7 4>; interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 1>; clocks = <&apb2_gates 1>;
resets = <&apb2_rst 1>; resets = <&apb2_rst 1>;
status = "disabled"; status = "disabled";
...@@ -459,7 +484,7 @@ i2c1: i2c@01c2b000 { ...@@ -459,7 +484,7 @@ i2c1: i2c@01c2b000 {
i2c2: i2c@01c2b400 { i2c2: i2c@01c2b400 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x01c2b400 0x400>; reg = <0x01c2b400 0x400>;
interrupts = <0 8 4>; interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb2_gates 2>; clocks = <&apb2_gates 2>;
resets = <&apb2_rst 2>; resets = <&apb2_rst 2>;
status = "disabled"; status = "disabled";
...@@ -475,13 +500,14 @@ gic: interrupt-controller@01c81000 { ...@@ -475,13 +500,14 @@ gic: interrupt-controller@01c81000 {
<0x01c86000 0x2000>; <0x01c86000 0x2000>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupts = <1 9 0xf04>; interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
}; };
rtc: rtc@01f00000 { rtc: rtc@01f00000 {
compatible = "allwinner,sun6i-a31-rtc"; compatible = "allwinner,sun6i-a31-rtc";
reg = <0x01f00000 0x54>; reg = <0x01f00000 0x54>;
interrupts = <0 40 4>, <0 41 4>; interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
}; };
prcm@01f01400 { prcm@01f01400 {
...@@ -531,7 +557,7 @@ apb0_rst: apb0_rst { ...@@ -531,7 +557,7 @@ apb0_rst: apb0_rst {
r_uart: serial@01f02800 { r_uart: serial@01f02800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x01f02800 0x400>; reg = <0x01f02800 0x400>;
interrupts = <0 38 4>; interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb0_gates 4>; clocks = <&apb0_gates 4>;
...@@ -542,7 +568,7 @@ r_uart: serial@01f02800 { ...@@ -542,7 +568,7 @@ r_uart: serial@01f02800 {
r_pio: pinctrl@01f02c00 { r_pio: pinctrl@01f02c00 {
compatible = "allwinner,sun8i-a23-r-pinctrl"; compatible = "allwinner,sun8i-a23-r-pinctrl";
reg = <0x01f02c00 0x400>; reg = <0x01f02c00 0x400>;
interrupts = <0 45 4>; interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb0_gates 0>; clocks = <&apb0_gates 0>;
resets = <&apb0_rst 0>; resets = <&apb0_rst 0>;
gpio-controller; gpio-controller;
...@@ -554,8 +580,8 @@ r_pio: pinctrl@01f02c00 { ...@@ -554,8 +580,8 @@ r_pio: pinctrl@01f02c00 {
r_uart_pins_a: r_uart@0 { r_uart_pins_a: r_uart@0 {
allwinner,pins = "PL2", "PL3"; allwinner,pins = "PL2", "PL3";
allwinner,function = "s_uart"; allwinner,function = "s_uart";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
}; };
......
...@@ -48,7 +48,11 @@ ...@@ -48,7 +48,11 @@
*/ */
/dts-v1/; /dts-v1/;
/include/ "sun9i-a80.dtsi" #include "sun9i-a80.dtsi"
#include "sunxi-common-regulators.dtsi"
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
model = "Merrii A80 Optimus Board"; model = "Merrii A80 Optimus Board";
...@@ -58,62 +62,86 @@ chosen { ...@@ -58,62 +62,86 @@ chosen {
bootargs = "earlyprintk console=ttyS0,115200"; bootargs = "earlyprintk console=ttyS0,115200";
}; };
soc { leds {
pio: pinctrl@06000800 { compatible = "gpio-leds";
i2c3_pins_a: i2c3@0 { pinctrl-names = "default";
/* Enable internal pull-up */ pinctrl-0 = <&led_pins_optimus>;
allwinner,pull = <1>;
/* The LED names match those found on the board */
led2 {
label = "optimus:led2:usr";
gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>;
};
/* led3 is on PM15, in R_PIO */
led4 {
label = "optimus:led4:usr";
gpios = <&pio 7 0 GPIO_ACTIVE_HIGH>;
}; };
};
};
&i2c3 {
pinctrl-names = "default";
pinctrl-0 = <&i2c3_pins_a>;
status = "okay";
};
&i2c3_pins_a {
/* Enable internal pull-up */
allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
};
&pio {
led_pins_optimus: led-pins@0 { led_pins_optimus: led-pins@0 {
allwinner,pins = "PH0", "PH1"; allwinner,pins = "PH0", "PH1";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart4_pins_a: uart4@0 { mmc0_cd_pin_optimus: mmc0_cd_pin@0 {
/* Enable internal pull-up */ allwinner,pins = "PH18";
allwinner,pull = <1>; allwinner,function = "gpio_in";
}; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
}; };
};
uart0: serial@07000000 { &mmc0 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&uart0_pins_a>; pinctrl-0 = <&mmc0_pins>, <&mmc0_cd_pin_optimus>;
vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>;
cd-gpios = <&pio 7 18 GPIO_ACTIVE_HIGH>; /* PH8 */
cd-inverted;
status = "okay"; status = "okay";
}; };
uart4: serial@07001000 { &mmc2 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&uart4_pins_a>; pinctrl-0 = <&mmc2_8bit_pins>;
vmmc-supply = <&reg_vcc3v0>;
bus-width = <8>;
non-removable;
status = "okay"; status = "okay";
}; };
i2c3: i2c@07003400 { &uart0 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&i2c3_pins_a>; pinctrl-0 = <&uart0_pins_a>;
status = "okay"; status = "okay";
}; };
};
leds { &uart4 {
compatible = "gpio-leds";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&led_pins_optimus>; pinctrl-0 = <&uart4_pins_a>;
status = "okay";
/* The LED names match those found on the board */ };
led2 {
label = "optimus:led2:usr";
gpios = <&pio 7 1 0>;
};
/* led3 is on PM15, in R_PIO */
led4 { &uart4_pins_a {
label = "optimus:led4:usr"; /* Enable internal pull-up */
gpios = <&pio 7 0 0>; allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
};
};
}; };
...@@ -47,7 +47,11 @@ ...@@ -47,7 +47,11 @@
* OTHER DEALINGS IN THE SOFTWARE. * OTHER DEALINGS IN THE SOFTWARE.
*/ */
/include/ "skeleton64.dtsi" #include "skeleton64.dtsi"
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/pinctrl/sun4i-a10.h>
/ { / {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
...@@ -215,11 +219,50 @@ cci400_clk: clk@06000078 { ...@@ -215,11 +219,50 @@ cci400_clk: clk@06000078 {
clock-output-names = "cci400"; clock-output-names = "cci400";
}; };
mmc0_clk: clk@06000410 {
#clock-cells = <1>;
compatible = "allwinner,sun9i-a80-mmc-clk";
reg = <0x06000410 0x4>;
clocks = <&osc24M>, <&pll4>;
clock-output-names = "mmc0", "mmc0_output",
"mmc0_sample";
};
mmc1_clk: clk@06000414 {
#clock-cells = <1>;
compatible = "allwinner,sun9i-a80-mmc-clk";
reg = <0x06000414 0x4>;
clocks = <&osc24M>, <&pll4>;
clock-output-names = "mmc1", "mmc1_output",
"mmc1_sample";
};
mmc2_clk: clk@06000418 {
#clock-cells = <1>;
compatible = "allwinner,sun9i-a80-mmc-clk";
reg = <0x06000418 0x4>;
clocks = <&osc24M>, <&pll4>;
clock-output-names = "mmc2", "mmc2_output",
"mmc2_sample";
};
mmc3_clk: clk@0600041c {
#clock-cells = <1>;
compatible = "allwinner,sun9i-a80-mmc-clk";
reg = <0x0600041c 0x4>;
clocks = <&osc24M>, <&pll4>;
clock-output-names = "mmc3", "mmc3_output",
"mmc3_sample";
};
ahb0_gates: clk@06000580 { ahb0_gates: clk@06000580 {
#clock-cells = <1>; #clock-cells = <1>;
compatible = "allwinner,sun9i-a80-ahb0-gates-clk"; compatible = "allwinner,sun9i-a80-ahb0-gates-clk";
reg = <0x06000580 0x4>; reg = <0x06000580 0x4>;
clocks = <&ahb0>; clocks = <&ahb0>;
clock-indices = <0>, <1>, <3>, <5>, <8>, <12>, <13>,
<14>, <15>, <16>, <18>, <20>, <21>,
<22>, <23>;
clock-output-names = "ahb0_fd", "ahb0_ve", "ahb0_gpu", clock-output-names = "ahb0_fd", "ahb0_ve", "ahb0_gpu",
"ahb0_ss", "ahb0_sd", "ahb0_nand1", "ahb0_ss", "ahb0_sd", "ahb0_nand1",
"ahb0_nand0", "ahb0_sdram", "ahb0_nand0", "ahb0_sdram",
...@@ -233,6 +276,7 @@ ahb1_gates: clk@06000584 { ...@@ -233,6 +276,7 @@ ahb1_gates: clk@06000584 {
compatible = "allwinner,sun9i-a80-ahb1-gates-clk"; compatible = "allwinner,sun9i-a80-ahb1-gates-clk";
reg = <0x06000584 0x4>; reg = <0x06000584 0x4>;
clocks = <&ahb1>; clocks = <&ahb1>;
clock-indices = <0>, <1>, <17>, <21>, <22>, <23>, <24>;
clock-output-names = "ahb1_usbotg", "ahb1_usbhci", clock-output-names = "ahb1_usbotg", "ahb1_usbhci",
"ahb1_gmac", "ahb1_msgbox", "ahb1_gmac", "ahb1_msgbox",
"ahb1_spinlock", "ahb1_hstimer", "ahb1_spinlock", "ahb1_hstimer",
...@@ -244,6 +288,8 @@ ahb2_gates: clk@06000588 { ...@@ -244,6 +288,8 @@ ahb2_gates: clk@06000588 {
compatible = "allwinner,sun9i-a80-ahb2-gates-clk"; compatible = "allwinner,sun9i-a80-ahb2-gates-clk";
reg = <0x06000588 0x4>; reg = <0x06000588 0x4>;
clocks = <&ahb2>; clocks = <&ahb2>;
clock-indices = <0>, <1>, <2>, <4>, <5>, <7>, <8>,
<11>;
clock-output-names = "ahb2_lcd0", "ahb2_lcd1", clock-output-names = "ahb2_lcd0", "ahb2_lcd1",
"ahb2_edp", "ahb2_csi", "ahb2_hdmi", "ahb2_edp", "ahb2_csi", "ahb2_hdmi",
"ahb2_de", "ahb2_mp", "ahb2_mipi_dsi"; "ahb2_de", "ahb2_mp", "ahb2_mipi_dsi";
...@@ -254,6 +300,8 @@ apb0_gates: clk@06000590 { ...@@ -254,6 +300,8 @@ apb0_gates: clk@06000590 {
compatible = "allwinner,sun9i-a80-apb0-gates-clk"; compatible = "allwinner,sun9i-a80-apb0-gates-clk";
reg = <0x06000590 0x4>; reg = <0x06000590 0x4>;
clocks = <&apb0>; clocks = <&apb0>;
clock-indices = <1>, <5>, <11>, <12>, <13>, <15>,
<17>, <18>, <19>;
clock-output-names = "apb0_spdif", "apb0_pio", clock-output-names = "apb0_spdif", "apb0_pio",
"apb0_ac97", "apb0_i2s0", "apb0_i2s1", "apb0_ac97", "apb0_i2s0", "apb0_i2s1",
"apb0_lradc", "apb0_gpadc", "apb0_twd", "apb0_lradc", "apb0_gpadc", "apb0_twd",
...@@ -265,6 +313,8 @@ apb1_gates: clk@06000594 { ...@@ -265,6 +313,8 @@ apb1_gates: clk@06000594 {
compatible = "allwinner,sun9i-a80-apb1-gates-clk"; compatible = "allwinner,sun9i-a80-apb1-gates-clk";
reg = <0x06000594 0x4>; reg = <0x06000594 0x4>;
clocks = <&apb1>; clocks = <&apb1>;
clock-indices = <0>, <1>, <2>, <3>, <4>,
<16>, <17>, <18>, <19>, <20>, <21>;
clock-output-names = "apb1_i2c0", "apb1_i2c1", clock-output-names = "apb1_i2c0", "apb1_i2c1",
"apb1_i2c2", "apb1_i2c3", "apb1_i2c4", "apb1_i2c2", "apb1_i2c3", "apb1_i2c4",
"apb1_uart0", "apb1_uart1", "apb1_uart0", "apb1_uart1",
...@@ -283,6 +333,67 @@ soc { ...@@ -283,6 +333,67 @@ soc {
*/ */
ranges = <0 0 0 0x20000000>; ranges = <0 0 0 0x20000000>;
mmc0: mmc@01c0f000 {
compatible = "allwinner,sun5i-a13-mmc";
reg = <0x01c0f000 0x1000>;
clocks = <&mmc_config_clk 0>, <&mmc0_clk 0>,
<&mmc0_clk 1>, <&mmc0_clk 2>;
clock-names = "ahb", "mmc", "output", "sample";
resets = <&mmc_config_clk 0>;
reset-names = "ahb";
interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
};
mmc1: mmc@01c10000 {
compatible = "allwinner,sun5i-a13-mmc";
reg = <0x01c10000 0x1000>;
clocks = <&mmc_config_clk 1>, <&mmc1_clk 0>,
<&mmc1_clk 1>, <&mmc1_clk 2>;
clock-names = "ahb", "mmc", "output", "sample";
resets = <&mmc_config_clk 1>;
reset-names = "ahb";
interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
};
mmc2: mmc@01c11000 {
compatible = "allwinner,sun5i-a13-mmc";
reg = <0x01c11000 0x1000>;
clocks = <&mmc_config_clk 2>, <&mmc2_clk 0>,
<&mmc2_clk 1>, <&mmc2_clk 2>;
clock-names = "ahb", "mmc", "output", "sample";
resets = <&mmc_config_clk 2>;
reset-names = "ahb";
interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
};
mmc3: mmc@01c12000 {
compatible = "allwinner,sun5i-a13-mmc";
reg = <0x01c12000 0x1000>;
clocks = <&mmc_config_clk 3>, <&mmc3_clk 0>,
<&mmc3_clk 1>, <&mmc3_clk 2>;
clock-names = "ahb", "mmc", "output", "sample";
resets = <&mmc_config_clk 3>;
reset-names = "ahb";
interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
status = "disabled";
};
mmc_config_clk: clk@01c13000 {
compatible = "allwinner,sun9i-a80-mmc-config-clk";
reg = <0x01c13000 0x10>;
clocks = <&ahb0_gates 8>;
clock-names = "ahb";
resets = <&ahb0_resets 8>;
reset-names = "ahb";
#clock-cells = <1>;
#reset-cells = <1>;
clock-output-names = "mmc0_config", "mmc1_config",
"mmc2_config", "mmc3_config";
};
gic: interrupt-controller@01c41000 { gic: interrupt-controller@01c41000 {
compatible = "arm,cortex-a7-gic", "arm,cortex-a15-gic"; compatible = "arm,cortex-a7-gic", "arm,cortex-a15-gic";
reg = <0x01c41000 0x1000>, reg = <0x01c41000 0x1000>,
...@@ -291,7 +402,7 @@ gic: interrupt-controller@01c41000 { ...@@ -291,7 +402,7 @@ gic: interrupt-controller@01c41000 {
<0x01c46000 0x2000>; <0x01c46000 0x2000>;
interrupt-controller; interrupt-controller;
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupts = <1 9 0xf04>; interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
}; };
ahb0_resets: reset@060005a0 { ahb0_resets: reset@060005a0 {
...@@ -327,12 +438,12 @@ apb1_resets: reset@060005b4 { ...@@ -327,12 +438,12 @@ apb1_resets: reset@060005b4 {
timer@06000c00 { timer@06000c00 {
compatible = "allwinner,sun4i-a10-timer"; compatible = "allwinner,sun4i-a10-timer";
reg = <0x06000c00 0xa0>; reg = <0x06000c00 0xa0>;
interrupts = <0 18 4>, interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>,
<0 19 4>, <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>,
<0 20 4>, <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>,
<0 21 4>, <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>,
<0 22 4>, <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>,
<0 23 4>; <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&osc24M>; clocks = <&osc24M>;
}; };
...@@ -340,11 +451,11 @@ timer@06000c00 { ...@@ -340,11 +451,11 @@ timer@06000c00 {
pio: pinctrl@06000800 { pio: pinctrl@06000800 {
compatible = "allwinner,sun9i-a80-pinctrl"; compatible = "allwinner,sun9i-a80-pinctrl";
reg = <0x06000800 0x400>; reg = <0x06000800 0x400>;
interrupts = <0 11 4>, interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>,
<0 15 4>, <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>,
<0 16 4>, <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>,
<0 17 4>, <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>,
<0 120 4>; <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb0_gates 5>; clocks = <&apb0_gates 5>;
gpio-controller; gpio-controller;
interrupt-controller; interrupt-controller;
...@@ -355,29 +466,46 @@ pio: pinctrl@06000800 { ...@@ -355,29 +466,46 @@ pio: pinctrl@06000800 {
i2c3_pins_a: i2c3@0 { i2c3_pins_a: i2c3@0 {
allwinner,pins = "PG10", "PG11"; allwinner,pins = "PG10", "PG11";
allwinner,function = "i2c3"; allwinner,function = "i2c3";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
mmc0_pins: mmc0 {
allwinner,pins = "PF0", "PF1" ,"PF2", "PF3",
"PF4", "PF5";
allwinner,function = "mmc0";
allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
mmc2_8bit_pins: mmc2_8bit {
allwinner,pins = "PC6", "PC7", "PC8", "PC9",
"PC10", "PC11", "PC12",
"PC13", "PC14", "PC15";
allwinner,function = "mmc2";
allwinner,drive = <SUN4I_PINCTRL_30_MA>;
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart0_pins_a: uart0@0 { uart0_pins_a: uart0@0 {
allwinner,pins = "PH12", "PH13"; allwinner,pins = "PH12", "PH13";
allwinner,function = "uart0"; allwinner,function = "uart0";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
uart4_pins_a: uart4@0 { uart4_pins_a: uart4@0 {
allwinner,pins = "PG12", "PG13", "PG14", "PG15"; allwinner,pins = "PG12", "PG13", "PG14", "PG15";
allwinner,function = "uart4"; allwinner,function = "uart4";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
}; };
uart0: serial@07000000 { uart0: serial@07000000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07000000 0x400>; reg = <0x07000000 0x400>;
interrupts = <0 0 4>; interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 16>; clocks = <&apb1_gates 16>;
...@@ -388,7 +516,7 @@ uart0: serial@07000000 { ...@@ -388,7 +516,7 @@ uart0: serial@07000000 {
uart1: serial@07000400 { uart1: serial@07000400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07000400 0x400>; reg = <0x07000400 0x400>;
interrupts = <0 1 4>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 17>; clocks = <&apb1_gates 17>;
...@@ -399,7 +527,7 @@ uart1: serial@07000400 { ...@@ -399,7 +527,7 @@ uart1: serial@07000400 {
uart2: serial@07000800 { uart2: serial@07000800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07000800 0x400>; reg = <0x07000800 0x400>;
interrupts = <0 2 4>; interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 18>; clocks = <&apb1_gates 18>;
...@@ -410,7 +538,7 @@ uart2: serial@07000800 { ...@@ -410,7 +538,7 @@ uart2: serial@07000800 {
uart3: serial@07000c00 { uart3: serial@07000c00 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07000c00 0x400>; reg = <0x07000c00 0x400>;
interrupts = <0 3 4>; interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 19>; clocks = <&apb1_gates 19>;
...@@ -421,7 +549,7 @@ uart3: serial@07000c00 { ...@@ -421,7 +549,7 @@ uart3: serial@07000c00 {
uart4: serial@07001000 { uart4: serial@07001000 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07001000 0x400>; reg = <0x07001000 0x400>;
interrupts = <0 4 4>; interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 20>; clocks = <&apb1_gates 20>;
...@@ -432,7 +560,7 @@ uart4: serial@07001000 { ...@@ -432,7 +560,7 @@ uart4: serial@07001000 {
uart5: serial@07001400 { uart5: serial@07001400 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x07001400 0x400>; reg = <0x07001400 0x400>;
interrupts = <0 5 4>; interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&apb1_gates 21>; clocks = <&apb1_gates 21>;
...@@ -443,7 +571,7 @@ uart5: serial@07001400 { ...@@ -443,7 +571,7 @@ uart5: serial@07001400 {
i2c0: i2c@07002800 { i2c0: i2c@07002800 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x07002800 0x400>; reg = <0x07002800 0x400>;
interrupts = <0 6 4>; interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 0>; clocks = <&apb1_gates 0>;
resets = <&apb1_resets 0>; resets = <&apb1_resets 0>;
status = "disabled"; status = "disabled";
...@@ -454,7 +582,7 @@ i2c0: i2c@07002800 { ...@@ -454,7 +582,7 @@ i2c0: i2c@07002800 {
i2c1: i2c@07002c00 { i2c1: i2c@07002c00 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x07002c00 0x400>; reg = <0x07002c00 0x400>;
interrupts = <0 7 4>; interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 1>; clocks = <&apb1_gates 1>;
resets = <&apb1_resets 1>; resets = <&apb1_resets 1>;
status = "disabled"; status = "disabled";
...@@ -465,7 +593,7 @@ i2c1: i2c@07002c00 { ...@@ -465,7 +593,7 @@ i2c1: i2c@07002c00 {
i2c2: i2c@07003000 { i2c2: i2c@07003000 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x07003000 0x400>; reg = <0x07003000 0x400>;
interrupts = <0 8 4>; interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 2>; clocks = <&apb1_gates 2>;
resets = <&apb1_resets 2>; resets = <&apb1_resets 2>;
status = "disabled"; status = "disabled";
...@@ -476,7 +604,7 @@ i2c2: i2c@07003000 { ...@@ -476,7 +604,7 @@ i2c2: i2c@07003000 {
i2c3: i2c@07003400 { i2c3: i2c@07003400 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x07003400 0x400>; reg = <0x07003400 0x400>;
interrupts = <0 9 4>; interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 3>; clocks = <&apb1_gates 3>;
resets = <&apb1_resets 3>; resets = <&apb1_resets 3>;
status = "disabled"; status = "disabled";
...@@ -487,7 +615,7 @@ i2c3: i2c@07003400 { ...@@ -487,7 +615,7 @@ i2c3: i2c@07003400 {
i2c4: i2c@07003800 { i2c4: i2c@07003800 {
compatible = "allwinner,sun6i-a31-i2c"; compatible = "allwinner,sun6i-a31-i2c";
reg = <0x07003800 0x400>; reg = <0x07003800 0x400>;
interrupts = <0 10 4>; interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&apb1_gates 4>; clocks = <&apb1_gates 4>;
resets = <&apb1_resets 4>; resets = <&apb1_resets 4>;
status = "disabled"; status = "disabled";
...@@ -498,13 +626,13 @@ i2c4: i2c@07003800 { ...@@ -498,13 +626,13 @@ i2c4: i2c@07003800 {
r_wdt: watchdog@08001000 { r_wdt: watchdog@08001000 {
compatible = "allwinner,sun6i-a31-wdt"; compatible = "allwinner,sun6i-a31-wdt";
reg = <0x08001000 0x20>; reg = <0x08001000 0x20>;
interrupts = <0 36 4>; interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
}; };
r_uart: serial@08002800 { r_uart: serial@08002800 {
compatible = "snps,dw-apb-uart"; compatible = "snps,dw-apb-uart";
reg = <0x08002800 0x400>; reg = <0x08002800 0x400>;
interrupts = <0 38 4>; interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
reg-shift = <2>; reg-shift = <2>;
reg-io-width = <4>; reg-io-width = <4>;
clocks = <&osc24M>; clocks = <&osc24M>;
......
...@@ -47,39 +47,40 @@ ...@@ -47,39 +47,40 @@
* OTHER DEALINGS IN THE SOFTWARE. * OTHER DEALINGS IN THE SOFTWARE.
*/ */
/ { #include <dt-bindings/gpio/gpio.h>
soc@01c00000 { #include <dt-bindings/pinctrl/sun4i-a10.h>
pio: pinctrl@01c20800 {
&pio {
ahci_pwr_pin_a: ahci_pwr_pin@0 { ahci_pwr_pin_a: ahci_pwr_pin@0 {
allwinner,pins = "PB8"; allwinner,pins = "PB8";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb0_vbus_pin_a: usb0_vbus_pin@0 { usb0_vbus_pin_a: usb0_vbus_pin@0 {
allwinner,pins = "PB9"; allwinner,pins = "PB9";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb1_vbus_pin_a: usb1_vbus_pin@0 { usb1_vbus_pin_a: usb1_vbus_pin@0 {
allwinner,pins = "PH6"; allwinner,pins = "PH6";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
}; };
usb2_vbus_pin_a: usb2_vbus_pin@0 { usb2_vbus_pin_a: usb2_vbus_pin@0 {
allwinner,pins = "PH3"; allwinner,pins = "PH3";
allwinner,function = "gpio_out"; allwinner,function = "gpio_out";
allwinner,drive = <0>; allwinner,drive = <SUN4I_PINCTRL_10_MA>;
allwinner,pull = <0>; allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
};
};
}; };
};
/ {
reg_ahci_5v: ahci-5v { reg_ahci_5v: ahci-5v {
compatible = "regulator-fixed"; compatible = "regulator-fixed";
pinctrl-names = "default"; pinctrl-names = "default";
...@@ -89,7 +90,7 @@ reg_ahci_5v: ahci-5v { ...@@ -89,7 +90,7 @@ reg_ahci_5v: ahci-5v {
regulator-max-microvolt = <5000000>; regulator-max-microvolt = <5000000>;
regulator-boot-on; regulator-boot-on;
enable-active-high; enable-active-high;
gpio = <&pio 1 8 0>; gpio = <&pio 1 8 GPIO_ACTIVE_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -101,7 +102,7 @@ reg_usb0_vbus: usb0-vbus { ...@@ -101,7 +102,7 @@ reg_usb0_vbus: usb0-vbus {
regulator-min-microvolt = <5000000>; regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>; regulator-max-microvolt = <5000000>;
enable-active-high; enable-active-high;
gpio = <&pio 1 9 0>; gpio = <&pio 1 9 GPIO_ACTIVE_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -113,7 +114,7 @@ reg_usb1_vbus: usb1-vbus { ...@@ -113,7 +114,7 @@ reg_usb1_vbus: usb1-vbus {
regulator-min-microvolt = <5000000>; regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>; regulator-max-microvolt = <5000000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 6 0>; gpio = <&pio 7 6 GPIO_ACTIVE_HIGH>;
status = "disabled"; status = "disabled";
}; };
...@@ -125,7 +126,7 @@ reg_usb2_vbus: usb2-vbus { ...@@ -125,7 +126,7 @@ reg_usb2_vbus: usb2-vbus {
regulator-min-microvolt = <5000000>; regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>; regulator-max-microvolt = <5000000>;
enable-active-high; enable-active-high;
gpio = <&pio 7 3 0>; gpio = <&pio 7 3 GPIO_ACTIVE_HIGH>;
status = "disabled"; status = "disabled";
}; };
......
/*
* Copyright 2014 Maxime Ripard
*
* Maxime Ripard <maxime.ripard@free-electrons.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef __DT_BINDINGS_DMA_SUN4I_A10_H_
#define __DT_BINDINGS_DMA_SUN4I_A10_H_
#define SUN4I_DMA_NORMAL 0
#define SUN4I_DMA_DEDICATED 1
#endif /* __DT_BINDINGS_DMA_SUN4I_A10_H_ */
/*
* Copyright 2014 Maxime Ripard
*
* Maxime Ripard <maxime.ripard@free-electrons.com>
*
* This file is dual-licensed: you can use it either under the terms
* of the GPL or the X11 license, at your option. Note that this dual
* licensing only applies to this file, and not this project as a
* whole.
*
* a) This file is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This file is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this file; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02110-1301 USA
*
* Or, alternatively,
*
* b) Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef __DT_BINDINGS_PINCTRL_SUN4I_A10_H_
#define __DT_BINDINGS_PINCTRL_SUN4I_A10_H_
#define SUN4I_PINCTRL_10_MA 0
#define SUN4I_PINCTRL_20_MA 1
#define SUN4I_PINCTRL_30_MA 2
#define SUN4I_PINCTRL_40_MA 3
#define SUN4I_PINCTRL_NO_PULL 0
#define SUN4I_PINCTRL_PULL_UP 1
#define SUN4I_PINCTRL_PULL_DOWN 2
#endif /* __DT_BINDINGS_PINCTRL_SUN4I_A10_H_ */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment