diff options
| author | Albert ARIBAUD <albert.u.boot@aribaud.net> | 2015-07-07 11:38:44 +0200 | 
|---|---|---|
| committer | Albert ARIBAUD <albert.u.boot@aribaud.net> | 2015-07-07 11:38:44 +0200 | 
| commit | 6f43ba70d15e15a08c25b3d956c70addb6740737 (patch) | |
| tree | e5ddc8498043c0c47559737ea60e4d7fc866e20a /arch/arm/dts | |
| parent | 003b09dad492ebc385b28067b8028a0c0ff9323f (diff) | |
| parent | 9c6b05cb724e18d1db3f9e1a75b2272572f06fbd (diff) | |
Merge branch 'u-boot/master' into 'u-boot-arm/master'
Diffstat (limited to 'arch/arm/dts')
74 files changed, 1950 insertions, 1182 deletions
| diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile index 267fd179060..9c735c672ab 100644 --- a/arch/arm/dts/Makefile +++ b/arch/arm/dts/Makefile @@ -95,6 +95,7 @@ dtb-$(CONFIG_MACH_SUN6I) += \  	sun6i-a31-hummingbird.dtb \  	sun6i-a31-i7.dtb \  	sun6i-a31-m9.dtb \ +	sun6i-a31-mele-a1000g-quad.dtb \  	sun6i-a31-mixtile-loftq.dtb \  	sun6i-a31s-cs908.dtb \  	sun6i-a31s-primo81.dtb @@ -121,18 +122,24 @@ dtb-$(CONFIG_MACH_SUN7I) += \  	sun7i-a20-wits-pro-a20-dkt.dtb \  	sun7i-a20-yones-toptech-bd1078.dtb  dtb-$(CONFIG_MACH_SUN8I_A23) += \ +	sun8i-a23-evb.dtb \  	sun8i-a23-ippo-q8h-v5.dtb \  	sun8i-a23-ippo-q8h-v1.2.dtb  dtb-$(CONFIG_MACH_SUN8I_A33) += \ -	sun8i-a33-astar-mid756.dtb \ +	sun8i-a33-et-q8-v1.6.dtb \ +	sun8i-a33-ga10h-v1.1.dtb \  	sun8i-a33-ippo-q8h-v1.2-lcd1024x600.dtb  dtb-$(CONFIG_MACH_SUN9I) += \  	sun9i-a80-optimus.dtb \  	sun9i-a80-cubieboard4.dtb +dtb-$(CONFIG_VF610) += vf500-colibri.dtb \ +	vf610-colibri.dtb +  targets += $(dtb-y) -DTC_FLAGS += -R 4 -p 0x1000 +# Add any required device tree compiler flags here +DTC_FLAGS +=  PHONY += dtbs  dtbs: $(addprefix $(obj)/, $(dtb-y)) diff --git a/arch/arm/dts/exynos4412-odroid.dts b/arch/arm/dts/exynos4412-odroid.dts index 415dfeab6a4..d572f1e72bb 100644 --- a/arch/arm/dts/exynos4412-odroid.dts +++ b/arch/arm/dts/exynos4412-odroid.dts @@ -43,140 +43,102 @@  			voltage-regulators {  				ldo1_reg: ldo1 { -					regulator-compatible = "LDO1";  					regulator-name = "VDD_ALIVE_1.0V";  					regulator-min-microvolt = <1000000>;  					regulator-max-microvolt = <1000000>;  				};  				ldo2_reg: ldo2 { -					regulator-compatible = "LDO2";  					regulator-name = "VDDQ_VM1M2_1.2V";  					regulator-min-microvolt = <1200000>;  					regulator-max-microvolt = <1200000>;  				};  				ldo3_reg: ldo3 { -					regulator-compatible = "LDO3";  					regulator-name = "VCC_1.8V_AP";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo4_reg: ldo4 { -					regulator-compatible = "LDO4";  					regulator-name = "VDDQ_MMC2_2.8V";  					regulator-min-microvolt = <2800000>;  					regulator-max-microvolt = <2800000>;  				};  				ldo5_reg: ldo5 { -					regulator-compatible = "LDO5";  					regulator-name = "VDDQ_MMC0/1/3_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo6_reg: ldo6 { -					regulator-compatible = "LDO6";  					regulator-name = "VMPLL_1.0V";  					regulator-min-microvolt = <1100000>;  					regulator-max-microvolt = <1100000>;  				};  				ldo7_reg: ldo7 { -					regulator-compatible = "LDO7";  					regulator-name = "VPLL_1.1V";  					regulator-min-microvolt = <1100000>;  					regulator-max-microvolt = <1100000>;  				};  				ldo8_reg: ldo8 { -					regulator-compatible = "LDO8";  					regulator-name = "VDD_MIPI/HDMI_1.0V";  					regulator-min-microvolt = <1000000>;  					regulator-max-microvolt = <1000000>;  				}; -				ldo9_reg: ldo9 { -					regulator-compatible = "LDO9"; -					regulator-name = "nc"; -					regulator-min-microvolt = <1800000>; -					regulator-max-microvolt = <1800000>; -				}; -  				ldo10_reg: ldo10 { -					regulator-compatible = "LDO10";  					regulator-name = "VDD_MIPI/HDMI_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo11_reg: ldo11 { -					regulator-compatible = "LDO11";  					regulator-name = "VDD_ABB1_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo12_reg: ldo12 { -					regulator-compatible = "LDO12";  					regulator-name = "VDD_UOTG_3.0V";  					regulator-min-microvolt = <3000000>;  					regulator-max-microvolt = <3000000>;  				};  				ldo13_reg: ldo13 { -					regulator-compatible = "LDO13";  					regulator-name = "VDD_C2C_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo14_reg: ldo14 { -					regulator-compatible = "LDO14";  					regulator-name = "VDD_ABB02_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo15_reg: ldo15 { -					regulator-compatible = "LDO15";  					regulator-name = "VDD_HSIC/OTG_1.0V";  					regulator-min-microvolt = <1000000>;  					regulator-max-microvolt = <1000000>;  				};  				ldo16_reg: ldo16 { -					regulator-compatible = "LDO16";  					regulator-name = "VDD_HSIC_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>;  				};  				ldo17_reg: ldo17 { -					regulator-compatible = "LDO17";  					regulator-name = "VDDQ_CAM_1.2V";  					regulator-min-microvolt = <1200000>;  					regulator-max-microvolt = <1200000>;  				}; -				ldo18_reg: ldo18 { -					regulator-compatible = "LDO18"; -					regulator-name = "nc"; -					regulator-min-microvolt = <1800000>; -					regulator-max-microvolt = <1800000>; -				}; - -				ldo19_reg: ldo19 { -					regulator-compatible = "LDO19"; -					regulator-name = "nc"; -					regulator-min-microvolt = <1800000>; -					regulator-max-microvolt = <1800000>; -				}; -  				ldo20_reg: ldo20 { -					regulator-compatible = "LDO20";  					regulator-name = "VDDQ_EMMC_1.8V";  					regulator-min-microvolt = <1800000>;  					regulator-max-microvolt = <1800000>; @@ -185,7 +147,6 @@  				};  				ldo21_reg: ldo21 { -					regulator-compatible = "LDO21";  					regulator-name = "TFLASH_2.8V";  					regulator-min-microvolt = <2800000>;  					regulator-max-microvolt = <2800000>; @@ -194,7 +155,6 @@  				};  				ldo22_reg: ldo22 { -					regulator-compatible = "LDO22";  					regulator-name = "VDDQ_EMMC_2.8V";  					regulator-min-microvolt = <2800000>;  					regulator-max-microvolt = <2800000>; @@ -202,20 +162,6 @@  					regulator-boot-on;  				}; -				ldo23_reg: ldo23 { -					regulator-compatible = "LDO23"; -					regulator-name = "nc"; -					regulator-min-microvolt = <3300000>; -					regulator-max-microvolt = <3300000>; -				}; - -				ldo24_reg: ldo24 { -					regulator-compatible = "LDO24"; -					regulator-name = "nc"; -					regulator-min-microvolt = <3000000>; -					regulator-max-microvolt = <3000000>; -				}; -  				ldo25_reg: ldo25 {  					regulator-compatible = "LDO25";  					regulator-name = "VDDQ_LCD_3.0V"; @@ -223,75 +169,53 @@  					regulator-max-microvolt = <3000000>;  				}; -				ldo26_reg: ldo26 { -					regulator-compatible = "LDO26"; -					regulator-name = "nc"; -					regulator-min-microvolt = <3000000>; -					regulator-max-microvolt = <3000000>; -				}; - -				buck1_reg: buck@1 { -					regulator-compatible = "BUCK1"; +				buck1_reg: buck1 {  					regulator-name = "VDD_MIF_1.0V";  					regulator-min-microvolt = <8500000>;  					regulator-max-microvolt = <1100000>;  				}; -				buck2_reg: buck@2 { -					regulator-compatible = "BUCK2"; +				buck2_reg: buck2 {  					regulator-name = "VDD_ARM_1.0V";  					regulator-min-microvolt = <850000>;  					regulator-max-microvolt = <1500000>;  				};  				buck3_reg: buck3 { -					regulator-compatible = "BUCK3";  					regulator-name = "VDD_INT_1.1V";  					regulator-min-microvolt = <850000>;  					regulator-max-microvolt = <1150000>;  				};  				buck4_reg: buck4 { -					regulator-compatible = "BUCK4";  					regulator-name = "VDD_G3D_1.0V";  					regulator-min-microvolt = <850000>;  					regulator-max-microvolt = <1150000>;  				};  				buck5_reg: buck5 { -					regulator-compatible = "BUCK5";  					regulator-name = "VDDQ_AP_1.2V";  					regulator-min-microvolt = <1200000>;  					regulator-max-microvolt = <1200000>;  				};  				buck6_reg: buck6 { -					regulator-compatible = "BUCK6";  					regulator-name = "VCC_INL1/7_1.35V";  					regulator-min-microvolt = <1350000>;  					regulator-max-microvolt = <1350000>;  				};  				buck7_reg: buck7 { -					regulator-compatible = "BUCK7";  					regulator-name = "VCC_INL2/3/5_2.0V";  					regulator-min-microvolt = <2000000>;  					regulator-max-microvolt = <2000000>;  				};  				buck8_reg: buck8 { -					regulator-compatible = "BUCK8";  					regulator-name = "VCC_P3V3_2.85V";  					regulator-min-microvolt = <2850000>;  					regulator-max-microvolt = <3300000>;  				}; - -				buck9_reg: buck9 { -					regulator-compatible = "BUCK9"; -					regulator-name = "nc"; -					regulator-min-microvolt = <1200000>; -					regulator-max-microvolt = <1200000>; -				};  			};  		};  	}; diff --git a/arch/arm/dts/ls1021a-qds.dts b/arch/arm/dts/ls1021a-qds.dts index 836781153d8..e6342923592 100644 --- a/arch/arm/dts/ls1021a-qds.dts +++ b/arch/arm/dts/ls1021a-qds.dts @@ -30,7 +30,7 @@  	dspiflash: at45db021d@0 {  		#address-cells = <1>;  		#size-cells = <1>; -		compatible = "spi-flash"; +		compatible = "atmel,dataflash";  		spi-max-frequency = <16000000>;  		spi-cpol;  		spi-cpha; diff --git a/arch/arm/dts/sun4i-a10-a1000.dts b/arch/arm/dts/sun4i-a10-a1000.dts index f03281434e5..2630d78d9e0 100644 --- a/arch/arm/dts/sun4i-a10-a1000.dts +++ b/arch/arm/dts/sun4i-a10-a1000.dts @@ -18,11 +18,6 @@   *     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 @@ -113,6 +108,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; @@ -130,7 +129,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-ba10-tvbox.dts b/arch/arm/dts/sun4i-a10-ba10-tvbox.dts index 1a3c7ddc538..93d435670ef 100644 --- a/arch/arm/dts/sun4i-a10-ba10-tvbox.dts +++ b/arch/arm/dts/sun4i-a10-ba10-tvbox.dts @@ -16,11 +16,6 @@   *     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 @@ -79,6 +74,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; @@ -96,7 +95,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-chuwi-v7-cw0825.dts b/arch/arm/dts/sun4i-a10-chuwi-v7-cw0825.dts index 35fb163827d..5878a0b11f7 100644 --- a/arch/arm/dts/sun4i-a10-chuwi-v7-cw0825.dts +++ b/arch/arm/dts/sun4i-a10-chuwi-v7-cw0825.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-cubieboard.dts b/arch/arm/dts/sun4i-a10-cubieboard.dts index 0ba67d79c2b..9afb4e01859 100644 --- a/arch/arm/dts/sun4i-a10-cubieboard.dts +++ b/arch/arm/dts/sun4i-a10-cubieboard.dts @@ -17,11 +17,6 @@   *     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 @@ -107,6 +102,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; @@ -126,7 +125,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; @@ -206,7 +205,8 @@  &spi0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi0_pins_a>; +	pinctrl-0 = <&spi0_pins_a>, +		    <&spi0_cs0_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-gemei-g9.dts b/arch/arm/dts/sun4i-a10-gemei-g9.dts index fbd638a3801..570754d8df6 100644 --- a/arch/arm/dts/sun4i-a10-gemei-g9.dts +++ b/arch/arm/dts/sun4i-a10-gemei-g9.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-hackberry.dts b/arch/arm/dts/sun4i-a10-hackberry.dts index f4437883fba..2b17c519915 100644 --- a/arch/arm/dts/sun4i-a10-hackberry.dts +++ b/arch/arm/dts/sun4i-a10-hackberry.dts @@ -18,11 +18,6 @@   *     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 @@ -91,9 +86,13 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-hyundai-a7hd.dts b/arch/arm/dts/sun4i-a10-hyundai-a7hd.dts index 9f06b180505..43f58fbe161 100644 --- a/arch/arm/dts/sun4i-a10-hyundai-a7hd.dts +++ b/arch/arm/dts/sun4i-a10-hyundai-a7hd.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-inet97fv2.dts b/arch/arm/dts/sun4i-a10-inet97fv2.dts index e19ef52f357..6c927a824ba 100644 --- a/arch/arm/dts/sun4i-a10-inet97fv2.dts +++ b/arch/arm/dts/sun4i-a10-inet97fv2.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-jesurun-q5.dts b/arch/arm/dts/sun4i-a10-jesurun-q5.dts index 1b0452fea27..dc2f2aeaff0 100644 --- a/arch/arm/dts/sun4i-a10-jesurun-q5.dts +++ b/arch/arm/dts/sun4i-a10-jesurun-q5.dts @@ -18,11 +18,6 @@   *     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 @@ -109,6 +104,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; @@ -126,7 +125,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-marsboard.dts b/arch/arm/dts/sun4i-a10-marsboard.dts index 00c54d2a182..02158bcd64e 100644 --- a/arch/arm/dts/sun4i-a10-marsboard.dts +++ b/arch/arm/dts/sun4i-a10-marsboard.dts @@ -17,11 +17,6 @@   *     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 @@ -104,6 +99,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &emac {  	pinctrl-names = "default";  	pinctrl-0 = <&emac_pins_a>; @@ -174,7 +173,8 @@  &spi0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi0_pins_a>; +	pinctrl-0 = <&spi0_pins_a>, +		    <&spi0_cs0_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun4i-a10-mini-xplus.dts b/arch/arm/dts/sun4i-a10-mini-xplus.dts index 0f24914c1a6..ebe2a04ef64 100644 --- a/arch/arm/dts/sun4i-a10-mini-xplus.dts +++ b/arch/arm/dts/sun4i-a10-mini-xplus.dts @@ -18,11 +18,6 @@   *     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 @@ -92,11 +87,11 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; -&ir0_pins_a { +&ir0_rx_pins_a {  	/* The ir receiver is not always populated */  	allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;  }; diff --git a/arch/arm/dts/sun4i-a10-mk802.dts b/arch/arm/dts/sun4i-a10-mk802.dts index 0f1c99133c9..3c7eebe1708 100644 --- a/arch/arm/dts/sun4i-a10-mk802.dts +++ b/arch/arm/dts/sun4i-a10-mk802.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-mk802ii.dts b/arch/arm/dts/sun4i-a10-mk802ii.dts index f97aa6f523f..c861fa7e356 100644 --- a/arch/arm/dts/sun4i-a10-mk802ii.dts +++ b/arch/arm/dts/sun4i-a10-mk802ii.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun4i-a10-olinuxino-lime.dts b/arch/arm/dts/sun4i-a10-olinuxino-lime.dts index 5840d5e16b9..b64aa4eb071 100644 --- a/arch/arm/dts/sun4i-a10-olinuxino-lime.dts +++ b/arch/arm/dts/sun4i-a10-olinuxino-lime.dts @@ -16,11 +16,6 @@   *     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 @@ -110,6 +105,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; diff --git a/arch/arm/dts/sun4i-a10-pcduino.dts b/arch/arm/dts/sun4i-a10-pcduino.dts index be6948e4164..4e3e1b9d821 100644 --- a/arch/arm/dts/sun4i-a10-pcduino.dts +++ b/arch/arm/dts/sun4i-a10-pcduino.dts @@ -17,11 +17,6 @@   *     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 @@ -124,6 +119,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; diff --git a/arch/arm/dts/sun4i-a10.dtsi b/arch/arm/dts/sun4i-a10.dtsi index 1d7fd68bea1..61c03d1fe53 100644 --- a/arch/arm/dts/sun4i-a10.dtsi +++ b/arch/arm/dts/sun4i-a10.dtsi @@ -17,11 +17,6 @@   *     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 @@ -66,7 +61,8 @@  		ranges;  		framebuffer@0 { -			compatible = "allwinner,simple-framebuffer", "simple-framebuffer"; +			compatible = "allwinner,simple-framebuffer", +				     "simple-framebuffer";  			allwinner,pipeline = "de_be0-lcd0-hdmi";  			clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 43>,  				 <&ahb_gates 44>; @@ -74,7 +70,8 @@  		};  		framebuffer@1 { -			compatible = "allwinner,simple-framebuffer", "simple-framebuffer"; +			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>; @@ -110,11 +107,11 @@  			clocks = <&cpu>;  			clock-latency = <244144>; /* 8 32k periods */  			operating-points = < -				/* kHz    uV */ +				/* kHz	  uV */  				1008000 1400000 -				912000  1350000 -				864000  1300000 -				624000  1250000 +				912000	1350000 +				864000	1300000 +				624000	1250000  				>;  			#cooling-cells = <2>;  			cooling-min-level = <0>; @@ -434,11 +431,12 @@  		usb_clk: clk@01c200cc {  			#clock-cells = <1>; -		        #reset-cells = <1>; +			#reset-cells = <1>;  			compatible = "allwinner,sun4i-a10-usb-clk";  			reg = <0x01c200cc 0x4>;  			clocks = <&pll6 1>; -			clock-output-names = "usb_ohci0", "usb_ohci1", "usb_phy"; +			clock-output-names = "usb_ohci0", "usb_ohci1", +					     "usb_phy";  		};  		spi3_clk: clk@01c200d4 { @@ -450,44 +448,46 @@  		};  	}; -	/* -	 * Note we use the address where the mmio registers start, not where -	 * the SRAM blocks start, this cannot be changed because that would be -	 * a devicetree ABI change. -	 */  	soc@01c00000 {  		compatible = "simple-bus";  		#address-cells = <1>;  		#size-cells = <1>;  		ranges; -		sram@00000000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00000000 0x4000>; -			allwinner,sram-name = "A1"; -		}; - -		sram@00004000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00004000 0x4000>; -			allwinner,sram-name = "A2"; -		}; - -		sram@00008000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00008000 0x4000>; -			allwinner,sram-name = "A3-A4"; -		}; - -		sram@00010000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00010000 0x1000>; -			allwinner,sram-name = "D"; -		}; -  		sram-controller@01c00000 {  			compatible = "allwinner,sun4i-a10-sram-controller";  			reg = <0x01c00000 0x30>; +			#address-cells = <1>; +			#size-cells = <1>; +			ranges; + +			sram_a: sram@00000000 { +				compatible = "mmio-sram"; +				reg = <0x00000000 0xc000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00000000 0xc000>; + +				emac_sram: sram-section@8000 { +					compatible = "allwinner,sun4i-a10-sram-a3-a4"; +					reg = <0x8000 0x4000>; +					status = "disabled"; +				}; +			}; + +			sram_d: sram@00010000 { +				compatible = "mmio-sram"; +				reg = <0x00010000 0x1000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00010000 0x1000>; + +				otg_sram: sram-section@0000 { +					compatible = "allwinner,sun4i-a10-sram-d"; +					reg = <0x0000 0x1000>; +					status = "disabled"; +				}; +			};  		};  		dma: dma-controller@01c02000 { @@ -531,6 +531,7 @@  			reg = <0x01c0b000 0x1000>;  			interrupts = <55>;  			clocks = <&ahb_gates 17>; +			allwinner,sram = <&emac_sram 1>;  			status = "disabled";  		}; @@ -784,7 +785,8 @@  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; @@ -797,43 +799,85 @@  				allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;  			}; -			ir0_pins_a: ir0@0 { -				allwinner,pins = "PB3","PB4"; +			ir0_rx_pins_a: ir0@0 { +				allwinner,pins = "PB4";  				allwinner,function = "ir0";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			}; -			ir1_pins_a: ir1@0 { -				allwinner,pins = "PB22","PB23"; +			ir0_tx_pins_a: ir0@1 { +				allwinner,pins = "PB3"; +				allwinner,function = "ir0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			ir1_rx_pins_a: ir1@0 { +				allwinner,pins = "PB23"; +				allwinner,function = "ir1"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			ir1_tx_pins_a: ir1@1 { +				allwinner,pins = "PB22";  				allwinner,function = "ir1";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			};  			spi0_pins_a: spi0@0 { -				allwinner,pins = "PI10", "PI11", "PI12", "PI13"; +				allwinner,pins = "PI11", "PI12", "PI13"; +				allwinner,function = "spi0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi0_cs0_pins_a: spi0_cs0@0 { +				allwinner,pins = "PI10";  				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,pins = "PI17", "PI18", "PI19"; +				allwinner,function = "spi1"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi1_cs0_pins_a: spi1_cs0@0 { +				allwinner,pins = "PI16";  				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,pins = "PC20", "PC21", "PC22";  				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,pins = "PB15", "PB16", "PB17"; +				allwinner,function = "spi2"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi2_cs0_pins_a: spi2_cs0@0 { +				allwinner,pins = "PC19"; +				allwinner,function = "spi2"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi2_cs0_pins_b: spi2_cs0@1 { +				allwinner,pins = "PB14";  				allwinner,function = "spi2";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; diff --git a/arch/arm/dts/sun5i-a10s-auxtek-t004.dts b/arch/arm/dts/sun5i-a10s-auxtek-t004.dts index ceb0582ac90..2b3511ea2e5 100644 --- a/arch/arm/dts/sun5i-a10s-auxtek-t004.dts +++ b/arch/arm/dts/sun5i-a10s-auxtek-t004.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a10s-mk802.dts b/arch/arm/dts/sun5i-a10s-mk802.dts index e1a11e1d967..46ff9407826 100644 --- a/arch/arm/dts/sun5i-a10s-mk802.dts +++ b/arch/arm/dts/sun5i-a10s-mk802.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a10s-olinuxino-micro.dts b/arch/arm/dts/sun5i-a10s-olinuxino-micro.dts index 85a8745fffb..a7e19e4847f 100644 --- a/arch/arm/dts/sun5i-a10s-olinuxino-micro.dts +++ b/arch/arm/dts/sun5i-a10s-olinuxino-micro.dts @@ -18,11 +18,6 @@   *     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 @@ -93,6 +88,10 @@  	status = "okay";  }; +&emac_sram { +	status = "okay"; +}; +  &i2c0 {  	pinctrl-names = "default";  	pinctrl-0 = <&i2c0_pins_a>; diff --git a/arch/arm/dts/sun5i-a10s-r7-tv-dongle.dts b/arch/arm/dts/sun5i-a10s-r7-tv-dongle.dts index 9980969d098..3b057983c74 100644 --- a/arch/arm/dts/sun5i-a10s-r7-tv-dongle.dts +++ b/arch/arm/dts/sun5i-a10s-r7-tv-dongle.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a10s.dtsi b/arch/arm/dts/sun5i-a10s.dtsi index a78c95dfb33..f11efb722bb 100644 --- a/arch/arm/dts/sun5i-a10s.dtsi +++ b/arch/arm/dts/sun5i-a10s.dtsi @@ -18,11 +18,6 @@   *     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 @@ -67,7 +62,8 @@  		ranges;  		framebuffer@0 { -			compatible = "allwinner,simple-framebuffer", "simple-framebuffer"; +			compatible = "allwinner,simple-framebuffer", +				     "simple-framebuffer";  			allwinner,pipeline = "de_be0-lcd0-hdmi";  			clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 43>,  				 <&ahb_gates 44>; @@ -89,13 +85,17 @@  			compatible = "allwinner,sun5i-a10s-ahb-gates-clk";  			reg = <0x01c20060 0x8>;  			clocks = <&ahb>; -			clock-output-names = "ahb_usbotg", "ahb_ehci", "ahb_ohci", -				"ahb_ss", "ahb_dma", "ahb_bist", "ahb_mmc0", -				"ahb_mmc1", "ahb_mmc2", "ahb_nand", "ahb_sdram", -				"ahb_emac", "ahb_ts", "ahb_spi0", "ahb_spi1", -				"ahb_spi2", "ahb_gps", "ahb_stimer", "ahb_ve", -				"ahb_tve", "ahb_lcd", "ahb_csi", "ahb_hdmi", -				"ahb_de_be", "ahb_de_fe", "ahb_iep", "ahb_mali400"; +			clock-output-names = "ahb_usbotg", "ahb_ehci", +					     "ahb_ohci", "ahb_ss", "ahb_dma", +					     "ahb_bist", "ahb_mmc0", "ahb_mmc1", +					     "ahb_mmc2", "ahb_nand", +					     "ahb_sdram", "ahb_emac", "ahb_ts", +					     "ahb_spi0", "ahb_spi1", "ahb_spi2", +					     "ahb_gps", "ahb_stimer", "ahb_ve", +					     "ahb_tve", "ahb_lcd", "ahb_csi", +					     "ahb_hdmi", "ahb_de_be", +					     "ahb_de_fe", "ahb_iep", +					     "ahb_mali400";  		};  		apb0_gates: clk@01c20068 { @@ -103,8 +103,9 @@  			compatible = "allwinner,sun5i-a10s-apb0-gates-clk";  			reg = <0x01c20068 0x4>;  			clocks = <&apb0>; -			clock-output-names = "apb0_codec", "apb0_iis", "apb0_pio", -				"apb0_ir", "apb0_keypad"; +			clock-output-names = "apb0_codec", "apb0_iis", +					     "apb0_pio", "apb0_ir", +					     "apb0_keypad";  		};  		apb1_gates: clk@01c2006c { @@ -124,6 +125,7 @@  			reg = <0x01c0b000 0x1000>;  			interrupts = <55>;  			clocks = <&ahb_gates 17>; +			allwinner,sram = <&emac_sram 1>;  			status = "disabled";  		}; @@ -193,9 +195,18 @@  	};  	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,drive = <SUN4I_PINCTRL_30_MA>;  		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  	};  }; + +&sram_a { +	emac_sram: sram-section@8000 { +		compatible = "allwinner,sun4i-a10-sram-a3-a4"; +		reg = <0x8000 0x4000>; +		status = "disabled"; +	}; +}; diff --git a/arch/arm/dts/sun5i-a13-hsg-h702.dts b/arch/arm/dts/sun5i-a13-hsg-h702.dts index adf78a234ff..990f9d61ae4 100644 --- a/arch/arm/dts/sun5i-a13-hsg-h702.dts +++ b/arch/arm/dts/sun5i-a13-hsg-h702.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a13-olinuxino-micro.dts b/arch/arm/dts/sun5i-a13-olinuxino-micro.dts index 4a00bcee927..ad84fe4276c 100644 --- a/arch/arm/dts/sun5i-a13-olinuxino-micro.dts +++ b/arch/arm/dts/sun5i-a13-olinuxino-micro.dts @@ -17,11 +17,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a13-olinuxino.dts b/arch/arm/dts/sun5i-a13-olinuxino.dts index 44401565533..42324005eb7 100644 --- a/arch/arm/dts/sun5i-a13-olinuxino.dts +++ b/arch/arm/dts/sun5i-a13-olinuxino.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun5i-a13-utoo-p66.dts b/arch/arm/dts/sun5i-a13-utoo-p66.dts index 6e19f789aeb..8c1bca70390 100644 --- a/arch/arm/dts/sun5i-a13-utoo-p66.dts +++ b/arch/arm/dts/sun5i-a13-utoo-p66.dts @@ -16,11 +16,6 @@   *     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 @@ -50,6 +45,7 @@  #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>  / { @@ -101,6 +97,20 @@  	pinctrl-0 = <&i2c1_pins_a>;  	status = "okay"; +	icn8318: touchscreen@40 { +		compatible = "chipone,icn8318"; +		reg = <0x40>; +		interrupt-parent = <&pio>; +		interrupts = <9 IRQ_TYPE_EDGE_FALLING>; /* EINT9 (PG9) */ +		pinctrl-names = "default"; +		pinctrl-0 = <&ts_wake_pin_p66>; +		wake-gpios = <&pio 1 3 GPIO_ACTIVE_HIGH>; /* PB3 */ +		touchscreen-size-x = <800>; +		touchscreen-size-y = <480>; +		touchscreen-inverted-x; +		touchscreen-swapped-x-y; +	}; +  	pcf8563: rtc@51 {  		compatible = "nxp,pcf8563";  		reg = <0x51>; @@ -166,6 +176,13 @@  		allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;  	}; +	ts_wake_pin_p66: ts_wake_pin@0 { +		allwinner,pins = "PB3"; +		allwinner,function = "gpio_out"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +	}; +  	usb0_vbus_pin_a: usb0_vbus_pin@0 {  		allwinner,pins = "PB4";  		allwinner,function = "gpio_out"; diff --git a/arch/arm/dts/sun5i-a13.dtsi b/arch/arm/dts/sun5i-a13.dtsi index 0188deed6f7..976d4faa217 100644 --- a/arch/arm/dts/sun5i-a13.dtsi +++ b/arch/arm/dts/sun5i-a13.dtsi @@ -18,11 +18,6 @@   *     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 @@ -109,12 +104,16 @@  			compatible = "allwinner,sun5i-a13-ahb-gates-clk";  			reg = <0x01c20060 0x8>;  			clocks = <&ahb>; -			clock-output-names = "ahb_usbotg", "ahb_ehci", "ahb_ohci", -				"ahb_ss", "ahb_dma", "ahb_bist", "ahb_mmc0", -				"ahb_mmc1", "ahb_mmc2", "ahb_nand", "ahb_sdram", -				"ahb_spi0", "ahb_spi1", "ahb_spi2", "ahb_stimer", -				"ahb_ve", "ahb_lcd", "ahb_csi", "ahb_de_be", -				"ahb_de_fe", "ahb_iep", "ahb_mali400"; +			clock-output-names = "ahb_usbotg", "ahb_ehci", +					     "ahb_ohci", "ahb_ss", "ahb_dma", +					     "ahb_bist", "ahb_mmc0", "ahb_mmc1", +					     "ahb_mmc2", "ahb_nand", +					     "ahb_sdram", "ahb_spi0", +					     "ahb_spi1", "ahb_spi2", +					     "ahb_stimer", "ahb_ve", "ahb_lcd", +					     "ahb_csi", "ahb_de_be", +					     "ahb_de_fe", "ahb_iep", +					     "ahb_mali400";  		};  		apb0_gates: clk@01c20068 { @@ -122,7 +121,8 @@  			compatible = "allwinner,sun5i-a13-apb0-gates-clk";  			reg = <0x01c20068 0x4>;  			clocks = <&apb0>; -			clock-output-names = "apb0_codec", "apb0_pio", "apb0_ir"; +			clock-output-names = "apb0_codec", "apb0_pio", +					     "apb0_ir";  		};  		apb1_gates: clk@01c2006c { @@ -139,13 +139,13 @@  &cpu0 {  	clock-latency = <244144>; /* 8 32k periods */  	operating-points = < -		/* kHz    uV */ +		/* kHz	  uV */  		1008000 1400000 -		912000  1350000 -		864000  1300000 -		624000  1200000 -		576000  1200000 -		432000  1200000 +		912000	1350000 +		864000	1300000 +		624000	1200000 +		576000	1200000 +		432000	1200000  		>;  	#cooling-cells = <2>;  	cooling-min-level = <0>; diff --git a/arch/arm/dts/sun5i.dtsi b/arch/arm/dts/sun5i.dtsi index 96b20d646b3..54b09783043 100644 --- a/arch/arm/dts/sun5i.dtsi +++ b/arch/arm/dts/sun5i.dtsi @@ -18,11 +18,6 @@   *     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 @@ -150,10 +145,16 @@  		ahb: ahb@01c20054 {  			#clock-cells = <0>; -			compatible = "allwinner,sun4i-a10-ahb-clk"; +			compatible = "allwinner,sun5i-a13-ahb-clk";  			reg = <0x01c20054 0x4>; -			clocks = <&axi>; +			clocks = <&axi>, <&cpu>, <&pll6 1>;  			clock-output-names = "ahb"; +			/* +			 * Use PLL6 as parent, instead of CPU/AXI +			 * which has rate changes due to cpufreq +			 */ +			assigned-clocks = <&ahb>; +			assigned-clock-parents = <&pll6 1>;  		};  		apb0: apb0@01c20054 { @@ -276,7 +277,7 @@  		usb_clk: clk@01c200cc {  			#clock-cells = <1>; -		        #reset-cells = <1>; +			#reset-cells = <1>;  			compatible = "allwinner,sun5i-a13-usb-clk";  			reg = <0x01c200cc 0x4>;  			clocks = <&pll6 1>; @@ -292,44 +293,40 @@  		};  	}; -	/* -	 * Note we use the address where the mmio registers start, not where -	 * the SRAM blocks start, this cannot be changed because that would be -	 * a devicetree ABI change. -	 */  	soc@01c00000 {  		compatible = "simple-bus";  		#address-cells = <1>;  		#size-cells = <1>;  		ranges; -		sram@00000000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00000000 0x4000>; -			allwinner,sram-name = "A1"; -		}; - -		sram@00004000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00004000 0x4000>; -			allwinner,sram-name = "A2"; -		}; - -		sram@00008000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00008000 0x4000>; -			allwinner,sram-name = "A3-A4"; -		}; - -		sram@00010000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00010000 0x1000>; -			allwinner,sram-name = "D"; -		}; -  		sram-controller@01c00000 {  			compatible = "allwinner,sun4i-a10-sram-controller";  			reg = <0x01c00000 0x30>; +			#address-cells = <1>; +			#size-cells = <1>; +			ranges; + +			sram_a: sram@00000000 { +				compatible = "mmio-sram"; +				reg = <0x00000000 0xc000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00000000 0xc000>; +			}; + +			sram_d: sram@00010000 { +				compatible = "mmio-sram"; +				reg = <0x00010000 0x1000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00010000 0x1000>; + +				otg_sram: sram-section@0000 { +					compatible = "allwinner,sun4i-a10-sram-d"; +					reg = <0x0000 0x1000>; +					status = "disabled"; +				}; +			};  		};  		dma: dma-controller@01c02000 { @@ -504,7 +501,8 @@  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; diff --git a/arch/arm/dts/sun6i-a31-app4-evb1.dts b/arch/arm/dts/sun6i-a31-app4-evb1.dts index b7b1df4be46..2f8cfab771e 100644 --- a/arch/arm/dts/sun6i-a31-app4-evb1.dts +++ b/arch/arm/dts/sun6i-a31-app4-evb1.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31-colombus.dts b/arch/arm/dts/sun6i-a31-colombus.dts index 95d7ec2b295..0cf9926d1e9 100644 --- a/arch/arm/dts/sun6i-a31-colombus.dts +++ b/arch/arm/dts/sun6i-a31-colombus.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31-hummingbird.dts b/arch/arm/dts/sun6i-a31-hummingbird.dts index 1e820bc0c76..d0cfadac069 100644 --- a/arch/arm/dts/sun6i-a31-hummingbird.dts +++ b/arch/arm/dts/sun6i-a31-hummingbird.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31-i7.dts b/arch/arm/dts/sun6i-a31-i7.dts index ce37d69d341..e9185dad67e 100644 --- a/arch/arm/dts/sun6i-a31-i7.dts +++ b/arch/arm/dts/sun6i-a31-i7.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31-m9.dts b/arch/arm/dts/sun6i-a31-m9.dts index 29f5fc717b4..a5660d61a96 100644 --- a/arch/arm/dts/sun6i-a31-m9.dts +++ b/arch/arm/dts/sun6i-a31-m9.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31-mele-a1000g-quad.dts b/arch/arm/dts/sun6i-a31-mele-a1000g-quad.dts new file mode 100644 index 00000000000..4404f37d132 --- /dev/null +++ b/arch/arm/dts/sun6i-a31-mele-a1000g-quad.dts @@ -0,0 +1,149 @@ +/* + * 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 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 "sun6i-a31.dtsi" +#include "sunxi-common-regulators.dtsi" + +#include <dt-bindings/gpio/gpio.h> +#include <dt-bindings/pinctrl/sun4i-a10.h> + +/ { +	model = "Mele A1000G Quad top set box"; +	compatible = "mele,a1000g-quad", "allwinner,sun6i-a31"; + +	aliases { +		serial0 = &uart0; +	}; + +	chosen { +		stdout-path = "serial0:115200n8"; +	}; + +	leds { +		compatible = "gpio-leds"; +		pinctrl-names = "default"; +		pinctrl-0 = <&led_pins_m9>; + +		blue { +			label = "m9:blue:usr"; +			gpios = <&pio 7 13 GPIO_ACTIVE_HIGH>; +		}; +	}; +}; + +&ehci0 { +	status = "okay"; +}; + +&ehci1 { +	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"; +}; + +&mmc0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_m9>; +	vmmc-supply = <®_vcc3v3>; +	bus-width = <4>; +	cd-gpios = <&pio 7 22 GPIO_ACTIVE_HIGH>; /* PH22 */ +	cd-inverted; +	status = "okay"; +}; + +&pio { +	led_pins_m9: led_pins@0 { +		allwinner,pins = "PH13"; +		allwinner,function = "gpio_out"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +	}; + +	mmc0_cd_pin_m9: mmc0_cd_pin@0 { +		allwinner,pins = "PH22"; +		allwinner,function = "gpio_in"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_PULL_UP>; +	}; + +	usb1_vbus_pin_m9: usb1_vbus_pin@0 { +		allwinner,pins = "PC27"; +		allwinner,function = "gpio_out"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +	}; +}; + +®_usb1_vbus { +	pinctrl-names = "default"; +	pinctrl-0 = <&usb1_vbus_pin_m9>; +	gpio = <&pio 2 27 GPIO_ACTIVE_HIGH>; +	status = "okay"; +}; + +&uart0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&uart0_pins_a>; +	status = "okay"; +}; + +&usbphy { +	usb1_vbus-supply = <®_usb1_vbus>; +	status = "okay"; +}; diff --git a/arch/arm/dts/sun6i-a31.dtsi b/arch/arm/dts/sun6i-a31.dtsi index 25a97f08d94..008047a018c 100644 --- a/arch/arm/dts/sun6i-a31.dtsi +++ b/arch/arm/dts/sun6i-a31.dtsi @@ -18,11 +18,6 @@   *     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 @@ -67,7 +62,8 @@  		ranges;  		framebuffer@0 { -			compatible = "allwinner,simple-framebuffer", "simple-framebuffer"; +			compatible = "allwinner,simple-framebuffer", +				     "simple-framebuffer";  			allwinner,pipeline = "de_be0-lcd0-hdmi";  			clocks = <&pll6 0>;  			status = "disabled"; @@ -104,11 +100,11 @@  			clocks = <&cpu>;  			clock-latency = <244144>; /* 8 32k periods */  			operating-points = < -				/* kHz    uV */ +				/* kHz	  uV */  				1008000	1200000 -				864000  1200000 -				720000  1100000 -				480000  1000000 +				864000	1200000 +				720000	1100000 +				480000	1000000  				>;  			#cooling-cells = <2>;  			cooling-min-level = <0>; @@ -241,6 +237,14 @@  			reg = <0x01c20054 0x4>;  			clocks = <&osc32k>, <&osc24M>, <&axi>, <&pll6 0>;  			clock-output-names = "ahb1"; + +			/* +			 * Clock AHB1 from PLL6, instead of CPU/AXI which +			 * has rate changes due to cpufreq. Also the DMA +			 * controller requires AHB1 clocked from PLL6. +			 */ +			assigned-clocks = <&ahb1>; +			assigned-clock-parents = <&pll6 0>;  		};  		ahb1_gates: clk@01c20060 { @@ -296,9 +300,10 @@  			reg = <0x01c2006c 0x4>;  			clocks = <&apb2>;  			clock-output-names = "apb2_i2c0", "apb2_i2c1", -					"apb2_i2c2", "apb2_i2c3", "apb2_uart0", -					"apb2_uart1", "apb2_uart2", "apb2_uart3", -					"apb2_uart4", "apb2_uart5"; +					     "apb2_i2c2", "apb2_i2c3", +					     "apb2_uart0", "apb2_uart1", +					     "apb2_uart2", "apb2_uart3", +					     "apb2_uart4", "apb2_uart5";  		};  		mmc0_clk: clk@01c20088 { @@ -375,7 +380,7 @@  		usb_clk: clk@01c200cc {  			#clock-cells = <1>; -		        #reset-cells = <1>; +			#reset-cells = <1>;  			compatible = "allwinner,sun6i-a31-usb-clk";  			reg = <0x01c200cc 0x4>;  			clocks = <&osc24M>; @@ -385,10 +390,13 @@  		};  		/* -		 * The following two are dummy clocks, placeholders used in the gmac_tx -		 * clock. The gmac driver will choose one parent depending on the PHY -		 * interface mode, using clk_set_rate auto-reparenting. -		 * The actual TX clock rate is not controlled by the gmac_tx clock. +		 * The following two are dummy clocks, placeholders +		 * used in the gmac_tx clock. The gmac driver will +		 * choose one parent depending on the PHY interface +		 * mode, using clk_set_rate auto-reparenting. +		 * +		 * The actual TX clock rate is not controlled by the +		 * gmac_tx clock.  		 */  		mii_phy_tx_clk: clk@1 {  			#clock-cells = <0>; @@ -426,10 +434,6 @@  			clocks = <&ahb1_gates 6>;  			resets = <&ahb1_rst 6>;  			#dma-cells = <1>; - -			/* DMA controller requires AHB1 clocked from PLL6 */ -			assigned-clocks = <&ahb1>; -			assigned-clock-parents = <&pll6 0>;  		};  		mmc0: mmc@01c0f000 { @@ -628,7 +632,8 @@  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; @@ -866,7 +871,8 @@  		};  		timer@01c60000 { -			compatible = "allwinner,sun6i-a31-hstimer", "allwinner,sun7i-a20-hstimer"; +			compatible = "allwinner,sun6i-a31-hstimer", +				     "allwinner,sun7i-a20-hstimer";  			reg = <0x01c60000 0x1000>;  			interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,  				     <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>, @@ -957,7 +963,8 @@  			ar100: ar100_clk {  				compatible = "allwinner,sun6i-a31-ar100-clk";  				#clock-cells = <0>; -				clocks = <&osc32k>, <&osc24M>, <&pll6 0>, <&pll6 0>; +				clocks = <&osc32k>, <&osc24M>, <&pll6 0>, +					 <&pll6 0>;  				clock-output-names = "ar100";  			}; diff --git a/arch/arm/dts/sun6i-a31s-cs908.dts b/arch/arm/dts/sun6i-a31s-cs908.dts index 68cb2bf3998..1e2411a2bce 100644 --- a/arch/arm/dts/sun6i-a31s-cs908.dts +++ b/arch/arm/dts/sun6i-a31s-cs908.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun6i-a31s.dtsi b/arch/arm/dts/sun6i-a31s.dtsi index eaf5ec8fd45..c17a32771b9 100644 --- a/arch/arm/dts/sun6i-a31s.dtsi +++ b/arch/arm/dts/sun6i-a31s.dtsi @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun7i-a20-bananapi.dts b/arch/arm/dts/sun7i-a20-bananapi.dts index b952ac44550..9f7b472e672 100644 --- a/arch/arm/dts/sun7i-a20-bananapi.dts +++ b/arch/arm/dts/sun7i-a20-bananapi.dts @@ -18,11 +18,6 @@   *     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 @@ -142,7 +137,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; @@ -197,7 +192,9 @@  &spi0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi0_pins_a>; +	pinctrl-0 = <&spi0_pins_a>, +		    <&spi0_cs0_pins_a>, +		    <&spi0_cs1_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-bananapro.dts b/arch/arm/dts/sun7i-a20-bananapro.dts index 9d9027f25a4..18fcc87f462 100644 --- a/arch/arm/dts/sun7i-a20-bananapro.dts +++ b/arch/arm/dts/sun7i-a20-bananapro.dts @@ -16,11 +16,6 @@   *     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 @@ -57,7 +52,7 @@  	aliases {  		serial0 = &uart0; -		serial1 = &uart2; +		serial1 = &uart4;  		serial2 = &uart7;  	}; @@ -154,7 +149,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; @@ -243,7 +238,9 @@  &spi0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi0_pins_a>; +	pinctrl-0 = <&spi0_pins_a>, +		    <&spi0_cs0_pins_a>, +		    <&spi0_cs1_pins_a>;  	status = "okay";  }; @@ -253,9 +250,9 @@  	status = "okay";  }; -&uart2 { +&uart4 {  	pinctrl-names = "default"; -	pinctrl-0 = <&uart2_pins_a>; +	pinctrl-0 = <&uart4_pins_b>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-cubieboard2.dts b/arch/arm/dts/sun7i-a20-cubieboard2.dts index 3c817ac9360..39a51d5143f 100644 --- a/arch/arm/dts/sun7i-a20-cubieboard2.dts +++ b/arch/arm/dts/sun7i-a20-cubieboard2.dts @@ -18,11 +18,6 @@   *     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 @@ -133,7 +128,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-cubietruck.dts b/arch/arm/dts/sun7i-a20-cubietruck.dts index 613a19e63e5..4611e2f5a99 100644 --- a/arch/arm/dts/sun7i-a20-cubietruck.dts +++ b/arch/arm/dts/sun7i-a20-cubietruck.dts @@ -18,11 +18,6 @@   *     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 @@ -160,7 +155,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-hummingbird.dts b/arch/arm/dts/sun7i-a20-hummingbird.dts index d3f15c2e721..37f4a549745 100644 --- a/arch/arm/dts/sun7i-a20-hummingbird.dts +++ b/arch/arm/dts/sun7i-a20-hummingbird.dts @@ -18,11 +18,6 @@   *     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 @@ -160,7 +155,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; @@ -245,7 +240,8 @@  &spi2 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi2_pins_b>; +	pinctrl-0 = <&spi2_pins_b>, +		    <&spi2_cs0_pins_b>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-i12-tvbox.dts b/arch/arm/dts/sun7i-a20-i12-tvbox.dts index 3f99b3f222a..f32f6f20d92 100644 --- a/arch/arm/dts/sun7i-a20-i12-tvbox.dts +++ b/arch/arm/dts/sun7i-a20-i12-tvbox.dts @@ -16,11 +16,6 @@   *     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 @@ -157,7 +152,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-m3.dts b/arch/arm/dts/sun7i-a20-m3.dts index f2fb26e7d6e..8d9ea48dd98 100644 --- a/arch/arm/dts/sun7i-a20-m3.dts +++ b/arch/arm/dts/sun7i-a20-m3.dts @@ -18,11 +18,6 @@   *     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 @@ -117,7 +112,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-mk808c.dts b/arch/arm/dts/sun7i-a20-mk808c.dts index f3f9eeb0d18..4f432f8ade7 100644 --- a/arch/arm/dts/sun7i-a20-mk808c.dts +++ b/arch/arm/dts/sun7i-a20-mk808c.dts @@ -1,20 +1,66 @@  /* - * Copyright 2015 Hans de Goede <hdegoede@redhat.com> + * Copyright 2015 Marcus Cooper   * - * Minimal dts file for the MK808C for u-boot only + * Marcus Cooper <codekipper@gmail.com>   * - * SPDX-License-Identifier:     GPL-2.0+ or X11 + * 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/irq.h>  / { -	model = "MK808C"; +	model = "mk808c";  	compatible = "allwinner,mk808c", "allwinner,sun7i-a20";  	aliases {  		serial0 = &uart0; +		serial1 = &uart2;  	};  	chosen { @@ -30,6 +76,43 @@  	status = "okay";  }; +&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>; +	}; +}; + +&i2c1 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c1_pins_a>; +	status = "okay"; +}; + +&i2c2 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c2_pins_a>; +	status = "okay"; +}; + +&mmc0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; +	vmmc-supply = <®_vcc3v0>; +	bus-width = <4>; +	cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */ +	cd-inverted; +	status = "okay"; +}; +  &ohci0 {  	status = "okay";  }; @@ -38,8 +121,28 @@  	status = "okay";  }; +®_usb1_vbus { +	status = "okay"; +}; + +®_usb2_vbus { +	status = "okay"; +}; +  &uart0 {  	pinctrl-names = "default";  	pinctrl-0 = <&uart0_pins_a>;  	status = "okay";  }; + +&uart2 { +	pinctrl-names = "default"; +	pinctrl-0 = <&uart2_pins_a>; +	status = "okay"; +}; + +&usbphy { +	usb1_vbus-supply = <®_usb1_vbus>; +	usb2_vbus-supply = <®_usb2_vbus>; +	status = "okay"; +}; diff --git a/arch/arm/dts/sun7i-a20-olinuxino-lime.dts b/arch/arm/dts/sun7i-a20-olinuxino-lime.dts index 6592cb21e32..769726dfb04 100644 --- a/arch/arm/dts/sun7i-a20-olinuxino-lime.dts +++ b/arch/arm/dts/sun7i-a20-olinuxino-lime.dts @@ -19,11 +19,6 @@   *     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 diff --git a/arch/arm/dts/sun7i-a20-olinuxino-lime2.dts b/arch/arm/dts/sun7i-a20-olinuxino-lime2.dts index 3a7a2c2b488..8acff78272b 100644 --- a/arch/arm/dts/sun7i-a20-olinuxino-lime2.dts +++ b/arch/arm/dts/sun7i-a20-olinuxino-lime2.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun7i-a20-olinuxino-micro.dts b/arch/arm/dts/sun7i-a20-olinuxino-micro.dts index 82802b6cb19..00f8f25ecca 100644 --- a/arch/arm/dts/sun7i-a20-olinuxino-micro.dts +++ b/arch/arm/dts/sun7i-a20-olinuxino-micro.dts @@ -18,11 +18,6 @@   *     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 @@ -250,13 +245,15 @@  &spi1 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi1_pins_a>; +	pinctrl-0 = <&spi1_pins_a>, +		    <&spi1_cs0_pins_a>;  	status = "okay";  };  &spi2 {  	pinctrl-names = "default"; -	pinctrl-0 = <&spi2_pins_a>; +	pinctrl-0 = <&spi2_pins_a>, +		    <&spi2_cs0_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-orangepi-mini.dts b/arch/arm/dts/sun7i-a20-orangepi-mini.dts index 0556938a5d4..73cd81ee02e 100644 --- a/arch/arm/dts/sun7i-a20-orangepi-mini.dts +++ b/arch/arm/dts/sun7i-a20-orangepi-mini.dts @@ -18,11 +18,6 @@   *     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 @@ -137,7 +132,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-orangepi.dts b/arch/arm/dts/sun7i-a20-orangepi.dts index 7e6405c5448..55a06ceb80e 100644 --- a/arch/arm/dts/sun7i-a20-orangepi.dts +++ b/arch/arm/dts/sun7i-a20-orangepi.dts @@ -18,11 +18,6 @@   *     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 @@ -132,7 +127,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-pcduino3-nano.dts b/arch/arm/dts/sun7i-a20-pcduino3-nano.dts index 810c5f76459..5361fce26b4 100644 --- a/arch/arm/dts/sun7i-a20-pcduino3-nano.dts +++ b/arch/arm/dts/sun7i-a20-pcduino3-nano.dts @@ -16,11 +16,6 @@   *     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 @@ -125,7 +120,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-pcduino3.dts b/arch/arm/dts/sun7i-a20-pcduino3.dts index cd05267781f..afc9ecebed2 100644 --- a/arch/arm/dts/sun7i-a20-pcduino3.dts +++ b/arch/arm/dts/sun7i-a20-pcduino3.dts @@ -17,11 +17,6 @@   *     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 @@ -154,7 +149,7 @@  &ir0 {  	pinctrl-names = "default"; -	pinctrl-0 = <&ir0_pins_a>; +	pinctrl-0 = <&ir0_rx_pins_a>;  	status = "okay";  }; diff --git a/arch/arm/dts/sun7i-a20-wexler-tab7200.dts b/arch/arm/dts/sun7i-a20-wexler-tab7200.dts index 2ad3b09dcb6..83c6d3f872f 100644 --- a/arch/arm/dts/sun7i-a20-wexler-tab7200.dts +++ b/arch/arm/dts/sun7i-a20-wexler-tab7200.dts @@ -17,11 +17,6 @@   *     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 diff --git a/arch/arm/dts/sun7i-a20.dtsi b/arch/arm/dts/sun7i-a20.dtsi index d4ba77202d7..6a63f30c9a6 100644 --- a/arch/arm/dts/sun7i-a20.dtsi +++ b/arch/arm/dts/sun7i-a20.dtsi @@ -18,11 +18,6 @@   *     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 @@ -68,7 +63,8 @@  		ranges;  		framebuffer@0 { -			compatible = "allwinner,simple-framebuffer", "simple-framebuffer"; +			compatible = "allwinner,simple-framebuffer", +				     "simple-framebuffer";  			allwinner,pipeline = "de_be0-lcd0-hdmi";  			clocks = <&pll5 1>, <&ahb_gates 36>, <&ahb_gates 43>,  				 <&ahb_gates 44>; @@ -104,14 +100,14 @@  			clocks = <&cpu>;  			clock-latency = <244144>; /* 8 32k periods */  			operating-points = < -				/* kHz    uV */ -				960000  1400000 -				912000  1400000 -				864000  1300000 -				720000  1200000 -				528000  1100000 -				312000  1000000 -				144000  900000 +				/* kHz	  uV */ +				960000	1400000 +				912000	1400000 +				864000	1300000 +				720000	1200000 +				528000	1100000 +				312000	1000000 +				144000	900000  				>;  			#cooling-cells = <2>;  			cooling-min-level = <0>; @@ -224,7 +220,8 @@  			compatible = "allwinner,sun4i-a10-pll6-clk";  			reg = <0x01c20028 0x4>;  			clocks = <&osc24M>; -			clock-output-names = "pll6_sata", "pll6_other", "pll6"; +			clock-output-names = "pll6_sata", "pll6_other", "pll6", +					     "pll6_div_4";  		};  		pll8: clk@01c20040 { @@ -253,10 +250,16 @@  		ahb: ahb@01c20054 {  			#clock-cells = <0>; -			compatible = "allwinner,sun4i-a10-ahb-clk"; +			compatible = "allwinner,sun5i-a13-ahb-clk";  			reg = <0x01c20054 0x4>; -			clocks = <&axi>; +			clocks = <&axi>, <&pll6 3>, <&pll6 1>;  			clock-output-names = "ahb"; +			/* +			 * Use PLL6 as parent, instead of CPU/AXI +			 * which has rate changes due to cpufreq +			 */ +			assigned-clocks = <&ahb>; +			assigned-clock-parents = <&pll6 3>;  		};  		ahb_gates: clk@01c20060 { @@ -441,11 +444,12 @@  		usb_clk: clk@01c200cc {  			#clock-cells = <1>; -		        #reset-cells = <1>; +			#reset-cells = <1>;  			compatible = "allwinner,sun4i-a10-usb-clk";  			reg = <0x01c200cc 0x4>;  			clocks = <&pll6 1>; -			clock-output-names = "usb_ohci0", "usb_ohci1", "usb_phy"; +			clock-output-names = "usb_ohci0", "usb_ohci1", +					     "usb_phy";  		};  		spi3_clk: clk@01c200d4 { @@ -465,10 +469,13 @@  		};  		/* -		 * The following two are dummy clocks, placeholders used in the gmac_tx -		 * clock. The gmac driver will choose one parent depending on the PHY -		 * interface mode, using clk_set_rate auto-reparenting. -		 * The actual TX clock rate is not controlled by the gmac_tx clock. +		 * The following two are dummy clocks, placeholders +		 * used in the gmac_tx clock. The gmac driver will +		 * choose one parent depending on the PHY interface +		 * mode, using clk_set_rate auto-reparenting. +		 * +		 * The actual TX clock rate is not controlled by the +		 * gmac_tx clock.  		 */  		mii_phy_tx_clk: clk@2 {  			#clock-cells = <0>; @@ -521,44 +528,46 @@  		};  	}; -	/* -	 * Note we use the address where the mmio registers start, not where -	 * the SRAM blocks start, this cannot be changed because that would be -	 * a devicetree ABI change. -	 */  	soc@01c00000 {  		compatible = "simple-bus";  		#address-cells = <1>;  		#size-cells = <1>;  		ranges; -		sram@00000000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00000000 0x4000>; -			allwinner,sram-name = "A1"; -		}; - -		sram@00004000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00004000 0x4000>; -			allwinner,sram-name = "A2"; -		}; - -		sram@00008000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00008000 0x4000>; -			allwinner,sram-name = "A3-A4"; -		}; - -		sram@00010000 { -			compatible = "allwinner,sun4i-a10-sram"; -			reg = <0x00010000 0x1000>; -			allwinner,sram-name = "D"; -		}; -  		sram-controller@01c00000 {  			compatible = "allwinner,sun4i-a10-sram-controller";  			reg = <0x01c00000 0x30>; +			#address-cells = <1>; +			#size-cells = <1>; +			ranges; + +			sram_a: sram@00000000 { +				compatible = "mmio-sram"; +				reg = <0x00000000 0xc000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00000000 0xc000>; + +				emac_sram: sram-section@8000 { +					compatible = "allwinner,sun4i-a10-sram-a3-a4"; +					reg = <0x8000 0x4000>; +					status = "disabled"; +				}; +			}; + +			sram_d: sram@00010000 { +				compatible = "mmio-sram"; +				reg = <0x00010000 0x1000>; +				#address-cells = <1>; +				#size-cells = <1>; +				ranges = <0 0x00010000 0x1000>; + +				otg_sram: sram-section@0000 { +					compatible = "allwinner,sun4i-a10-sram-d"; +					reg = <0x0000 0x1000>; +					status = "disabled"; +				}; +			};  		};  		nmi_intc: interrupt-controller@01c00030 { @@ -610,6 +619,7 @@  			reg = <0x01c0b000 0x1000>;  			interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&ahb_gates 17>; +			allwinner,sram = <&emac_sram 1>;  			status = "disabled";  		}; @@ -837,6 +847,13 @@  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			}; +			uart4_pins_b: uart4@1 { +				allwinner,pins = "PH4", "PH5"; +				allwinner,function = "uart4"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; +  			uart5_pins_a: uart5@0 {  				allwinner,pins = "PI10", "PI11";  				allwinner,function = "uart5"; @@ -938,35 +955,71 @@  			};  			spi0_pins_a: spi0@0 { -				allwinner,pins = "PI10", "PI11", "PI12", "PI13", "PI14"; +				allwinner,pins = "PI11", "PI12", "PI13"; +				allwinner,function = "spi0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi0_cs0_pins_a: spi0_cs0@0 { +				allwinner,pins = "PI10"; +				allwinner,function = "spi0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi0_cs1_pins_a: spi0_cs1@0 { +				allwinner,pins = "PI14";  				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,pins = "PI17", "PI18", "PI19"; +				allwinner,function = "spi1"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi1_cs0_pins_a: spi1_cs0@0 { +				allwinner,pins = "PI16";  				allwinner,function = "spi1";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			};  			spi2_pins_a: spi2@0 { -				allwinner,pins = "PC19", "PC20", "PC21", "PC22"; +				allwinner,pins = "PC20", "PC21", "PC22";  				allwinner,function = "spi2";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			};  			spi2_pins_b: spi2@1 { -				allwinner,pins = "PB14", "PB15", "PB16", "PB17"; +				allwinner,pins = "PB15", "PB16", "PB17"; +				allwinner,function = "spi2"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi2_cs0_pins_a: spi2_cs0@0 { +				allwinner,pins = "PC19"; +				allwinner,function = "spi2"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			spi2_cs0_pins_b: spi2_cs0@1 { +				allwinner,pins = "PB14";  				allwinner,function = "spi2";  				allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; @@ -980,28 +1033,44 @@  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;  			};  			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,drive = <SUN4I_PINCTRL_30_MA>;  				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			}; -			ir0_pins_a: ir0@0 { -				    allwinner,pins = "PB3","PB4"; +			ir0_rx_pins_a: ir0@0 { +				    allwinner,pins = "PB4"; +				    allwinner,function = "ir0"; +				    allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				    allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			ir0_tx_pins_a: ir0@1 { +				    allwinner,pins = "PB3";  				    allwinner,function = "ir0";  				    allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				    allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;  			}; -			ir1_pins_a: ir1@0 { -				    allwinner,pins = "PB22","PB23"; +			ir1_rx_pins_a: ir1@0 { +				    allwinner,pins = "PB23"; +				    allwinner,function = "ir1"; +				    allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				    allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			ir1_tx_pins_a: ir1@1 { +				    allwinner,pins = "PB22";  				    allwinner,function = "ir1";  				    allwinner,drive = <SUN4I_PINCTRL_10_MA>;  				    allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; @@ -1171,7 +1240,8 @@  		};  		i2c0: i2c@01c2ac00 { -			compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; +			compatible = "allwinner,sun7i-a20-i2c", +				     "allwinner,sun4i-a10-i2c";  			reg = <0x01c2ac00 0x400>;  			interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&apb1_gates 0>; @@ -1181,7 +1251,8 @@  		};  		i2c1: i2c@01c2b000 { -			compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; +			compatible = "allwinner,sun7i-a20-i2c", +				     "allwinner,sun4i-a10-i2c";  			reg = <0x01c2b000 0x400>;  			interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&apb1_gates 1>; @@ -1191,7 +1262,8 @@  		};  		i2c2: i2c@01c2b400 { -			compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; +			compatible = "allwinner,sun7i-a20-i2c", +				     "allwinner,sun4i-a10-i2c";  			reg = <0x01c2b400 0x400>;  			interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&apb1_gates 2>; @@ -1201,7 +1273,8 @@  		};  		i2c3: i2c@01c2b800 { -			compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; +			compatible = "allwinner,sun7i-a20-i2c", +				     "allwinner,sun4i-a10-i2c";  			reg = <0x01c2b800 0x400>;  			interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&apb1_gates 3>; @@ -1211,7 +1284,8 @@  		};  		i2c4: i2c@01c2c000 { -			compatible = "allwinner,sun7i-a20-i2c", "allwinner,sun4i-a10-i2c"; +			compatible = "allwinner,sun7i-a20-i2c", +				     "allwinner,sun4i-a10-i2c";  			reg = <0x01c2c000 0x400>;  			interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;  			clocks = <&apb1_gates 15>; diff --git a/arch/arm/dts/sun8i-a23-a33.dtsi b/arch/arm/dts/sun8i-a23-a33.dtsi new file mode 100644 index 00000000000..faea94e45ee --- /dev/null +++ b/arch/arm/dts/sun8i-a23-a33.dtsi @@ -0,0 +1,626 @@ +/* + * Copyright 2014 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. + * + * 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. + */ + +#include "skeleton.dtsi" + +#include <dt-bindings/interrupt-controller/arm-gic.h> + +#include <dt-bindings/pinctrl/sun4i-a10.h> + +/ { +	interrupt-parent = <&gic>; + +	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"; +		}; +	}; + +	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 { +		enable-method = "allwinner,sun8i-a23"; +		#address-cells = <1>; +		#size-cells = <0>; + +		cpu@0 { +			compatible = "arm,cortex-a7"; +			device_type = "cpu"; +			reg = <0>; +		}; + +		cpu@1 { +			compatible = "arm,cortex-a7"; +			device_type = "cpu"; +			reg = <1>; +		}; +	}; + +	clocks { +		#address-cells = <1>; +		#size-cells = <1>; +		ranges; + +		osc24M: osc24M_clk { +			#clock-cells = <0>; +			compatible = "fixed-clock"; +			clock-frequency = <24000000>; +			clock-output-names = "osc24M"; +		}; + +		osc32k: osc32k_clk { +			#clock-cells = <0>; +			compatible = "fixed-clock"; +			clock-frequency = <32768>; +			clock-output-names = "osc32k"; +		}; + +		pll1: clk@01c20000 { +			#clock-cells = <0>; +			compatible = "allwinner,sun8i-a23-pll1-clk"; +			reg = <0x01c20000 0x4>; +			clocks = <&osc24M>; +			clock-output-names = "pll1"; +		}; + +		/* dummy clock until actually implemented */ +		pll5: pll5_clk { +			#clock-cells = <0>; +			compatible = "fixed-clock"; +			clock-frequency = <0>; +			clock-output-names = "pll5"; +		}; + +		pll6: clk@01c20028 { +			#clock-cells = <1>; +			compatible = "allwinner,sun6i-a31-pll6-clk"; +			reg = <0x01c20028 0x4>; +			clocks = <&osc24M>; +			clock-output-names = "pll6", "pll6x2"; +		}; + +		cpu: cpu_clk@01c20050 { +			#clock-cells = <0>; +			compatible = "allwinner,sun4i-a10-cpu-clk"; +			reg = <0x01c20050 0x4>; + +			/* +			 * PLL1 is listed twice here. +			 * While it looks suspicious, it's actually documented +			 * that way both in the datasheet and in the code from +			 * Allwinner. +			 */ +			clocks = <&osc32k>, <&osc24M>, <&pll1>, <&pll1>; +			clock-output-names = "cpu"; +		}; + +		axi: axi_clk@01c20050 { +			#clock-cells = <0>; +			compatible = "allwinner,sun8i-a23-axi-clk"; +			reg = <0x01c20050 0x4>; +			clocks = <&cpu>; +			clock-output-names = "axi"; +		}; + +		ahb1: ahb1_clk@01c20054 { +			#clock-cells = <0>; +			compatible = "allwinner,sun6i-a31-ahb1-clk"; +			reg = <0x01c20054 0x4>; +			clocks = <&osc32k>, <&osc24M>, <&axi>, <&pll6 0>; +			clock-output-names = "ahb1"; +		}; + +		apb1: apb1_clk@01c20054 { +			#clock-cells = <0>; +			compatible = "allwinner,sun4i-a10-apb0-clk"; +			reg = <0x01c20054 0x4>; +			clocks = <&ahb1>; +			clock-output-names = "apb1"; +		}; + +		ahb1_gates: clk@01c20060 { +			#clock-cells = <1>; +			compatible = "allwinner,sun8i-a23-ahb1-gates-clk"; +			reg = <0x01c20060 0x8>; +			clocks = <&ahb1>; +			clock-output-names = "ahb1_mipidsi", "ahb1_dma", +					"ahb1_mmc0", "ahb1_mmc1", "ahb1_mmc2", +					"ahb1_nand", "ahb1_sdram", +					"ahb1_hstimer", "ahb1_spi0", +					"ahb1_spi1", "ahb1_otg", "ahb1_ehci", +					"ahb1_ohci", "ahb1_ve", "ahb1_lcd", +					"ahb1_csi", "ahb1_be",	"ahb1_fe", +					"ahb1_gpu", "ahb1_spinlock", +					"ahb1_drc"; +		}; + +		apb1_gates: clk@01c20068 { +			#clock-cells = <1>; +			compatible = "allwinner,sun8i-a23-apb1-gates-clk"; +			reg = <0x01c20068 0x4>; +			clocks = <&apb1>; +			clock-output-names = "apb1_codec", "apb1_pio", +					"apb1_daudio0",	"apb1_daudio1"; +		}; + +		apb2: clk@01c20058 { +			#clock-cells = <0>; +			compatible = "allwinner,sun4i-a10-apb1-clk"; +			reg = <0x01c20058 0x4>; +			clocks = <&osc32k>, <&osc24M>, <&pll6 0>, <&pll6 0>; +			clock-output-names = "apb2"; +		}; + +		apb2_gates: clk@01c2006c { +			#clock-cells = <1>; +			compatible = "allwinner,sun8i-a23-apb2-gates-clk"; +			reg = <0x01c2006c 0x4>; +			clocks = <&apb2>; +			clock-output-names = "apb2_i2c0", "apb2_i2c1", +					"apb2_i2c2", "apb2_uart0", +					"apb2_uart1", "apb2_uart2", +					"apb2_uart3", "apb2_uart4"; +		}; + +		mmc0_clk: clk@01c20088 { +			#clock-cells = <1>; +			compatible = "allwinner,sun4i-a10-mmc-clk"; +			reg = <0x01c20088 0x4>; +			clocks = <&osc24M>, <&pll6 0>; +			clock-output-names = "mmc0", +					     "mmc0_output", +					     "mmc0_sample"; +		}; + +		mmc1_clk: clk@01c2008c { +			#clock-cells = <1>; +			compatible = "allwinner,sun4i-a10-mmc-clk"; +			reg = <0x01c2008c 0x4>; +			clocks = <&osc24M>, <&pll6 0>; +			clock-output-names = "mmc1", +					     "mmc1_output", +					     "mmc1_sample"; +		}; + +		mmc2_clk: clk@01c20090 { +			#clock-cells = <1>; +			compatible = "allwinner,sun4i-a10-mmc-clk"; +			reg = <0x01c20090 0x4>; +			clocks = <&osc24M>, <&pll6 0>; +			clock-output-names = "mmc2", +					     "mmc2_output", +					     "mmc2_sample"; +		}; + +		usb_clk: clk@01c200cc { +			#clock-cells = <1>; +			#reset-cells = <1>; +			compatible = "allwinner,sun8i-a23-usb-clk"; +			reg = <0x01c200cc 0x4>; +			clocks = <&osc24M>; +			clock-output-names = "usb_phy0", "usb_phy1", "usb_hsic", +					     "usb_hsic_12M", "usb_ohci0"; +		}; +	}; + +	soc@01c00000 { +		compatible = "simple-bus"; +		#address-cells = <1>; +		#size-cells = <1>; +		ranges; + +		dma: dma-controller@01c02000 { +			compatible = "allwinner,sun8i-a23-dma"; +			reg = <0x01c02000 0x1000>; +			interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&ahb1_gates 6>; +			resets = <&ahb1_rst 6>; +			#dma-cells = <1>; +		}; + +		mmc0: mmc@01c0f000 { +			compatible = "allwinner,sun5i-a13-mmc"; +			reg = <0x01c0f000 0x1000>; +			clocks = <&ahb1_gates 8>, +				 <&mmc0_clk 0>, +				 <&mmc0_clk 1>, +				 <&mmc0_clk 2>; +			clock-names = "ahb", +				      "mmc", +				      "output", +				      "sample"; +			resets = <&ahb1_rst 8>; +			reset-names = "ahb"; +			interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		mmc1: mmc@01c10000 { +			compatible = "allwinner,sun5i-a13-mmc"; +			reg = <0x01c10000 0x1000>; +			clocks = <&ahb1_gates 9>, +				 <&mmc1_clk 0>, +				 <&mmc1_clk 1>, +				 <&mmc1_clk 2>; +			clock-names = "ahb", +				      "mmc", +				      "output", +				      "sample"; +			resets = <&ahb1_rst 9>; +			reset-names = "ahb"; +			interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		mmc2: mmc@01c11000 { +			compatible = "allwinner,sun5i-a13-mmc"; +			reg = <0x01c11000 0x1000>; +			clocks = <&ahb1_gates 10>, +				 <&mmc2_clk 0>, +				 <&mmc2_clk 1>, +				 <&mmc2_clk 2>; +			clock-names = "ahb", +				      "mmc", +				      "output", +				      "sample"; +			resets = <&ahb1_rst 10>; +			reset-names = "ahb"; +			interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		pio: pinctrl@01c20800 { +			/* compatible gets set in SoC specific dtsi file */ +			reg = <0x01c20800 0x400>; +			/* interrupts get set in SoC specific dtsi file */ +			clocks = <&apb1_gates 5>; +			gpio-controller; +			interrupt-controller; +			#address-cells = <1>; +			#size-cells = <0>; +			#gpio-cells = <3>; + +			uart0_pins_a: uart0@0 { +				allwinner,pins = "PF2", "PF4"; +				allwinner,function = "uart0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			mmc0_pins_a: mmc0@0 { +				allwinner,pins = "PF0", "PF1", "PF2", +						 "PF3", "PF4", "PF5"; +				allwinner,function = "mmc0"; +				allwinner,drive = <SUN4I_PINCTRL_30_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			mmc1_pins_a: mmc1@0 { +				allwinner,pins = "PG0", "PG1", "PG2", +						 "PG3", "PG4", "PG5"; +				allwinner,function = "mmc1"; +				allwinner,drive = <SUN4I_PINCTRL_30_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			i2c0_pins_a: i2c0@0 { +				allwinner,pins = "PH2", "PH3"; +				allwinner,function = "i2c0"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			i2c1_pins_a: i2c1@0 { +				allwinner,pins = "PH4", "PH5"; +				allwinner,function = "i2c1"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; + +			i2c2_pins_a: i2c2@0 { +				allwinner,pins = "PE12", "PE13"; +				allwinner,function = "i2c2"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; +		}; + +		ahb1_rst: reset@01c202c0 { +			#reset-cells = <1>; +			compatible = "allwinner,sun6i-a31-clock-reset"; +			reg = <0x01c202c0 0xc>; +		}; + +		apb1_rst: reset@01c202d0 { +			#reset-cells = <1>; +			compatible = "allwinner,sun6i-a31-clock-reset"; +			reg = <0x01c202d0 0x4>; +		}; + +		apb2_rst: reset@01c202d8 { +			#reset-cells = <1>; +			compatible = "allwinner,sun6i-a31-clock-reset"; +			reg = <0x01c202d8 0x4>; +		}; + +		timer@01c20c00 { +			compatible = "allwinner,sun4i-a10-timer"; +			reg = <0x01c20c00 0xa0>; +			interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>, +				     <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&osc24M>; +		}; + +		wdt0: watchdog@01c20ca0 { +			compatible = "allwinner,sun6i-a31-wdt"; +			reg = <0x01c20ca0 0x20>; +			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 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01c28000 0x400>; +			interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb2_gates 16>; +			resets = <&apb2_rst 16>; +			dmas = <&dma 6>, <&dma 6>; +			dma-names = "rx", "tx"; +			status = "disabled"; +		}; + +		uart1: serial@01c28400 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01c28400 0x400>; +			interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb2_gates 17>; +			resets = <&apb2_rst 17>; +			dmas = <&dma 7>, <&dma 7>; +			dma-names = "rx", "tx"; +			status = "disabled"; +		}; + +		uart2: serial@01c28800 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01c28800 0x400>; +			interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb2_gates 18>; +			resets = <&apb2_rst 18>; +			dmas = <&dma 8>, <&dma 8>; +			dma-names = "rx", "tx"; +			status = "disabled"; +		}; + +		uart3: serial@01c28c00 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01c28c00 0x400>; +			interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb2_gates 19>; +			resets = <&apb2_rst 19>; +			dmas = <&dma 9>, <&dma 9>; +			dma-names = "rx", "tx"; +			status = "disabled"; +		}; + +		uart4: serial@01c29000 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01c29000 0x400>; +			interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb2_gates 20>; +			resets = <&apb2_rst 20>; +			dmas = <&dma 10>, <&dma 10>; +			dma-names = "rx", "tx"; +			status = "disabled"; +		}; + +		i2c0: i2c@01c2ac00 { +			compatible = "allwinner,sun6i-a31-i2c"; +			reg = <0x01c2ac00 0x400>; +			interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&apb2_gates 0>; +			resets = <&apb2_rst 0>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		i2c1: i2c@01c2b000 { +			compatible = "allwinner,sun6i-a31-i2c"; +			reg = <0x01c2b000 0x400>; +			interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&apb2_gates 1>; +			resets = <&apb2_rst 1>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		i2c2: i2c@01c2b400 { +			compatible = "allwinner,sun6i-a31-i2c"; +			reg = <0x01c2b400 0x400>; +			interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&apb2_gates 2>; +			resets = <&apb2_rst 2>; +			status = "disabled"; +			#address-cells = <1>; +			#size-cells = <0>; +		}; + +		gic: interrupt-controller@01c81000 { +			compatible = "arm,cortex-a7-gic", "arm,cortex-a15-gic"; +			reg = <0x01c81000 0x1000>, +			      <0x01c82000 0x1000>, +			      <0x01c84000 0x2000>, +			      <0x01c86000 0x2000>; +			interrupt-controller; +			#interrupt-cells = <3>; +			interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; +		}; + +		rtc: rtc@01f00000 { +			compatible = "allwinner,sun6i-a31-rtc"; +			reg = <0x01f00000 0x54>; +			interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>, +				     <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>; +		}; + +		prcm@01f01400 { +			compatible = "allwinner,sun8i-a23-prcm"; +			reg = <0x01f01400 0x200>; + +			ar100: ar100_clk { +				compatible = "fixed-factor-clock"; +				#clock-cells = <0>; +				clock-div = <1>; +				clock-mult = <1>; +				clocks = <&osc24M>; +				clock-output-names = "ar100"; +			}; + +			ahb0: ahb0_clk { +				compatible = "fixed-factor-clock"; +				#clock-cells = <0>; +				clock-div = <1>; +				clock-mult = <1>; +				clocks = <&ar100>; +				clock-output-names = "ahb0"; +			}; + +			apb0: apb0_clk { +				compatible = "allwinner,sun8i-a23-apb0-clk"; +				#clock-cells = <0>; +				clocks = <&ahb0>; +				clock-output-names = "apb0"; +			}; + +			apb0_gates: apb0_gates_clk { +				compatible = "allwinner,sun8i-a23-apb0-gates-clk"; +				#clock-cells = <1>; +				clocks = <&apb0>; +				clock-output-names = "apb0_pio", "apb0_timer", +						"apb0_rsb", "apb0_uart", +						"apb0_i2c"; +			}; + +			apb0_rst: apb0_rst { +				compatible = "allwinner,sun6i-a31-clock-reset"; +				#reset-cells = <1>; +			}; +		}; + +		cpucfg@01f01c00 { +			compatible = "allwinner,sun8i-a23-cpuconfig"; +			reg = <0x01f01c00 0x300>; +		}; + +		r_uart: serial@01f02800 { +			compatible = "snps,dw-apb-uart"; +			reg = <0x01f02800 0x400>; +			interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; +			reg-shift = <2>; +			reg-io-width = <4>; +			clocks = <&apb0_gates 4>; +			resets = <&apb0_rst 4>; +			status = "disabled"; +		}; + +		r_pio: pinctrl@01f02c00 { +			compatible = "allwinner,sun8i-a23-r-pinctrl"; +			reg = <0x01f02c00 0x400>; +			interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>; +			clocks = <&apb0_gates 0>; +			resets = <&apb0_rst 0>; +			gpio-controller; +			interrupt-controller; +			#address-cells = <1>; +			#size-cells = <0>; +			#gpio-cells = <3>; + +			r_uart_pins_a: r_uart@0 { +				allwinner,pins = "PL2", "PL3"; +				allwinner,function = "s_uart"; +				allwinner,drive = <SUN4I_PINCTRL_10_MA>; +				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; +			}; +		}; +	}; +}; diff --git a/arch/arm/dts/sun8i-a23-evb.dts b/arch/arm/dts/sun8i-a23-evb.dts new file mode 100644 index 00000000000..610786e635f --- /dev/null +++ b/arch/arm/dts/sun8i-a23-evb.dts @@ -0,0 +1,134 @@ +/* + * Copyright 2015 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. + * + * 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-a23.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 = "Allwinner A23 Evaluation Board"; +	compatible = "allwinner,sun8i-a23-evb", "allwinner,sun8i-a23"; + +	aliases { +		i2c0 = &i2c0; +		i2c1 = &i2c1; +		serial0 = &r_uart; +	}; + +	chosen { +		stdout-path = "serial0:115200n8"; +	}; +}; + +&i2c0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c0_pins_a>; +	status = "okay"; +}; + +&i2c1 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c1_pins_a>; +	status = "okay"; +}; + +&lradc { +	vref-supply = <®_vcc3v0>; +	status = "okay"; + +	button@190 { +		label = "Volume Up"; +		linux,code = <KEY_VOLUMEUP>; +		channel = <0>; +		voltage = <190000>; +	}; + +	button@390 { +		label = "Volume Down"; +		linux,code = <KEY_VOLUMEDOWN>; +		channel = <0>; +		voltage = <390000>; +	}; + +	button@600 { +		label = "Home"; +		linux,code = <KEY_HOME>; +		channel = <0>; +		voltage = <600000>; +	}; +}; + +&mmc0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_evb>; +	vmmc-supply = <®_vcc3v0>; +	bus-width = <4>; +	cd-gpios = <&pio 1 4 GPIO_ACTIVE_HIGH>; /* PB4 */ +	cd-inverted; +	status = "okay"; +}; + +&pio { +	mmc0_cd_pin_evb: mmc0_cd_pin@0 { +		allwinner,pins = "PB4"; +		allwinner,function = "gpio_in"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_PULL_UP>; +	}; +}; + +/* + * The RX line has a non-populated resistance. In order to use it, you + * need to solder R207 on the back of the board in order to close the + * line and get a working UART. + */ +&r_uart { +	pinctrl-names = "default"; +	pinctrl-0 = <&r_uart_pins_a>; +	status = "okay"; +}; diff --git a/arch/arm/dts/sun8i-a23-ippo-q8h-v1.2.dts b/arch/arm/dts/sun8i-a23-ippo-q8h-v1.2.dts index dd31c53e2ab..382d64c3b78 100644 --- a/arch/arm/dts/sun8i-a23-ippo-q8h-v1.2.dts +++ b/arch/arm/dts/sun8i-a23-ippo-q8h-v1.2.dts @@ -16,11 +16,6 @@   *     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 diff --git a/arch/arm/dts/sun8i-a23-ippo-q8h-v5.dts b/arch/arm/dts/sun8i-a23-ippo-q8h-v5.dts index f5658d123f9..95134c69cfc 100644 --- a/arch/arm/dts/sun8i-a23-ippo-q8h-v5.dts +++ b/arch/arm/dts/sun8i-a23-ippo-q8h-v5.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun8i-a23.dtsi b/arch/arm/dts/sun8i-a23.dtsi index 6d6eda398e3..8698f7aa31c 100644 --- a/arch/arm/dts/sun8i-a23.dtsi +++ b/arch/arm/dts/sun8i-a23.dtsi @@ -18,11 +18,6 @@   *     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 @@ -47,217 +42,14 @@   *     OTHER DEALINGS IN THE SOFTWARE.   */ -#include "skeleton.dtsi" - -#include <dt-bindings/interrupt-controller/arm-gic.h> - -#include <dt-bindings/pinctrl/sun4i-a10.h> +#include "sun8i-a23-a33.dtsi"  / { -	interrupt-parent = <&gic>; - -	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"; -		}; -	}; - -	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 { -		enable-method = "allwinner,sun8i-a23"; -		#address-cells = <1>; -		#size-cells = <0>; - -		cpu@0 { -			compatible = "arm,cortex-a7"; -			device_type = "cpu"; -			reg = <0>; -		}; - -		cpu@1 { -			compatible = "arm,cortex-a7"; -			device_type = "cpu"; -			reg = <1>; -		}; -	}; -  	memory {  		reg = <0x40000000 0x40000000>;  	};  	clocks { -		#address-cells = <1>; -		#size-cells = <1>; -		ranges; - -		osc24M: osc24M_clk { -			#clock-cells = <0>; -			compatible = "fixed-clock"; -			clock-frequency = <24000000>; -			clock-output-names = "osc24M"; -		}; - -		osc32k: osc32k_clk { -			#clock-cells = <0>; -			compatible = "fixed-clock"; -			clock-frequency = <32768>; -			clock-output-names = "osc32k"; -		}; - -		pll1: clk@01c20000 { -			#clock-cells = <0>; -			compatible = "allwinner,sun8i-a23-pll1-clk"; -			reg = <0x01c20000 0x4>; -			clocks = <&osc24M>; -			clock-output-names = "pll1"; -		}; - -		/* dummy clock until actually implemented */ -		pll5: pll5_clk { -			#clock-cells = <0>; -			compatible = "fixed-clock"; -			clock-frequency = <0>; -			clock-output-names = "pll5"; -		}; - -		pll6: clk@01c20028 { -			#clock-cells = <1>; -			compatible = "allwinner,sun6i-a31-pll6-clk"; -			reg = <0x01c20028 0x4>; -			clocks = <&osc24M>; -			clock-output-names = "pll6", "pll6x2"; -		}; - -		cpu: cpu_clk@01c20050 { -			#clock-cells = <0>; -			compatible = "allwinner,sun4i-a10-cpu-clk"; -			reg = <0x01c20050 0x4>; - -			/* -			 * PLL1 is listed twice here. -			 * While it looks suspicious, it's actually documented -			 * that way both in the datasheet and in the code from -			 * Allwinner. -			 */ -			clocks = <&osc32k>, <&osc24M>, <&pll1>, <&pll1>; -			clock-output-names = "cpu"; -		}; - -		axi: axi_clk@01c20050 { -			#clock-cells = <0>; -			compatible = "allwinner,sun8i-a23-axi-clk"; -			reg = <0x01c20050 0x4>; -			clocks = <&cpu>; -			clock-output-names = "axi"; -		}; - -		ahb1: ahb1_clk@01c20054 { -			#clock-cells = <0>; -			compatible = "allwinner,sun6i-a31-ahb1-clk"; -			reg = <0x01c20054 0x4>; -			clocks = <&osc32k>, <&osc24M>, <&axi>, <&pll6 0>; -			clock-output-names = "ahb1"; -		}; - -		apb1: apb1_clk@01c20054 { -			#clock-cells = <0>; -			compatible = "allwinner,sun4i-a10-apb0-clk"; -			reg = <0x01c20054 0x4>; -			clocks = <&ahb1>; -			clock-output-names = "apb1"; -		}; - -		ahb1_gates: clk@01c20060 { -			#clock-cells = <1>; -			compatible = "allwinner,sun8i-a23-ahb1-gates-clk"; -			reg = <0x01c20060 0x8>; -			clocks = <&ahb1>; -			clock-output-names = "ahb1_mipidsi", "ahb1_dma", -					"ahb1_mmc0", "ahb1_mmc1", "ahb1_mmc2", -					"ahb1_nand", "ahb1_sdram", -					"ahb1_hstimer", "ahb1_spi0", -					"ahb1_spi1", "ahb1_otg", "ahb1_ehci", -					"ahb1_ohci", "ahb1_ve", "ahb1_lcd", -					"ahb1_csi", "ahb1_be",	"ahb1_fe", -					"ahb1_gpu", "ahb1_spinlock", -					"ahb1_drc"; -		}; - -		apb1_gates: clk@01c20068 { -			#clock-cells = <1>; -			compatible = "allwinner,sun8i-a23-apb1-gates-clk"; -			reg = <0x01c20068 0x4>; -			clocks = <&apb1>; -			clock-output-names = "apb1_codec", "apb1_pio", -					"apb1_daudio0",	"apb1_daudio1"; -		}; - -		apb2: clk@01c20058 { -			#clock-cells = <0>; -			compatible = "allwinner,sun4i-a10-apb1-clk"; -			reg = <0x01c20058 0x4>; -			clocks = <&osc32k>, <&osc24M>, <&pll6 0>, <&pll6 0>; -			clock-output-names = "apb2"; -		}; - -		apb2_gates: clk@01c2006c { -			#clock-cells = <1>; -			compatible = "allwinner,sun8i-a23-apb2-gates-clk"; -			reg = <0x01c2006c 0x4>; -			clocks = <&apb2>; -			clock-output-names = "apb2_i2c0", "apb2_i2c1", -					"apb2_i2c2", "apb2_uart0", -					"apb2_uart1", "apb2_uart2", -					"apb2_uart3", "apb2_uart4"; -		}; - -		mmc0_clk: clk@01c20088 { -			#clock-cells = <1>; -			compatible = "allwinner,sun4i-a10-mmc-clk"; -			reg = <0x01c20088 0x4>; -			clocks = <&osc24M>, <&pll6 0>; -			clock-output-names = "mmc0", -					     "mmc0_output", -					     "mmc0_sample"; -		}; - -		mmc1_clk: clk@01c2008c { -			#clock-cells = <1>; -			compatible = "allwinner,sun4i-a10-mmc-clk"; -			reg = <0x01c2008c 0x4>; -			clocks = <&osc24M>, <&pll6 0>; -			clock-output-names = "mmc1", -					     "mmc1_output", -					     "mmc1_sample"; -		}; - -		mmc2_clk: clk@01c20090 { -			#clock-cells = <1>; -			compatible = "allwinner,sun4i-a10-mmc-clk"; -			reg = <0x01c20090 0x4>; -			clocks = <&osc24M>, <&pll6 0>; -			clock-output-names = "mmc2", -					     "mmc2_output", -					     "mmc2_sample"; -		}; -  		mbus_clk: clk@01c2015c {  			#clock-cells = <0>;  			compatible = "allwinner,sun8i-a23-mbus-clk"; @@ -266,368 +58,11 @@  			clock-output-names = "mbus";  		};  	}; +}; -	soc@01c00000 { -		compatible = "simple-bus"; -		#address-cells = <1>; -		#size-cells = <1>; -		ranges; - -		dma: dma-controller@01c02000 { -			compatible = "allwinner,sun8i-a23-dma"; -			reg = <0x01c02000 0x1000>; -			interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&ahb1_gates 6>; -			resets = <&ahb1_rst 6>; -			#dma-cells = <1>; -		}; - -		mmc0: mmc@01c0f000 { -			compatible = "allwinner,sun5i-a13-mmc"; -			reg = <0x01c0f000 0x1000>; -			clocks = <&ahb1_gates 8>, -				 <&mmc0_clk 0>, -				 <&mmc0_clk 1>, -				 <&mmc0_clk 2>; -			clock-names = "ahb", -				      "mmc", -				      "output", -				      "sample"; -			resets = <&ahb1_rst 8>; -			reset-names = "ahb"; -			interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		mmc1: mmc@01c10000 { -			compatible = "allwinner,sun5i-a13-mmc"; -			reg = <0x01c10000 0x1000>; -			clocks = <&ahb1_gates 9>, -				 <&mmc1_clk 0>, -				 <&mmc1_clk 1>, -				 <&mmc1_clk 2>; -			clock-names = "ahb", -				      "mmc", -				      "output", -				      "sample"; -			resets = <&ahb1_rst 9>; -			reset-names = "ahb"; -			interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		mmc2: mmc@01c11000 { -			compatible = "allwinner,sun5i-a13-mmc"; -			reg = <0x01c11000 0x1000>; -			clocks = <&ahb1_gates 10>, -				 <&mmc2_clk 0>, -				 <&mmc2_clk 1>, -				 <&mmc2_clk 2>; -			clock-names = "ahb", -				      "mmc", -				      "output", -				      "sample"; -			resets = <&ahb1_rst 10>; -			reset-names = "ahb"; -			interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		pio: pinctrl@01c20800 { -			compatible = "allwinner,sun8i-a23-pinctrl"; -			reg = <0x01c20800 0x400>; -			interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>, -				     <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>, -				     <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&apb1_gates 5>; -			gpio-controller; -			interrupt-controller; -			#address-cells = <1>; -			#size-cells = <0>; -			#gpio-cells = <3>; - -			uart0_pins_a: uart0@0 { -				allwinner,pins = "PF2", "PF4"; -				allwinner,function = "uart0"; -				allwinner,drive = <SUN4I_PINCTRL_10_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; - -			mmc0_pins_a: mmc0@0 { -				allwinner,pins = "PF0","PF1","PF2","PF3","PF4","PF5"; -				allwinner,function = "mmc0"; -				allwinner,drive = <SUN4I_PINCTRL_30_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; - -			mmc1_pins_a: mmc1@0 { -				allwinner,pins = "PG0","PG1","PG2","PG3","PG4","PG5"; -				allwinner,function = "mmc1"; -				allwinner,drive = <SUN4I_PINCTRL_30_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; - -			i2c0_pins_a: i2c0@0 { -				allwinner,pins = "PH2", "PH3"; -				allwinner,function = "i2c0"; -				allwinner,drive = <SUN4I_PINCTRL_10_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; - -			i2c1_pins_a: i2c1@0 { -				allwinner,pins = "PH4", "PH5"; -				allwinner,function = "i2c1"; -				allwinner,drive = <SUN4I_PINCTRL_10_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; - -			i2c2_pins_a: i2c2@0 { -				allwinner,pins = "PE12", "PE13"; -				allwinner,function = "i2c2"; -				allwinner,drive = <SUN4I_PINCTRL_10_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; -		}; - -		ahb1_rst: reset@01c202c0 { -			#reset-cells = <1>; -			compatible = "allwinner,sun6i-a31-clock-reset"; -			reg = <0x01c202c0 0xc>; -		}; - -		apb1_rst: reset@01c202d0 { -			#reset-cells = <1>; -			compatible = "allwinner,sun6i-a31-clock-reset"; -			reg = <0x01c202d0 0x4>; -		}; - -		apb2_rst: reset@01c202d8 { -			#reset-cells = <1>; -			compatible = "allwinner,sun6i-a31-clock-reset"; -			reg = <0x01c202d8 0x4>; -		}; - -		timer@01c20c00 { -			compatible = "allwinner,sun4i-a10-timer"; -			reg = <0x01c20c00 0xa0>; -			interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>, -				     <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&osc24M>; -		}; - -		wdt0: watchdog@01c20ca0 { -			compatible = "allwinner,sun6i-a31-wdt"; -			reg = <0x01c20ca0 0x20>; -			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 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01c28000 0x400>; -			interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb2_gates 16>; -			resets = <&apb2_rst 16>; -			dmas = <&dma 6>, <&dma 6>; -			dma-names = "rx", "tx"; -			status = "disabled"; -		}; - -		uart1: serial@01c28400 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01c28400 0x400>; -			interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb2_gates 17>; -			resets = <&apb2_rst 17>; -			dmas = <&dma 7>, <&dma 7>; -			dma-names = "rx", "tx"; -			status = "disabled"; -		}; - -		uart2: serial@01c28800 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01c28800 0x400>; -			interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb2_gates 18>; -			resets = <&apb2_rst 18>; -			dmas = <&dma 8>, <&dma 8>; -			dma-names = "rx", "tx"; -			status = "disabled"; -		}; - -		uart3: serial@01c28c00 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01c28c00 0x400>; -			interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb2_gates 19>; -			resets = <&apb2_rst 19>; -			dmas = <&dma 9>, <&dma 9>; -			dma-names = "rx", "tx"; -			status = "disabled"; -		}; - -		uart4: serial@01c29000 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01c29000 0x400>; -			interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb2_gates 20>; -			resets = <&apb2_rst 20>; -			dmas = <&dma 10>, <&dma 10>; -			dma-names = "rx", "tx"; -			status = "disabled"; -		}; - -		i2c0: i2c@01c2ac00 { -			compatible = "allwinner,sun6i-a31-i2c"; -			reg = <0x01c2ac00 0x400>; -			interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&apb2_gates 0>; -			resets = <&apb2_rst 0>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		i2c1: i2c@01c2b000 { -			compatible = "allwinner,sun6i-a31-i2c"; -			reg = <0x01c2b000 0x400>; -			interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&apb2_gates 1>; -			resets = <&apb2_rst 1>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		i2c2: i2c@01c2b400 { -			compatible = "allwinner,sun6i-a31-i2c"; -			reg = <0x01c2b400 0x400>; -			interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&apb2_gates 2>; -			resets = <&apb2_rst 2>; -			status = "disabled"; -			#address-cells = <1>; -			#size-cells = <0>; -		}; - -		gic: interrupt-controller@01c81000 { -			compatible = "arm,cortex-a7-gic", "arm,cortex-a15-gic"; -			reg = <0x01c81000 0x1000>, -			      <0x01c82000 0x1000>, -			      <0x01c84000 0x2000>, -			      <0x01c86000 0x2000>; -			interrupt-controller; -			#interrupt-cells = <3>; -			interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; -		}; - -		rtc: rtc@01f00000 { -			compatible = "allwinner,sun6i-a31-rtc"; -			reg = <0x01f00000 0x54>; -			interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>, -				     <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>; -		}; - -		prcm@01f01400 { -			compatible = "allwinner,sun8i-a23-prcm"; -			reg = <0x01f01400 0x200>; - -			ar100: ar100_clk { -				compatible = "fixed-factor-clock"; -				#clock-cells = <0>; -				clock-div = <1>; -				clock-mult = <1>; -				clocks = <&osc24M>; -				clock-output-names = "ar100"; -			}; - -			ahb0: ahb0_clk { -				compatible = "fixed-factor-clock"; -				#clock-cells = <0>; -				clock-div = <1>; -				clock-mult = <1>; -				clocks = <&ar100>; -				clock-output-names = "ahb0"; -			}; - -			apb0: apb0_clk { -				compatible = "allwinner,sun8i-a23-apb0-clk"; -				#clock-cells = <0>; -				clocks = <&ahb0>; -				clock-output-names = "apb0"; -			}; - -			apb0_gates: apb0_gates_clk { -				compatible = "allwinner,sun8i-a23-apb0-gates-clk"; -				#clock-cells = <1>; -				clocks = <&apb0>; -				clock-output-names = "apb0_pio", "apb0_timer", -						"apb0_rsb", "apb0_uart", -						"apb0_i2c"; -			}; - -			apb0_rst: apb0_rst { -				compatible = "allwinner,sun6i-a31-clock-reset"; -				#reset-cells = <1>; -			}; -		}; - -		cpucfg@01f01c00 { -			compatible = "allwinner,sun8i-a23-cpuconfig"; -			reg = <0x01f01c00 0x300>; -		}; - -		r_uart: serial@01f02800 { -			compatible = "snps,dw-apb-uart"; -			reg = <0x01f02800 0x400>; -			interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; -			reg-shift = <2>; -			reg-io-width = <4>; -			clocks = <&apb0_gates 4>; -			resets = <&apb0_rst 4>; -			status = "disabled"; -		}; - -		r_pio: pinctrl@01f02c00 { -			compatible = "allwinner,sun8i-a23-r-pinctrl"; -			reg = <0x01f02c00 0x400>; -			interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>; -			clocks = <&apb0_gates 0>; -			resets = <&apb0_rst 0>; -			gpio-controller; -			interrupt-controller; -			#address-cells = <1>; -			#size-cells = <0>; -			#gpio-cells = <3>; - -			r_uart_pins_a: r_uart@0 { -				allwinner,pins = "PL2", "PL3"; -				allwinner,function = "s_uart"; -				allwinner,drive = <SUN4I_PINCTRL_10_MA>; -				allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; -			}; -		}; -	}; +&pio { +	compatible = "allwinner,sun8i-a23-pinctrl"; +	interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>, +		     <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>, +		     <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;  }; diff --git a/arch/arm/dts/sun8i-a33-astar-mid756.dts b/arch/arm/dts/sun8i-a33-astar-mid756.dts deleted file mode 100644 index d9ce4465f0d..00000000000 --- a/arch/arm/dts/sun8i-a33-astar-mid756.dts +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright 2015 Hans de Goede <hdegoede@redhat.com> - * - * Minimal dts file for the Astar MID756 for u-boot only - * - * SPDX-License-Identifier:     GPL-2.0+ or X11 - */ - -/dts-v1/; -#include "sun8i-a23.dtsi" - -/ { -	model = "Astar MID756"; -	compatible = "astar,mid756", "allwinner,sun8i-a23"; - -	aliases { -		serial0 = &r_uart; -	}; - -	chosen { -		stdout-path = "serial0:115200n8"; -	}; -}; - -&r_uart { -	pinctrl-names = "default"; -	pinctrl-0 = <&r_uart_pins_a>; -	status = "okay"; -}; diff --git a/arch/arm/dts/sun8i-a33-et-q8-v1.6.dts b/arch/arm/dts/sun8i-a33-et-q8-v1.6.dts new file mode 100644 index 00000000000..19db844863b --- /dev/null +++ b/arch/arm/dts/sun8i-a33-et-q8-v1.6.dts @@ -0,0 +1,88 @@ +/* + * Copyright 2015 Vishnu Patekar + * Vishnu Patekar <vishnupatekar0510@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. + * + * 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-a33.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 = "ET Q8 Quad Core Tablet (v1.6)"; +	compatible = "et,q8-v1.6", "allwinner,sun8i-a33"; + +	aliases { +		serial0 = &uart0; +	}; + +	chosen { +		stdout-path = "serial0:115200n8"; +	}; +}; + +&lradc { +	vref-supply = <®_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>; +	}; +}; + +&uart0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&uart0_pins_a>; +	status = "okay"; +}; diff --git a/arch/arm/dts/sun8i-a33-ga10h-v1.1.dts b/arch/arm/dts/sun8i-a33-ga10h-v1.1.dts new file mode 100644 index 00000000000..866703355b9 --- /dev/null +++ b/arch/arm/dts/sun8i-a33-ga10h-v1.1.dts @@ -0,0 +1,125 @@ +/* + * 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. + * + * 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-a33.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 = "Allwinner GA10H Quad Core Tablet (v1.1)"; +	compatible = "allwinner,ga10h-v1.1", "allwinner,sun8i-a33"; + +	aliases { +		serial0 = &r_uart; +	}; + +	chosen { +		stdout-path = "serial0:115200n8"; +	}; +}; + +&i2c0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c0_pins_a>; +	status = "okay"; +}; + +&i2c1 { +	pinctrl-names = "default"; +	pinctrl-0 = <&i2c1_pins_a>; +	status = "okay"; +}; + +&lradc { +	vref-supply = <®_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>; +	}; + +	button@600 { +		label = "Back"; +		linux,code = <KEY_BACK>; +		channel = <0>; +		voltage = <600000>; +	}; +}; + +&mmc0 { +	pinctrl-names = "default"; +	pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_q8h>; +	vmmc-supply = <®_vcc3v0>; +	bus-width = <4>; +	cd-gpios = <&pio 1 4 GPIO_ACTIVE_HIGH>; /* PB4 */ +	cd-inverted; +	status = "okay"; +}; + +&pio { +	mmc0_cd_pin_q8h: mmc0_cd_pin@0 { +		allwinner,pins = "PB4"; +		allwinner,function = "gpio_in"; +		allwinner,drive = <SUN4I_PINCTRL_10_MA>; +		allwinner,pull = <SUN4I_PINCTRL_PULL_UP>; +	}; +}; + +&r_uart { +	pinctrl-names = "default"; +	pinctrl-0 = <&r_uart_pins_a>; +	status = "okay"; +}; diff --git a/arch/arm/dts/sun8i-a33-ippo-q8h-v1.2-lcd1024x600.dts b/arch/arm/dts/sun8i-a33-ippo-q8h-v1.2-lcd1024x600.dts index 4a431874fbc..97771495c21 100644 --- a/arch/arm/dts/sun8i-a33-ippo-q8h-v1.2-lcd1024x600.dts +++ b/arch/arm/dts/sun8i-a33-ippo-q8h-v1.2-lcd1024x600.dts @@ -7,7 +7,7 @@   */  /dts-v1/; -#include "sun8i-a23.dtsi" +#include "sun8i-a33.dtsi"  / {  	model = "Ippo Q8H V1.2 (A33, 1024x600)"; diff --git a/arch/arm/dts/sun8i-a33.dtsi b/arch/arm/dts/sun8i-a33.dtsi new file mode 100644 index 00000000000..9b43bc6e792 --- /dev/null +++ b/arch/arm/dts/sun8i-a33.dtsi @@ -0,0 +1,89 @@ +/* + * Copyright 2014 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. + * + * 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. + */ + +#include "sun8i-a23-a33.dtsi" + +/ { +	cpus { +		cpu@2 { +			compatible = "arm,cortex-a7"; +			device_type = "cpu"; +			reg = <2>; +		}; + +		cpu@3 { +			compatible = "arm,cortex-a7"; +			device_type = "cpu"; +			reg = <3>; +		}; +	}; + +	memory { +		reg = <0x40000000 0x80000000>; +	}; + +	clocks { +		/* Dummy clock for pll11 (DDR1) until actually implemented */ +		pll11: pll11_clk { +			#clock-cells = <0>; +			compatible = "fixed-clock"; +			clock-frequency = <0>; +			clock-output-names = "pll11"; +		}; + +		mbus_clk: clk@01c2015c { +			#clock-cells = <0>; +			compatible = "allwinner,sun8i-a23-mbus-clk"; +			reg = <0x01c2015c 0x4>; +			clocks = <&osc24M>, <&pll6 1>, <&pll5>, <&pll11>; +			clock-output-names = "mbus"; +		}; +	}; +}; + +&pio { +	compatible = "allwinner,sun8i-a33-pinctrl"; +	interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>, +		     <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>; +}; diff --git a/arch/arm/dts/sun9i-a80-optimus.dts b/arch/arm/dts/sun9i-a80-optimus.dts index e463138a4d0..6ce4b5e8b61 100644 --- a/arch/arm/dts/sun9i-a80-optimus.dts +++ b/arch/arm/dts/sun9i-a80-optimus.dts @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/sun9i-a80.dtsi b/arch/arm/dts/sun9i-a80.dtsi index d3dece2eea7..a43ad779ee2 100644 --- a/arch/arm/dts/sun9i-a80.dtsi +++ b/arch/arm/dts/sun9i-a80.dtsi @@ -18,11 +18,6 @@   *     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 @@ -289,7 +284,7 @@  					"ahb0_ss", "ahb0_sd", "ahb0_nand1",  					"ahb0_nand0", "ahb0_sdram",  					"ahb0_mipi_hsi", "ahb0_sata", "ahb0_ts", -					"ahb0_spi0","ahb0_spi1", "ahb0_spi2", +					"ahb0_spi0", "ahb0_spi1", "ahb0_spi2",  					"ahb0_spi3";  		}; @@ -570,6 +565,12 @@  			clocks = <&osc24M>;  		}; +		wdt: watchdog@06000ca0 { +			compatible = "allwinner,sun6i-a31-wdt"; +			reg = <0x06000ca0 0x20>; +			interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>; +		}; +  		pio: pinctrl@06000800 {  			compatible = "allwinner,sun9i-a80-pinctrl";  			reg = <0x06000800 0x400>; diff --git a/arch/arm/dts/sunxi-common-regulators.dtsi b/arch/arm/dts/sunxi-common-regulators.dtsi index e02baa66b33..51cc8383f70 100644 --- a/arch/arm/dts/sunxi-common-regulators.dtsi +++ b/arch/arm/dts/sunxi-common-regulators.dtsi @@ -18,11 +18,6 @@   *     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 diff --git a/arch/arm/dts/tegra124-nyan-big.dts b/arch/arm/dts/tegra124-nyan-big.dts index 5a39e93c68c..8be6adbf07c 100644 --- a/arch/arm/dts/tegra124-nyan-big.dts +++ b/arch/arm/dts/tegra124-nyan-big.dts @@ -163,12 +163,15 @@  	spi@7000d400 {  		status = "okay"; +		spi-deactivate-delay = <200>; +		spi-max-frequency = <3000000>;  		cros_ec: cros-ec@0 {  			compatible = "google,cros-ec-spi";  			spi-max-frequency = <3000000>;  			interrupt-parent = <&gpio>;  			interrupts = <TEGRA_GPIO(C, 7) IRQ_TYPE_LEVEL_LOW>; +			ec-interrupt = <&gpio TEGRA_GPIO(C, 7) GPIO_ACTIVE_LOW>;  			reg = <0>;  			google,cros-ec-spi-msg-delay = <2000>; diff --git a/arch/arm/dts/vf-colibri.dtsi b/arch/arm/dts/vf-colibri.dtsi new file mode 100644 index 00000000000..7a8e9bee338 --- /dev/null +++ b/arch/arm/dts/vf-colibri.dtsi @@ -0,0 +1,21 @@ +/* + * Copyright 2014 Toradex AG + * + * SPDX-License-Identifier:     GPL-2.0+ or X11 + * + * This program 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. + */ +#include "vf.dtsi" + +&dspi1 { +	status = "okay"; +	bus-num = <1>; + +	spi_cmd: sspi@0 { +		reg = <0>; +		spi-max-frequency = <50000000>; +	}; +}; diff --git a/arch/arm/dts/vf.dtsi b/arch/arm/dts/vf.dtsi new file mode 100644 index 00000000000..78706e118e6 --- /dev/null +++ b/arch/arm/dts/vf.dtsi @@ -0,0 +1,100 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:     GPL-2.0+ or X11 + * + * This program 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. + */ +/include/ "skeleton.dtsi" + +/ { +	aliases { +		gpio0 = &gpio0; +		gpio1 = &gpio1; +		gpio2 = &gpio2; +		gpio3 = &gpio3; +		gpio4 = &gpio4; +		spi0 = &dspi0; +		spi1 = &dspi1; +	}; + +	soc { +		#address-cells = <1>; +		#size-cells = <1>; +		compatible = "simple-bus"; +		ranges; + +		aips0: aips-bus@40000000 { +			compatible = "fsl,aips-bus", "simple-bus"; +			#address-cells = <1>; +			#size-cells = <1>; +			ranges; + +			dspi0: dspi0@4002c000 { +				#address-cells = <1>; +				#size-cells = <0>; +				compatible = "fsl,vf610-dspi"; +				reg = <0x4002c000 0x1000>; +				num-cs = <5>; +				status = "disabled"; +			}; + +			dspi1: dspi1@4002d000 { +				#address-cells = <1>; +				#size-cells = <0>; +				compatible = "fsl,vf610-dspi"; +				reg = <0x4002d000 0x1000>; +				num-cs = <5>; +				status = "disabled"; +			}; + +			qspi0: quadspi@40044000 { +				#address-cells = <1>; +				#size-cells = <0>; +				compatible = "fsl,vf610-qspi"; +				reg = <0x40044000 0x1000>; +				status = "disabled"; +			}; + +			gpio0: gpio@40049000 { +				compatible = "fsl,vf610-gpio"; +				reg = <0x400ff000 0x40>; +				#gpio-cells = <2>; +			}; + +			gpio1: gpio@4004a000 { +				compatible = "fsl,vf610-gpio"; +				reg = <0x400ff040 0x40>; +				#gpio-cells = <2>; +			}; + +			gpio2: gpio@4004b000 { +				compatible = "fsl,vf610-gpio"; +				reg = <0x400ff080 0x40>; +				#gpio-cells = <2>; +			}; + +			gpio3: gpio@4004c000 { +				compatible = "fsl,vf610-gpio"; +				reg = <0x400ff0c0 0x40>; +				#gpio-cells = <2>; +			}; + +			gpio4: gpio@4004d000 { +				compatible = "fsl,vf610-gpio"; +				reg = <0x400ff100 0x40>; +				#gpio-cells = <2>; +			}; +		}; + +		aips1: aips-bus@40080000 { +			compatible = "fsl,aips-bus", "simple-bus"; +			#address-cells = <1>; +			#size-cells = <1>; +			ranges; +		}; +	}; +}; diff --git a/arch/arm/dts/vf500-colibri.dts b/arch/arm/dts/vf500-colibri.dts new file mode 100644 index 00000000000..e3833064d20 --- /dev/null +++ b/arch/arm/dts/vf500-colibri.dts @@ -0,0 +1,18 @@ +/* + * Copyright 2014 Toradex AG + * + * SPDX-License-Identifier:     GPL-2.0+ or X11 + * + * This program 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. + */ + +/dts-v1/; +#include "vf-colibri.dtsi" + +/ { +	model = "Toradex Colibri VF50"; +	compatible = "toradex,vf500-colibri_vf50", "toradex,vf500-colibri_vf50", "fsl,vf500"; +}; diff --git a/arch/arm/dts/vf610-colibri.dts b/arch/arm/dts/vf610-colibri.dts new file mode 100644 index 00000000000..63bb3f4ee77 --- /dev/null +++ b/arch/arm/dts/vf610-colibri.dts @@ -0,0 +1,18 @@ +/* + * Copyright 2014 Toradex AG + * + * SPDX-License-Identifier:     GPL-2.0+ or X11 + * + * This program 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. + */ + +/dts-v1/; +#include "vf-colibri.dtsi" + +/ { +	model = "Toradex Colibri VF61"; +	compatible = "toradex,vf610-colibri_vf61", "toradex,vf610-colibri_vf61", "fsl,vf610"; +}; | 
