123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302 |
- --- a/arch/arm/boot/dts/Makefile
- +++ b/arch/arm/boot/dts/Makefile
- @@ -662,6 +662,7 @@ dtb-$(CONFIG_MACH_SUN8I) += \
- sun8i-a33-ippo-q8h-v1.2.dtb \
- sun8i-a33-q8-tablet.dtb \
- sun8i-a33-sinlinx-sina33.dtb \
- + sun8i-h3-orangepi-2.dtb \
- sun8i-h3-orangepi-plus.dtb
- dtb-$(CONFIG_MACH_SUN9I) += \
- sun9i-a80-optimus.dtb \
- --- /dev/null
- +++ b/arch/arm/boot/dts/sun8i-h3-orangepi-2.dts
- @@ -0,0 +1,186 @@
- +/*
- + * Copyright (C) 2016 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.
- + *
- + * 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 "sun8i-h3.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 = "Xunlong Orange Pi 2";
- + compatible = "xunlong,orangepi-2", "allwinner,sun8i-h3";
- +
- + aliases {
- + serial0 = &uart0;
- + };
- +
- + chosen {
- + stdout-path = "serial0:115200n8";
- + };
- +
- + leds {
- + compatible = "gpio-leds";
- + pinctrl-names = "default";
- + pinctrl-0 = <&leds_opc>, <&leds_r_opc>;
- +
- + status_led {
- + label = "orangepi:red:status";
- + gpios = <&pio 0 15 GPIO_ACTIVE_HIGH>;
- + };
- +
- + pwr_led {
- + label = "orangepi:green:pwr";
- + gpios = <&r_pio 0 10 GPIO_ACTIVE_HIGH>;
- + default-state = "on";
- + };
- + };
- +
- + r_gpio_keys {
- + compatible = "gpio-keys";
- + pinctrl-names = "default";
- + pinctrl-0 = <&sw_r_opc>;
- +
- + sw2 {
- + label = "sw2";
- + linux,code = <BTN_1>;
- + gpios = <&r_pio 0 4 GPIO_ACTIVE_LOW>;
- + };
- +
- + sw4 {
- + label = "sw4";
- + linux,code = <BTN_0>;
- + gpios = <&r_pio 0 3 GPIO_ACTIVE_LOW>;
- + };
- + };
- +
- + wifi_pwrseq: wifi_pwrseq {
- + compatible = "mmc-pwrseq-simple";
- + pinctrl-names = "default";
- + pinctrl-0 = <&wifi_pwrseq_pin_orangepi>;
- + reset-gpios = <&r_pio 0 7 GPIO_ACTIVE_LOW>; /* PL7 WIFI_EN */
- + };
- +};
- +
- +&ehci1 {
- + status = "okay";
- +};
- +
- +&ir {
- + pinctrl-names = "default";
- + pinctrl-0 = <&ir_pins_a>;
- + status = "okay";
- +};
- +
- +&mmc0 {
- + pinctrl-names = "default";
- + pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin>;
- + vmmc-supply = <®_vcc3v3>;
- + bus-width = <4>;
- + cd-gpios = <&pio 5 6 GPIO_ACTIVE_HIGH>; /* PF6 */
- + cd-inverted;
- + status = "okay";
- +};
- +
- +&mmc1 {
- + pinctrl-names = "default";
- + pinctrl-0 = <&mmc1_pins_a>;
- + vmmc-supply = <®_vcc3v3>;
- + mmc-pwrseq = <&wifi_pwrseq>;
- + bus-width = <4>;
- + non-removable;
- + status = "okay";
- +};
- +
- +&pio {
- + leds_opc: led_pins@0 {
- + allwinner,pins = "PA15";
- + allwinner,function = "gpio_out";
- + allwinner,drive = <SUN4I_PINCTRL_10_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- +};
- +
- +&r_pio {
- + leds_r_opc: led_pins@0 {
- + allwinner,pins = "PL10";
- + allwinner,function = "gpio_out";
- + allwinner,drive = <SUN4I_PINCTRL_10_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- +
- + sw_r_opc: key_pins@0 {
- + allwinner,pins = "PL3", "PL4";
- + allwinner,function = "gpio_in";
- + allwinner,drive = <SUN4I_PINCTRL_10_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- +
- + wifi_pwrseq_pin_orangepi: wifi_pwrseq_pin@0 {
- + allwinner,pins = "PL7";
- + allwinner,function = "gpio_out";
- + allwinner,drive = <SUN4I_PINCTRL_10_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- +};
- +
- +®_usb1_vbus {
- + gpio = <&pio 6 13 GPIO_ACTIVE_HIGH>;
- + status = "okay";
- +};
- +
- +&uart0 {
- + pinctrl-names = "default";
- + pinctrl-0 = <&uart0_pins_a>;
- + status = "okay";
- +};
- +
- +&usb1_vbus_pin_a {
- + allwinner,pins = "PG13";
- +};
- +
- +&usbphy {
- + usb1_vbus-supply = <®_usb1_vbus>;
- + status = "okay";
- +};
- --- a/arch/arm/boot/dts/sun8i-h3.dtsi
- +++ b/arch/arm/boot/dts/sun8i-h3.dtsi
- @@ -288,6 +288,33 @@
- clocks = <&osc24M>, <&pll6 1>, <&pll5>;
- clock-output-names = "mbus";
- };
- +
- + apb0: apb0_clk {
- + compatible = "fixed-factor-clock";
- + #clock-cells = <0>;
- + clock-div = <1>;
- + clock-mult = <1>;
- + clocks = <&osc24M>;
- + clock-output-names = "apb0";
- + };
- +
- + apb0_gates: clk@01f01428 {
- + compatible = "allwinner,sun8i-h3-apb0-gates-clk",
- + "allwinner,sun4i-a10-gates-clk";
- + reg = <0x01f01428 0x4>;
- + #clock-cells = <1>;
- + clocks = <&apb0>;
- + clock-indices = <0>, <1>;
- + clock-output-names = "apb0_pio", "apb0_ir";
- + };
- +
- + ir_clk: ir_clk@01f01454 {
- + compatible = "allwinner,sun4i-a10-mod0-clk";
- + reg = <0x01f01454 0x4>;
- + #clock-cells = <0>;
- + clocks = <&osc32k>, <&osc24M>;
- + clock-output-names = "ir";
- + };
- };
-
- soc {
- @@ -472,7 +499,7 @@
- gpio-controller;
- #gpio-cells = <3>;
- interrupt-controller;
- - #interrupt-cells = <2>;
- + #interrupt-cells = <3>;
-
- uart0_pins_a: uart0@0 {
- allwinner,pins = "PA4", "PA5";
- @@ -503,6 +530,16 @@
- allwinner,drive = <SUN4I_PINCTRL_30_MA>;
- allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- };
- +
- + mmc2_8bit_pins: mmc2_8bit {
- + allwinner,pins = "PC5", "PC6", "PC8",
- + "PC9", "PC10", "PC11",
- + "PC12", "PC13", "PC14",
- + "PC15", "PC16";
- + allwinner,function = "mmc2";
- + allwinner,drive = <SUN4I_PINCTRL_30_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- };
-
- ahb_rst: reset@01c202c0 {
- @@ -606,5 +643,40 @@
- interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
- <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
- };
- +
- + apb0_reset: reset@01f014b0 {
- + reg = <0x01f014b0 0x4>;
- + compatible = "allwinner,sun6i-a31-clock-reset";
- + #reset-cells = <1>;
- + };
- +
- + ir: ir@01f02000 {
- + compatible = "allwinner,sun5i-a13-ir";
- + clocks = <&apb0_gates 1>, <&ir_clk>;
- + clock-names = "apb", "ir";
- + resets = <&apb0_reset 1>;
- + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
- + reg = <0x01f02000 0x40>;
- + status = "disabled";
- + };
- +
- + r_pio: pinctrl@01f02c00 {
- + compatible = "allwinner,sun8i-h3-r-pinctrl";
- + reg = <0x01f02c00 0x400>;
- + interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
- + clocks = <&apb0_gates 0>;
- + resets = <&apb0_reset 0>;
- + gpio-controller;
- + #gpio-cells = <3>;
- + interrupt-controller;
- + #interrupt-cells = <3>;
- +
- + ir_pins_a: ir@0 {
- + allwinner,pins = "PL11";
- + allwinner,function = "s_cir_rx";
- + allwinner,drive = <SUN4I_PINCTRL_10_MA>;
- + allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
- + };
- + };
- };
- };
|