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