Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / drivers / video / fbdev / omap2 / dss / hdmi5_core.h
1 /*
2  * HDMI driver definition for TI OMAP5 processors.
3  *
4  * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/
5  *
6  * This program is free software; you can redistribute it and/or modify it
7  * under the terms of the GNU General Public License version 2 as published by
8  * the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
13  * more details.
14  *
15  * You should have received a copy of the GNU General Public License along with
16  * this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18
19 #ifndef _HDMI5_CORE_H_
20 #define _HDMI5_CORE_H_
21
22 #include "hdmi.h"
23
24 /* HDMI IP Core System */
25
26 /* HDMI Identification */
27 #define HDMI_CORE_DESIGN_ID                     0x00000
28 #define HDMI_CORE_REVISION_ID                   0x00004
29 #define HDMI_CORE_PRODUCT_ID0                   0x00008
30 #define HDMI_CORE_PRODUCT_ID1                   0x0000C
31 #define HDMI_CORE_CONFIG0_ID                    0x00010
32 #define HDMI_CORE_CONFIG1_ID                    0x00014
33 #define HDMI_CORE_CONFIG2_ID                    0x00018
34 #define HDMI_CORE_CONFIG3_ID                    0x0001C
35
36 /* HDMI Interrupt */
37 #define HDMI_CORE_IH_FC_STAT0                   0x00400
38 #define HDMI_CORE_IH_FC_STAT1                   0x00404
39 #define HDMI_CORE_IH_FC_STAT2                   0x00408
40 #define HDMI_CORE_IH_AS_STAT0                   0x0040C
41 #define HDMI_CORE_IH_PHY_STAT0                  0x00410
42 #define HDMI_CORE_IH_I2CM_STAT0                 0x00414
43 #define HDMI_CORE_IH_CEC_STAT0                  0x00418
44 #define HDMI_CORE_IH_VP_STAT0                   0x0041C
45 #define HDMI_CORE_IH_I2CMPHY_STAT0              0x00420
46 #define HDMI_CORE_IH_MUTE                       0x007FC
47
48 /* HDMI Video Sampler */
49 #define HDMI_CORE_TX_INVID0                     0x00800
50 #define HDMI_CORE_TX_INSTUFFING                 0x00804
51 #define HDMI_CORE_TX_RGYDATA0                   0x00808
52 #define HDMI_CORE_TX_RGYDATA1                   0x0080C
53 #define HDMI_CORE_TX_RCRDATA0                   0x00810
54 #define HDMI_CORE_TX_RCRDATA1                   0x00814
55 #define HDMI_CORE_TX_BCBDATA0                   0x00818
56 #define HDMI_CORE_TX_BCBDATA1                   0x0081C
57
58 /* HDMI Video Packetizer */
59 #define HDMI_CORE_VP_STATUS                     0x02000
60 #define HDMI_CORE_VP_PR_CD                      0x02004
61 #define HDMI_CORE_VP_STUFF                      0x02008
62 #define HDMI_CORE_VP_REMAP                      0x0200C
63 #define HDMI_CORE_VP_CONF                       0x02010
64 #define HDMI_CORE_VP_STAT                       0x02014
65 #define HDMI_CORE_VP_INT                        0x02018
66 #define HDMI_CORE_VP_MASK                       0x0201C
67 #define HDMI_CORE_VP_POL                        0x02020
68
69 /* Frame Composer */
70 #define HDMI_CORE_FC_INVIDCONF                  0x04000
71 #define HDMI_CORE_FC_INHACTIV0                  0x04004
72 #define HDMI_CORE_FC_INHACTIV1                  0x04008
73 #define HDMI_CORE_FC_INHBLANK0                  0x0400C
74 #define HDMI_CORE_FC_INHBLANK1                  0x04010
75 #define HDMI_CORE_FC_INVACTIV0                  0x04014
76 #define HDMI_CORE_FC_INVACTIV1                  0x04018
77 #define HDMI_CORE_FC_INVBLANK                   0x0401C
78 #define HDMI_CORE_FC_HSYNCINDELAY0              0x04020
79 #define HDMI_CORE_FC_HSYNCINDELAY1              0x04024
80 #define HDMI_CORE_FC_HSYNCINWIDTH0              0x04028
81 #define HDMI_CORE_FC_HSYNCINWIDTH1              0x0402C
82 #define HDMI_CORE_FC_VSYNCINDELAY               0x04030
83 #define HDMI_CORE_FC_VSYNCINWIDTH               0x04034
84 #define HDMI_CORE_FC_INFREQ0                    0x04038
85 #define HDMI_CORE_FC_INFREQ1                    0x0403C
86 #define HDMI_CORE_FC_INFREQ2                    0x04040
87 #define HDMI_CORE_FC_CTRLDUR                    0x04044
88 #define HDMI_CORE_FC_EXCTRLDUR                  0x04048
89 #define HDMI_CORE_FC_EXCTRLSPAC                 0x0404C
90 #define HDMI_CORE_FC_CH0PREAM                   0x04050
91 #define HDMI_CORE_FC_CH1PREAM                   0x04054
92 #define HDMI_CORE_FC_CH2PREAM                   0x04058
93 #define HDMI_CORE_FC_AVICONF3                   0x0405C
94 #define HDMI_CORE_FC_GCP                        0x04060
95 #define HDMI_CORE_FC_AVICONF0                   0x04064
96 #define HDMI_CORE_FC_AVICONF1                   0x04068
97 #define HDMI_CORE_FC_AVICONF2                   0x0406C
98 #define HDMI_CORE_FC_AVIVID                     0x04070
99 #define HDMI_CORE_FC_AVIETB0                    0x04074
100 #define HDMI_CORE_FC_AVIETB1                    0x04078
101 #define HDMI_CORE_FC_AVISBB0                    0x0407C
102 #define HDMI_CORE_FC_AVISBB1                    0x04080
103 #define HDMI_CORE_FC_AVIELB0                    0x04084
104 #define HDMI_CORE_FC_AVIELB1                    0x04088
105 #define HDMI_CORE_FC_AVISRB0                    0x0408C
106 #define HDMI_CORE_FC_AVISRB1                    0x04090
107 #define HDMI_CORE_FC_AUDICONF0                  0x04094
108 #define HDMI_CORE_FC_AUDICONF1                  0x04098
109 #define HDMI_CORE_FC_AUDICONF2                  0x0409C
110 #define HDMI_CORE_FC_AUDICONF3                  0x040A0
111 #define HDMI_CORE_FC_VSDIEEEID0                 0x040A4
112 #define HDMI_CORE_FC_VSDSIZE                    0x040A8
113 #define HDMI_CORE_FC_VSDIEEEID1                 0x040C0
114 #define HDMI_CORE_FC_VSDIEEEID2                 0x040C4
115 #define HDMI_CORE_FC_VSDPAYLOAD(n)              (n * 4 + 0x040C8)
116 #define HDMI_CORE_FC_SPDVENDORNAME(n)           (n * 4 + 0x04128)
117 #define HDMI_CORE_FC_SPDPRODUCTNAME(n)          (n * 4 + 0x04148)
118 #define HDMI_CORE_FC_SPDDEVICEINF               0x04188
119 #define HDMI_CORE_FC_AUDSCONF                   0x0418C
120 #define HDMI_CORE_FC_AUDSSTAT                   0x04190
121 #define HDMI_CORE_FC_AUDSV                      0x04194
122 #define HDMI_CORE_FC_AUDSU                      0x04198
123 #define HDMI_CORE_FC_AUDSCHNLS(n)               (n * 4 + 0x0419C)
124 #define HDMI_CORE_FC_CTRLQHIGH                  0x041CC
125 #define HDMI_CORE_FC_CTRLQLOW                   0x041D0
126 #define HDMI_CORE_FC_ACP0                       0x041D4
127 #define HDMI_CORE_FC_ACP(n)                     ((16-n) * 4 + 0x04208)
128 #define HDMI_CORE_FC_ISCR1_0                    0x04248
129 #define HDMI_CORE_FC_ISCR1(n)                   ((16-n) * 4 + 0x0424C)
130 #define HDMI_CORE_FC_ISCR2(n)                   ((15-n) * 4 + 0x0428C)
131 #define HDMI_CORE_FC_DATAUTO0                   0x042CC
132 #define HDMI_CORE_FC_DATAUTO1                   0x042D0
133 #define HDMI_CORE_FC_DATAUTO2                   0x042D4
134 #define HDMI_CORE_FC_DATMAN                     0x042D8
135 #define HDMI_CORE_FC_DATAUTO3                   0x042DC
136 #define HDMI_CORE_FC_RDRB(n)                    (n * 4 + 0x042E0)
137 #define HDMI_CORE_FC_STAT0                      0x04340
138 #define HDMI_CORE_FC_INT0                       0x04344
139 #define HDMI_CORE_FC_MASK0                      0x04348
140 #define HDMI_CORE_FC_POL0                       0x0434C
141 #define HDMI_CORE_FC_STAT1                      0x04350
142 #define HDMI_CORE_FC_INT1                       0x04354
143 #define HDMI_CORE_FC_MASK1                      0x04358
144 #define HDMI_CORE_FC_POL1                       0x0435C
145 #define HDMI_CORE_FC_STAT2                      0x04360
146 #define HDMI_CORE_FC_INT2                       0x04364
147 #define HDMI_CORE_FC_MASK2                      0x04368
148 #define HDMI_CORE_FC_POL2                       0x0436C
149 #define HDMI_CORE_FC_PRCONF                     0x04380
150 #define HDMI_CORE_FC_GMD_STAT                   0x04400
151 #define HDMI_CORE_FC_GMD_EN                     0x04404
152 #define HDMI_CORE_FC_GMD_UP                     0x04408
153 #define HDMI_CORE_FC_GMD_CONF                   0x0440C
154 #define HDMI_CORE_FC_GMD_HB                     0x04410
155 #define HDMI_CORE_FC_GMD_PB(n)                  (n * 4 + 0x04414)
156 #define HDMI_CORE_FC_DBGFORCE                   0x04800
157 #define HDMI_CORE_FC_DBGAUD0CH0                 0x04804
158 #define HDMI_CORE_FC_DBGAUD1CH0                 0x04808
159 #define HDMI_CORE_FC_DBGAUD2CH0                 0x0480C
160 #define HDMI_CORE_FC_DBGAUD0CH1                 0x04810
161 #define HDMI_CORE_FC_DBGAUD1CH1                 0x04814
162 #define HDMI_CORE_FC_DBGAUD2CH1                 0x04818
163 #define HDMI_CORE_FC_DBGAUD0CH2                 0x0481C
164 #define HDMI_CORE_FC_DBGAUD1CH2                 0x04820
165 #define HDMI_CORE_FC_DBGAUD2CH2                 0x04824
166 #define HDMI_CORE_FC_DBGAUD0CH3                 0x04828
167 #define HDMI_CORE_FC_DBGAUD1CH3                 0x0482C
168 #define HDMI_CORE_FC_DBGAUD2CH3                 0x04830
169 #define HDMI_CORE_FC_DBGAUD0CH4                 0x04834
170 #define HDMI_CORE_FC_DBGAUD1CH4                 0x04838
171 #define HDMI_CORE_FC_DBGAUD2CH4                 0x0483C
172 #define HDMI_CORE_FC_DBGAUD0CH5                 0x04840
173 #define HDMI_CORE_FC_DBGAUD1CH5                 0x04844
174 #define HDMI_CORE_FC_DBGAUD2CH5                 0x04848
175 #define HDMI_CORE_FC_DBGAUD0CH6                 0x0484C
176 #define HDMI_CORE_FC_DBGAUD1CH6                 0x04850
177 #define HDMI_CORE_FC_DBGAUD2CH6                 0x04854
178 #define HDMI_CORE_FC_DBGAUD0CH7                 0x04858
179 #define HDMI_CORE_FC_DBGAUD1CH7                 0x0485C
180 #define HDMI_CORE_FC_DBGAUD2CH7                 0x04860
181 #define HDMI_CORE_FC_DBGTMDS0                   0x04864
182 #define HDMI_CORE_FC_DBGTMDS1                   0x04868
183 #define HDMI_CORE_FC_DBGTMDS2                   0x0486C
184 #define HDMI_CORE_PHY_MASK0                     0x0C018
185 #define HDMI_CORE_PHY_I2CM_INT_ADDR             0x0C09C
186 #define HDMI_CORE_PHY_I2CM_CTLINT_ADDR          0x0C0A0
187
188 /* HDMI Audio */
189 #define HDMI_CORE_AUD_CONF0                     0x0C400
190 #define HDMI_CORE_AUD_CONF1                     0x0C404
191 #define HDMI_CORE_AUD_INT                       0x0C408
192 #define HDMI_CORE_AUD_N1                        0x0C800
193 #define HDMI_CORE_AUD_N2                        0x0C804
194 #define HDMI_CORE_AUD_N3                        0x0C808
195 #define HDMI_CORE_AUD_CTS1                      0x0C80C
196 #define HDMI_CORE_AUD_CTS2                      0x0C810
197 #define HDMI_CORE_AUD_CTS3                      0x0C814
198 #define HDMI_CORE_AUD_INCLKFS                   0x0C818
199 #define HDMI_CORE_AUD_CC08                      0x0CC08
200 #define HDMI_CORE_AUD_GP_CONF0                  0x0D400
201 #define HDMI_CORE_AUD_GP_CONF1                  0x0D404
202 #define HDMI_CORE_AUD_GP_CONF2                  0x0D408
203 #define HDMI_CORE_AUD_D010                      0x0D010
204 #define HDMI_CORE_AUD_GP_STAT                   0x0D40C
205 #define HDMI_CORE_AUD_GP_INT                    0x0D410
206 #define HDMI_CORE_AUD_GP_POL                    0x0D414
207 #define HDMI_CORE_AUD_GP_MASK                   0x0D418
208
209 /* HDMI Main Controller */
210 #define HDMI_CORE_MC_CLKDIS                     0x10004
211 #define HDMI_CORE_MC_SWRSTZREQ                  0x10008
212 #define HDMI_CORE_MC_FLOWCTRL                   0x10010
213 #define HDMI_CORE_MC_PHYRSTZ                    0x10014
214 #define HDMI_CORE_MC_LOCKONCLOCK                0x10018
215
216 /* HDMI COLOR SPACE CONVERTER */
217 #define HDMI_CORE_CSC_CFG                       0x10400
218 #define HDMI_CORE_CSC_SCALE                     0x10404
219 #define HDMI_CORE_CSC_COEF_A1_MSB               0x10408
220 #define HDMI_CORE_CSC_COEF_A1_LSB               0x1040C
221 #define HDMI_CORE_CSC_COEF_A2_MSB               0x10410
222 #define HDMI_CORE_CSC_COEF_A2_LSB               0x10414
223 #define HDMI_CORE_CSC_COEF_A3_MSB               0x10418
224 #define HDMI_CORE_CSC_COEF_A3_LSB               0x1041C
225 #define HDMI_CORE_CSC_COEF_A4_MSB               0x10420
226 #define HDMI_CORE_CSC_COEF_A4_LSB               0x10424
227 #define HDMI_CORE_CSC_COEF_B1_MSB               0x10428
228 #define HDMI_CORE_CSC_COEF_B1_LSB               0x1042C
229 #define HDMI_CORE_CSC_COEF_B2_MSB               0x10430
230 #define HDMI_CORE_CSC_COEF_B2_LSB               0x10434
231 #define HDMI_CORE_CSC_COEF_B3_MSB               0x10438
232 #define HDMI_CORE_CSC_COEF_B3_LSB               0x1043C
233 #define HDMI_CORE_CSC_COEF_B4_MSB               0x10440
234 #define HDMI_CORE_CSC_COEF_B4_LSB               0x10444
235 #define HDMI_CORE_CSC_COEF_C1_MSB               0x10448
236 #define HDMI_CORE_CSC_COEF_C1_LSB               0x1044C
237 #define HDMI_CORE_CSC_COEF_C2_MSB               0x10450
238 #define HDMI_CORE_CSC_COEF_C2_LSB               0x10454
239 #define HDMI_CORE_CSC_COEF_C3_MSB               0x10458
240 #define HDMI_CORE_CSC_COEF_C3_LSB               0x1045C
241 #define HDMI_CORE_CSC_COEF_C4_MSB               0x10460
242 #define HDMI_CORE_CSC_COEF_C4_LSB               0x10464
243
244 /* HDMI HDCP */
245 #define HDMI_CORE_HDCP_MASK                     0x14020
246
247 /* HDMI CEC */
248 #define HDMI_CORE_CEC_MASK                      0x17408
249
250 /* HDMI I2C Master */
251 #define HDMI_CORE_I2CM_SLAVE                    0x157C8
252 #define HDMI_CORE_I2CM_ADDRESS                  0x157CC
253 #define HDMI_CORE_I2CM_DATAO                    0x157D0
254 #define HDMI_CORE_I2CM_DATAI                    0X157D4
255 #define HDMI_CORE_I2CM_OPERATION                0x157D8
256 #define HDMI_CORE_I2CM_INT                      0x157DC
257 #define HDMI_CORE_I2CM_CTLINT                   0x157E0
258 #define HDMI_CORE_I2CM_DIV                      0x157E4
259 #define HDMI_CORE_I2CM_SEGADDR                  0x157E8
260 #define HDMI_CORE_I2CM_SOFTRSTZ                 0x157EC
261 #define HDMI_CORE_I2CM_SEGPTR                   0x157F0
262 #define HDMI_CORE_I2CM_SS_SCL_HCNT_1_ADDR       0x157F4
263 #define HDMI_CORE_I2CM_SS_SCL_HCNT_0_ADDR       0x157F8
264 #define HDMI_CORE_I2CM_SS_SCL_LCNT_1_ADDR       0x157FC
265 #define HDMI_CORE_I2CM_SS_SCL_LCNT_0_ADDR       0x15800
266 #define HDMI_CORE_I2CM_FS_SCL_HCNT_1_ADDR       0x15804
267 #define HDMI_CORE_I2CM_FS_SCL_HCNT_0_ADDR       0x15808
268 #define HDMI_CORE_I2CM_FS_SCL_LCNT_1_ADDR       0x1580C
269 #define HDMI_CORE_I2CM_FS_SCL_LCNT_0_ADDR       0x15810
270 #define HDMI_CORE_I2CM_SDA_HOLD_ADDR            0x15814
271
272 enum hdmi_core_packet_mode {
273         HDMI_PACKETMODERESERVEDVALUE = 0,
274         HDMI_PACKETMODE24BITPERPIXEL = 4,
275         HDMI_PACKETMODE30BITPERPIXEL = 5,
276         HDMI_PACKETMODE36BITPERPIXEL = 6,
277         HDMI_PACKETMODE48BITPERPIXEL = 7,
278 };
279
280 struct hdmi_core_vid_config {
281         struct hdmi_config v_fc_config;
282         enum hdmi_core_packet_mode packet_mode;
283         int data_enable_pol;
284         int vblank_osc;
285         int hblank;
286         int vblank;
287 };
288
289 struct csc_table {
290         u16 a1, a2, a3, a4;
291         u16 b1, b2, b3, b4;
292         u16 c1, c2, c3, c4;
293 };
294
295 int hdmi5_read_edid(struct hdmi_core_data *core, u8 *edid, int len);
296 void hdmi5_core_dump(struct hdmi_core_data *core, struct seq_file *s);
297 int hdmi5_core_handle_irqs(struct hdmi_core_data *core);
298 void hdmi5_configure(struct hdmi_core_data *core, struct hdmi_wp_data *wp,
299                         struct hdmi_config *cfg);
300 int hdmi5_core_init(struct platform_device *pdev, struct hdmi_core_data *core);
301
302 int hdmi5_audio_config(struct hdmi_core_data *core, struct hdmi_wp_data *wp,
303                         struct omap_dss_audio *audio, u32 pclk);
304 #endif