xref: /openbmc/u-boot/doc/device-tree-bindings/gpu/nvidia,tegra20-host1x.txt (revision 0b45a79faa2f61bc095c785cfbfe4aa5206d9d13)
1NVIDIA 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};
373