WIP FPC-III support
[linux/fpc-iii.git] / Documentation / devicetree / bindings / display / tegra / nvidia,tegra20-host1x.txt
blob34d993338453917eb4b69c72cfffcee165fa7f46
1 NVIDIA Tegra host1x
3 Required properties:
4 - compatible: "nvidia,tegra<chip>-host1x"
5 - reg: Physical base address and length of the controller's registers.
6   For pre-Tegra186, one entry describing the whole register area.
7   For Tegra186, one entry for each entry in reg-names:
8     "vm" - VM region assigned to Linux
9     "hypervisor" - Hypervisor region (only if Linux acts as hypervisor)
10 - interrupts: The interrupt outputs from the controller.
11 - #address-cells: The number of cells used to represent physical base addresses
12   in the host1x address space. Should be 1.
13 - #size-cells: The number of cells used to represent the size of an address
14   range in the host1x address space. Should be 1.
15 - ranges: The mapping of the host1x address space to the CPU address space.
16 - clocks: Must contain one entry, for the module clock.
17   See ../clocks/clock-bindings.txt for details.
18 - resets: Must contain an entry for each entry in reset-names.
19   See ../reset/reset.txt for details.
20 - reset-names: Must include the following entries:
21   - host1x
23 Each host1x client module having to perform DMA through the Memory Controller
24 should have the interconnect endpoints set to the Memory Client and External
25 Memory respectively.
27 The host1x top-level node defines a number of children, each representing one
28 of the following host1x client modules:
30 - mpe: video encoder
32   Required properties:
33   - compatible: "nvidia,tegra<chip>-mpe"
34   - reg: Physical base address and length of the controller's registers.
35   - interrupts: The interrupt outputs from the controller.
36   - clocks: Must contain one entry, for the module clock.
37     See ../clocks/clock-bindings.txt for details.
38   - resets: Must contain an entry for each entry in reset-names.
39     See ../reset/reset.txt for details.
40   - reset-names: Must include the following entries:
41     - mpe
43   Optional properties:
44   - interconnects: Must contain entry for the MPE memory clients.
45   - interconnect-names: Must include name of the interconnect path for each
46     interconnect entry. Consult TRM documentation for information about
47     available memory clients, see MEMORY CONTROLLER section.
49 - vi: video input
51   Required properties:
52   - compatible: "nvidia,tegra<chip>-vi"
53   - reg: Physical base address and length of the controller registers.
54   - interrupts: The interrupt outputs from the controller.
55   - clocks: clocks: Must contain one entry, for the module clock.
56     See ../clocks/clock-bindings.txt for details.
57   - Tegra20/Tegra30/Tegra114/Tegra124:
58     - resets: Must contain an entry for each entry in reset-names.
59       See ../reset/reset.txt for details.
60     - reset-names: Must include the following entries:
61       - vi
62   - Tegra210:
63     - power-domains: Must include venc powergate node as vi is in VE partition.
65   ports (optional node)
66   vi can have optional ports node and max 6 ports are supported. Each port
67   should have single 'endpoint' child node. All port nodes are grouped under
68   ports node. Please refer to the bindings defined in
69   Documentation/devicetree/bindings/media/video-interfaces.txt
71   csi (required node)
72   Tegra210 has CSI part of VI sharing same host interface and register space.
73   So, VI device node should have CSI child node.
75     - csi: mipi csi interface to vi
77       Required properties:
78       - compatible: "nvidia,tegra210-csi"
79       - reg: Physical base address offset to parent and length of the controller
80         registers.
81       - clocks: Must contain entries csi, cilab, cilcd, cile, csi_tpg clocks.
82         See ../clocks/clock-bindings.txt for details.
83       - power-domains: Must include sor powergate node as csicil is in
84         SOR partition.
86       channel (optional nodes)
87       Maximum 6 channels are supported with each csi brick as either x4 or x2
88       based on hw connectivity to sensor.
90       Required properties:
91       - reg: csi port number. Valid port numbers are 0 through 5.
92       - nvidia,mipi-calibrate: Should contain a phandle and a specifier
93         specifying which pads are used by this CSI port and need to be
94         calibrated. See also ../display/tegra/nvidia,tegra114-mipi.txt.
96       Each channel node must contain 2 port nodes which can be grouped
97       under 'ports' node and each port should have a single child 'endpoint'
98       node.
100         ports node
101         Please refer to the bindings defined in
102         Documentation/devicetree/bindings/media/video-interfaces.txt
104         ports node must contain below 2 port nodes.
105         port@0 with single child 'endpoint' node always a sink.
106         port@1 with single child 'endpoint' node always a source.
108         port@0 (required node)
109         Required properties:
110         - reg: 0
112           endpoint (required node)
113           Required properties:
114           - data-lanes: an array of data lane from 1 to 4. Valid array
115             lengths are 1/2/4.
116           - remote-endpoint: phandle to sensor 'endpoint' node.
118         port@1 (required node)
119         Required properties:
120         - reg: 1
122           endpoint (required node)
123           Required properties:
124           - remote-endpoint: phandle to vi port 'endpoint' node.
126   Optional properties:
127   - interconnects: Must contain entry for the VI memory clients.
128   - interconnect-names: Must include name of the interconnect path for each
129     interconnect entry. Consult TRM documentation for information about
130     available memory clients, see MEMORY CONTROLLER section.
132 - epp: encoder pre-processor
134   Required properties:
135   - compatible: "nvidia,tegra<chip>-epp"
136   - reg: Physical base address and length of the controller's registers.
137   - interrupts: The interrupt outputs from the controller.
138   - clocks: Must contain one entry, for the module clock.
139     See ../clocks/clock-bindings.txt for details.
140   - resets: Must contain an entry for each entry in reset-names.
141     See ../reset/reset.txt for details.
142   - reset-names: Must include the following entries:
143     - epp
145   Optional properties:
146   - interconnects: Must contain entry for the EPP memory clients.
147   - interconnect-names: Must include name of the interconnect path for each
148     interconnect entry. Consult TRM documentation for information about
149     available memory clients, see MEMORY CONTROLLER section.
151 - isp: image signal processor
153   Required properties:
154   - compatible: "nvidia,tegra<chip>-isp"
155   - reg: Physical base address and length of the controller's registers.
156   - interrupts: The interrupt outputs from the controller.
157   - clocks: Must contain one entry, for the module clock.
158     See ../clocks/clock-bindings.txt for details.
159   - resets: Must contain an entry for each entry in reset-names.
160     See ../reset/reset.txt for details.
161   - reset-names: Must include the following entries:
162     - isp
164   Optional properties:
165   - interconnects: Must contain entry for the ISP memory clients.
166   - interconnect-names: Must include name of the interconnect path for each
167     interconnect entry. Consult TRM documentation for information about
168     available memory clients, see MEMORY CONTROLLER section.
170 - gr2d: 2D graphics engine
172   Required properties:
173   - compatible: "nvidia,tegra<chip>-gr2d"
174   - reg: Physical base address and length of the controller's registers.
175   - interrupts: The interrupt outputs from the controller.
176   - clocks: Must contain one entry, for the module clock.
177     See ../clocks/clock-bindings.txt for details.
178   - resets: Must contain an entry for each entry in reset-names.
179     See ../reset/reset.txt for details.
180   - reset-names: Must include the following entries:
181     - 2d
183   Optional properties:
184   - interconnects: Must contain entry for the GR2D memory clients.
185   - interconnect-names: Must include name of the interconnect path for each
186     interconnect entry. Consult TRM documentation for information about
187     available memory clients, see MEMORY CONTROLLER section.
189 - gr3d: 3D graphics engine
191   Required properties:
192   - compatible: "nvidia,tegra<chip>-gr3d"
193   - reg: Physical base address and length of the controller's registers.
194   - clocks: Must contain an entry for each entry in clock-names.
195     See ../clocks/clock-bindings.txt for details.
196   - clock-names: Must include the following entries:
197     (This property may be omitted if the only clock in the list is "3d")
198     - 3d
199       This MUST be the first entry.
200     - 3d2 (Only required on SoCs with two 3D clocks)
201   - resets: Must contain an entry for each entry in reset-names.
202     See ../reset/reset.txt for details.
203   - reset-names: Must include the following entries:
204     - 3d
205     - 3d2 (Only required on SoCs with two 3D clocks)
207   Optional properties:
208   - interconnects: Must contain entry for the GR3D memory clients.
209   - interconnect-names: Must include name of the interconnect path for each
210     interconnect entry. Consult TRM documentation for information about
211     available memory clients, see MEMORY CONTROLLER section.
213 - dc: display controller
215   Required properties:
216   - compatible: "nvidia,tegra<chip>-dc"
217   - reg: Physical base address and length of the controller's registers.
218   - interrupts: The interrupt outputs from the controller.
219   - clocks: Must contain an entry for each entry in clock-names.
220     See ../clocks/clock-bindings.txt for details.
221   - clock-names: Must include the following entries:
222     - dc
223       This MUST be the first entry.
224     - parent
225   - resets: Must contain an entry for each entry in reset-names.
226     See ../reset/reset.txt for details.
227   - reset-names: Must include the following entries:
228     - dc
229   - nvidia,head: The number of the display controller head. This is used to
230     setup the various types of output to receive video data from the given
231     head.
233   Each display controller node has a child node, named "rgb", that represents
234   the RGB output associated with the controller. It can take the following
235   optional properties:
236   - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
237   - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
238   - nvidia,edid: supplies a binary EDID blob
239   - nvidia,panel: phandle of a display panel
240   - interconnects: Must contain entry for the DC memory clients.
241   - interconnect-names: Must include name of the interconnect path for each
242     interconnect entry. Consult TRM documentation for information about
243     available memory clients, see MEMORY CONTROLLER section.
245 - hdmi: High Definition Multimedia Interface
247   Required properties:
248   - compatible: "nvidia,tegra<chip>-hdmi"
249   - reg: Physical base address and length of the controller's registers.
250   - interrupts: The interrupt outputs from the controller.
251   - hdmi-supply: supply for the +5V HDMI connector pin
252   - vdd-supply: regulator for supply voltage
253   - pll-supply: regulator for PLL
254   - clocks: Must contain an entry for each entry in clock-names.
255     See ../clocks/clock-bindings.txt for details.
256   - clock-names: Must include the following entries:
257     - hdmi
258       This MUST be the first entry.
259     - parent
260   - resets: Must contain an entry for each entry in reset-names.
261     See ../reset/reset.txt for details.
262   - reset-names: Must include the following entries:
263     - hdmi
265   Optional properties:
266   - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
267   - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
268   - nvidia,edid: supplies a binary EDID blob
269   - nvidia,panel: phandle of a display panel
271 - tvo: TV encoder output
273   Required properties:
274   - compatible: "nvidia,tegra<chip>-tvo"
275   - reg: Physical base address and length of the controller's registers.
276   - interrupts: The interrupt outputs from the controller.
277   - clocks: Must contain one entry, for the module clock.
278     See ../clocks/clock-bindings.txt for details.
280 - dsi: display serial interface
282   Required properties:
283   - compatible: "nvidia,tegra<chip>-dsi"
284   - reg: Physical base address and length of the controller's registers.
285   - clocks: Must contain an entry for each entry in clock-names.
286     See ../clocks/clock-bindings.txt for details.
287   - clock-names: Must include the following entries:
288     - dsi
289       This MUST be the first entry.
290     - lp
291     - parent
292   - resets: Must contain an entry for each entry in reset-names.
293     See ../reset/reset.txt for details.
294   - reset-names: Must include the following entries:
295     - dsi
296   - avdd-dsi-supply: phandle of a supply that powers the DSI controller
297   - nvidia,mipi-calibrate: Should contain a phandle and a specifier specifying
298     which pads are used by this DSI output and need to be calibrated. See also
299     ../display/tegra/nvidia,tegra114-mipi.txt.
301   Optional properties:
302   - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
303   - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
304   - nvidia,edid: supplies a binary EDID blob
305   - nvidia,panel: phandle of a display panel
306   - nvidia,ganged-mode: contains a phandle to a second DSI controller to gang
307     up with in order to support up to 8 data lanes
309 - sor: serial output resource
311   Required properties:
312   - compatible: Should be:
313     - "nvidia,tegra124-sor": for Tegra124 and Tegra132
314     - "nvidia,tegra132-sor": for Tegra132
315     - "nvidia,tegra210-sor": for Tegra210
316     - "nvidia,tegra210-sor1": for Tegra210
317     - "nvidia,tegra186-sor": for Tegra186
318     - "nvidia,tegra186-sor1": for Tegra186
319   - reg: Physical base address and length of the controller's registers.
320   - interrupts: The interrupt outputs from the controller.
321   - clocks: Must contain an entry for each entry in clock-names.
322     See ../clocks/clock-bindings.txt for details.
323   - clock-names: Must include the following entries:
324     - sor: clock input for the SOR hardware
325     - out: SOR output clock
326     - parent: input for the pixel clock
327     - dp: reference clock for the SOR clock
328     - safe: safe reference for the SOR clock during power up
330     For Tegra186 and later:
331     - pad: SOR pad output clock (on Tegra186 and later)
333     Obsolete:
334     - source: source clock for the SOR clock (obsolete, use "out" instead)
336   - resets: Must contain an entry for each entry in reset-names.
337     See ../reset/reset.txt for details.
338   - reset-names: Must include the following entries:
339     - sor
341   Required properties on Tegra186 and later:
342   - nvidia,interface: index of the SOR interface
344   Optional properties:
345   - nvidia,ddc-i2c-bus: phandle of an I2C controller used for DDC EDID probing
346   - nvidia,hpd-gpio: specifies a GPIO used for hotplug detection
347   - nvidia,edid: supplies a binary EDID blob
348   - nvidia,panel: phandle of a display panel
349   - nvidia,xbar-cfg: 5 cells containing the crossbar configuration. Each lane
350     of the SOR, identified by the cell's index, is mapped via the crossbar to
351     the pad specified by the cell's value.
353   Optional properties when driving an eDP output:
354   - nvidia,dpaux: phandle to a DispayPort AUX interface
356 - dpaux: DisplayPort AUX interface
357   - compatible : Should contain one of the following:
358     - "nvidia,tegra124-dpaux": for Tegra124 and Tegra132
359     - "nvidia,tegra210-dpaux": for Tegra210
360   - reg: Physical base address and length of the controller's registers.
361   - interrupts: The interrupt outputs from the controller.
362   - clocks: Must contain an entry for each entry in clock-names.
363     See ../clocks/clock-bindings.txt for details.
364   - clock-names: Must include the following entries:
365     - dpaux: clock input for the DPAUX hardware
366     - parent: reference clock
367   - resets: Must contain an entry for each entry in reset-names.
368     See ../reset/reset.txt for details.
369   - reset-names: Must include the following entries:
370     - dpaux
371   - vdd-supply: phandle of a supply that powers the DisplayPort link
372   - i2c-bus: Subnode where I2C slave devices are listed. This subnode
373     must be always present. If there are no I2C slave devices, an empty
374     node should be added. See ../../i2c/i2c.txt for more information.
376   See ../pinctrl/nvidia,tegra124-dpaux-padctl.txt for information
377   regarding the DPAUX pad controller bindings.
379 - vic: Video Image Compositor
380   - compatible : "nvidia,tegra<chip>-vic"
381   - reg: Physical base address and length of the controller's registers.
382   - interrupts: The interrupt outputs from the controller.
383   - clocks: Must contain an entry for each entry in clock-names.
384     See ../clocks/clock-bindings.txt for details.
385   - clock-names: Must include the following entries:
386     - vic: clock input for the VIC hardware
387   - resets: Must contain an entry for each entry in reset-names.
388     See ../reset/reset.txt for details.
389   - reset-names: Must include the following entries:
390     - vic
392   Optional properties:
393   - interconnects: Must contain entry for the VIC memory clients.
394   - interconnect-names: Must include name of the interconnect path for each
395     interconnect entry. Consult TRM documentation for information about
396     available memory clients, see MEMORY CONTROLLER section.
398 Example:
400 / {
401         ...
403         host1x {
404                 compatible = "nvidia,tegra20-host1x", "simple-bus";
405                 reg = <0x50000000 0x00024000>;
406                 interrupts = <0 65 0x04   /* mpcore syncpt */
407                               0 67 0x04>; /* mpcore general */
408                 clocks = <&tegra_car TEGRA20_CLK_HOST1X>;
409                 resets = <&tegra_car 28>;
410                 reset-names = "host1x";
412                 #address-cells = <1>;
413                 #size-cells = <1>;
415                 ranges = <0x54000000 0x54000000 0x04000000>;
417                 mpe {
418                         compatible = "nvidia,tegra20-mpe";
419                         reg = <0x54040000 0x00040000>;
420                         interrupts = <0 68 0x04>;
421                         clocks = <&tegra_car TEGRA20_CLK_MPE>;
422                         resets = <&tegra_car 60>;
423                         reset-names = "mpe";
424                 };
426                 vi@54080000 {
427                         compatible = "nvidia,tegra210-vi";
428                         reg = <0x0 0x54080000 0x0 0x700>;
429                         interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
430                         assigned-clocks = <&tegra_car TEGRA210_CLK_VI>;
431                         assigned-clock-parents = <&tegra_car TEGRA210_CLK_PLL_C4_OUT0>;
433                         clocks = <&tegra_car TEGRA210_CLK_VI>;
434                         power-domains = <&pd_venc>;
436                         #address-cells = <1>;
437                         #size-cells = <1>;
439                         ranges = <0x0 0x0 0x54080000 0x2000>;
441                         ports {
442                                 #address-cells = <1>;
443                                 #size-cells = <0>;
445                                 port@0 {
446                                         reg = <0>;
447                                         imx219_vi_in0: endpoint {
448                                                 remote-endpoint = <&imx219_csi_out0>;
449                                         };
450                                 };
451                         };
453                         csi@838 {
454                                 compatible = "nvidia,tegra210-csi";
455                                 reg = <0x838 0x1300>;
456                                 assigned-clocks = <&tegra_car TEGRA210_CLK_CILAB>,
457                                                   <&tegra_car TEGRA210_CLK_CILCD>,
458                                                   <&tegra_car TEGRA210_CLK_CILE>,
459                                                   <&tegra_car TEGRA210_CLK_CSI_TPG>;
460                                 assigned-clock-parents = <&tegra_car TEGRA210_CLK_PLL_P>,
461                                                          <&tegra_car TEGRA210_CLK_PLL_P>,
462                                                          <&tegra_car TEGRA210_CLK_PLL_P>;
463                                 assigned-clock-rates = <102000000>,
464                                                        <102000000>,
465                                                        <102000000>,
466                                                        <972000000>;
468                                 clocks = <&tegra_car TEGRA210_CLK_CSI>,
469                                          <&tegra_car TEGRA210_CLK_CILAB>,
470                                          <&tegra_car TEGRA210_CLK_CILCD>,
471                                          <&tegra_car TEGRA210_CLK_CILE>,
472                                          <&tegra_car TEGRA210_CLK_CSI_TPG>;
473                                 clock-names = "csi", "cilab", "cilcd", "cile", "csi_tpg";
474                                 power-domains = <&pd_sor>;
476                                 #address-cells = <1>;
477                                 #size-cells = <0>;
479                                 channel@0 {
480                                         reg = <0>;
481                                         nvidia,mipi-calibrate = <&mipi 0x001>;
483                                         ports {
484                                                 #address-cells = <1>;
485                                                 #size-cells = <0>;
487                                                 port@0 {
488                                                         reg = <0>;
489                                                         imx219_csi_in0: endpoint {
490                                                                 data-lanes = <1 2>;
491                                                                 remote-endpoint = <&imx219_out0>;
492                                                         };
493                                                 };
495                                                 port@1 {
496                                                         reg = <1>;
497                                                         imx219_csi_out0: endpoint {
498                                                                 remote-endpoint = <&imx219_vi_in0>;
499                                                         };
500                                                 };
501                                         };
502                                 };
503                         };
504                 };
506                 epp {
507                         compatible = "nvidia,tegra20-epp";
508                         reg = <0x540c0000 0x00040000>;
509                         interrupts = <0 70 0x04>;
510                         clocks = <&tegra_car TEGRA20_CLK_EPP>;
511                         resets = <&tegra_car 19>;
512                         reset-names = "epp";
513                 };
515                 isp {
516                         compatible = "nvidia,tegra20-isp";
517                         reg = <0x54100000 0x00040000>;
518                         interrupts = <0 71 0x04>;
519                         clocks = <&tegra_car TEGRA20_CLK_ISP>;
520                         resets = <&tegra_car 23>;
521                         reset-names = "isp";
522                 };
524                 gr2d {
525                         compatible = "nvidia,tegra20-gr2d";
526                         reg = <0x54140000 0x00040000>;
527                         interrupts = <0 72 0x04>;
528                         clocks = <&tegra_car TEGRA20_CLK_GR2D>;
529                         resets = <&tegra_car 21>;
530                         reset-names = "2d";
531                 };
533                 gr3d {
534                         compatible = "nvidia,tegra20-gr3d";
535                         reg = <0x54180000 0x00040000>;
536                         clocks = <&tegra_car TEGRA20_CLK_GR3D>;
537                         resets = <&tegra_car 24>;
538                         reset-names = "3d";
539                 };
541                 dc@54200000 {
542                         compatible = "nvidia,tegra20-dc";
543                         reg = <0x54200000 0x00040000>;
544                         interrupts = <0 73 0x04>;
545                         clocks = <&tegra_car TEGRA20_CLK_DISP1>,
546                                  <&tegra_car TEGRA20_CLK_PLL_P>;
547                         clock-names = "dc", "parent";
548                         resets = <&tegra_car 27>;
549                         reset-names = "dc";
551                         interconnects = <&mc TEGRA20_MC_DISPLAY0A &emc>,
552                                         <&mc TEGRA20_MC_DISPLAY0B &emc>,
553                                         <&mc TEGRA20_MC_DISPLAY0C &emc>,
554                                         <&mc TEGRA20_MC_DISPLAYHC &emc>;
555                         interconnect-names = "wina",
556                                              "winb",
557                                              "winc",
558                                              "cursor";
560                         rgb {
561                                 status = "disabled";
562                         };
563                 };
565                 dc@54240000 {
566                         compatible = "nvidia,tegra20-dc";
567                         reg = <0x54240000 0x00040000>;
568                         interrupts = <0 74 0x04>;
569                         clocks = <&tegra_car TEGRA20_CLK_DISP2>,
570                                  <&tegra_car TEGRA20_CLK_PLL_P>;
571                         clock-names = "dc", "parent";
572                         resets = <&tegra_car 26>;
573                         reset-names = "dc";
575                         interconnects = <&mc TEGRA20_MC_DISPLAY0AB &emc>,
576                                         <&mc TEGRA20_MC_DISPLAY0BB &emc>,
577                                         <&mc TEGRA20_MC_DISPLAY0CB &emc>,
578                                         <&mc TEGRA20_MC_DISPLAYHCB &emc>;
579                         interconnect-names = "wina",
580                                              "winb",
581                                              "winc",
582                                              "cursor";
584                         rgb {
585                                 status = "disabled";
586                         };
587                 };
589                 hdmi {
590                         compatible = "nvidia,tegra20-hdmi";
591                         reg = <0x54280000 0x00040000>;
592                         interrupts = <0 75 0x04>;
593                         clocks = <&tegra_car TEGRA20_CLK_HDMI>,
594                                  <&tegra_car TEGRA20_CLK_PLL_D_OUT0>;
595                         clock-names = "hdmi", "parent";
596                         resets = <&tegra_car 51>;
597                         reset-names = "hdmi";
598                         status = "disabled";
599                 };
601                 tvo {
602                         compatible = "nvidia,tegra20-tvo";
603                         reg = <0x542c0000 0x00040000>;
604                         interrupts = <0 76 0x04>;
605                         clocks = <&tegra_car TEGRA20_CLK_TVO>;
606                         status = "disabled";
607                 };
609                 dsi {
610                         compatible = "nvidia,tegra20-dsi";
611                         reg = <0x54300000 0x00040000>;
612                         clocks = <&tegra_car TEGRA20_CLK_DSI>,
613                                  <&tegra_car TEGRA20_CLK_PLL_D_OUT0>;
614                         clock-names = "dsi", "parent";
615                         resets = <&tegra_car 48>;
616                         reset-names = "dsi";
617                         status = "disabled";
618                 };
619         };
621         ...