blob: b48f4ef31d937ff8c4944e379d55357045653f02 [file] [log] [blame]
Simon Glassffc78992015-04-14 21:03:30 -06001NVIDIA Tegra host1x
2
3Required properties:
4- compatible: "nvidia,tegra<chip>-host1x"
5- reg: Physical base address and length of the controller's registers.
6- interrupts: The interrupt outputs from the controller.
7- #address-cells: The number of cells used to represent physical base addresses
8 in the host1x address space. Should be 1.
9- #size-cells: The number of cells used to represent the size of an address
10 range in the host1x address space. Should be 1.
11- ranges: The mapping of the host1x address space to the CPU address space.
12- clocks: Must contain one entry, for the module clock.
13 See ../clocks/clock-bindings.txt for details.
14- resets: Must contain an entry for each entry in reset-names.
15 See ../reset/reset.txt for details.
16- reset-names: Must include the following entries:
17 - host1x
18
19The host1x top-level node defines a number of children, each representing one
20of the following host1x client modules:
21
22- mpe: video encoder
23
24 Required properties:
25 - compatible: "nvidia,tegra<chip>-mpe"
26 - reg: Physical base address and length of the controller's registers.
27 - interrupts: The interrupt outputs from the controller.
28 - clocks: Must contain one entry, for the module clock.
29 See ../clocks/clock-bindings.txt for details.
30 - resets: Must contain an entry for each entry in reset-names.
31 See ../reset/reset.txt for details.
32 - reset-names: Must include the following entries:
33 - mpe
34
35- vi: video input
36
37 Required properties:
38 - compatible: "nvidia,tegra<chip>-vi"
39 - reg: Physical base address and length of the controller's registers.
40 - interrupts: The interrupt outputs from the controller.
41 - clocks: Must contain one entry, for the module clock.
42 See ../clocks/clock-bindings.txt for details.
43 - resets: Must contain an entry for each entry in reset-names.
44 See ../reset/reset.txt for details.
45 - reset-names: Must include the following entries:
46 - vi
47
48- epp: encoder pre-processor
49
50 Required properties:
51 - compatible: "nvidia,tegra<chip>-epp"
52 - reg: Physical base address and length of the controller's registers.
53 - interrupts: The interrupt outputs from the controller.
54 - clocks: Must contain one entry, for the module clock.
55 See ../clocks/clock-bindings.txt for details.
56 - resets: Must contain an entry for each entry in reset-names.
57 See ../reset/reset.txt for details.
58 - reset-names: Must include the following entries:
59 - epp
60
61- isp: image signal processor
62
63 Required properties:
64 - compatible: "nvidia,tegra<chip>-isp"
65 - reg: Physical base address and length of the controller's registers.
66 - interrupts: The interrupt outputs from the controller.
67 - clocks: Must contain one entry, for the module clock.
68 See ../clocks/clock-bindings.txt for details.
69 - resets: Must contain an entry for each entry in reset-names.
70 See ../reset/reset.txt for details.
71 - reset-names: Must include the following entries:
72 - isp
73
74- gr2d: 2D graphics engine
75
76 Required properties:
77 - compatible: "nvidia,tegra<chip>-gr2d"
78 - reg: Physical base address and length of the controller's registers.
79 - interrupts: The interrupt outputs from the controller.
80 - clocks: Must contain one entry, for the module clock.
81 See ../clocks/clock-bindings.txt for details.
82 - resets: Must contain an entry for each entry in reset-names.
83 See ../reset/reset.txt for details.
84 - reset-names: Must include the following entries:
85 - 2d
86
87- gr3d: 3D graphics engine
88
89 Required properties:
90 - compatible: "nvidia,tegra<chip>-gr3d"
91 - reg: Physical base address and length of the controller's registers.
92 - clocks: Must contain an entry for each entry in clock-names.
93 See ../clocks/clock-bindings.txt for details.
94 - clock-names: Must include the following entries:
95 (This property may be omitted if the only clock in the list is "3d")
96 - 3d
97 This MUST be the first entry.
98 - 3d2 (Only required on SoCs with two 3D clocks)
99 - resets: Must contain an entry for each entry in reset-names.
100 See ../reset/reset.txt for details.
101 - reset-names: Must include the following entries:
102 - 3d
103 - 3d2 (Only required on SoCs with two 3D clocks)
104
105- dc: display controller
106
107 Required properties:
108 - compatible: "nvidia,tegra<chip>-dc"
109 - reg: Physical base address and length of the controller's registers.
110 - interrupts: The interrupt outputs from the controller.
111 - clocks: Must contain an entry for each entry in clock-names.
112 See ../clocks/clock-bindings.txt for details.
113 - clock-names: Must include the following entries:
114 - dc
115 This MUST be the first entry.
116 - parent
117 - resets: Must contain an entry for each entry in reset-names.
118 See ../reset/reset.txt for details.
119 - reset-names: Must include the following entries:
120 - dc
121 - nvidia,head: The number of the display controller head. This is used to
122 setup the various types of output to receive video data from the given
123 head.
124
125 Each display controller node has a child node, named "rgb", that represents
126 the RGB output associated with the controller. It can take the following
127 optional properties:
128 - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
129 - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
130 - nvidia,edid: supplies a binary EDID blob
131 - nvidia,panel: phandle of a display panel
132
133- hdmi: High Definition Multimedia Interface
134
135 Required properties:
136 - compatible: "nvidia,tegra<chip>-hdmi"
137 - reg: Physical base address and length of the controller's registers.
138 - interrupts: The interrupt outputs from the controller.
139 - hdmi-supply: supply for the +5V HDMI connector pin
140 - vdd-supply: regulator for supply voltage
141 - pll-supply: regulator for PLL
142 - clocks: Must contain an entry for each entry in clock-names.
143 See ../clocks/clock-bindings.txt for details.
144 - clock-names: Must include the following entries:
145 - hdmi
146 This MUST be the first entry.
147 - parent
148 - resets: Must contain an entry for each entry in reset-names.
149 See ../reset/reset.txt for details.
150 - reset-names: Must include the following entries:
151 - hdmi
152
153 Optional properties:
154 - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
155 - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
156 - nvidia,edid: supplies a binary EDID blob
157 - nvidia,panel: phandle of a display panel
158
159- tvo: TV encoder output
160
161 Required properties:
162 - compatible: "nvidia,tegra<chip>-tvo"
163 - reg: Physical base address and length of the controller's registers.
164 - interrupts: The interrupt outputs from the controller.
165 - clocks: Must contain one entry, for the module clock.
166 See ../clocks/clock-bindings.txt for details.
167
168- dsi: display serial interface
169
170 Required properties:
171 - compatible: "nvidia,tegra<chip>-dsi"
172 - reg: Physical base address and length of the controller's registers.
173 - clocks: Must contain an entry for each entry in clock-names.
174 See ../clocks/clock-bindings.txt for details.
175 - clock-names: Must include the following entries:
176 - dsi
177 This MUST be the first entry.
178 - lp
179 - parent
180 - resets: Must contain an entry for each entry in reset-names.
181 See ../reset/reset.txt for details.
182 - reset-names: Must include the following entries:
183 - dsi
184 - avdd-dsi-supply: phandle of a supply that powers the DSI controller
185 - nvidia,mipi-calibrate: Should contain a phandle and a specifier specifying
186 which pads are used by this DSI output and need to be calibrated. See also
187 ../mipi/nvidia,tegra114-mipi.txt.
188
189 Optional properties:
190 - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
191 - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
192 - nvidia,edid: supplies a binary EDID blob
193 - nvidia,panel: phandle of a display panel
194
195- sor: serial output resource
196
197 Required properties:
198 - compatible: "nvidia,tegra124-sor"
199 - reg: Physical base address and length of the controller's registers.
200 - interrupts: The interrupt outputs from the controller.
201 - clocks: Must contain an entry for each entry in clock-names.
202 See ../clocks/clock-bindings.txt for details.
203 - clock-names: Must include the following entries:
204 - sor: clock input for the SOR hardware
205 - parent: input for the pixel clock
206 - dp: reference clock for the SOR clock
207 - safe: safe reference for the SOR clock during power up
208 - resets: Must contain an entry for each entry in reset-names.
209 See ../reset/reset.txt for details.
210 - reset-names: Must include the following entries:
211 - sor
212
213 Optional properties:
214 - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
215 - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
216 - nvidia,edid: supplies a binary EDID blob
217 - nvidia,panel: phandle of a display panel
218
219 Optional properties when driving an eDP output:
220 - nvidia,dpaux: phandle to a DispayPort AUX interface
221
222- dpaux: DisplayPort AUX interface
223 - compatible: "nvidia,tegra124-dpaux"
224 - reg: Physical base address and length of the controller's registers.
225 - interrupts: The interrupt outputs from the controller.
226 - clocks: Must contain an entry for each entry in clock-names.
227 See ../clocks/clock-bindings.txt for details.
228 - clock-names: Must include the following entries:
229 - dpaux: clock input for the DPAUX hardware
230 - parent: reference clock
231 - resets: Must contain an entry for each entry in reset-names.
232 See ../reset/reset.txt for details.
233 - reset-names: Must include the following entries:
234 - dpaux
235 - vdd-supply: phandle of a supply that powers the DisplayPort link
236
237Example:
238
239/ {
240 ...
241
242 host1x {
243 compatible = "nvidia,tegra20-host1x", "simple-bus";
244 reg = <0x50000000 0x00024000>;
245 interrupts = <0 65 0x04 /* mpcore syncpt */
246 0 67 0x04>; /* mpcore general */
247 clocks = <&tegra_car TEGRA20_CLK_HOST1X>;
248 resets = <&tegra_car 28>;
249 reset-names = "host1x";
250
251 #address-cells = <1>;
252 #size-cells = <1>;
253
254 ranges = <0x54000000 0x54000000 0x04000000>;
255
256 mpe {
257 compatible = "nvidia,tegra20-mpe";
258 reg = <0x54040000 0x00040000>;
259 interrupts = <0 68 0x04>;
260 clocks = <&tegra_car TEGRA20_CLK_MPE>;
261 resets = <&tegra_car 60>;
262 reset-names = "mpe";
263 };
264
265 vi {
266 compatible = "nvidia,tegra20-vi";
267 reg = <0x54080000 0x00040000>;
268 interrupts = <0 69 0x04>;
269 clocks = <&tegra_car TEGRA20_CLK_VI>;
270 resets = <&tegra_car 100>;
271 reset-names = "vi";
272 };
273
274 epp {
275 compatible = "nvidia,tegra20-epp";
276 reg = <0x540c0000 0x00040000>;
277 interrupts = <0 70 0x04>;
278 clocks = <&tegra_car TEGRA20_CLK_EPP>;
279 resets = <&tegra_car 19>;
280 reset-names = "epp";
281 };
282
283 isp {
284 compatible = "nvidia,tegra20-isp";
285 reg = <0x54100000 0x00040000>;
286 interrupts = <0 71 0x04>;
287 clocks = <&tegra_car TEGRA20_CLK_ISP>;
288 resets = <&tegra_car 23>;
289 reset-names = "isp";
290 };
291
292 gr2d {
293 compatible = "nvidia,tegra20-gr2d";
294 reg = <0x54140000 0x00040000>;
295 interrupts = <0 72 0x04>;
296 clocks = <&tegra_car TEGRA20_CLK_GR2D>;
297 resets = <&tegra_car 21>;
298 reset-names = "2d";
299 };
300
301 gr3d {
302 compatible = "nvidia,tegra20-gr3d";
303 reg = <0x54180000 0x00040000>;
304 clocks = <&tegra_car TEGRA20_CLK_GR3D>;
305 resets = <&tegra_car 24>;
306 reset-names = "3d";
307 };
308
309 dc@54200000 {
310 compatible = "nvidia,tegra20-dc";
311 reg = <0x54200000 0x00040000>;
312 interrupts = <0 73 0x04>;
313 clocks = <&tegra_car TEGRA20_CLK_DISP1>,
314 <&tegra_car TEGRA20_CLK_PLL_P>;
315 clock-names = "dc", "parent";
316 resets = <&tegra_car 27>;
317 reset-names = "dc";
318
319 rgb {
320 status = "disabled";
321 };
322 };
323
324 dc@54240000 {
325 compatible = "nvidia,tegra20-dc";
326 reg = <0x54240000 0x00040000>;
327 interrupts = <0 74 0x04>;
328 clocks = <&tegra_car TEGRA20_CLK_DISP2>,
329 <&tegra_car TEGRA20_CLK_PLL_P>;
330 clock-names = "dc", "parent";
331 resets = <&tegra_car 26>;
332 reset-names = "dc";
333
334 rgb {
335 status = "disabled";
336 };
337 };
338
339 hdmi {
340 compatible = "nvidia,tegra20-hdmi";
341 reg = <0x54280000 0x00040000>;
342 interrupts = <0 75 0x04>;
343 clocks = <&tegra_car TEGRA20_CLK_HDMI>,
344 <&tegra_car TEGRA20_CLK_PLL_D_OUT0>;
345 clock-names = "hdmi", "parent";
346 resets = <&tegra_car 51>;
347 reset-names = "hdmi";
348 status = "disabled";
349 };
350
351 tvo {
352 compatible = "nvidia,tegra20-tvo";
353 reg = <0x542c0000 0x00040000>;
354 interrupts = <0 76 0x04>;
355 clocks = <&tegra_car TEGRA20_CLK_TVO>;
356 status = "disabled";
357 };
358
359 dsi {
360 compatible = "nvidia,tegra20-dsi";
361 reg = <0x54300000 0x00040000>;
362 clocks = <&tegra_car TEGRA20_CLK_DSI>,
363 <&tegra_car TEGRA20_CLK_PLL_D_OUT0>;
364 clock-names = "dsi", "parent";
365 resets = <&tegra_car 48>;
366 reset-names = "dsi";
367 status = "disabled";
368 };
369 };
370
371 ...
372};