1*724ba675SRob Herring/*
2*724ba675SRob Herring * Copyright 2013 Maxime Ripard
3*724ba675SRob Herring *
4*724ba675SRob Herring * Maxime Ripard <maxime.ripard@free-electrons.com>
5*724ba675SRob Herring *
6*724ba675SRob Herring * This file is dual-licensed: you can use it either under the terms
7*724ba675SRob Herring * of the GPL or the X11 license, at your option. Note that this dual
8*724ba675SRob Herring * licensing only applies to this file, and not this project as a
9*724ba675SRob Herring * whole.
10*724ba675SRob Herring *
11*724ba675SRob Herring *  a) This library is free software; you can redistribute it and/or
12*724ba675SRob Herring *     modify it under the terms of the GNU General Public License as
13*724ba675SRob Herring *     published by the Free Software Foundation; either version 2 of the
14*724ba675SRob Herring *     License, or (at your option) any later version.
15*724ba675SRob Herring *
16*724ba675SRob Herring *     This library is distributed in the hope that it will be useful,
17*724ba675SRob Herring *     but WITHOUT ANY WARRANTY; without even the implied warranty of
18*724ba675SRob Herring *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19*724ba675SRob Herring *     GNU General Public License for more details.
20*724ba675SRob Herring *
21*724ba675SRob Herring * Or, alternatively,
22*724ba675SRob Herring *
23*724ba675SRob Herring *  b) Permission is hereby granted, free of charge, to any person
24*724ba675SRob Herring *     obtaining a copy of this software and associated documentation
25*724ba675SRob Herring *     files (the "Software"), to deal in the Software without
26*724ba675SRob Herring *     restriction, including without limitation the rights to use,
27*724ba675SRob Herring *     copy, modify, merge, publish, distribute, sublicense, and/or
28*724ba675SRob Herring *     sell copies of the Software, and to permit persons to whom the
29*724ba675SRob Herring *     Software is furnished to do so, subject to the following
30*724ba675SRob Herring *     conditions:
31*724ba675SRob Herring *
32*724ba675SRob Herring *     The above copyright notice and this permission notice shall be
33*724ba675SRob Herring *     included in all copies or substantial portions of the Software.
34*724ba675SRob Herring *
35*724ba675SRob Herring *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
36*724ba675SRob Herring *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
37*724ba675SRob Herring *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
38*724ba675SRob Herring *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
39*724ba675SRob Herring *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
40*724ba675SRob Herring *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
41*724ba675SRob Herring *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
42*724ba675SRob Herring *     OTHER DEALINGS IN THE SOFTWARE.
43*724ba675SRob Herring */
44*724ba675SRob Herring
45*724ba675SRob Herring#include "sun5i.dtsi"
46*724ba675SRob Herring
47*724ba675SRob Herring#include <dt-bindings/dma/sun4i-a10.h>
48*724ba675SRob Herring
49*724ba675SRob Herring/ {
50*724ba675SRob Herring	aliases {
51*724ba675SRob Herring		ethernet0 = &emac;
52*724ba675SRob Herring	};
53*724ba675SRob Herring
54*724ba675SRob Herring	chosen {
55*724ba675SRob Herring		#address-cells = <1>;
56*724ba675SRob Herring		#size-cells = <1>;
57*724ba675SRob Herring		ranges;
58*724ba675SRob Herring
59*724ba675SRob Herring		framebuffer-lcd0-hdmi {
60*724ba675SRob Herring			compatible = "allwinner,simple-framebuffer",
61*724ba675SRob Herring				     "simple-framebuffer";
62*724ba675SRob Herring			allwinner,pipeline = "de_be0-lcd0-hdmi";
63*724ba675SRob Herring			clocks = <&ccu CLK_AHB_LCD>, <&ccu CLK_AHB_HDMI>,
64*724ba675SRob Herring				 <&ccu CLK_AHB_DE_BE>, <&ccu CLK_DRAM_DE_BE>,
65*724ba675SRob Herring				 <&ccu CLK_DE_BE>, <&ccu CLK_HDMI>;
66*724ba675SRob Herring			status = "disabled";
67*724ba675SRob Herring		};
68*724ba675SRob Herring	};
69*724ba675SRob Herring
70*724ba675SRob Herring	display-engine {
71*724ba675SRob Herring		compatible = "allwinner,sun5i-a10s-display-engine";
72*724ba675SRob Herring		allwinner,pipelines = <&fe0>;
73*724ba675SRob Herring	};
74*724ba675SRob Herring
75*724ba675SRob Herring	soc {
76*724ba675SRob Herring		hdmi: hdmi@1c16000 {
77*724ba675SRob Herring			compatible = "allwinner,sun5i-a10s-hdmi";
78*724ba675SRob Herring			reg = <0x01c16000 0x1000>;
79*724ba675SRob Herring			interrupts = <58>;
80*724ba675SRob Herring			clocks = <&ccu CLK_AHB_HDMI>, <&ccu CLK_HDMI>,
81*724ba675SRob Herring				 <&ccu CLK_PLL_VIDEO0_2X>,
82*724ba675SRob Herring				 <&ccu CLK_PLL_VIDEO1_2X>;
83*724ba675SRob Herring			clock-names = "ahb", "mod", "pll-0", "pll-1";
84*724ba675SRob Herring			dmas = <&dma SUN4I_DMA_NORMAL 16>,
85*724ba675SRob Herring			       <&dma SUN4I_DMA_NORMAL 16>,
86*724ba675SRob Herring			       <&dma SUN4I_DMA_DEDICATED 24>;
87*724ba675SRob Herring			dma-names = "ddc-tx", "ddc-rx", "audio-tx";
88*724ba675SRob Herring			status = "disabled";
89*724ba675SRob Herring
90*724ba675SRob Herring			ports {
91*724ba675SRob Herring				#address-cells = <1>;
92*724ba675SRob Herring				#size-cells = <0>;
93*724ba675SRob Herring
94*724ba675SRob Herring				hdmi_in: port@0 {
95*724ba675SRob Herring					reg = <0>;
96*724ba675SRob Herring
97*724ba675SRob Herring					hdmi_in_tcon0: endpoint {
98*724ba675SRob Herring						remote-endpoint = <&tcon0_out_hdmi>;
99*724ba675SRob Herring					};
100*724ba675SRob Herring				};
101*724ba675SRob Herring
102*724ba675SRob Herring				hdmi_out: port@1 {
103*724ba675SRob Herring					reg = <1>;
104*724ba675SRob Herring				};
105*724ba675SRob Herring			};
106*724ba675SRob Herring		};
107*724ba675SRob Herring
108*724ba675SRob Herring		pwm: pwm@1c20e00 {
109*724ba675SRob Herring			compatible = "allwinner,sun5i-a10s-pwm";
110*724ba675SRob Herring			reg = <0x01c20e00 0xc>;
111*724ba675SRob Herring			clocks = <&ccu CLK_HOSC>;
112*724ba675SRob Herring			#pwm-cells = <3>;
113*724ba675SRob Herring			status = "disabled";
114*724ba675SRob Herring		};
115*724ba675SRob Herring	};
116*724ba675SRob Herring};
117*724ba675SRob Herring
118*724ba675SRob Herring&ccu {
119*724ba675SRob Herring	compatible = "allwinner,sun5i-a10s-ccu";
120*724ba675SRob Herring};
121*724ba675SRob Herring
122*724ba675SRob Herring&mmc1 {
123*724ba675SRob Herring	pinctrl-names = "default";
124*724ba675SRob Herring	pinctrl-0 = <&mmc1_pins>;
125*724ba675SRob Herring};
126*724ba675SRob Herring
127*724ba675SRob Herring&pio {
128*724ba675SRob Herring	compatible = "allwinner,sun5i-a10s-pinctrl";
129*724ba675SRob Herring
130*724ba675SRob Herring	uart0_pb_pins: uart0-pb-pins {
131*724ba675SRob Herring		pins = "PB19", "PB20";
132*724ba675SRob Herring		function = "uart0";
133*724ba675SRob Herring	};
134*724ba675SRob Herring
135*724ba675SRob Herring	uart2_pc_pins: uart2-pc-pins {
136*724ba675SRob Herring		pins = "PC18", "PC19";
137*724ba675SRob Herring		function = "uart2";
138*724ba675SRob Herring	};
139*724ba675SRob Herring
140*724ba675SRob Herring	emac_pa_pins: emac-pa-pins {
141*724ba675SRob Herring		pins = "PA0", "PA1", "PA2",
142*724ba675SRob Herring				"PA3", "PA4", "PA5", "PA6",
143*724ba675SRob Herring				"PA7", "PA8", "PA9", "PA10",
144*724ba675SRob Herring				"PA11", "PA12", "PA13", "PA14",
145*724ba675SRob Herring				"PA15", "PA16";
146*724ba675SRob Herring		function = "emac";
147*724ba675SRob Herring	};
148*724ba675SRob Herring
149*724ba675SRob Herring	mmc1_pins: mmc1-pins {
150*724ba675SRob Herring		pins = "PG3", "PG4", "PG5",
151*724ba675SRob Herring				 "PG6", "PG7", "PG8";
152*724ba675SRob Herring		function = "mmc1";
153*724ba675SRob Herring		drive-strength = <30>;
154*724ba675SRob Herring	};
155*724ba675SRob Herring
156*724ba675SRob Herring	spi2_pb_pins: spi2-pb-pins {
157*724ba675SRob Herring		pins = "PB12", "PB13", "PB14";
158*724ba675SRob Herring		function = "spi2";
159*724ba675SRob Herring	};
160*724ba675SRob Herring
161*724ba675SRob Herring	spi2_cs0_pb_pin: spi2-cs0-pb-pin {
162*724ba675SRob Herring		pins = "PB11";
163*724ba675SRob Herring		function = "spi2";
164*724ba675SRob Herring	};
165*724ba675SRob Herring};
166*724ba675SRob Herring
167*724ba675SRob Herring&tcon0_out {
168*724ba675SRob Herring	tcon0_out_hdmi: endpoint@2 {
169*724ba675SRob Herring		reg = <2>;
170*724ba675SRob Herring		remote-endpoint = <&hdmi_in_tcon0>;
171*724ba675SRob Herring		allwinner,tcon-channel = <1>;
172*724ba675SRob Herring	};
173*724ba675SRob Herring};
174