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