]> Git Repo - J-linux.git/blob - drivers/gpu/drm/i915/display/intel_tv.c
Merge tag 'input-for-v6.7-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor...
[J-linux.git] / drivers / gpu / drm / i915 / display / intel_tv.c
1 /*
2  * Copyright © 2006-2008 Intel Corporation
3  *   Jesse Barnes <[email protected]>
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice (including the next
13  * paragraph) shall be included in all copies or substantial portions of the
14  * Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22  * DEALINGS IN THE SOFTWARE.
23  *
24  * Authors:
25  *    Eric Anholt <[email protected]>
26  *
27  */
28
29 /** @file
30  * Integrated TV-out support for the 915GM and 945GM.
31  */
32
33 #include <drm/drm_atomic_helper.h>
34 #include <drm/drm_crtc.h>
35 #include <drm/drm_edid.h>
36
37 #include "i915_drv.h"
38 #include "i915_reg.h"
39 #include "intel_connector.h"
40 #include "intel_crtc.h"
41 #include "intel_de.h"
42 #include "intel_display_irq.h"
43 #include "intel_display_types.h"
44 #include "intel_dpll.h"
45 #include "intel_hotplug.h"
46 #include "intel_load_detect.h"
47 #include "intel_tv.h"
48 #include "intel_tv_regs.h"
49
50 enum tv_margin {
51         TV_MARGIN_LEFT, TV_MARGIN_TOP,
52         TV_MARGIN_RIGHT, TV_MARGIN_BOTTOM
53 };
54
55 struct intel_tv {
56         struct intel_encoder base;
57
58         int type;
59 };
60
61 struct video_levels {
62         u16 blank, black;
63         u8 burst;
64 };
65
66 struct color_conversion {
67         u16 ry, gy, by, ay;
68         u16 ru, gu, bu, au;
69         u16 rv, gv, bv, av;
70 };
71
72 static const u32 filter_table[] = {
73         0xB1403000, 0x2E203500, 0x35002E20, 0x3000B140,
74         0x35A0B160, 0x2DC02E80, 0xB1403480, 0xB1603000,
75         0x2EA03640, 0x34002D80, 0x3000B120, 0x36E0B160,
76         0x2D202EF0, 0xB1203380, 0xB1603000, 0x2F303780,
77         0x33002CC0, 0x3000B100, 0x3820B160, 0x2C802F50,
78         0xB10032A0, 0xB1603000, 0x2F9038C0, 0x32202C20,
79         0x3000B0E0, 0x3980B160, 0x2BC02FC0, 0xB0E031C0,
80         0xB1603000, 0x2FF03A20, 0x31602B60, 0xB020B0C0,
81         0x3AE0B160, 0x2B001810, 0xB0C03120, 0xB140B020,
82         0x18283BA0, 0x30C02A80, 0xB020B0A0, 0x3C60B140,
83         0x2A201838, 0xB0A03080, 0xB120B020, 0x18383D20,
84         0x304029C0, 0xB040B080, 0x3DE0B100, 0x29601848,
85         0xB0803000, 0xB100B040, 0x18483EC0, 0xB0402900,
86         0xB040B060, 0x3F80B0C0, 0x28801858, 0xB060B080,
87         0xB0A0B060, 0x18602820, 0xB0A02820, 0x0000B060,
88         0xB1403000, 0x2E203500, 0x35002E20, 0x3000B140,
89         0x35A0B160, 0x2DC02E80, 0xB1403480, 0xB1603000,
90         0x2EA03640, 0x34002D80, 0x3000B120, 0x36E0B160,
91         0x2D202EF0, 0xB1203380, 0xB1603000, 0x2F303780,
92         0x33002CC0, 0x3000B100, 0x3820B160, 0x2C802F50,
93         0xB10032A0, 0xB1603000, 0x2F9038C0, 0x32202C20,
94         0x3000B0E0, 0x3980B160, 0x2BC02FC0, 0xB0E031C0,
95         0xB1603000, 0x2FF03A20, 0x31602B60, 0xB020B0C0,
96         0x3AE0B160, 0x2B001810, 0xB0C03120, 0xB140B020,
97         0x18283BA0, 0x30C02A80, 0xB020B0A0, 0x3C60B140,
98         0x2A201838, 0xB0A03080, 0xB120B020, 0x18383D20,
99         0x304029C0, 0xB040B080, 0x3DE0B100, 0x29601848,
100         0xB0803000, 0xB100B040, 0x18483EC0, 0xB0402900,
101         0xB040B060, 0x3F80B0C0, 0x28801858, 0xB060B080,
102         0xB0A0B060, 0x18602820, 0xB0A02820, 0x0000B060,
103         0x36403000, 0x2D002CC0, 0x30003640, 0x2D0036C0,
104         0x35C02CC0, 0x37403000, 0x2C802D40, 0x30003540,
105         0x2D8037C0, 0x34C02C40, 0x38403000, 0x2BC02E00,
106         0x30003440, 0x2E2038C0, 0x34002B80, 0x39803000,
107         0x2B402E40, 0x30003380, 0x2E603A00, 0x33402B00,
108         0x3A803040, 0x2A802EA0, 0x30403300, 0x2EC03B40,
109         0x32802A40, 0x3C003040, 0x2A002EC0, 0x30803240,
110         0x2EC03C80, 0x320029C0, 0x3D403080, 0x29402F00,
111         0x308031C0, 0x2F203DC0, 0x31802900, 0x3E8030C0,
112         0x28802F40, 0x30C03140, 0x2F203F40, 0x31402840,
113         0x28003100, 0x28002F00, 0x00003100, 0x36403000,
114         0x2D002CC0, 0x30003640, 0x2D0036C0,
115         0x35C02CC0, 0x37403000, 0x2C802D40, 0x30003540,
116         0x2D8037C0, 0x34C02C40, 0x38403000, 0x2BC02E00,
117         0x30003440, 0x2E2038C0, 0x34002B80, 0x39803000,
118         0x2B402E40, 0x30003380, 0x2E603A00, 0x33402B00,
119         0x3A803040, 0x2A802EA0, 0x30403300, 0x2EC03B40,
120         0x32802A40, 0x3C003040, 0x2A002EC0, 0x30803240,
121         0x2EC03C80, 0x320029C0, 0x3D403080, 0x29402F00,
122         0x308031C0, 0x2F203DC0, 0x31802900, 0x3E8030C0,
123         0x28802F40, 0x30C03140, 0x2F203F40, 0x31402840,
124         0x28003100, 0x28002F00, 0x00003100,
125 };
126
127 /*
128  * Color conversion values have 3 separate fixed point formats:
129  *
130  * 10 bit fields (ay, au)
131  *   1.9 fixed point (b.bbbbbbbbb)
132  * 11 bit fields (ry, by, ru, gu, gv)
133  *   exp.mantissa (ee.mmmmmmmmm)
134  *   ee = 00 = 10^-1 (0.mmmmmmmmm)
135  *   ee = 01 = 10^-2 (0.0mmmmmmmmm)
136  *   ee = 10 = 10^-3 (0.00mmmmmmmmm)
137  *   ee = 11 = 10^-4 (0.000mmmmmmmmm)
138  * 12 bit fields (gy, rv, bu)
139  *   exp.mantissa (eee.mmmmmmmmm)
140  *   eee = 000 = 10^-1 (0.mmmmmmmmm)
141  *   eee = 001 = 10^-2 (0.0mmmmmmmmm)
142  *   eee = 010 = 10^-3 (0.00mmmmmmmmm)
143  *   eee = 011 = 10^-4 (0.000mmmmmmmmm)
144  *   eee = 100 = reserved
145  *   eee = 101 = reserved
146  *   eee = 110 = reserved
147  *   eee = 111 = 10^0 (m.mmmmmmmm) (only usable for 1.0 representation)
148  *
149  * Saturation and contrast are 8 bits, with their own representation:
150  * 8 bit field (saturation, contrast)
151  *   exp.mantissa (ee.mmmmmm)
152  *   ee = 00 = 10^-1 (0.mmmmmm)
153  *   ee = 01 = 10^0 (m.mmmmm)
154  *   ee = 10 = 10^1 (mm.mmmm)
155  *   ee = 11 = 10^2 (mmm.mmm)
156  *
157  * Simple conversion function:
158  *
159  * static u32
160  * float_to_csc_11(float f)
161  * {
162  *     u32 exp;
163  *     u32 mant;
164  *     u32 ret;
165  *
166  *     if (f < 0)
167  *         f = -f;
168  *
169  *     if (f >= 1) {
170  *         exp = 0x7;
171  *         mant = 1 << 8;
172  *     } else {
173  *         for (exp = 0; exp < 3 && f < 0.5; exp++)
174  *         f *= 2.0;
175  *         mant = (f * (1 << 9) + 0.5);
176  *         if (mant >= (1 << 9))
177  *             mant = (1 << 9) - 1;
178  *     }
179  *     ret = (exp << 9) | mant;
180  *     return ret;
181  * }
182  */
183
184 /*
185  * Behold, magic numbers!  If we plant them they might grow a big
186  * s-video cable to the sky... or something.
187  *
188  * Pre-converted to appropriate hex value.
189  */
190
191 /*
192  * PAL & NTSC values for composite & s-video connections
193  */
194 static const struct color_conversion ntsc_m_csc_composite = {
195         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0104,
196         .ru = 0x0733, .gu = 0x052d, .bu = 0x05c7, .au = 0x0200,
197         .rv = 0x0340, .gv = 0x030c, .bv = 0x06d0, .av = 0x0200,
198 };
199
200 static const struct video_levels ntsc_m_levels_composite = {
201         .blank = 225, .black = 267, .burst = 113,
202 };
203
204 static const struct color_conversion ntsc_m_csc_svideo = {
205         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0133,
206         .ru = 0x076a, .gu = 0x0564, .bu = 0x030d, .au = 0x0200,
207         .rv = 0x037a, .gv = 0x033d, .bv = 0x06f6, .av = 0x0200,
208 };
209
210 static const struct video_levels ntsc_m_levels_svideo = {
211         .blank = 266, .black = 316, .burst = 133,
212 };
213
214 static const struct color_conversion ntsc_j_csc_composite = {
215         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0119,
216         .ru = 0x074c, .gu = 0x0546, .bu = 0x05ec, .au = 0x0200,
217         .rv = 0x035a, .gv = 0x0322, .bv = 0x06e1, .av = 0x0200,
218 };
219
220 static const struct video_levels ntsc_j_levels_composite = {
221         .blank = 225, .black = 225, .burst = 113,
222 };
223
224 static const struct color_conversion ntsc_j_csc_svideo = {
225         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x014c,
226         .ru = 0x0788, .gu = 0x0581, .bu = 0x0322, .au = 0x0200,
227         .rv = 0x0399, .gv = 0x0356, .bv = 0x070a, .av = 0x0200,
228 };
229
230 static const struct video_levels ntsc_j_levels_svideo = {
231         .blank = 266, .black = 266, .burst = 133,
232 };
233
234 static const struct color_conversion pal_csc_composite = {
235         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0113,
236         .ru = 0x0745, .gu = 0x053f, .bu = 0x05e1, .au = 0x0200,
237         .rv = 0x0353, .gv = 0x031c, .bv = 0x06dc, .av = 0x0200,
238 };
239
240 static const struct video_levels pal_levels_composite = {
241         .blank = 237, .black = 237, .burst = 118,
242 };
243
244 static const struct color_conversion pal_csc_svideo = {
245         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0145,
246         .ru = 0x0780, .gu = 0x0579, .bu = 0x031c, .au = 0x0200,
247         .rv = 0x0390, .gv = 0x034f, .bv = 0x0705, .av = 0x0200,
248 };
249
250 static const struct video_levels pal_levels_svideo = {
251         .blank = 280, .black = 280, .burst = 139,
252 };
253
254 static const struct color_conversion pal_m_csc_composite = {
255         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0104,
256         .ru = 0x0733, .gu = 0x052d, .bu = 0x05c7, .au = 0x0200,
257         .rv = 0x0340, .gv = 0x030c, .bv = 0x06d0, .av = 0x0200,
258 };
259
260 static const struct video_levels pal_m_levels_composite = {
261         .blank = 225, .black = 267, .burst = 113,
262 };
263
264 static const struct color_conversion pal_m_csc_svideo = {
265         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0133,
266         .ru = 0x076a, .gu = 0x0564, .bu = 0x030d, .au = 0x0200,
267         .rv = 0x037a, .gv = 0x033d, .bv = 0x06f6, .av = 0x0200,
268 };
269
270 static const struct video_levels pal_m_levels_svideo = {
271         .blank = 266, .black = 316, .burst = 133,
272 };
273
274 static const struct color_conversion pal_n_csc_composite = {
275         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0104,
276         .ru = 0x0733, .gu = 0x052d, .bu = 0x05c7, .au = 0x0200,
277         .rv = 0x0340, .gv = 0x030c, .bv = 0x06d0, .av = 0x0200,
278 };
279
280 static const struct video_levels pal_n_levels_composite = {
281         .blank = 225, .black = 267, .burst = 118,
282 };
283
284 static const struct color_conversion pal_n_csc_svideo = {
285         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0133,
286         .ru = 0x076a, .gu = 0x0564, .bu = 0x030d, .au = 0x0200,
287         .rv = 0x037a, .gv = 0x033d, .bv = 0x06f6, .av = 0x0200,
288 };
289
290 static const struct video_levels pal_n_levels_svideo = {
291         .blank = 266, .black = 316, .burst = 139,
292 };
293
294 /*
295  * Component connections
296  */
297 static const struct color_conversion sdtv_csc_yprpb = {
298         .ry = 0x0332, .gy = 0x012d, .by = 0x07d3, .ay = 0x0145,
299         .ru = 0x0559, .gu = 0x0353, .bu = 0x0100, .au = 0x0200,
300         .rv = 0x0100, .gv = 0x03ad, .bv = 0x074d, .av = 0x0200,
301 };
302
303 static const struct color_conversion hdtv_csc_yprpb = {
304         .ry = 0x05b3, .gy = 0x016e, .by = 0x0728, .ay = 0x0145,
305         .ru = 0x07d5, .gu = 0x038b, .bu = 0x0100, .au = 0x0200,
306         .rv = 0x0100, .gv = 0x03d1, .bv = 0x06bc, .av = 0x0200,
307 };
308
309 static const struct video_levels component_levels = {
310         .blank = 279, .black = 279, .burst = 0,
311 };
312
313
314 struct tv_mode {
315         const char *name;
316
317         u32 clock;
318         u16 refresh; /* in millihertz (for precision) */
319         u8 oversample;
320         u8 hsync_end;
321         u16 hblank_start, hblank_end, htotal;
322         bool progressive : 1, trilevel_sync : 1, component_only : 1;
323         u8 vsync_start_f1, vsync_start_f2, vsync_len;
324         bool veq_ena : 1;
325         u8 veq_start_f1, veq_start_f2, veq_len;
326         u8 vi_end_f1, vi_end_f2;
327         u16 nbr_end;
328         bool burst_ena : 1;
329         u8 hburst_start, hburst_len;
330         u8 vburst_start_f1;
331         u16 vburst_end_f1;
332         u8 vburst_start_f2;
333         u16 vburst_end_f2;
334         u8 vburst_start_f3;
335         u16 vburst_end_f3;
336         u8 vburst_start_f4;
337         u16 vburst_end_f4;
338         /*
339          * subcarrier programming
340          */
341         u16 dda2_size, dda3_size;
342         u8 dda1_inc;
343         u16 dda2_inc, dda3_inc;
344         u32 sc_reset;
345         bool pal_burst : 1;
346         /*
347          * blank/black levels
348          */
349         const struct video_levels *composite_levels, *svideo_levels;
350         const struct color_conversion *composite_color, *svideo_color;
351         const u32 *filter_table;
352 };
353
354
355 /*
356  * Sub carrier DDA
357  *
358  *  I think this works as follows:
359  *
360  *  subcarrier freq = pixel_clock * (dda1_inc + dda2_inc / dda2_size) / 4096
361  *
362  * Presumably, when dda3 is added in, it gets to adjust the dda2_inc value
363  *
364  * So,
365  *  dda1_ideal = subcarrier/pixel * 4096
366  *  dda1_inc = floor (dda1_ideal)
367  *  dda2 = dda1_ideal - dda1_inc
368  *
369  *  then pick a ratio for dda2 that gives the closest approximation. If
370  *  you can't get close enough, you can play with dda3 as well. This
371  *  seems likely to happen when dda2 is small as the jumps would be larger
372  *
373  * To invert this,
374  *
375  *  pixel_clock = subcarrier * 4096 / (dda1_inc + dda2_inc / dda2_size)
376  *
377  * The constants below were all computed using a 107.520MHz clock
378  */
379
380 /*
381  * Register programming values for TV modes.
382  *
383  * These values account for -1s required.
384  */
385 static const struct tv_mode tv_modes[] = {
386         {
387                 .name           = "NTSC-M",
388                 .clock          = 108000,
389                 .refresh        = 59940,
390                 .oversample     = 8,
391                 .component_only = false,
392                 /* 525 Lines, 60 Fields, 15.734KHz line, Sub-Carrier 3.580MHz */
393
394                 .hsync_end      = 64,               .hblank_end         = 124,
395                 .hblank_start   = 836,              .htotal             = 857,
396
397                 .progressive    = false,            .trilevel_sync = false,
398
399                 .vsync_start_f1 = 6,                .vsync_start_f2     = 7,
400                 .vsync_len      = 6,
401
402                 .veq_ena        = true,             .veq_start_f1       = 0,
403                 .veq_start_f2   = 1,                .veq_len            = 18,
404
405                 .vi_end_f1      = 20,               .vi_end_f2          = 21,
406                 .nbr_end        = 240,
407
408                 .burst_ena      = true,
409                 .hburst_start   = 72,               .hburst_len         = 34,
410                 .vburst_start_f1 = 9,               .vburst_end_f1      = 240,
411                 .vburst_start_f2 = 10,              .vburst_end_f2      = 240,
412                 .vburst_start_f3 = 9,               .vburst_end_f3      = 240,
413                 .vburst_start_f4 = 10,              .vburst_end_f4      = 240,
414
415                 /* desired 3.5800000 actual 3.5800000 clock 107.52 */
416                 .dda1_inc       =    135,
417                 .dda2_inc       =  20800,           .dda2_size          =  27456,
418                 .dda3_inc       =      0,           .dda3_size          =      0,
419                 .sc_reset       = TV_SC_RESET_EVERY_4,
420                 .pal_burst      = false,
421
422                 .composite_levels = &ntsc_m_levels_composite,
423                 .composite_color = &ntsc_m_csc_composite,
424                 .svideo_levels  = &ntsc_m_levels_svideo,
425                 .svideo_color = &ntsc_m_csc_svideo,
426
427                 .filter_table = filter_table,
428         },
429         {
430                 .name           = "NTSC-443",
431                 .clock          = 108000,
432                 .refresh        = 59940,
433                 .oversample     = 8,
434                 .component_only = false,
435                 /* 525 Lines, 60 Fields, 15.734KHz line, Sub-Carrier 4.43MHz */
436                 .hsync_end      = 64,               .hblank_end         = 124,
437                 .hblank_start   = 836,              .htotal             = 857,
438
439                 .progressive    = false,            .trilevel_sync = false,
440
441                 .vsync_start_f1 = 6,                .vsync_start_f2     = 7,
442                 .vsync_len      = 6,
443
444                 .veq_ena        = true,             .veq_start_f1       = 0,
445                 .veq_start_f2   = 1,                .veq_len            = 18,
446
447                 .vi_end_f1      = 20,               .vi_end_f2          = 21,
448                 .nbr_end        = 240,
449
450                 .burst_ena      = true,
451                 .hburst_start   = 72,               .hburst_len         = 34,
452                 .vburst_start_f1 = 9,               .vburst_end_f1      = 240,
453                 .vburst_start_f2 = 10,              .vburst_end_f2      = 240,
454                 .vburst_start_f3 = 9,               .vburst_end_f3      = 240,
455                 .vburst_start_f4 = 10,              .vburst_end_f4      = 240,
456
457                 /* desired 4.4336180 actual 4.4336180 clock 107.52 */
458                 .dda1_inc       =    168,
459                 .dda2_inc       =   4093,       .dda2_size      =  27456,
460                 .dda3_inc       =    310,       .dda3_size      =    525,
461                 .sc_reset   = TV_SC_RESET_NEVER,
462                 .pal_burst  = false,
463
464                 .composite_levels = &ntsc_m_levels_composite,
465                 .composite_color = &ntsc_m_csc_composite,
466                 .svideo_levels  = &ntsc_m_levels_svideo,
467                 .svideo_color = &ntsc_m_csc_svideo,
468
469                 .filter_table = filter_table,
470         },
471         {
472                 .name           = "NTSC-J",
473                 .clock          = 108000,
474                 .refresh        = 59940,
475                 .oversample     = 8,
476                 .component_only = false,
477
478                 /* 525 Lines, 60 Fields, 15.734KHz line, Sub-Carrier 3.580MHz */
479                 .hsync_end      = 64,               .hblank_end         = 124,
480                 .hblank_start = 836,        .htotal             = 857,
481
482                 .progressive    = false,    .trilevel_sync = false,
483
484                 .vsync_start_f1 = 6,        .vsync_start_f2     = 7,
485                 .vsync_len      = 6,
486
487                 .veq_ena      = true,       .veq_start_f1       = 0,
488                 .veq_start_f2 = 1,          .veq_len            = 18,
489
490                 .vi_end_f1      = 20,               .vi_end_f2          = 21,
491                 .nbr_end        = 240,
492
493                 .burst_ena      = true,
494                 .hburst_start   = 72,               .hburst_len         = 34,
495                 .vburst_start_f1 = 9,               .vburst_end_f1      = 240,
496                 .vburst_start_f2 = 10,              .vburst_end_f2      = 240,
497                 .vburst_start_f3 = 9,               .vburst_end_f3      = 240,
498                 .vburst_start_f4 = 10,              .vburst_end_f4      = 240,
499
500                 /* desired 3.5800000 actual 3.5800000 clock 107.52 */
501                 .dda1_inc       =    135,
502                 .dda2_inc       =  20800,           .dda2_size          =  27456,
503                 .dda3_inc       =      0,           .dda3_size          =      0,
504                 .sc_reset       = TV_SC_RESET_EVERY_4,
505                 .pal_burst      = false,
506
507                 .composite_levels = &ntsc_j_levels_composite,
508                 .composite_color = &ntsc_j_csc_composite,
509                 .svideo_levels  = &ntsc_j_levels_svideo,
510                 .svideo_color = &ntsc_j_csc_svideo,
511
512                 .filter_table = filter_table,
513         },
514         {
515                 .name           = "PAL-M",
516                 .clock          = 108000,
517                 .refresh        = 59940,
518                 .oversample     = 8,
519                 .component_only = false,
520
521                 /* 525 Lines, 60 Fields, 15.734KHz line, Sub-Carrier 3.580MHz */
522                 .hsync_end      = 64,             .hblank_end           = 124,
523                 .hblank_start = 836,      .htotal               = 857,
524
525                 .progressive    = false,            .trilevel_sync = false,
526
527                 .vsync_start_f1 = 6,                .vsync_start_f2     = 7,
528                 .vsync_len      = 6,
529
530                 .veq_ena        = true,             .veq_start_f1       = 0,
531                 .veq_start_f2   = 1,                .veq_len            = 18,
532
533                 .vi_end_f1      = 20,               .vi_end_f2          = 21,
534                 .nbr_end        = 240,
535
536                 .burst_ena      = true,
537                 .hburst_start   = 72,               .hburst_len         = 34,
538                 .vburst_start_f1 = 9,               .vburst_end_f1      = 240,
539                 .vburst_start_f2 = 10,              .vburst_end_f2      = 240,
540                 .vburst_start_f3 = 9,               .vburst_end_f3      = 240,
541                 .vburst_start_f4 = 10,              .vburst_end_f4      = 240,
542
543                 /* desired 3.5800000 actual 3.5800000 clock 107.52 */
544                 .dda1_inc       =    135,
545                 .dda2_inc       =  16704,           .dda2_size          =  27456,
546                 .dda3_inc       =      0,           .dda3_size          =      0,
547                 .sc_reset       = TV_SC_RESET_EVERY_8,
548                 .pal_burst  = true,
549
550                 .composite_levels = &pal_m_levels_composite,
551                 .composite_color = &pal_m_csc_composite,
552                 .svideo_levels  = &pal_m_levels_svideo,
553                 .svideo_color = &pal_m_csc_svideo,
554
555                 .filter_table = filter_table,
556         },
557         {
558                 /* 625 Lines, 50 Fields, 15.625KHz line, Sub-Carrier 4.434MHz */
559                 .name       = "PAL-N",
560                 .clock          = 108000,
561                 .refresh        = 50000,
562                 .oversample     = 8,
563                 .component_only = false,
564
565                 .hsync_end      = 64,               .hblank_end         = 128,
566                 .hblank_start = 844,        .htotal             = 863,
567
568                 .progressive  = false,    .trilevel_sync = false,
569
570
571                 .vsync_start_f1 = 6,       .vsync_start_f2      = 7,
572                 .vsync_len      = 6,
573
574                 .veq_ena        = true,             .veq_start_f1       = 0,
575                 .veq_start_f2   = 1,                .veq_len            = 18,
576
577                 .vi_end_f1      = 24,               .vi_end_f2          = 25,
578                 .nbr_end        = 286,
579
580                 .burst_ena      = true,
581                 .hburst_start = 73,         .hburst_len         = 34,
582                 .vburst_start_f1 = 8,       .vburst_end_f1      = 285,
583                 .vburst_start_f2 = 8,       .vburst_end_f2      = 286,
584                 .vburst_start_f3 = 9,       .vburst_end_f3      = 286,
585                 .vburst_start_f4 = 9,       .vburst_end_f4      = 285,
586
587
588                 /* desired 4.4336180 actual 4.4336180 clock 107.52 */
589                 .dda1_inc       =    135,
590                 .dda2_inc       =  23578,       .dda2_size      =  27648,
591                 .dda3_inc       =    134,       .dda3_size      =    625,
592                 .sc_reset   = TV_SC_RESET_EVERY_8,
593                 .pal_burst  = true,
594
595                 .composite_levels = &pal_n_levels_composite,
596                 .composite_color = &pal_n_csc_composite,
597                 .svideo_levels  = &pal_n_levels_svideo,
598                 .svideo_color = &pal_n_csc_svideo,
599
600                 .filter_table = filter_table,
601         },
602         {
603                 /* 625 Lines, 50 Fields, 15.625KHz line, Sub-Carrier 4.434MHz */
604                 .name       = "PAL",
605                 .clock          = 108000,
606                 .refresh        = 50000,
607                 .oversample     = 8,
608                 .component_only = false,
609
610                 .hsync_end      = 64,               .hblank_end         = 142,
611                 .hblank_start   = 844,      .htotal             = 863,
612
613                 .progressive    = false,    .trilevel_sync = false,
614
615                 .vsync_start_f1 = 5,        .vsync_start_f2     = 6,
616                 .vsync_len      = 5,
617
618                 .veq_ena        = true,     .veq_start_f1       = 0,
619                 .veq_start_f2   = 1,        .veq_len            = 15,
620
621                 .vi_end_f1      = 24,               .vi_end_f2          = 25,
622                 .nbr_end        = 286,
623
624                 .burst_ena      = true,
625                 .hburst_start   = 73,               .hburst_len         = 32,
626                 .vburst_start_f1 = 8,               .vburst_end_f1      = 285,
627                 .vburst_start_f2 = 8,               .vburst_end_f2      = 286,
628                 .vburst_start_f3 = 9,               .vburst_end_f3      = 286,
629                 .vburst_start_f4 = 9,               .vburst_end_f4      = 285,
630
631                 /* desired 4.4336180 actual 4.4336180 clock 107.52 */
632                 .dda1_inc       =    168,
633                 .dda2_inc       =   4122,       .dda2_size      =  27648,
634                 .dda3_inc       =     67,       .dda3_size      =    625,
635                 .sc_reset   = TV_SC_RESET_EVERY_8,
636                 .pal_burst  = true,
637
638                 .composite_levels = &pal_levels_composite,
639                 .composite_color = &pal_csc_composite,
640                 .svideo_levels  = &pal_levels_svideo,
641                 .svideo_color = &pal_csc_svideo,
642
643                 .filter_table = filter_table,
644         },
645         {
646                 .name       = "480p",
647                 .clock          = 108000,
648                 .refresh        = 59940,
649                 .oversample     = 4,
650                 .component_only = true,
651
652                 .hsync_end      = 64,               .hblank_end         = 122,
653                 .hblank_start   = 842,              .htotal             = 857,
654
655                 .progressive    = true,             .trilevel_sync = false,
656
657                 .vsync_start_f1 = 12,               .vsync_start_f2     = 12,
658                 .vsync_len      = 12,
659
660                 .veq_ena        = false,
661
662                 .vi_end_f1      = 44,               .vi_end_f2          = 44,
663                 .nbr_end        = 479,
664
665                 .burst_ena      = false,
666
667                 .filter_table = filter_table,
668         },
669         {
670                 .name       = "576p",
671                 .clock          = 108000,
672                 .refresh        = 50000,
673                 .oversample     = 4,
674                 .component_only = true,
675
676                 .hsync_end      = 64,               .hblank_end         = 139,
677                 .hblank_start   = 859,              .htotal             = 863,
678
679                 .progressive    = true,             .trilevel_sync = false,
680
681                 .vsync_start_f1 = 10,               .vsync_start_f2     = 10,
682                 .vsync_len      = 10,
683
684                 .veq_ena        = false,
685
686                 .vi_end_f1      = 48,               .vi_end_f2          = 48,
687                 .nbr_end        = 575,
688
689                 .burst_ena      = false,
690
691                 .filter_table = filter_table,
692         },
693         {
694                 .name       = "720p@60Hz",
695                 .clock          = 148500,
696                 .refresh        = 60000,
697                 .oversample     = 2,
698                 .component_only = true,
699
700                 .hsync_end      = 80,               .hblank_end         = 300,
701                 .hblank_start   = 1580,             .htotal             = 1649,
702
703                 .progressive    = true,             .trilevel_sync = true,
704
705                 .vsync_start_f1 = 10,               .vsync_start_f2     = 10,
706                 .vsync_len      = 10,
707
708                 .veq_ena        = false,
709
710                 .vi_end_f1      = 29,               .vi_end_f2          = 29,
711                 .nbr_end        = 719,
712
713                 .burst_ena      = false,
714
715                 .filter_table = filter_table,
716         },
717         {
718                 .name       = "720p@50Hz",
719                 .clock          = 148500,
720                 .refresh        = 50000,
721                 .oversample     = 2,
722                 .component_only = true,
723
724                 .hsync_end      = 80,               .hblank_end         = 300,
725                 .hblank_start   = 1580,             .htotal             = 1979,
726
727                 .progressive    = true,             .trilevel_sync = true,
728
729                 .vsync_start_f1 = 10,               .vsync_start_f2     = 10,
730                 .vsync_len      = 10,
731
732                 .veq_ena        = false,
733
734                 .vi_end_f1      = 29,               .vi_end_f2          = 29,
735                 .nbr_end        = 719,
736
737                 .burst_ena      = false,
738
739                 .filter_table = filter_table,
740         },
741         {
742                 .name       = "1080i@50Hz",
743                 .clock          = 148500,
744                 .refresh        = 50000,
745                 .oversample     = 2,
746                 .component_only = true,
747
748                 .hsync_end      = 88,               .hblank_end         = 235,
749                 .hblank_start   = 2155,             .htotal             = 2639,
750
751                 .progressive    = false,          .trilevel_sync = true,
752
753                 .vsync_start_f1 = 4,              .vsync_start_f2     = 5,
754                 .vsync_len      = 10,
755
756                 .veq_ena        = true,     .veq_start_f1       = 4,
757                 .veq_start_f2   = 4,        .veq_len            = 10,
758
759
760                 .vi_end_f1      = 21,           .vi_end_f2          = 22,
761                 .nbr_end        = 539,
762
763                 .burst_ena      = false,
764
765                 .filter_table = filter_table,
766         },
767         {
768                 .name       = "1080i@60Hz",
769                 .clock          = 148500,
770                 .refresh        = 60000,
771                 .oversample     = 2,
772                 .component_only = true,
773
774                 .hsync_end      = 88,               .hblank_end         = 235,
775                 .hblank_start   = 2155,             .htotal             = 2199,
776
777                 .progressive    = false,            .trilevel_sync = true,
778
779                 .vsync_start_f1 = 4,               .vsync_start_f2     = 5,
780                 .vsync_len      = 10,
781
782                 .veq_ena        = true,             .veq_start_f1       = 4,
783                 .veq_start_f2   = 4,                .veq_len            = 10,
784
785
786                 .vi_end_f1      = 21,               .vi_end_f2          = 22,
787                 .nbr_end        = 539,
788
789                 .burst_ena      = false,
790
791                 .filter_table = filter_table,
792         },
793
794         {
795                 .name       = "1080p@30Hz",
796                 .clock          = 148500,
797                 .refresh        = 30000,
798                 .oversample     = 2,
799                 .component_only = true,
800
801                 .hsync_end      = 88,               .hblank_end         = 235,
802                 .hblank_start   = 2155,             .htotal             = 2199,
803
804                 .progressive    = true,             .trilevel_sync = true,
805
806                 .vsync_start_f1 = 8,               .vsync_start_f2     = 8,
807                 .vsync_len      = 10,
808
809                 .veq_ena        = false,        .veq_start_f1   = 0,
810                 .veq_start_f2   = 0,                .veq_len            = 0,
811
812                 .vi_end_f1      = 44,               .vi_end_f2          = 44,
813                 .nbr_end        = 1079,
814
815                 .burst_ena      = false,
816
817                 .filter_table = filter_table,
818         },
819
820         {
821                 .name       = "1080p@50Hz",
822                 .clock          = 148500,
823                 .refresh        = 50000,
824                 .oversample     = 1,
825                 .component_only = true,
826
827                 .hsync_end      = 88,               .hblank_end         = 235,
828                 .hblank_start   = 2155,             .htotal             = 2639,
829
830                 .progressive    = true,             .trilevel_sync = true,
831
832                 .vsync_start_f1 = 8,               .vsync_start_f2     = 8,
833                 .vsync_len      = 10,
834
835                 .veq_ena        = false,        .veq_start_f1   = 0,
836                 .veq_start_f2   = 0,                .veq_len            = 0,
837
838                 .vi_end_f1      = 44,               .vi_end_f2          = 44,
839                 .nbr_end        = 1079,
840
841                 .burst_ena      = false,
842
843                 .filter_table = filter_table,
844         },
845
846         {
847                 .name       = "1080p@60Hz",
848                 .clock          = 148500,
849                 .refresh        = 60000,
850                 .oversample     = 1,
851                 .component_only = true,
852
853                 .hsync_end      = 88,               .hblank_end         = 235,
854                 .hblank_start   = 2155,             .htotal             = 2199,
855
856                 .progressive    = true,             .trilevel_sync = true,
857
858                 .vsync_start_f1 = 8,               .vsync_start_f2     = 8,
859                 .vsync_len      = 10,
860
861                 .veq_ena        = false,                    .veq_start_f1       = 0,
862                 .veq_start_f2   = 0,                .veq_len            = 0,
863
864                 .vi_end_f1      = 44,               .vi_end_f2          = 44,
865                 .nbr_end        = 1079,
866
867                 .burst_ena      = false,
868
869                 .filter_table = filter_table,
870         },
871 };
872
873 struct intel_tv_connector_state {
874         struct drm_connector_state base;
875
876         /*
877          * May need to override the user margins for
878          * gen3 >1024 wide source vertical centering.
879          */
880         struct {
881                 u16 top, bottom;
882         } margins;
883
884         bool bypass_vfilter;
885 };
886
887 #define to_intel_tv_connector_state(x) container_of(x, struct intel_tv_connector_state, base)
888
889 static struct drm_connector_state *
890 intel_tv_connector_duplicate_state(struct drm_connector *connector)
891 {
892         struct intel_tv_connector_state *state;
893
894         state = kmemdup(connector->state, sizeof(*state), GFP_KERNEL);
895         if (!state)
896                 return NULL;
897
898         __drm_atomic_helper_connector_duplicate_state(connector, &state->base);
899         return &state->base;
900 }
901
902 static struct intel_tv *enc_to_tv(struct intel_encoder *encoder)
903 {
904         return container_of(encoder, struct intel_tv, base);
905 }
906
907 static struct intel_tv *intel_attached_tv(struct intel_connector *connector)
908 {
909         return enc_to_tv(intel_attached_encoder(connector));
910 }
911
912 static bool
913 intel_tv_get_hw_state(struct intel_encoder *encoder, enum pipe *pipe)
914 {
915         struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
916         u32 tmp = intel_de_read(dev_priv, TV_CTL);
917
918         *pipe = (tmp & TV_ENC_PIPE_SEL_MASK) >> TV_ENC_PIPE_SEL_SHIFT;
919
920         return tmp & TV_ENC_ENABLE;
921 }
922
923 static void
924 intel_enable_tv(struct intel_atomic_state *state,
925                 struct intel_encoder *encoder,
926                 const struct intel_crtc_state *pipe_config,
927                 const struct drm_connector_state *conn_state)
928 {
929         struct drm_device *dev = encoder->base.dev;
930         struct drm_i915_private *dev_priv = to_i915(dev);
931
932         /* Prevents vblank waits from timing out in intel_tv_detect_type() */
933         intel_crtc_wait_for_next_vblank(to_intel_crtc(pipe_config->uapi.crtc));
934
935         intel_de_rmw(dev_priv, TV_CTL, 0, TV_ENC_ENABLE);
936 }
937
938 static void
939 intel_disable_tv(struct intel_atomic_state *state,
940                  struct intel_encoder *encoder,
941                  const struct intel_crtc_state *old_crtc_state,
942                  const struct drm_connector_state *old_conn_state)
943 {
944         struct drm_device *dev = encoder->base.dev;
945         struct drm_i915_private *dev_priv = to_i915(dev);
946
947         intel_de_rmw(dev_priv, TV_CTL, TV_ENC_ENABLE, 0);
948 }
949
950 static const struct tv_mode *intel_tv_mode_find(const struct drm_connector_state *conn_state)
951 {
952         int format = conn_state->tv.mode;
953
954         return &tv_modes[format];
955 }
956
957 static enum drm_mode_status
958 intel_tv_mode_valid(struct drm_connector *connector,
959                     struct drm_display_mode *mode)
960 {
961         struct drm_i915_private *i915 = to_i915(connector->dev);
962         const struct tv_mode *tv_mode = intel_tv_mode_find(connector->state);
963         int max_dotclk = i915->max_dotclk_freq;
964         enum drm_mode_status status;
965
966         status = intel_cpu_transcoder_mode_valid(i915, mode);
967         if (status != MODE_OK)
968                 return status;
969
970         if (mode->flags & DRM_MODE_FLAG_DBLSCAN)
971                 return MODE_NO_DBLESCAN;
972
973         if (mode->clock > max_dotclk)
974                 return MODE_CLOCK_HIGH;
975
976         /* Ensure TV refresh is close to desired refresh */
977         if (abs(tv_mode->refresh - drm_mode_vrefresh(mode) * 1000) >= 1000)
978                 return MODE_CLOCK_RANGE;
979
980         return MODE_OK;
981 }
982
983 static int
984 intel_tv_mode_vdisplay(const struct tv_mode *tv_mode)
985 {
986         if (tv_mode->progressive)
987                 return tv_mode->nbr_end + 1;
988         else
989                 return 2 * (tv_mode->nbr_end + 1);
990 }
991
992 static void
993 intel_tv_mode_to_mode(struct drm_display_mode *mode,
994                       const struct tv_mode *tv_mode,
995                       int clock)
996 {
997         mode->clock = clock / (tv_mode->oversample >> !tv_mode->progressive);
998
999         /*
1000          * tv_mode horizontal timings:
1001          *
1002          * hsync_end
1003          *    | hblank_end
1004          *    |    | hblank_start
1005          *    |    |       | htotal
1006          *    |     _______    |
1007          *     ____/       \___
1008          * \__/                \
1009          */
1010         mode->hdisplay =
1011                 tv_mode->hblank_start - tv_mode->hblank_end;
1012         mode->hsync_start = mode->hdisplay +
1013                 tv_mode->htotal - tv_mode->hblank_start;
1014         mode->hsync_end = mode->hsync_start +
1015                 tv_mode->hsync_end;
1016         mode->htotal = tv_mode->htotal + 1;
1017
1018         /*
1019          * tv_mode vertical timings:
1020          *
1021          * vsync_start
1022          *    | vsync_end
1023          *    |  | vi_end nbr_end
1024          *    |  |    |       |
1025          *    |  |     _______
1026          * \__    ____/       \
1027          *    \__/
1028          */
1029         mode->vdisplay = intel_tv_mode_vdisplay(tv_mode);
1030         if (tv_mode->progressive) {
1031                 mode->vsync_start = mode->vdisplay +
1032                         tv_mode->vsync_start_f1 + 1;
1033                 mode->vsync_end = mode->vsync_start +
1034                         tv_mode->vsync_len;
1035                 mode->vtotal = mode->vdisplay +
1036                         tv_mode->vi_end_f1 + 1;
1037         } else {
1038                 mode->vsync_start = mode->vdisplay +
1039                         tv_mode->vsync_start_f1 + 1 +
1040                         tv_mode->vsync_start_f2 + 1;
1041                 mode->vsync_end = mode->vsync_start +
1042                         2 * tv_mode->vsync_len;
1043                 mode->vtotal = mode->vdisplay +
1044                         tv_mode->vi_end_f1 + 1 +
1045                         tv_mode->vi_end_f2 + 1;
1046         }
1047
1048         /* TV has it's own notion of sync and other mode flags, so clear them. */
1049         mode->flags = 0;
1050
1051         snprintf(mode->name, sizeof(mode->name),
1052                  "%dx%d%c (%s)",
1053                  mode->hdisplay, mode->vdisplay,
1054                  tv_mode->progressive ? 'p' : 'i',
1055                  tv_mode->name);
1056 }
1057
1058 static void intel_tv_scale_mode_horiz(struct drm_display_mode *mode,
1059                                       int hdisplay, int left_margin,
1060                                       int right_margin)
1061 {
1062         int hsync_start = mode->hsync_start - mode->hdisplay + right_margin;
1063         int hsync_end = mode->hsync_end - mode->hdisplay + right_margin;
1064         int new_htotal = mode->htotal * hdisplay /
1065                 (mode->hdisplay - left_margin - right_margin);
1066
1067         mode->clock = mode->clock * new_htotal / mode->htotal;
1068
1069         mode->hdisplay = hdisplay;
1070         mode->hsync_start = hdisplay + hsync_start * new_htotal / mode->htotal;
1071         mode->hsync_end = hdisplay + hsync_end * new_htotal / mode->htotal;
1072         mode->htotal = new_htotal;
1073 }
1074
1075 static void intel_tv_scale_mode_vert(struct drm_display_mode *mode,
1076                                      int vdisplay, int top_margin,
1077                                      int bottom_margin)
1078 {
1079         int vsync_start = mode->vsync_start - mode->vdisplay + bottom_margin;
1080         int vsync_end = mode->vsync_end - mode->vdisplay + bottom_margin;
1081         int new_vtotal = mode->vtotal * vdisplay /
1082                 (mode->vdisplay - top_margin - bottom_margin);
1083
1084         mode->clock = mode->clock * new_vtotal / mode->vtotal;
1085
1086         mode->vdisplay = vdisplay;
1087         mode->vsync_start = vdisplay + vsync_start * new_vtotal / mode->vtotal;
1088         mode->vsync_end = vdisplay + vsync_end * new_vtotal / mode->vtotal;
1089         mode->vtotal = new_vtotal;
1090 }
1091
1092 static void
1093 intel_tv_get_config(struct intel_encoder *encoder,
1094                     struct intel_crtc_state *pipe_config)
1095 {
1096         struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1097         struct drm_display_mode *adjusted_mode =
1098                 &pipe_config->hw.adjusted_mode;
1099         struct drm_display_mode mode = {};
1100         u32 tv_ctl, hctl1, hctl3, vctl1, vctl2, tmp;
1101         struct tv_mode tv_mode = {};
1102         int hdisplay = adjusted_mode->crtc_hdisplay;
1103         int vdisplay = adjusted_mode->crtc_vdisplay;
1104         int xsize, ysize, xpos, ypos;
1105
1106         pipe_config->output_types |= BIT(INTEL_OUTPUT_TVOUT);
1107
1108         tv_ctl = intel_de_read(dev_priv, TV_CTL);
1109         hctl1 = intel_de_read(dev_priv, TV_H_CTL_1);
1110         hctl3 = intel_de_read(dev_priv, TV_H_CTL_3);
1111         vctl1 = intel_de_read(dev_priv, TV_V_CTL_1);
1112         vctl2 = intel_de_read(dev_priv, TV_V_CTL_2);
1113
1114         tv_mode.htotal = (hctl1 & TV_HTOTAL_MASK) >> TV_HTOTAL_SHIFT;
1115         tv_mode.hsync_end = (hctl1 & TV_HSYNC_END_MASK) >> TV_HSYNC_END_SHIFT;
1116
1117         tv_mode.hblank_start = (hctl3 & TV_HBLANK_START_MASK) >> TV_HBLANK_START_SHIFT;
1118         tv_mode.hblank_end = (hctl3 & TV_HSYNC_END_MASK) >> TV_HBLANK_END_SHIFT;
1119
1120         tv_mode.nbr_end = (vctl1 & TV_NBR_END_MASK) >> TV_NBR_END_SHIFT;
1121         tv_mode.vi_end_f1 = (vctl1 & TV_VI_END_F1_MASK) >> TV_VI_END_F1_SHIFT;
1122         tv_mode.vi_end_f2 = (vctl1 & TV_VI_END_F2_MASK) >> TV_VI_END_F2_SHIFT;
1123
1124         tv_mode.vsync_len = (vctl2 & TV_VSYNC_LEN_MASK) >> TV_VSYNC_LEN_SHIFT;
1125         tv_mode.vsync_start_f1 = (vctl2 & TV_VSYNC_START_F1_MASK) >> TV_VSYNC_START_F1_SHIFT;
1126         tv_mode.vsync_start_f2 = (vctl2 & TV_VSYNC_START_F2_MASK) >> TV_VSYNC_START_F2_SHIFT;
1127
1128         tv_mode.clock = pipe_config->port_clock;
1129
1130         tv_mode.progressive = tv_ctl & TV_PROGRESSIVE;
1131
1132         switch (tv_ctl & TV_OVERSAMPLE_MASK) {
1133         case TV_OVERSAMPLE_8X:
1134                 tv_mode.oversample = 8;
1135                 break;
1136         case TV_OVERSAMPLE_4X:
1137                 tv_mode.oversample = 4;
1138                 break;
1139         case TV_OVERSAMPLE_2X:
1140                 tv_mode.oversample = 2;
1141                 break;
1142         default:
1143                 tv_mode.oversample = 1;
1144                 break;
1145         }
1146
1147         tmp = intel_de_read(dev_priv, TV_WIN_POS);
1148         xpos = tmp >> 16;
1149         ypos = tmp & 0xffff;
1150
1151         tmp = intel_de_read(dev_priv, TV_WIN_SIZE);
1152         xsize = tmp >> 16;
1153         ysize = tmp & 0xffff;
1154
1155         intel_tv_mode_to_mode(&mode, &tv_mode, pipe_config->port_clock);
1156
1157         drm_dbg_kms(&dev_priv->drm, "TV mode: " DRM_MODE_FMT "\n",
1158                     DRM_MODE_ARG(&mode));
1159
1160         intel_tv_scale_mode_horiz(&mode, hdisplay,
1161                                   xpos, mode.hdisplay - xsize - xpos);
1162         intel_tv_scale_mode_vert(&mode, vdisplay,
1163                                  ypos, mode.vdisplay - ysize - ypos);
1164
1165         adjusted_mode->crtc_clock = mode.clock;
1166         if (adjusted_mode->flags & DRM_MODE_FLAG_INTERLACE)
1167                 adjusted_mode->crtc_clock /= 2;
1168
1169         /* pixel counter doesn't work on i965gm TV output */
1170         if (IS_I965GM(dev_priv))
1171                 pipe_config->mode_flags |=
1172                         I915_MODE_FLAG_USE_SCANLINE_COUNTER;
1173 }
1174
1175 static bool intel_tv_source_too_wide(struct drm_i915_private *dev_priv,
1176                                      int hdisplay)
1177 {
1178         return DISPLAY_VER(dev_priv) == 3 && hdisplay > 1024;
1179 }
1180
1181 static bool intel_tv_vert_scaling(const struct drm_display_mode *tv_mode,
1182                                   const struct drm_connector_state *conn_state,
1183                                   int vdisplay)
1184 {
1185         return tv_mode->crtc_vdisplay -
1186                 conn_state->tv.margins.top -
1187                 conn_state->tv.margins.bottom !=
1188                 vdisplay;
1189 }
1190
1191 static int
1192 intel_tv_compute_config(struct intel_encoder *encoder,
1193                         struct intel_crtc_state *pipe_config,
1194                         struct drm_connector_state *conn_state)
1195 {
1196         struct intel_atomic_state *state =
1197                 to_intel_atomic_state(pipe_config->uapi.state);
1198         struct intel_crtc *crtc = to_intel_crtc(pipe_config->uapi.crtc);
1199         struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1200         struct intel_tv_connector_state *tv_conn_state =
1201                 to_intel_tv_connector_state(conn_state);
1202         const struct tv_mode *tv_mode = intel_tv_mode_find(conn_state);
1203         struct drm_display_mode *adjusted_mode =
1204                 &pipe_config->hw.adjusted_mode;
1205         int hdisplay = adjusted_mode->crtc_hdisplay;
1206         int vdisplay = adjusted_mode->crtc_vdisplay;
1207         int ret;
1208
1209         if (!tv_mode)
1210                 return -EINVAL;
1211
1212         if (adjusted_mode->flags & DRM_MODE_FLAG_DBLSCAN)
1213                 return -EINVAL;
1214
1215         pipe_config->sink_format = INTEL_OUTPUT_FORMAT_RGB;
1216         pipe_config->output_format = INTEL_OUTPUT_FORMAT_RGB;
1217
1218         drm_dbg_kms(&dev_priv->drm, "forcing bpc to 8 for TV\n");
1219         pipe_config->pipe_bpp = 8*3;
1220
1221         pipe_config->port_clock = tv_mode->clock;
1222
1223         ret = intel_dpll_crtc_compute_clock(state, crtc);
1224         if (ret)
1225                 return ret;
1226
1227         pipe_config->clock_set = true;
1228
1229         intel_tv_mode_to_mode(adjusted_mode, tv_mode, pipe_config->port_clock);
1230         drm_mode_set_crtcinfo(adjusted_mode, 0);
1231
1232         if (intel_tv_source_too_wide(dev_priv, hdisplay) ||
1233             !intel_tv_vert_scaling(adjusted_mode, conn_state, vdisplay)) {
1234                 int extra, top, bottom;
1235
1236                 extra = adjusted_mode->crtc_vdisplay - vdisplay;
1237
1238                 if (extra < 0) {
1239                         drm_dbg_kms(&dev_priv->drm,
1240                                     "No vertical scaling for >1024 pixel wide modes\n");
1241                         return -EINVAL;
1242                 }
1243
1244                 /* Need to turn off the vertical filter and center the image */
1245
1246                 /* Attempt to maintain the relative sizes of the margins */
1247                 top = conn_state->tv.margins.top;
1248                 bottom = conn_state->tv.margins.bottom;
1249
1250                 if (top + bottom)
1251                         top = extra * top / (top + bottom);
1252                 else
1253                         top = extra / 2;
1254                 bottom = extra - top;
1255
1256                 tv_conn_state->margins.top = top;
1257                 tv_conn_state->margins.bottom = bottom;
1258
1259                 tv_conn_state->bypass_vfilter = true;
1260
1261                 if (!tv_mode->progressive) {
1262                         adjusted_mode->clock /= 2;
1263                         adjusted_mode->crtc_clock /= 2;
1264                         adjusted_mode->flags |= DRM_MODE_FLAG_INTERLACE;
1265                 }
1266         } else {
1267                 tv_conn_state->margins.top = conn_state->tv.margins.top;
1268                 tv_conn_state->margins.bottom = conn_state->tv.margins.bottom;
1269
1270                 tv_conn_state->bypass_vfilter = false;
1271         }
1272
1273         drm_dbg_kms(&dev_priv->drm, "TV mode: " DRM_MODE_FMT "\n",
1274                     DRM_MODE_ARG(adjusted_mode));
1275
1276         /*
1277          * The pipe scanline counter behaviour looks as follows when
1278          * using the TV encoder:
1279          *
1280          * time ->
1281          *
1282          * dsl=vtotal-1       |             |
1283          *                   ||            ||
1284          *               ___| |        ___| |
1285          *              /     |       /     |
1286          *             /      |      /      |
1287          * dsl=0   ___/       |_____/       |
1288          *        | | |  |  | |
1289          *         ^ ^ ^   ^ ^
1290          *         | | |   | pipe vblank/first part of tv vblank
1291          *         | | |   bottom margin
1292          *         | | active
1293          *         | top margin
1294          *         remainder of tv vblank
1295          *
1296          * When the TV encoder is used the pipe wants to run faster
1297          * than expected rate. During the active portion the TV
1298          * encoder stalls the pipe every few lines to keep it in
1299          * check. When the TV encoder reaches the bottom margin the
1300          * pipe simply stops. Once we reach the TV vblank the pipe is
1301          * no longer stalled and it runs at the max rate (apparently
1302          * oversample clock on gen3, cdclk on gen4). Once the pipe
1303          * reaches the pipe vtotal the pipe stops for the remainder
1304          * of the TV vblank/top margin. The pipe starts up again when
1305          * the TV encoder exits the top margin.
1306          *
1307          * To avoid huge hassles for vblank timestamping we scale
1308          * the pipe timings as if the pipe always runs at the average
1309          * rate it maintains during the active period. This also
1310          * gives us a reasonable guesstimate as to the pixel rate.
1311          * Due to the variation in the actual pipe speed the scanline
1312          * counter will give us slightly erroneous results during the
1313          * TV vblank/margins. But since vtotal was selected such that
1314          * it matches the average rate of the pipe during the active
1315          * portion the error shouldn't cause any serious grief to
1316          * vblank timestamps.
1317          *
1318          * For posterity here is the empirically derived formula
1319          * that gives us the maximum length of the pipe vblank
1320          * we can use without causing display corruption. Following
1321          * this would allow us to have a ticking scanline counter
1322          * everywhere except during the bottom margin (there the
1323          * pipe always stops). Ie. this would eliminate the second
1324          * flat portion of the above graph. However this would also
1325          * complicate vblank timestamping as the pipe vtotal would
1326          * no longer match the average rate the pipe runs at during
1327          * the active portion. Hence following this formula seems
1328          * more trouble that it's worth.
1329          *
1330          * if (GRAPHICS_VER(dev_priv) == 4) {
1331          *      num = cdclk * (tv_mode->oversample >> !tv_mode->progressive);
1332          *      den = tv_mode->clock;
1333          * } else {
1334          *      num = tv_mode->oversample >> !tv_mode->progressive;
1335          *      den = 1;
1336          * }
1337          * max_pipe_vblank_len ~=
1338          *      (num * tv_htotal * (tv_vblank_len + top_margin)) /
1339          *      (den * pipe_htotal);
1340          */
1341         intel_tv_scale_mode_horiz(adjusted_mode, hdisplay,
1342                                   conn_state->tv.margins.left,
1343                                   conn_state->tv.margins.right);
1344         intel_tv_scale_mode_vert(adjusted_mode, vdisplay,
1345                                  tv_conn_state->margins.top,
1346                                  tv_conn_state->margins.bottom);
1347         drm_mode_set_crtcinfo(adjusted_mode, 0);
1348         adjusted_mode->name[0] = '\0';
1349
1350         /* pixel counter doesn't work on i965gm TV output */
1351         if (IS_I965GM(dev_priv))
1352                 pipe_config->mode_flags |=
1353                         I915_MODE_FLAG_USE_SCANLINE_COUNTER;
1354
1355         return 0;
1356 }
1357
1358 static void
1359 set_tv_mode_timings(struct drm_i915_private *dev_priv,
1360                     const struct tv_mode *tv_mode,
1361                     bool burst_ena)
1362 {
1363         u32 hctl1, hctl2, hctl3;
1364         u32 vctl1, vctl2, vctl3, vctl4, vctl5, vctl6, vctl7;
1365
1366         hctl1 = (tv_mode->hsync_end << TV_HSYNC_END_SHIFT) |
1367                 (tv_mode->htotal << TV_HTOTAL_SHIFT);
1368
1369         hctl2 = (tv_mode->hburst_start << 16) |
1370                 (tv_mode->hburst_len << TV_HBURST_LEN_SHIFT);
1371
1372         if (burst_ena)
1373                 hctl2 |= TV_BURST_ENA;
1374
1375         hctl3 = (tv_mode->hblank_start << TV_HBLANK_START_SHIFT) |
1376                 (tv_mode->hblank_end << TV_HBLANK_END_SHIFT);
1377
1378         vctl1 = (tv_mode->nbr_end << TV_NBR_END_SHIFT) |
1379                 (tv_mode->vi_end_f1 << TV_VI_END_F1_SHIFT) |
1380                 (tv_mode->vi_end_f2 << TV_VI_END_F2_SHIFT);
1381
1382         vctl2 = (tv_mode->vsync_len << TV_VSYNC_LEN_SHIFT) |
1383                 (tv_mode->vsync_start_f1 << TV_VSYNC_START_F1_SHIFT) |
1384                 (tv_mode->vsync_start_f2 << TV_VSYNC_START_F2_SHIFT);
1385
1386         vctl3 = (tv_mode->veq_len << TV_VEQ_LEN_SHIFT) |
1387                 (tv_mode->veq_start_f1 << TV_VEQ_START_F1_SHIFT) |
1388                 (tv_mode->veq_start_f2 << TV_VEQ_START_F2_SHIFT);
1389
1390         if (tv_mode->veq_ena)
1391                 vctl3 |= TV_EQUAL_ENA;
1392
1393         vctl4 = (tv_mode->vburst_start_f1 << TV_VBURST_START_F1_SHIFT) |
1394                 (tv_mode->vburst_end_f1 << TV_VBURST_END_F1_SHIFT);
1395
1396         vctl5 = (tv_mode->vburst_start_f2 << TV_VBURST_START_F2_SHIFT) |
1397                 (tv_mode->vburst_end_f2 << TV_VBURST_END_F2_SHIFT);
1398
1399         vctl6 = (tv_mode->vburst_start_f3 << TV_VBURST_START_F3_SHIFT) |
1400                 (tv_mode->vburst_end_f3 << TV_VBURST_END_F3_SHIFT);
1401
1402         vctl7 = (tv_mode->vburst_start_f4 << TV_VBURST_START_F4_SHIFT) |
1403                 (tv_mode->vburst_end_f4 << TV_VBURST_END_F4_SHIFT);
1404
1405         intel_de_write(dev_priv, TV_H_CTL_1, hctl1);
1406         intel_de_write(dev_priv, TV_H_CTL_2, hctl2);
1407         intel_de_write(dev_priv, TV_H_CTL_3, hctl3);
1408         intel_de_write(dev_priv, TV_V_CTL_1, vctl1);
1409         intel_de_write(dev_priv, TV_V_CTL_2, vctl2);
1410         intel_de_write(dev_priv, TV_V_CTL_3, vctl3);
1411         intel_de_write(dev_priv, TV_V_CTL_4, vctl4);
1412         intel_de_write(dev_priv, TV_V_CTL_5, vctl5);
1413         intel_de_write(dev_priv, TV_V_CTL_6, vctl6);
1414         intel_de_write(dev_priv, TV_V_CTL_7, vctl7);
1415 }
1416
1417 static void set_color_conversion(struct drm_i915_private *dev_priv,
1418                                  const struct color_conversion *color_conversion)
1419 {
1420         if (!color_conversion)
1421                 return;
1422
1423         intel_de_write(dev_priv, TV_CSC_Y,
1424                        (color_conversion->ry << 16) | color_conversion->gy);
1425         intel_de_write(dev_priv, TV_CSC_Y2,
1426                        (color_conversion->by << 16) | color_conversion->ay);
1427         intel_de_write(dev_priv, TV_CSC_U,
1428                        (color_conversion->ru << 16) | color_conversion->gu);
1429         intel_de_write(dev_priv, TV_CSC_U2,
1430                        (color_conversion->bu << 16) | color_conversion->au);
1431         intel_de_write(dev_priv, TV_CSC_V,
1432                        (color_conversion->rv << 16) | color_conversion->gv);
1433         intel_de_write(dev_priv, TV_CSC_V2,
1434                        (color_conversion->bv << 16) | color_conversion->av);
1435 }
1436
1437 static void intel_tv_pre_enable(struct intel_atomic_state *state,
1438                                 struct intel_encoder *encoder,
1439                                 const struct intel_crtc_state *pipe_config,
1440                                 const struct drm_connector_state *conn_state)
1441 {
1442         struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1443         struct intel_crtc *crtc = to_intel_crtc(pipe_config->uapi.crtc);
1444         struct intel_tv *intel_tv = enc_to_tv(encoder);
1445         const struct intel_tv_connector_state *tv_conn_state =
1446                 to_intel_tv_connector_state(conn_state);
1447         const struct tv_mode *tv_mode = intel_tv_mode_find(conn_state);
1448         u32 tv_ctl, tv_filter_ctl;
1449         u32 scctl1, scctl2, scctl3;
1450         int i, j;
1451         const struct video_levels *video_levels;
1452         const struct color_conversion *color_conversion;
1453         bool burst_ena;
1454         int xpos, ypos;
1455         unsigned int xsize, ysize;
1456
1457         if (!tv_mode)
1458                 return; /* can't happen (mode_prepare prevents this) */
1459
1460         tv_ctl = intel_de_read(dev_priv, TV_CTL);
1461         tv_ctl &= TV_CTL_SAVE;
1462
1463         switch (intel_tv->type) {
1464         default:
1465         case DRM_MODE_CONNECTOR_Unknown:
1466         case DRM_MODE_CONNECTOR_Composite:
1467                 tv_ctl |= TV_ENC_OUTPUT_COMPOSITE;
1468                 video_levels = tv_mode->composite_levels;
1469                 color_conversion = tv_mode->composite_color;
1470                 burst_ena = tv_mode->burst_ena;
1471                 break;
1472         case DRM_MODE_CONNECTOR_Component:
1473                 tv_ctl |= TV_ENC_OUTPUT_COMPONENT;
1474                 video_levels = &component_levels;
1475                 if (tv_mode->burst_ena)
1476                         color_conversion = &sdtv_csc_yprpb;
1477                 else
1478                         color_conversion = &hdtv_csc_yprpb;
1479                 burst_ena = false;
1480                 break;
1481         case DRM_MODE_CONNECTOR_SVIDEO:
1482                 tv_ctl |= TV_ENC_OUTPUT_SVIDEO;
1483                 video_levels = tv_mode->svideo_levels;
1484                 color_conversion = tv_mode->svideo_color;
1485                 burst_ena = tv_mode->burst_ena;
1486                 break;
1487         }
1488
1489         tv_ctl |= TV_ENC_PIPE_SEL(crtc->pipe);
1490
1491         switch (tv_mode->oversample) {
1492         case 8:
1493                 tv_ctl |= TV_OVERSAMPLE_8X;
1494                 break;
1495         case 4:
1496                 tv_ctl |= TV_OVERSAMPLE_4X;
1497                 break;
1498         case 2:
1499                 tv_ctl |= TV_OVERSAMPLE_2X;
1500                 break;
1501         default:
1502                 tv_ctl |= TV_OVERSAMPLE_NONE;
1503                 break;
1504         }
1505
1506         if (tv_mode->progressive)
1507                 tv_ctl |= TV_PROGRESSIVE;
1508         if (tv_mode->trilevel_sync)
1509                 tv_ctl |= TV_TRILEVEL_SYNC;
1510         if (tv_mode->pal_burst)
1511                 tv_ctl |= TV_PAL_BURST;
1512
1513         scctl1 = 0;
1514         if (tv_mode->dda1_inc)
1515                 scctl1 |= TV_SC_DDA1_EN;
1516         if (tv_mode->dda2_inc)
1517                 scctl1 |= TV_SC_DDA2_EN;
1518         if (tv_mode->dda3_inc)
1519                 scctl1 |= TV_SC_DDA3_EN;
1520         scctl1 |= tv_mode->sc_reset;
1521         if (video_levels)
1522                 scctl1 |= video_levels->burst << TV_BURST_LEVEL_SHIFT;
1523         scctl1 |= tv_mode->dda1_inc << TV_SCDDA1_INC_SHIFT;
1524
1525         scctl2 = tv_mode->dda2_size << TV_SCDDA2_SIZE_SHIFT |
1526                 tv_mode->dda2_inc << TV_SCDDA2_INC_SHIFT;
1527
1528         scctl3 = tv_mode->dda3_size << TV_SCDDA3_SIZE_SHIFT |
1529                 tv_mode->dda3_inc << TV_SCDDA3_INC_SHIFT;
1530
1531         /* Enable two fixes for the chips that need them. */
1532         if (IS_I915GM(dev_priv))
1533                 tv_ctl |= TV_ENC_C0_FIX | TV_ENC_SDP_FIX;
1534
1535         set_tv_mode_timings(dev_priv, tv_mode, burst_ena);
1536
1537         intel_de_write(dev_priv, TV_SC_CTL_1, scctl1);
1538         intel_de_write(dev_priv, TV_SC_CTL_2, scctl2);
1539         intel_de_write(dev_priv, TV_SC_CTL_3, scctl3);
1540
1541         set_color_conversion(dev_priv, color_conversion);
1542
1543         if (DISPLAY_VER(dev_priv) >= 4)
1544                 intel_de_write(dev_priv, TV_CLR_KNOBS, 0x00404000);
1545         else
1546                 intel_de_write(dev_priv, TV_CLR_KNOBS, 0x00606000);
1547
1548         if (video_levels)
1549                 intel_de_write(dev_priv, TV_CLR_LEVEL,
1550                                ((video_levels->black << TV_BLACK_LEVEL_SHIFT) | (video_levels->blank << TV_BLANK_LEVEL_SHIFT)));
1551
1552         assert_transcoder_disabled(dev_priv, pipe_config->cpu_transcoder);
1553
1554         /* Filter ctl must be set before TV_WIN_SIZE */
1555         tv_filter_ctl = TV_AUTO_SCALE;
1556         if (tv_conn_state->bypass_vfilter)
1557                 tv_filter_ctl |= TV_V_FILTER_BYPASS;
1558         intel_de_write(dev_priv, TV_FILTER_CTL_1, tv_filter_ctl);
1559
1560         xsize = tv_mode->hblank_start - tv_mode->hblank_end;
1561         ysize = intel_tv_mode_vdisplay(tv_mode);
1562
1563         xpos = conn_state->tv.margins.left;
1564         ypos = tv_conn_state->margins.top;
1565         xsize -= (conn_state->tv.margins.left +
1566                   conn_state->tv.margins.right);
1567         ysize -= (tv_conn_state->margins.top +
1568                   tv_conn_state->margins.bottom);
1569         intel_de_write(dev_priv, TV_WIN_POS, (xpos << 16) | ypos);
1570         intel_de_write(dev_priv, TV_WIN_SIZE, (xsize << 16) | ysize);
1571
1572         j = 0;
1573         for (i = 0; i < 60; i++)
1574                 intel_de_write(dev_priv, TV_H_LUMA(i),
1575                                tv_mode->filter_table[j++]);
1576         for (i = 0; i < 60; i++)
1577                 intel_de_write(dev_priv, TV_H_CHROMA(i),
1578                                tv_mode->filter_table[j++]);
1579         for (i = 0; i < 43; i++)
1580                 intel_de_write(dev_priv, TV_V_LUMA(i),
1581                                tv_mode->filter_table[j++]);
1582         for (i = 0; i < 43; i++)
1583                 intel_de_write(dev_priv, TV_V_CHROMA(i),
1584                                tv_mode->filter_table[j++]);
1585         intel_de_write(dev_priv, TV_DAC,
1586                        intel_de_read(dev_priv, TV_DAC) & TV_DAC_SAVE);
1587         intel_de_write(dev_priv, TV_CTL, tv_ctl);
1588 }
1589
1590 static int
1591 intel_tv_detect_type(struct intel_tv *intel_tv,
1592                       struct drm_connector *connector)
1593 {
1594         struct intel_crtc *crtc = to_intel_crtc(connector->state->crtc);
1595         struct drm_device *dev = connector->dev;
1596         struct drm_i915_private *dev_priv = to_i915(dev);
1597         u32 tv_ctl, save_tv_ctl;
1598         u32 tv_dac, save_tv_dac;
1599         int type;
1600
1601         /* Disable TV interrupts around load detect or we'll recurse */
1602         if (connector->polled & DRM_CONNECTOR_POLL_HPD) {
1603                 spin_lock_irq(&dev_priv->irq_lock);
1604                 i915_disable_pipestat(dev_priv, 0,
1605                                       PIPE_HOTPLUG_INTERRUPT_STATUS |
1606                                       PIPE_HOTPLUG_TV_INTERRUPT_STATUS);
1607                 spin_unlock_irq(&dev_priv->irq_lock);
1608         }
1609
1610         save_tv_dac = tv_dac = intel_de_read(dev_priv, TV_DAC);
1611         save_tv_ctl = tv_ctl = intel_de_read(dev_priv, TV_CTL);
1612
1613         /* Poll for TV detection */
1614         tv_ctl &= ~(TV_ENC_ENABLE | TV_ENC_PIPE_SEL_MASK | TV_TEST_MODE_MASK);
1615         tv_ctl |= TV_TEST_MODE_MONITOR_DETECT;
1616         tv_ctl |= TV_ENC_PIPE_SEL(crtc->pipe);
1617
1618         tv_dac &= ~(TVDAC_SENSE_MASK | DAC_A_MASK | DAC_B_MASK | DAC_C_MASK);
1619         tv_dac |= (TVDAC_STATE_CHG_EN |
1620                    TVDAC_A_SENSE_CTL |
1621                    TVDAC_B_SENSE_CTL |
1622                    TVDAC_C_SENSE_CTL |
1623                    DAC_CTL_OVERRIDE |
1624                    DAC_A_0_7_V |
1625                    DAC_B_0_7_V |
1626                    DAC_C_0_7_V);
1627
1628
1629         /*
1630          * The TV sense state should be cleared to zero on cantiga platform. Otherwise
1631          * the TV is misdetected. This is hardware requirement.
1632          */
1633         if (IS_GM45(dev_priv))
1634                 tv_dac &= ~(TVDAC_STATE_CHG_EN | TVDAC_A_SENSE_CTL |
1635                             TVDAC_B_SENSE_CTL | TVDAC_C_SENSE_CTL);
1636
1637         intel_de_write(dev_priv, TV_CTL, tv_ctl);
1638         intel_de_write(dev_priv, TV_DAC, tv_dac);
1639         intel_de_posting_read(dev_priv, TV_DAC);
1640
1641         intel_crtc_wait_for_next_vblank(crtc);
1642
1643         type = -1;
1644         tv_dac = intel_de_read(dev_priv, TV_DAC);
1645         drm_dbg_kms(&dev_priv->drm, "TV detected: %x, %x\n", tv_ctl, tv_dac);
1646         /*
1647          *  A B C
1648          *  0 1 1 Composite
1649          *  1 0 X svideo
1650          *  0 0 0 Component
1651          */
1652         if ((tv_dac & TVDAC_SENSE_MASK) == (TVDAC_B_SENSE | TVDAC_C_SENSE)) {
1653                 drm_dbg_kms(&dev_priv->drm,
1654                             "Detected Composite TV connection\n");
1655                 type = DRM_MODE_CONNECTOR_Composite;
1656         } else if ((tv_dac & (TVDAC_A_SENSE|TVDAC_B_SENSE)) == TVDAC_A_SENSE) {
1657                 drm_dbg_kms(&dev_priv->drm,
1658                             "Detected S-Video TV connection\n");
1659                 type = DRM_MODE_CONNECTOR_SVIDEO;
1660         } else if ((tv_dac & TVDAC_SENSE_MASK) == 0) {
1661                 drm_dbg_kms(&dev_priv->drm,
1662                             "Detected Component TV connection\n");
1663                 type = DRM_MODE_CONNECTOR_Component;
1664         } else {
1665                 drm_dbg_kms(&dev_priv->drm, "Unrecognised TV connection\n");
1666                 type = -1;
1667         }
1668
1669         intel_de_write(dev_priv, TV_DAC, save_tv_dac & ~TVDAC_STATE_CHG_EN);
1670         intel_de_write(dev_priv, TV_CTL, save_tv_ctl);
1671         intel_de_posting_read(dev_priv, TV_CTL);
1672
1673         /* For unknown reasons the hw barfs if we don't do this vblank wait. */
1674         intel_crtc_wait_for_next_vblank(crtc);
1675
1676         /* Restore interrupt config */
1677         if (connector->polled & DRM_CONNECTOR_POLL_HPD) {
1678                 spin_lock_irq(&dev_priv->irq_lock);
1679                 i915_enable_pipestat(dev_priv, 0,
1680                                      PIPE_HOTPLUG_INTERRUPT_STATUS |
1681                                      PIPE_HOTPLUG_TV_INTERRUPT_STATUS);
1682                 spin_unlock_irq(&dev_priv->irq_lock);
1683         }
1684
1685         return type;
1686 }
1687
1688 /*
1689  * Here we set accurate tv format according to connector type
1690  * i.e Component TV should not be assigned by NTSC or PAL
1691  */
1692 static void intel_tv_find_better_format(struct drm_connector *connector)
1693 {
1694         struct intel_tv *intel_tv = intel_attached_tv(to_intel_connector(connector));
1695         const struct tv_mode *tv_mode = intel_tv_mode_find(connector->state);
1696         int i;
1697
1698         /* Component supports everything so we can keep the current mode */
1699         if (intel_tv->type == DRM_MODE_CONNECTOR_Component)
1700                 return;
1701
1702         /* If the current mode is fine don't change it */
1703         if (!tv_mode->component_only)
1704                 return;
1705
1706         for (i = 0; i < ARRAY_SIZE(tv_modes); i++) {
1707                 tv_mode = &tv_modes[i];
1708
1709                 if (!tv_mode->component_only)
1710                         break;
1711         }
1712
1713         connector->state->tv.mode = i;
1714 }
1715
1716 static int
1717 intel_tv_detect(struct drm_connector *connector,
1718                 struct drm_modeset_acquire_ctx *ctx,
1719                 bool force)
1720 {
1721         struct drm_i915_private *i915 = to_i915(connector->dev);
1722         struct intel_tv *intel_tv = intel_attached_tv(to_intel_connector(connector));
1723         enum drm_connector_status status;
1724         int type;
1725
1726         drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] force=%d\n",
1727                     connector->base.id, connector->name, force);
1728
1729         if (!intel_display_device_enabled(i915))
1730                 return connector_status_disconnected;
1731
1732         if (force) {
1733                 struct drm_atomic_state *state;
1734
1735                 state = intel_load_detect_get_pipe(connector, ctx);
1736                 if (IS_ERR(state))
1737                         return PTR_ERR(state);
1738
1739                 if (state) {
1740                         type = intel_tv_detect_type(intel_tv, connector);
1741                         intel_load_detect_release_pipe(connector, state, ctx);
1742                         status = type < 0 ?
1743                                 connector_status_disconnected :
1744                                 connector_status_connected;
1745                 } else {
1746                         status = connector_status_unknown;
1747                 }
1748
1749                 if (status == connector_status_connected) {
1750                         intel_tv->type = type;
1751                         intel_tv_find_better_format(connector);
1752                 }
1753
1754                 return status;
1755         } else
1756                 return connector->status;
1757 }
1758
1759 static const struct input_res {
1760         u16 w, h;
1761 } input_res_table[] = {
1762         { 640, 480 },
1763         { 800, 600 },
1764         { 1024, 768 },
1765         { 1280, 1024 },
1766         { 848, 480 },
1767         { 1280, 720 },
1768         { 1920, 1080 },
1769 };
1770
1771 /* Choose preferred mode according to line number of TV format */
1772 static bool
1773 intel_tv_is_preferred_mode(const struct drm_display_mode *mode,
1774                            const struct tv_mode *tv_mode)
1775 {
1776         int vdisplay = intel_tv_mode_vdisplay(tv_mode);
1777
1778         /* prefer 480 line modes for all SD TV modes */
1779         if (vdisplay <= 576)
1780                 vdisplay = 480;
1781
1782         return vdisplay == mode->vdisplay;
1783 }
1784
1785 static void
1786 intel_tv_set_mode_type(struct drm_display_mode *mode,
1787                        const struct tv_mode *tv_mode)
1788 {
1789         mode->type = DRM_MODE_TYPE_DRIVER;
1790
1791         if (intel_tv_is_preferred_mode(mode, tv_mode))
1792                 mode->type |= DRM_MODE_TYPE_PREFERRED;
1793 }
1794
1795 static int
1796 intel_tv_get_modes(struct drm_connector *connector)
1797 {
1798         struct drm_i915_private *dev_priv = to_i915(connector->dev);
1799         const struct tv_mode *tv_mode = intel_tv_mode_find(connector->state);
1800         int i, count = 0;
1801
1802         for (i = 0; i < ARRAY_SIZE(input_res_table); i++) {
1803                 const struct input_res *input = &input_res_table[i];
1804                 struct drm_display_mode *mode;
1805
1806                 if (input->w > 1024 &&
1807                     !tv_mode->progressive &&
1808                     !tv_mode->component_only)
1809                         continue;
1810
1811                 /* no vertical scaling with wide sources on gen3 */
1812                 if (DISPLAY_VER(dev_priv) == 3 && input->w > 1024 &&
1813                     input->h > intel_tv_mode_vdisplay(tv_mode))
1814                         continue;
1815
1816                 mode = drm_mode_create(connector->dev);
1817                 if (!mode)
1818                         continue;
1819
1820                 /*
1821                  * We take the TV mode and scale it to look
1822                  * like it had the expected h/vdisplay. This
1823                  * provides the most information to userspace
1824                  * about the actual timings of the mode. We
1825                  * do ignore the margins though.
1826                  */
1827                 intel_tv_mode_to_mode(mode, tv_mode, tv_mode->clock);
1828                 if (count == 0) {
1829                         drm_dbg_kms(&dev_priv->drm, "TV mode: " DRM_MODE_FMT "\n",
1830                                     DRM_MODE_ARG(mode));
1831                 }
1832                 intel_tv_scale_mode_horiz(mode, input->w, 0, 0);
1833                 intel_tv_scale_mode_vert(mode, input->h, 0, 0);
1834                 intel_tv_set_mode_type(mode, tv_mode);
1835
1836                 drm_mode_set_name(mode);
1837
1838                 drm_mode_probed_add(connector, mode);
1839                 count++;
1840         }
1841
1842         return count;
1843 }
1844
1845 static const struct drm_connector_funcs intel_tv_connector_funcs = {
1846         .late_register = intel_connector_register,
1847         .early_unregister = intel_connector_unregister,
1848         .destroy = intel_connector_destroy,
1849         .fill_modes = drm_helper_probe_single_connector_modes,
1850         .atomic_destroy_state = drm_atomic_helper_connector_destroy_state,
1851         .atomic_duplicate_state = intel_tv_connector_duplicate_state,
1852 };
1853
1854 static int intel_tv_atomic_check(struct drm_connector *connector,
1855                                  struct drm_atomic_state *state)
1856 {
1857         struct drm_connector_state *new_state;
1858         struct drm_crtc_state *new_crtc_state;
1859         struct drm_connector_state *old_state;
1860
1861         new_state = drm_atomic_get_new_connector_state(state, connector);
1862         if (!new_state->crtc)
1863                 return 0;
1864
1865         old_state = drm_atomic_get_old_connector_state(state, connector);
1866         new_crtc_state = drm_atomic_get_new_crtc_state(state, new_state->crtc);
1867
1868         if (old_state->tv.mode != new_state->tv.mode ||
1869             old_state->tv.margins.left != new_state->tv.margins.left ||
1870             old_state->tv.margins.right != new_state->tv.margins.right ||
1871             old_state->tv.margins.top != new_state->tv.margins.top ||
1872             old_state->tv.margins.bottom != new_state->tv.margins.bottom) {
1873                 /* Force a modeset. */
1874
1875                 new_crtc_state->connectors_changed = true;
1876         }
1877
1878         return 0;
1879 }
1880
1881 static const struct drm_connector_helper_funcs intel_tv_connector_helper_funcs = {
1882         .detect_ctx = intel_tv_detect,
1883         .mode_valid = intel_tv_mode_valid,
1884         .get_modes = intel_tv_get_modes,
1885         .atomic_check = intel_tv_atomic_check,
1886 };
1887
1888 static const struct drm_encoder_funcs intel_tv_enc_funcs = {
1889         .destroy = intel_encoder_destroy,
1890 };
1891
1892 static void intel_tv_add_properties(struct drm_connector *connector)
1893 {
1894         struct drm_i915_private *i915 = to_i915(connector->dev);
1895         struct drm_connector_state *conn_state = connector->state;
1896         const char *tv_format_names[ARRAY_SIZE(tv_modes)];
1897         int i;
1898
1899         /* BIOS margin values */
1900         conn_state->tv.margins.left = 54;
1901         conn_state->tv.margins.top = 36;
1902         conn_state->tv.margins.right = 46;
1903         conn_state->tv.margins.bottom = 37;
1904
1905         conn_state->tv.mode = 0;
1906
1907         /* Create TV properties then attach current values */
1908         for (i = 0; i < ARRAY_SIZE(tv_modes); i++) {
1909                 /* 1080p50/1080p60 not supported on gen3 */
1910                 if (DISPLAY_VER(i915) == 3 && tv_modes[i].oversample == 1)
1911                         break;
1912
1913                 tv_format_names[i] = tv_modes[i].name;
1914         }
1915         drm_mode_create_tv_properties_legacy(&i915->drm, i, tv_format_names);
1916
1917         drm_object_attach_property(&connector->base,
1918                                    i915->drm.mode_config.legacy_tv_mode_property,
1919                                    conn_state->tv.mode);
1920         drm_object_attach_property(&connector->base,
1921                                    i915->drm.mode_config.tv_left_margin_property,
1922                                    conn_state->tv.margins.left);
1923         drm_object_attach_property(&connector->base,
1924                                    i915->drm.mode_config.tv_top_margin_property,
1925                                    conn_state->tv.margins.top);
1926         drm_object_attach_property(&connector->base,
1927                                    i915->drm.mode_config.tv_right_margin_property,
1928                                    conn_state->tv.margins.right);
1929         drm_object_attach_property(&connector->base,
1930                                    i915->drm.mode_config.tv_bottom_margin_property,
1931                                    conn_state->tv.margins.bottom);
1932 }
1933
1934 void
1935 intel_tv_init(struct drm_i915_private *dev_priv)
1936 {
1937         struct drm_connector *connector;
1938         struct intel_tv *intel_tv;
1939         struct intel_encoder *intel_encoder;
1940         struct intel_connector *intel_connector;
1941         u32 tv_dac_on, tv_dac_off, save_tv_dac;
1942
1943         if ((intel_de_read(dev_priv, TV_CTL) & TV_FUSE_STATE_MASK) == TV_FUSE_STATE_DISABLED)
1944                 return;
1945
1946         if (!intel_bios_is_tv_present(dev_priv)) {
1947                 drm_dbg_kms(&dev_priv->drm, "Integrated TV is not present.\n");
1948                 return;
1949         }
1950
1951         /*
1952          * Sanity check the TV output by checking to see if the
1953          * DAC register holds a value
1954          */
1955         save_tv_dac = intel_de_read(dev_priv, TV_DAC);
1956
1957         intel_de_write(dev_priv, TV_DAC, save_tv_dac | TVDAC_STATE_CHG_EN);
1958         tv_dac_on = intel_de_read(dev_priv, TV_DAC);
1959
1960         intel_de_write(dev_priv, TV_DAC, save_tv_dac & ~TVDAC_STATE_CHG_EN);
1961         tv_dac_off = intel_de_read(dev_priv, TV_DAC);
1962
1963         intel_de_write(dev_priv, TV_DAC, save_tv_dac);
1964
1965         /*
1966          * If the register does not hold the state change enable
1967          * bit, (either as a 0 or a 1), assume it doesn't really
1968          * exist
1969          */
1970         if ((tv_dac_on & TVDAC_STATE_CHG_EN) == 0 ||
1971             (tv_dac_off & TVDAC_STATE_CHG_EN) != 0)
1972                 return;
1973
1974         intel_tv = kzalloc(sizeof(*intel_tv), GFP_KERNEL);
1975         if (!intel_tv) {
1976                 return;
1977         }
1978
1979         intel_connector = intel_connector_alloc();
1980         if (!intel_connector) {
1981                 kfree(intel_tv);
1982                 return;
1983         }
1984
1985         intel_encoder = &intel_tv->base;
1986         connector = &intel_connector->base;
1987
1988         /*
1989          * The documentation, for the older chipsets at least, recommend
1990          * using a polling method rather than hotplug detection for TVs.
1991          * This is because in order to perform the hotplug detection, the PLLs
1992          * for the TV must be kept alive increasing power drain and starving
1993          * bandwidth from other encoders. Notably for instance, it causes
1994          * pipe underruns on Crestline when this encoder is supposedly idle.
1995          *
1996          * More recent chipsets favour HDMI rather than integrated S-Video.
1997          */
1998         intel_connector->polled = DRM_CONNECTOR_POLL_CONNECT;
1999
2000         drm_connector_init(&dev_priv->drm, connector, &intel_tv_connector_funcs,
2001                            DRM_MODE_CONNECTOR_SVIDEO);
2002
2003         drm_encoder_init(&dev_priv->drm, &intel_encoder->base, &intel_tv_enc_funcs,
2004                          DRM_MODE_ENCODER_TVDAC, "TV");
2005
2006         intel_encoder->compute_config = intel_tv_compute_config;
2007         intel_encoder->get_config = intel_tv_get_config;
2008         intel_encoder->pre_enable = intel_tv_pre_enable;
2009         intel_encoder->enable = intel_enable_tv;
2010         intel_encoder->disable = intel_disable_tv;
2011         intel_encoder->get_hw_state = intel_tv_get_hw_state;
2012         intel_connector->get_hw_state = intel_connector_get_hw_state;
2013
2014         intel_connector_attach_encoder(intel_connector, intel_encoder);
2015
2016         intel_encoder->type = INTEL_OUTPUT_TVOUT;
2017         intel_encoder->power_domain = POWER_DOMAIN_PORT_OTHER;
2018         intel_encoder->port = PORT_NONE;
2019         intel_encoder->pipe_mask = ~0;
2020         intel_encoder->cloneable = 0;
2021         intel_tv->type = DRM_MODE_CONNECTOR_Unknown;
2022
2023         drm_connector_helper_add(connector, &intel_tv_connector_helper_funcs);
2024
2025         intel_tv_add_properties(connector);
2026 }
This page took 0.148817 seconds and 4 git commands to generate.