1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
|
#ifndef _UAPI_MSM_HDMI_MODES_H__
#define _UAPI_MSM_HDMI_MODES_H__
#include <linux/types.h>
#include <linux/errno.h>
#define MSM_HDMI_RGB_888_24BPP_FORMAT BIT(0)
#define MSM_HDMI_YUV_420_12BPP_FORMAT BIT(1)
enum aspect_ratio {
HDMI_RES_AR_INVALID,
HDMI_RES_AR_4_3,
HDMI_RES_AR_5_4,
HDMI_RES_AR_16_9,
HDMI_RES_AR_16_10,
HDMI_RES_AR_64_27,
HDMI_RES_AR_256_135,
HDMI_RES_AR_MAX,
};
enum msm_hdmi_s3d_mode {
HDMI_S3D_NONE,
HDMI_S3D_SIDE_BY_SIDE,
HDMI_S3D_TOP_AND_BOTTOM,
HDMI_S3D_FRAME_PACKING,
HDMI_S3D_MAX,
};
struct msm_hdmi_mode_timing_info {
uint32_t video_format;
uint32_t active_h;
uint32_t front_porch_h;
uint32_t pulse_width_h;
uint32_t back_porch_h;
uint32_t active_low_h;
uint32_t active_v;
uint32_t front_porch_v;
uint32_t pulse_width_v;
uint32_t back_porch_v;
uint32_t active_low_v;
/* Must divide by 1000 to get the actual frequency in MHZ */
uint32_t pixel_freq;
/* Must divide by 1000 to get the actual frequency in HZ */
uint32_t refresh_rate;
uint32_t interlaced;
uint32_t supported;
enum aspect_ratio ar;
/* Flags indicating support for specific pixel formats */
uint32_t pixel_formats;
};
#define MSM_HDMI_INIT_RES_PAGE 1
#define MSM_HDMI_MODES_CEA (1 << 0)
#define MSM_HDMI_MODES_XTND (1 << 1)
#define MSM_HDMI_MODES_DVI (1 << 2)
#define MSM_HDMI_MODES_ALL (MSM_HDMI_MODES_CEA |\
MSM_HDMI_MODES_XTND |\
MSM_HDMI_MODES_DVI)
/* all video formats defined by CEA 861D */
#define HDMI_VFRMT_UNKNOWN 0
#define HDMI_VFRMT_640x480p60_4_3 1
#define HDMI_VFRMT_720x480p60_4_3 2
#define HDMI_VFRMT_720x480p60_16_9 3
#define HDMI_VFRMT_1280x720p60_16_9 4
#define HDMI_VFRMT_1920x1080i60_16_9 5
#define HDMI_VFRMT_720x480i60_4_3 6
#define HDMI_VFRMT_1440x480i60_4_3 HDMI_VFRMT_720x480i60_4_3
#define HDMI_VFRMT_720x480i60_16_9 7
#define HDMI_VFRMT_1440x480i60_16_9 HDMI_VFRMT_720x480i60_16_9
#define HDMI_VFRMT_720x240p60_4_3 8
#define HDMI_VFRMT_1440x240p60_4_3 HDMI_VFRMT_720x240p60_4_3
#define HDMI_VFRMT_720x240p60_16_9 9
#define HDMI_VFRMT_1440x240p60_16_9 HDMI_VFRMT_720x240p60_16_9
#define HDMI_VFRMT_2880x480i60_4_3 10
#define HDMI_VFRMT_2880x480i60_16_9 11
#define HDMI_VFRMT_2880x240p60_4_3 12
#define HDMI_VFRMT_2880x240p60_16_9 13
#define HDMI_VFRMT_1440x480p60_4_3 14
#define HDMI_VFRMT_1440x480p60_16_9 15
#define HDMI_VFRMT_1920x1080p60_16_9 16
#define HDMI_VFRMT_720x576p50_4_3 17
#define HDMI_VFRMT_720x576p50_16_9 18
#define HDMI_VFRMT_1280x720p50_16_9 19
#define HDMI_VFRMT_1920x1080i50_16_9 20
#define HDMI_VFRMT_720x576i50_4_3 21
#define HDMI_VFRMT_1440x576i50_4_3 HDMI_VFRMT_720x576i50_4_3
#define HDMI_VFRMT_720x576i50_16_9 22
#define HDMI_VFRMT_1440x576i50_16_9 HDMI_VFRMT_720x576i50_16_9
#define HDMI_VFRMT_720x288p50_4_3 23
#define HDMI_VFRMT_1440x288p50_4_3 HDMI_VFRMT_720x288p50_4_3
#define HDMI_VFRMT_720x288p50_16_9 24
#define HDMI_VFRMT_1440x288p50_16_9 HDMI_VFRMT_720x288p50_16_9
#define HDMI_VFRMT_2880x576i50_4_3 25
#define HDMI_VFRMT_2880x576i50_16_9 26
#define HDMI_VFRMT_2880x288p50_4_3 27
#define HDMI_VFRMT_2880x288p50_16_9 28
#define HDMI_VFRMT_1440x576p50_4_3 29
#define HDMI_VFRMT_1440x576p50_16_9 30
#define HDMI_VFRMT_1920x1080p50_16_9 31
#define HDMI_VFRMT_1920x1080p24_16_9 32
#define HDMI_VFRMT_1920x1080p25_16_9 33
#define HDMI_VFRMT_1920x1080p30_16_9 34
#define HDMI_VFRMT_2880x480p60_4_3 35
#define HDMI_VFRMT_2880x480p60_16_9 36
#define HDMI_VFRMT_2880x576p50_4_3 37
#define HDMI_VFRMT_2880x576p50_16_9 38
#define HDMI_VFRMT_1920x1250i50_16_9 39
#define HDMI_VFRMT_1920x1080i100_16_9 40
#define HDMI_VFRMT_1280x720p100_16_9 41
#define HDMI_VFRMT_720x576p100_4_3 42
#define HDMI_VFRMT_720x576p100_16_9 43
#define HDMI_VFRMT_720x576i100_4_3 44
#define HDMI_VFRMT_1440x576i100_4_3 HDMI_VFRMT_720x576i100_4_3
#define HDMI_VFRMT_720x576i100_16_9 45
#define HDMI_VFRMT_1440x576i100_16_9 HDMI_VFRMT_720x576i100_16_9
#define HDMI_VFRMT_1920x1080i120_16_9 46
#define HDMI_VFRMT_1280x720p120_16_9 47
#define HDMI_VFRMT_720x480p120_4_3 48
#define HDMI_VFRMT_720x480p120_16_9 49
#define HDMI_VFRMT_720x480i120_4_3 50
#define HDMI_VFRMT_1440x480i120_4_3 HDMI_VFRMT_720x480i120_4_3
#define HDMI_VFRMT_720x480i120_16_9 51
#define HDMI_VFRMT_1440x480i120_16_9 HDMI_VFRMT_720x480i120_16_9
#define HDMI_VFRMT_720x576p200_4_3 52
#define HDMI_VFRMT_720x576p200_16_9 53
#define HDMI_VFRMT_720x576i200_4_3 54
#define HDMI_VFRMT_1440x576i200_4_3 HDMI_VFRMT_720x576i200_4_3
#define HDMI_VFRMT_720x576i200_16_9 55
#define HDMI_VFRMT_1440x576i200_16_9 HDMI_VFRMT_720x576i200_16_9
#define HDMI_VFRMT_720x480p240_4_3 56
#define HDMI_VFRMT_720x480p240_16_9 57
#define HDMI_VFRMT_720x480i240_4_3 58
#define HDMI_VFRMT_1440x480i240_4_3 HDMI_VFRMT_720x480i240_4_3
#define HDMI_VFRMT_720x480i240_16_9 59
#define HDMI_VFRMT_1440x480i240_16_9 HDMI_VFRMT_720x480i240_16_9
#define HDMI_VFRMT_1280x720p24_16_9 60
#define HDMI_VFRMT_1280x720p25_16_9 61
#define HDMI_VFRMT_1280x720p30_16_9 62
#define HDMI_VFRMT_1920x1080p120_16_9 63
#define HDMI_VFRMT_1920x1080p100_16_9 64
#define HDMI_VFRMT_1280x720p24_64_27 65
#define HDMI_VFRMT_1280x720p25_64_27 66
#define HDMI_VFRMT_1280x720p30_64_27 67
#define HDMI_VFRMT_1280x720p50_64_27 68
#define HDMI_VFRMT_1280x720p60_64_27 69
#define HDMI_VFRMT_1280x720p100_64_27 70
#define HDMI_VFRMT_1280x720p120_64_27 71
#define HDMI_VFRMT_1920x1080p24_64_27 72
#define HDMI_VFRMT_1920x1080p25_64_27 73
#define HDMI_VFRMT_1920x1080p30_64_27 74
#define HDMI_VFRMT_1920x1080p50_64_27 75
#define HDMI_VFRMT_1920x1080p60_64_27 76
#define HDMI_VFRMT_1920x1080p100_64_27 77
#define HDMI_VFRMT_1920x1080p120_64_27 78
#define HDMI_VFRMT_1680x720p24_64_27 79
#define HDMI_VFRMT_1680x720p25_64_27 80
#define HDMI_VFRMT_1680x720p30_64_27 81
#define HDMI_VFRMT_1680x720p50_64_27 82
#define HDMI_VFRMT_1680x720p60_64_27 83
#define HDMI_VFRMT_1680x720p100_64_27 84
#define HDMI_VFRMT_1680x720p120_64_27 85
#define HDMI_VFRMT_2560x1080p24_64_27 86
#define HDMI_VFRMT_2560x1080p25_64_27 87
#define HDMI_VFRMT_2560x1080p30_64_27 88
#define HDMI_VFRMT_2560x1080p50_64_27 89
#define HDMI_VFRMT_2560x1080p60_64_27 90
#define HDMI_VFRMT_2560x1080p100_64_27 91
#define HDMI_VFRMT_2560x1080p120_64_27 92
#define HDMI_VFRMT_3840x2160p24_16_9 93
#define HDMI_VFRMT_3840x2160p25_16_9 94
#define HDMI_VFRMT_3840x2160p30_16_9 95
#define HDMI_VFRMT_3840x2160p50_16_9 96
#define HDMI_VFRMT_3840x2160p60_16_9 97
#define HDMI_VFRMT_4096x2160p24_256_135 98
#define HDMI_VFRMT_4096x2160p25_256_135 99
#define HDMI_VFRMT_4096x2160p30_256_135 100
#define HDMI_VFRMT_4096x2160p50_256_135 101
#define HDMI_VFRMT_4096x2160p60_256_135 102
#define HDMI_VFRMT_3840x2160p24_64_27 103
#define HDMI_VFRMT_3840x2160p25_64_27 104
#define HDMI_VFRMT_3840x2160p30_64_27 105
#define HDMI_VFRMT_3840x2160p50_64_27 106
#define HDMI_VFRMT_3840x2160p60_64_27 107
/* Video Identification Codes from 107-127 are reserved for the future */
#define HDMI_VFRMT_END 127
#define EVFRMT_OFF(x) (HDMI_VFRMT_END + x)
/* extended video formats */
#define HDMI_EVFRMT_3840x2160p30_16_9 EVFRMT_OFF(1)
#define HDMI_EVFRMT_3840x2160p25_16_9 EVFRMT_OFF(2)
#define HDMI_EVFRMT_3840x2160p24_16_9 EVFRMT_OFF(3)
#define HDMI_EVFRMT_4096x2160p24_16_9 EVFRMT_OFF(4)
#define HDMI_EVFRMT_END HDMI_EVFRMT_4096x2160p24_16_9
#define WQXGA_OFF(x) (HDMI_EVFRMT_END + x)
/* WQXGA */
#define HDMI_VFRMT_2560x1600p60_16_9 WQXGA_OFF(1)
#define HDMI_WQXGAFRMT_END HDMI_VFRMT_2560x1600p60_16_9
#define WXGA_OFF(x) (HDMI_WQXGAFRMT_END + x)
/* WXGA */
#define HDMI_VFRMT_1280x800p60_16_10 WXGA_OFF(1)
#define HDMI_VFRMT_1366x768p60_16_10 WXGA_OFF(2)
#define HDMI_WXGAFRMT_END HDMI_VFRMT_1366x768p60_16_10
#define ETI_OFF(x) (HDMI_WXGAFRMT_END + x)
/* ESTABLISHED TIMINGS I */
#define HDMI_VFRMT_800x600p60_4_3 ETI_OFF(1)
#define ETI_VFRMT_END HDMI_VFRMT_800x600p60_4_3
#define ETII_OFF(x) (ETI_VFRMT_END + x)
/* ESTABLISHED TIMINGS II */
#define HDMI_VFRMT_1024x768p60_4_3 ETII_OFF(1)
#define HDMI_VFRMT_1280x1024p60_5_4 ETII_OFF(2)
#define ETII_VFRMT_END HDMI_VFRMT_1280x1024p60_5_4
#define ETIII_OFF(x) (ETII_VFRMT_END + x)
/* ESTABLISHED TIMINGS III */
#define HDMI_VFRMT_848x480p60_16_9 ETIII_OFF(1)
#define HDMI_VFRMT_1280x960p60_4_3 ETIII_OFF(2)
#define HDMI_VFRMT_1360x768p60_16_9 ETIII_OFF(3)
#define HDMI_VFRMT_1440x900p60_16_10 ETIII_OFF(4)
#define HDMI_VFRMT_1400x1050p60_4_3 ETIII_OFF(5)
#define HDMI_VFRMT_1680x1050p60_16_10 ETIII_OFF(6)
#define HDMI_VFRMT_1600x1200p60_4_3 ETIII_OFF(7)
#define HDMI_VFRMT_1920x1200p60_16_10 ETIII_OFF(8)
#define ETIII_VFRMT_END HDMI_VFRMT_1920x1200p60_16_10
#define MISC_VFRMT_OFF(x) (ETIII_VFRMT_END + x)
#define HDMI_VFRMT_640x480p59_4_3 MISC_VFRMT_OFF(1)
#define MISC_VFRMT_END HDMI_VFRMT_640x480p59_4_3
#define RESERVE_OFF(x) (MISC_VFRMT_END + x)
#define HDMI_VFRMT_RESERVE1 RESERVE_OFF(1)
#define HDMI_VFRMT_RESERVE2 RESERVE_OFF(2)
#define HDMI_VFRMT_RESERVE3 RESERVE_OFF(3)
#define HDMI_VFRMT_RESERVE4 RESERVE_OFF(4)
#define HDMI_VFRMT_RESERVE5 RESERVE_OFF(5)
#define HDMI_VFRMT_RESERVE6 RESERVE_OFF(6)
#define HDMI_VFRMT_RESERVE7 RESERVE_OFF(7)
#define HDMI_VFRMT_RESERVE8 RESERVE_OFF(8)
#define RESERVE_VFRMT_END HDMI_VFRMT_RESERVE8
#define HDMI_VFRMT_MAX (RESERVE_VFRMT_END + 1)
/* Timing information for supported modes */
#define VFRMT_NOT_SUPPORTED(VFRMT) \
{VFRMT, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, false, \
HDMI_RES_AR_INVALID}
#define HDMI_VFRMT_640x480p60_4_3_TIMING \
{HDMI_VFRMT_640x480p60_4_3, 640, 16, 96, 48, true, \
480, 10, 2, 33, true, 25200, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_720x480p60_4_3_TIMING \
{HDMI_VFRMT_720x480p60_4_3, 720, 16, 62, 60, true, \
480, 9, 6, 30, true, 27027, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_720x480p60_16_9_TIMING \
{HDMI_VFRMT_720x480p60_16_9, 720, 16, 62, 60, true, \
480, 9, 6, 30, true, 27027, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1280x720p60_16_9_TIMING \
{HDMI_VFRMT_1280x720p60_16_9, 1280, 110, 40, 220, false, \
720, 5, 5, 20, false, 74250, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080i60_16_9_TIMING \
{HDMI_VFRMT_1920x1080i60_16_9, 1920, 88, 44, 148, false, \
540, 2, 5, 5, false, 74250, 60000, true, false, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1440x480i60_4_3_TIMING \
{HDMI_VFRMT_1440x480i60_4_3, 1440, 38, 124, 114, true, \
240, 4, 3, 15, true, 27000, 60000, true, false, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1440x480i60_16_9_TIMING \
{HDMI_VFRMT_1440x480i60_16_9, 1440, 38, 124, 114, true, \
240, 4, 3, 15, true, 27000, 60000, true, false, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080p60_16_9_TIMING \
{HDMI_VFRMT_1920x1080p60_16_9, 1920, 88, 44, 148, false, \
1080, 4, 5, 36, false, 148500, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_720x576p50_4_3_TIMING \
{HDMI_VFRMT_720x576p50_4_3, 720, 12, 64, 68, true, \
576, 5, 5, 39, true, 27000, 50000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_720x576p50_16_9_TIMING \
{HDMI_VFRMT_720x576p50_16_9, 720, 12, 64, 68, true, \
576, 5, 5, 39, true, 27000, 50000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1280x720p50_16_9_TIMING \
{HDMI_VFRMT_1280x720p50_16_9, 1280, 440, 40, 220, false, \
720, 5, 5, 20, false, 74250, 50000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1440x576i50_4_3_TIMING \
{HDMI_VFRMT_1440x576i50_4_3, 1440, 24, 126, 138, true, \
288, 2, 3, 19, true, 27000, 50000, true, false, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1440x576i50_16_9_TIMING \
{HDMI_VFRMT_1440x576i50_16_9, 1440, 24, 126, 138, true, \
288, 2, 3, 19, true, 27000, 50000, true, false, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080p50_16_9_TIMING \
{HDMI_VFRMT_1920x1080p50_16_9, 1920, 528, 44, 148, false, \
1080, 4, 5, 36, false, 148500, 50000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080p24_16_9_TIMING \
{HDMI_VFRMT_1920x1080p24_16_9, 1920, 638, 44, 148, false, \
1080, 4, 5, 36, false, 74250, 24000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080p25_16_9_TIMING \
{HDMI_VFRMT_1920x1080p25_16_9, 1920, 528, 44, 148, false, \
1080, 4, 5, 36, false, 74250, 25000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1920x1080p30_16_9_TIMING \
{HDMI_VFRMT_1920x1080p30_16_9, 1920, 88, 44, 148, false, \
1080, 4, 5, 36, false, 74250, 30000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1024x768p60_4_3_TIMING \
{HDMI_VFRMT_1024x768p60_4_3, 1024, 24, 136, 160, false, \
768, 2, 6, 29, false, 65000, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1280x1024p60_5_4_TIMING \
{HDMI_VFRMT_1280x1024p60_5_4, 1280, 48, 112, 248, false, \
1024, 1, 3, 38, false, 108000, 60000, false, true, HDMI_RES_AR_5_4, 0}
#define HDMI_VFRMT_2560x1600p60_16_9_TIMING \
{HDMI_VFRMT_2560x1600p60_16_9, 2560, 48, 32, 80, false, \
1600, 3, 6, 37, false, 268500, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_EVFRMT_3840x2160p30_16_9_TIMING \
{HDMI_EVFRMT_3840x2160p30_16_9, 3840, 176, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 30000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_EVFRMT_3840x2160p25_16_9_TIMING \
{HDMI_EVFRMT_3840x2160p25_16_9, 3840, 1056, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 25000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_EVFRMT_3840x2160p24_16_9_TIMING \
{HDMI_EVFRMT_3840x2160p24_16_9, 3840, 1276, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 24000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_EVFRMT_4096x2160p24_16_9_TIMING \
{HDMI_EVFRMT_4096x2160p24_16_9, 4096, 1020, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 24000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_800x600p60_4_3_TIMING \
{HDMI_VFRMT_800x600p60_4_3, 800, 40, 128, 88, false, \
600, 1, 4, 23, false, 40000, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_848x480p60_16_9_TIMING \
{HDMI_VFRMT_848x480p60_16_9, 848, 16, 112, 112, false, \
480, 6, 8, 23, false, 33750, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1280x960p60_4_3_TIMING\
{HDMI_VFRMT_1280x960p60_4_3, 1280, 96, 112, 312, false, \
960, 1, 3, 36, false, 108000, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1360x768p60_16_9_TIMING\
{HDMI_VFRMT_1360x768p60_16_9, 1360, 64, 112, 256, false, \
768, 3, 6, 18, false, 85500, 60000, false, true, HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_1440x900p60_16_10_TIMING\
{HDMI_VFRMT_1440x900p60_16_10, 1440, 48, 32, 80, false, \
900, 3, 6, 17, true, 88750, 60000, false, true, HDMI_RES_AR_16_10, 0}
#define HDMI_VFRMT_1400x1050p60_4_3_TIMING\
{HDMI_VFRMT_1400x1050p60_4_3, 1400, 48, 32, 80, false, \
1050, 3, 4, 23, true, 101000, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1680x1050p60_16_10_TIMING\
{HDMI_VFRMT_1680x1050p60_16_10, 1680, 48, 32, 80, false, \
1050, 3, 6, 21, true, 119000, 60000, false, true, HDMI_RES_AR_16_10, 0}
#define HDMI_VFRMT_1600x1200p60_4_3_TIMING\
{HDMI_VFRMT_1600x1200p60_4_3, 1600, 64, 192, 304, false, \
1200, 1, 3, 46, false, 162000, 60000, false, true, HDMI_RES_AR_4_3, 0}
#define HDMI_VFRMT_1920x1200p60_16_10_TIMING\
{HDMI_VFRMT_1920x1200p60_16_10, 1920, 48, 32, 80, false,\
1200, 3, 6, 26, true, 154000, 60000, false, true, HDMI_RES_AR_16_10, 0}
#define HDMI_VFRMT_1366x768p60_16_10_TIMING\
{HDMI_VFRMT_1366x768p60_16_10, 1366, 70, 143, 213, false,\
768, 3, 3, 24, false, 85500, 60000, false, true, HDMI_RES_AR_16_10, 0}
#define HDMI_VFRMT_1280x800p60_16_10_TIMING\
{HDMI_VFRMT_1280x800p60_16_10, 1280, 72, 128, 200, true,\
800, 3, 6, 22, false, 83500, 60000, false, true, HDMI_RES_AR_16_10, 0}
#define HDMI_VFRMT_3840x2160p24_16_9_TIMING \
{HDMI_VFRMT_3840x2160p24_16_9, 3840, 1276, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 24000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_3840x2160p25_16_9_TIMING \
{HDMI_VFRMT_3840x2160p25_16_9, 3840, 1056, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 25000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_3840x2160p30_16_9_TIMING \
{HDMI_VFRMT_3840x2160p30_16_9, 3840, 176, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 30000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_3840x2160p50_16_9_TIMING \
{HDMI_VFRMT_3840x2160p50_16_9, 3840, 1056, 88, 296, false, \
2160, 8, 10, 72, false, 594000, 50000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_3840x2160p60_16_9_TIMING \
{HDMI_VFRMT_3840x2160p60_16_9, 3840, 176, 88, 296, false, \
2160, 8, 10, 72, false, 594000, 60000, false, true, \
HDMI_RES_AR_16_9, 0}
#define HDMI_VFRMT_4096x2160p24_256_135_TIMING \
{HDMI_VFRMT_4096x2160p24_256_135, 4096, 1020, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 24000, false, true, \
HDMI_RES_AR_256_135, 0}
#define HDMI_VFRMT_4096x2160p25_256_135_TIMING \
{HDMI_VFRMT_4096x2160p25_256_135, 4096, 968, 88, 128, false, \
2160, 8, 10, 72, false, 297000, 25000, false, true, \
HDMI_RES_AR_256_135, 0}
#define HDMI_VFRMT_4096x2160p30_256_135_TIMING \
{HDMI_VFRMT_4096x2160p30_256_135, 4096, 88, 88, 128, false, \
2160, 8, 10, 72, false, 297000, 30000, false, true, \
HDMI_RES_AR_256_135, 0}
#define HDMI_VFRMT_4096x2160p50_256_135_TIMING \
{HDMI_VFRMT_4096x2160p50_256_135, 4096, 968, 88, 128, false, \
2160, 8, 10, 72, false, 594000, 50000, false, true, \
HDMI_RES_AR_256_135, 0}
#define HDMI_VFRMT_4096x2160p60_256_135_TIMING \
{HDMI_VFRMT_4096x2160p60_256_135, 4096, 88, 88, 128, false, \
2160, 8, 10, 72, false, 594000, 60000, false, true, \
HDMI_RES_AR_256_135, 0}
#define HDMI_VFRMT_3840x2160p24_64_27_TIMING \
{HDMI_VFRMT_3840x2160p24_64_27, 3840, 1276, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 24000, false, true, \
HDMI_RES_AR_64_27, 0}
#define HDMI_VFRMT_3840x2160p25_64_27_TIMING \
{HDMI_VFRMT_3840x2160p25_64_27, 3840, 1056, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 25000, false, true, \
HDMI_RES_AR_64_27, 0}
#define HDMI_VFRMT_3840x2160p30_64_27_TIMING \
{HDMI_VFRMT_3840x2160p30_64_27, 3840, 176, 88, 296, false, \
2160, 8, 10, 72, false, 297000, 30000, false, true, \
HDMI_RES_AR_64_27, 0}
#define HDMI_VFRMT_3840x2160p50_64_27_TIMING \
{HDMI_VFRMT_3840x2160p50_64_27, 3840, 1056, 88, 296, false, \
2160, 8, 10, 72, false, 594000, 50000, false, true, \
HDMI_RES_AR_64_27, 0}
#define HDMI_VFRMT_3840x2160p60_64_27_TIMING \
{HDMI_VFRMT_3840x2160p60_64_27, 3840, 176, 88, 296, false, \
2160, 8, 10, 72, false, 594000, 60000, false, true, \
HDMI_RES_AR_64_27, 0}
#define HDMI_VFRMT_640x480p59_4_3_TIMING \
{HDMI_VFRMT_640x480p59_4_3, 640, 16, 96, 48, true, \
480, 10, 2, 33, true, 25170, 59928, false, true, \
HDMI_RES_AR_4_3, 1}
#define MSM_HDMI_MODES_SET_TIMING(LUT, MODE) do { \
struct msm_hdmi_mode_timing_info mode = MODE##_TIMING; \
LUT[MODE] = mode;\
} while (0)
#define MSM_HDMI_MODES_INIT_TIMINGS(__lut) \
do { \
unsigned int i; \
for (i = 0; i < HDMI_VFRMT_MAX; i++) { \
struct msm_hdmi_mode_timing_info mode = \
VFRMT_NOT_SUPPORTED(i); \
(__lut)[i] = mode; \
} \
} while (0)
#define MSM_HDMI_MODES_SET_SUPP_TIMINGS(__lut, __type) \
do { \
if (__type & MSM_HDMI_MODES_CEA) { \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_640x480p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_720x480p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_720x480p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1280x720p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080i60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1440x480i60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1440x480i60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_720x576p50_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_720x576p50_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1280x720p50_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1440x576i50_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1440x576i50_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080p50_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080p24_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080p25_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1080p30_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p24_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p25_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p30_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p50_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_4096x2160p24_256_135);\
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_4096x2160p25_256_135);\
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_4096x2160p30_256_135);\
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_4096x2160p50_256_135);\
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_4096x2160p60_256_135);\
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p24_64_27); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p25_64_27); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p30_64_27); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p50_64_27); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_3840x2160p60_64_27); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_640x480p59_4_3); \
} \
if (__type & MSM_HDMI_MODES_XTND) { \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_EVFRMT_3840x2160p30_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_EVFRMT_3840x2160p25_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_EVFRMT_3840x2160p24_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_EVFRMT_4096x2160p24_16_9); \
} \
if (__type & MSM_HDMI_MODES_DVI) { \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1024x768p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1280x1024p60_5_4); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_2560x1600p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_800x600p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_848x480p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1280x960p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1360x768p60_16_9); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1440x900p60_16_10); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1400x1050p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1680x1050p60_16_10); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1600x1200p60_4_3); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1920x1200p60_16_10); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1366x768p60_16_10); \
MSM_HDMI_MODES_SET_TIMING(__lut, \
HDMI_VFRMT_1280x800p60_16_10); \
} \
} while (0)
#define MSM_HDMI_MODES_GET_DETAILS(mode, MODE) do { \
struct msm_hdmi_mode_timing_info info = MODE##_TIMING; \
*mode = info; \
} while (0)
#endif /* _UAPI_MSM_HDMI_MODES_H__ */
|