2 * Copyright (C) 2011 Samsung Electronics Co.Ltd
4 * Seung-Woo Kim <sw0312.kim@samsung.com>
5 * Inki Dae <inki.dae@samsung.com>
6 * Joonyoung Shim <jy0922.shim@samsung.com>
8 * Based on drivers/media/video/s5p-tv/hdmi_drv.c
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by the
12 * Free Software Foundation; either version 2 of the License, or (at your
13 * option) any later version.
18 #include <drm/drm_edid.h>
19 #include <drm/drm_crtc_helper.h>
21 #include "regs-hdmi.h"
23 #include <linux/kernel.h>
24 #include <linux/spinlock.h>
25 #include <linux/wait.h>
26 #include <linux/i2c.h>
27 #include <linux/platform_device.h>
28 #include <linux/interrupt.h>
29 #include <linux/irq.h>
30 #include <linux/delay.h>
31 #include <linux/pm_runtime.h>
32 #include <linux/clk.h>
33 #include <linux/regulator/consumer.h>
36 #include <linux/i2c.h>
37 #include <linux/of_gpio.h>
38 #include <linux/hdmi.h>
40 #include <drm/exynos_drm.h>
42 #include "exynos_drm_drv.h"
43 #include "exynos_mixer.h"
45 #include <linux/gpio.h>
46 #include <media/s5p_hdmi.h>
48 #define MAX_WIDTH 1920
49 #define MAX_HEIGHT 1080
50 #define get_hdmi_display(dev) platform_get_drvdata(to_platform_device(dev))
52 /* AVI header and aspect ratio */
53 #define HDMI_AVI_VERSION 0x02
54 #define HDMI_AVI_LENGTH 0x0D
57 #define HDMI_AUI_VERSION 0x01
58 #define HDMI_AUI_LENGTH 0x0A
59 #define AVI_SAME_AS_PIC_ASPECT_RATIO 0x8
60 #define AVI_4_3_CENTER_RATIO 0x9
61 #define AVI_16_9_CENTER_RATIO 0xa
68 struct hdmi_resources
{
70 struct clk
*sclk_hdmi
;
71 struct clk
*sclk_pixel
;
72 struct clk
*sclk_hdmiphy
;
74 struct clk
*mout_hdmi
;
75 struct regulator_bulk_data
*regul_bulk
;
100 struct hdmi_v13_core_regs
{
113 struct hdmi_v14_core_regs
{
126 u8 v_sync_line_bef_2
[2];
127 u8 v_sync_line_bef_1
[2];
128 u8 v_sync_line_aft_2
[2];
129 u8 v_sync_line_aft_1
[2];
130 u8 v_sync_line_aft_pxl_2
[2];
131 u8 v_sync_line_aft_pxl_1
[2];
132 u8 v_blank_f2
[2]; /* for 3D mode */
133 u8 v_blank_f3
[2]; /* for 3D mode */
134 u8 v_blank_f4
[2]; /* for 3D mode */
135 u8 v_blank_f5
[2]; /* for 3D mode */
136 u8 v_sync_line_aft_3
[2];
137 u8 v_sync_line_aft_4
[2];
138 u8 v_sync_line_aft_5
[2];
139 u8 v_sync_line_aft_6
[2];
140 u8 v_sync_line_aft_pxl_3
[2];
141 u8 v_sync_line_aft_pxl_4
[2];
142 u8 v_sync_line_aft_pxl_5
[2];
143 u8 v_sync_line_aft_pxl_6
[2];
152 struct hdmi_v13_conf
{
153 struct hdmi_v13_core_regs core
;
154 struct hdmi_tg_regs tg
;
157 struct hdmi_v14_conf
{
158 struct hdmi_v14_core_regs core
;
159 struct hdmi_tg_regs tg
;
162 struct hdmi_conf_regs
{
165 enum hdmi_picture_aspect aspect_ratio
;
167 struct hdmi_v13_conf v13_conf
;
168 struct hdmi_v14_conf v14_conf
;
172 struct hdmi_context
{
174 struct drm_device
*drm_dev
;
178 struct mutex hdmi_mutex
;
183 struct i2c_client
*ddc_port
;
184 struct i2c_client
*hdmiphy_port
;
186 /* current hdmiphy conf regs */
187 struct hdmi_conf_regs mode_conf
;
189 struct hdmi_resources res
;
196 struct hdmiphy_config
{
201 /* list of phy config settings */
202 static const struct hdmiphy_config hdmiphy_v13_configs
[] = {
204 .pixel_clock
= 27000000,
206 0x01, 0x05, 0x00, 0xD8, 0x10, 0x1C, 0x30, 0x40,
207 0x6B, 0x10, 0x02, 0x51, 0xDF, 0xF2, 0x54, 0x87,
208 0x84, 0x00, 0x30, 0x38, 0x00, 0x08, 0x10, 0xE0,
209 0x22, 0x40, 0xE3, 0x26, 0x00, 0x00, 0x00, 0x00,
213 .pixel_clock
= 27027000,
215 0x01, 0x05, 0x00, 0xD4, 0x10, 0x9C, 0x09, 0x64,
216 0x6B, 0x10, 0x02, 0x51, 0xDF, 0xF2, 0x54, 0x87,
217 0x84, 0x00, 0x30, 0x38, 0x00, 0x08, 0x10, 0xE0,
218 0x22, 0x40, 0xE3, 0x26, 0x00, 0x00, 0x00, 0x00,
222 .pixel_clock
= 74176000,
224 0x01, 0x05, 0x00, 0xD8, 0x10, 0x9C, 0xef, 0x5B,
225 0x6D, 0x10, 0x01, 0x51, 0xef, 0xF3, 0x54, 0xb9,
226 0x84, 0x00, 0x30, 0x38, 0x00, 0x08, 0x10, 0xE0,
227 0x22, 0x40, 0xa5, 0x26, 0x01, 0x00, 0x00, 0x00,
231 .pixel_clock
= 74250000,
233 0x01, 0x05, 0x00, 0xd8, 0x10, 0x9c, 0xf8, 0x40,
234 0x6a, 0x10, 0x01, 0x51, 0xff, 0xf1, 0x54, 0xba,
235 0x84, 0x00, 0x10, 0x38, 0x00, 0x08, 0x10, 0xe0,
236 0x22, 0x40, 0xa4, 0x26, 0x01, 0x00, 0x00, 0x00,
240 .pixel_clock
= 148500000,
242 0x01, 0x05, 0x00, 0xD8, 0x10, 0x9C, 0xf8, 0x40,
243 0x6A, 0x18, 0x00, 0x51, 0xff, 0xF1, 0x54, 0xba,
244 0x84, 0x00, 0x10, 0x38, 0x00, 0x08, 0x10, 0xE0,
245 0x22, 0x40, 0xa4, 0x26, 0x02, 0x00, 0x00, 0x00,
250 static const struct hdmiphy_config hdmiphy_v14_configs
[] = {
252 .pixel_clock
= 25200000,
254 0x01, 0x51, 0x2A, 0x75, 0x40, 0x01, 0x00, 0x08,
255 0x82, 0x80, 0xfc, 0xd8, 0x45, 0xa0, 0xac, 0x80,
256 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
257 0x54, 0xf4, 0x24, 0x00, 0x00, 0x00, 0x01, 0x80,
261 .pixel_clock
= 27000000,
263 0x01, 0xd1, 0x22, 0x51, 0x40, 0x08, 0xfc, 0x20,
264 0x98, 0xa0, 0xcb, 0xd8, 0x45, 0xa0, 0xac, 0x80,
265 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
266 0x54, 0xe4, 0x24, 0x00, 0x00, 0x00, 0x01, 0x80,
270 .pixel_clock
= 27027000,
272 0x01, 0xd1, 0x2d, 0x72, 0x40, 0x64, 0x12, 0x08,
273 0x43, 0xa0, 0x0e, 0xd9, 0x45, 0xa0, 0xac, 0x80,
274 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
275 0x54, 0xe3, 0x24, 0x00, 0x00, 0x00, 0x01, 0x00,
279 .pixel_clock
= 36000000,
281 0x01, 0x51, 0x2d, 0x55, 0x40, 0x01, 0x00, 0x08,
282 0x82, 0x80, 0x0e, 0xd9, 0x45, 0xa0, 0xac, 0x80,
283 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
284 0x54, 0xab, 0x24, 0x00, 0x00, 0x00, 0x01, 0x80,
288 .pixel_clock
= 40000000,
290 0x01, 0x51, 0x32, 0x55, 0x40, 0x01, 0x00, 0x08,
291 0x82, 0x80, 0x2c, 0xd9, 0x45, 0xa0, 0xac, 0x80,
292 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
293 0x54, 0x9a, 0x24, 0x00, 0x00, 0x00, 0x01, 0x80,
297 .pixel_clock
= 65000000,
299 0x01, 0xd1, 0x36, 0x34, 0x40, 0x1e, 0x0a, 0x08,
300 0x82, 0xa0, 0x45, 0xd9, 0x45, 0xa0, 0xac, 0x80,
301 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
302 0x54, 0xbd, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
306 .pixel_clock
= 71000000,
308 0x01, 0x91, 0x1e, 0x15, 0x40, 0x3c, 0xce, 0x08,
309 0x04, 0x20, 0xb2, 0xd8, 0x45, 0xa0, 0xac, 0x80,
310 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
311 0x54, 0xad, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
315 .pixel_clock
= 73250000,
317 0x01, 0xd1, 0x1f, 0x15, 0x40, 0x18, 0xe9, 0x08,
318 0x02, 0xa0, 0xb7, 0xd8, 0x45, 0xa0, 0xac, 0x80,
319 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
320 0x54, 0xa8, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
324 .pixel_clock
= 74176000,
326 0x01, 0xd1, 0x3e, 0x35, 0x40, 0x5b, 0xde, 0x08,
327 0x82, 0xa0, 0x73, 0xd9, 0x45, 0xa0, 0xac, 0x80,
328 0x56, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
329 0x54, 0xa6, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
333 .pixel_clock
= 74250000,
335 0x01, 0xd1, 0x1f, 0x10, 0x40, 0x40, 0xf8, 0x08,
336 0x81, 0xa0, 0xba, 0xd8, 0x45, 0xa0, 0xac, 0x80,
337 0x3c, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
338 0x54, 0xa5, 0x24, 0x01, 0x00, 0x00, 0x01, 0x00,
342 .pixel_clock
= 83500000,
344 0x01, 0xd1, 0x23, 0x11, 0x40, 0x0c, 0xfb, 0x08,
345 0x85, 0xa0, 0xd1, 0xd8, 0x45, 0xa0, 0xac, 0x80,
346 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
347 0x54, 0x93, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
351 .pixel_clock
= 88750000,
353 0x01, 0x91, 0x25, 0x17, 0x40, 0x30, 0xfe, 0x08,
354 0x06, 0x20, 0xde, 0xd8, 0x45, 0xa0, 0xac, 0x80,
355 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
356 0x54, 0x8a, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
360 .pixel_clock
= 106500000,
362 0x01, 0xd1, 0x2c, 0x12, 0x40, 0x0c, 0x09, 0x08,
363 0x84, 0xa0, 0x0a, 0xd9, 0x45, 0xa0, 0xac, 0x80,
364 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
365 0x54, 0x73, 0x24, 0x01, 0x00, 0x00, 0x01, 0x80,
369 .pixel_clock
= 108000000,
371 0x01, 0x51, 0x2d, 0x15, 0x40, 0x01, 0x00, 0x08,
372 0x82, 0x80, 0x0e, 0xd9, 0x45, 0xa0, 0xac, 0x80,
373 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
374 0x54, 0xc7, 0x25, 0x03, 0x00, 0x00, 0x01, 0x80,
378 .pixel_clock
= 115500000,
380 0x01, 0xd1, 0x30, 0x1a, 0x40, 0x40, 0x10, 0x04,
381 0x04, 0xa0, 0x21, 0xd9, 0x45, 0xa0, 0xac, 0x80,
382 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
383 0x54, 0xaa, 0x25, 0x03, 0x00, 0x00, 0x01, 0x80,
387 .pixel_clock
= 119000000,
389 0x01, 0x91, 0x32, 0x14, 0x40, 0x60, 0xd8, 0x08,
390 0x06, 0x20, 0x2a, 0xd9, 0x45, 0xa0, 0xac, 0x80,
391 0x06, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
392 0x54, 0x9d, 0x25, 0x03, 0x00, 0x00, 0x01, 0x80,
396 .pixel_clock
= 146250000,
398 0x01, 0xd1, 0x3d, 0x15, 0x40, 0x18, 0xfd, 0x08,
399 0x83, 0xa0, 0x6e, 0xd9, 0x45, 0xa0, 0xac, 0x80,
400 0x08, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
401 0x54, 0x50, 0x25, 0x03, 0x00, 0x00, 0x01, 0x80,
405 .pixel_clock
= 148500000,
407 0x01, 0xd1, 0x1f, 0x00, 0x40, 0x40, 0xf8, 0x08,
408 0x81, 0xa0, 0xba, 0xd8, 0x45, 0xa0, 0xac, 0x80,
409 0x3c, 0x80, 0x11, 0x04, 0x02, 0x22, 0x44, 0x86,
410 0x54, 0x4b, 0x25, 0x03, 0x00, 0x00, 0x01, 0x00,
415 static inline u32
hdmi_reg_read(struct hdmi_context
*hdata
, u32 reg_id
)
417 return readl(hdata
->regs
+ reg_id
);
420 static inline void hdmi_reg_writeb(struct hdmi_context
*hdata
,
421 u32 reg_id
, u8 value
)
423 writeb(value
, hdata
->regs
+ reg_id
);
426 static inline void hdmi_reg_writemask(struct hdmi_context
*hdata
,
427 u32 reg_id
, u32 value
, u32 mask
)
429 u32 old
= readl(hdata
->regs
+ reg_id
);
430 value
= (value
& mask
) | (old
& ~mask
);
431 writel(value
, hdata
->regs
+ reg_id
);
434 static void hdmi_v13_regs_dump(struct hdmi_context
*hdata
, char *prefix
)
436 #define DUMPREG(reg_id) \
437 DRM_DEBUG_KMS("%s:" #reg_id " = %08x\n", prefix, \
438 readl(hdata->regs + reg_id))
439 DRM_DEBUG_KMS("%s: ---- CONTROL REGISTERS ----\n", prefix
);
440 DUMPREG(HDMI_INTC_FLAG
);
441 DUMPREG(HDMI_INTC_CON
);
442 DUMPREG(HDMI_HPD_STATUS
);
443 DUMPREG(HDMI_V13_PHY_RSTOUT
);
444 DUMPREG(HDMI_V13_PHY_VPLL
);
445 DUMPREG(HDMI_V13_PHY_CMU
);
446 DUMPREG(HDMI_V13_CORE_RSTOUT
);
448 DRM_DEBUG_KMS("%s: ---- CORE REGISTERS ----\n", prefix
);
452 DUMPREG(HDMI_SYS_STATUS
);
453 DUMPREG(HDMI_V13_PHY_STATUS
);
454 DUMPREG(HDMI_STATUS_EN
);
456 DUMPREG(HDMI_MODE_SEL
);
457 DUMPREG(HDMI_V13_HPD_GEN
);
458 DUMPREG(HDMI_V13_DC_CONTROL
);
459 DUMPREG(HDMI_V13_VIDEO_PATTERN_GEN
);
461 DRM_DEBUG_KMS("%s: ---- CORE SYNC REGISTERS ----\n", prefix
);
462 DUMPREG(HDMI_H_BLANK_0
);
463 DUMPREG(HDMI_H_BLANK_1
);
464 DUMPREG(HDMI_V13_V_BLANK_0
);
465 DUMPREG(HDMI_V13_V_BLANK_1
);
466 DUMPREG(HDMI_V13_V_BLANK_2
);
467 DUMPREG(HDMI_V13_H_V_LINE_0
);
468 DUMPREG(HDMI_V13_H_V_LINE_1
);
469 DUMPREG(HDMI_V13_H_V_LINE_2
);
470 DUMPREG(HDMI_VSYNC_POL
);
471 DUMPREG(HDMI_INT_PRO_MODE
);
472 DUMPREG(HDMI_V13_V_BLANK_F_0
);
473 DUMPREG(HDMI_V13_V_BLANK_F_1
);
474 DUMPREG(HDMI_V13_V_BLANK_F_2
);
475 DUMPREG(HDMI_V13_H_SYNC_GEN_0
);
476 DUMPREG(HDMI_V13_H_SYNC_GEN_1
);
477 DUMPREG(HDMI_V13_H_SYNC_GEN_2
);
478 DUMPREG(HDMI_V13_V_SYNC_GEN_1_0
);
479 DUMPREG(HDMI_V13_V_SYNC_GEN_1_1
);
480 DUMPREG(HDMI_V13_V_SYNC_GEN_1_2
);
481 DUMPREG(HDMI_V13_V_SYNC_GEN_2_0
);
482 DUMPREG(HDMI_V13_V_SYNC_GEN_2_1
);
483 DUMPREG(HDMI_V13_V_SYNC_GEN_2_2
);
484 DUMPREG(HDMI_V13_V_SYNC_GEN_3_0
);
485 DUMPREG(HDMI_V13_V_SYNC_GEN_3_1
);
486 DUMPREG(HDMI_V13_V_SYNC_GEN_3_2
);
488 DRM_DEBUG_KMS("%s: ---- TG REGISTERS ----\n", prefix
);
489 DUMPREG(HDMI_TG_CMD
);
490 DUMPREG(HDMI_TG_H_FSZ_L
);
491 DUMPREG(HDMI_TG_H_FSZ_H
);
492 DUMPREG(HDMI_TG_HACT_ST_L
);
493 DUMPREG(HDMI_TG_HACT_ST_H
);
494 DUMPREG(HDMI_TG_HACT_SZ_L
);
495 DUMPREG(HDMI_TG_HACT_SZ_H
);
496 DUMPREG(HDMI_TG_V_FSZ_L
);
497 DUMPREG(HDMI_TG_V_FSZ_H
);
498 DUMPREG(HDMI_TG_VSYNC_L
);
499 DUMPREG(HDMI_TG_VSYNC_H
);
500 DUMPREG(HDMI_TG_VSYNC2_L
);
501 DUMPREG(HDMI_TG_VSYNC2_H
);
502 DUMPREG(HDMI_TG_VACT_ST_L
);
503 DUMPREG(HDMI_TG_VACT_ST_H
);
504 DUMPREG(HDMI_TG_VACT_SZ_L
);
505 DUMPREG(HDMI_TG_VACT_SZ_H
);
506 DUMPREG(HDMI_TG_FIELD_CHG_L
);
507 DUMPREG(HDMI_TG_FIELD_CHG_H
);
508 DUMPREG(HDMI_TG_VACT_ST2_L
);
509 DUMPREG(HDMI_TG_VACT_ST2_H
);
510 DUMPREG(HDMI_TG_VSYNC_TOP_HDMI_L
);
511 DUMPREG(HDMI_TG_VSYNC_TOP_HDMI_H
);
512 DUMPREG(HDMI_TG_VSYNC_BOT_HDMI_L
);
513 DUMPREG(HDMI_TG_VSYNC_BOT_HDMI_H
);
514 DUMPREG(HDMI_TG_FIELD_TOP_HDMI_L
);
515 DUMPREG(HDMI_TG_FIELD_TOP_HDMI_H
);
516 DUMPREG(HDMI_TG_FIELD_BOT_HDMI_L
);
517 DUMPREG(HDMI_TG_FIELD_BOT_HDMI_H
);
521 static void hdmi_v14_regs_dump(struct hdmi_context
*hdata
, char *prefix
)
525 #define DUMPREG(reg_id) \
526 DRM_DEBUG_KMS("%s:" #reg_id " = %08x\n", prefix, \
527 readl(hdata->regs + reg_id))
529 DRM_DEBUG_KMS("%s: ---- CONTROL REGISTERS ----\n", prefix
);
530 DUMPREG(HDMI_INTC_CON
);
531 DUMPREG(HDMI_INTC_FLAG
);
532 DUMPREG(HDMI_HPD_STATUS
);
533 DUMPREG(HDMI_INTC_CON_1
);
534 DUMPREG(HDMI_INTC_FLAG_1
);
535 DUMPREG(HDMI_PHY_STATUS_0
);
536 DUMPREG(HDMI_PHY_STATUS_PLL
);
537 DUMPREG(HDMI_PHY_CON_0
);
538 DUMPREG(HDMI_PHY_RSTOUT
);
539 DUMPREG(HDMI_PHY_VPLL
);
540 DUMPREG(HDMI_PHY_CMU
);
541 DUMPREG(HDMI_CORE_RSTOUT
);
543 DRM_DEBUG_KMS("%s: ---- CORE REGISTERS ----\n", prefix
);
547 DUMPREG(HDMI_SYS_STATUS
);
548 DUMPREG(HDMI_PHY_STATUS_0
);
549 DUMPREG(HDMI_STATUS_EN
);
551 DUMPREG(HDMI_MODE_SEL
);
552 DUMPREG(HDMI_ENC_EN
);
553 DUMPREG(HDMI_DC_CONTROL
);
554 DUMPREG(HDMI_VIDEO_PATTERN_GEN
);
556 DRM_DEBUG_KMS("%s: ---- CORE SYNC REGISTERS ----\n", prefix
);
557 DUMPREG(HDMI_H_BLANK_0
);
558 DUMPREG(HDMI_H_BLANK_1
);
559 DUMPREG(HDMI_V2_BLANK_0
);
560 DUMPREG(HDMI_V2_BLANK_1
);
561 DUMPREG(HDMI_V1_BLANK_0
);
562 DUMPREG(HDMI_V1_BLANK_1
);
563 DUMPREG(HDMI_V_LINE_0
);
564 DUMPREG(HDMI_V_LINE_1
);
565 DUMPREG(HDMI_H_LINE_0
);
566 DUMPREG(HDMI_H_LINE_1
);
567 DUMPREG(HDMI_HSYNC_POL
);
569 DUMPREG(HDMI_VSYNC_POL
);
570 DUMPREG(HDMI_INT_PRO_MODE
);
571 DUMPREG(HDMI_V_BLANK_F0_0
);
572 DUMPREG(HDMI_V_BLANK_F0_1
);
573 DUMPREG(HDMI_V_BLANK_F1_0
);
574 DUMPREG(HDMI_V_BLANK_F1_1
);
576 DUMPREG(HDMI_H_SYNC_START_0
);
577 DUMPREG(HDMI_H_SYNC_START_1
);
578 DUMPREG(HDMI_H_SYNC_END_0
);
579 DUMPREG(HDMI_H_SYNC_END_1
);
581 DUMPREG(HDMI_V_SYNC_LINE_BEF_2_0
);
582 DUMPREG(HDMI_V_SYNC_LINE_BEF_2_1
);
583 DUMPREG(HDMI_V_SYNC_LINE_BEF_1_0
);
584 DUMPREG(HDMI_V_SYNC_LINE_BEF_1_1
);
586 DUMPREG(HDMI_V_SYNC_LINE_AFT_2_0
);
587 DUMPREG(HDMI_V_SYNC_LINE_AFT_2_1
);
588 DUMPREG(HDMI_V_SYNC_LINE_AFT_1_0
);
589 DUMPREG(HDMI_V_SYNC_LINE_AFT_1_1
);
591 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_2_0
);
592 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_2_1
);
593 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_1_0
);
594 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_1_1
);
596 DUMPREG(HDMI_V_BLANK_F2_0
);
597 DUMPREG(HDMI_V_BLANK_F2_1
);
598 DUMPREG(HDMI_V_BLANK_F3_0
);
599 DUMPREG(HDMI_V_BLANK_F3_1
);
600 DUMPREG(HDMI_V_BLANK_F4_0
);
601 DUMPREG(HDMI_V_BLANK_F4_1
);
602 DUMPREG(HDMI_V_BLANK_F5_0
);
603 DUMPREG(HDMI_V_BLANK_F5_1
);
605 DUMPREG(HDMI_V_SYNC_LINE_AFT_3_0
);
606 DUMPREG(HDMI_V_SYNC_LINE_AFT_3_1
);
607 DUMPREG(HDMI_V_SYNC_LINE_AFT_4_0
);
608 DUMPREG(HDMI_V_SYNC_LINE_AFT_4_1
);
609 DUMPREG(HDMI_V_SYNC_LINE_AFT_5_0
);
610 DUMPREG(HDMI_V_SYNC_LINE_AFT_5_1
);
611 DUMPREG(HDMI_V_SYNC_LINE_AFT_6_0
);
612 DUMPREG(HDMI_V_SYNC_LINE_AFT_6_1
);
614 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_3_0
);
615 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_3_1
);
616 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_4_0
);
617 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_4_1
);
618 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_5_0
);
619 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_5_1
);
620 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_6_0
);
621 DUMPREG(HDMI_V_SYNC_LINE_AFT_PXL_6_1
);
623 DUMPREG(HDMI_VACT_SPACE_1_0
);
624 DUMPREG(HDMI_VACT_SPACE_1_1
);
625 DUMPREG(HDMI_VACT_SPACE_2_0
);
626 DUMPREG(HDMI_VACT_SPACE_2_1
);
627 DUMPREG(HDMI_VACT_SPACE_3_0
);
628 DUMPREG(HDMI_VACT_SPACE_3_1
);
629 DUMPREG(HDMI_VACT_SPACE_4_0
);
630 DUMPREG(HDMI_VACT_SPACE_4_1
);
631 DUMPREG(HDMI_VACT_SPACE_5_0
);
632 DUMPREG(HDMI_VACT_SPACE_5_1
);
633 DUMPREG(HDMI_VACT_SPACE_6_0
);
634 DUMPREG(HDMI_VACT_SPACE_6_1
);
636 DRM_DEBUG_KMS("%s: ---- TG REGISTERS ----\n", prefix
);
637 DUMPREG(HDMI_TG_CMD
);
638 DUMPREG(HDMI_TG_H_FSZ_L
);
639 DUMPREG(HDMI_TG_H_FSZ_H
);
640 DUMPREG(HDMI_TG_HACT_ST_L
);
641 DUMPREG(HDMI_TG_HACT_ST_H
);
642 DUMPREG(HDMI_TG_HACT_SZ_L
);
643 DUMPREG(HDMI_TG_HACT_SZ_H
);
644 DUMPREG(HDMI_TG_V_FSZ_L
);
645 DUMPREG(HDMI_TG_V_FSZ_H
);
646 DUMPREG(HDMI_TG_VSYNC_L
);
647 DUMPREG(HDMI_TG_VSYNC_H
);
648 DUMPREG(HDMI_TG_VSYNC2_L
);
649 DUMPREG(HDMI_TG_VSYNC2_H
);
650 DUMPREG(HDMI_TG_VACT_ST_L
);
651 DUMPREG(HDMI_TG_VACT_ST_H
);
652 DUMPREG(HDMI_TG_VACT_SZ_L
);
653 DUMPREG(HDMI_TG_VACT_SZ_H
);
654 DUMPREG(HDMI_TG_FIELD_CHG_L
);
655 DUMPREG(HDMI_TG_FIELD_CHG_H
);
656 DUMPREG(HDMI_TG_VACT_ST2_L
);
657 DUMPREG(HDMI_TG_VACT_ST2_H
);
658 DUMPREG(HDMI_TG_VACT_ST3_L
);
659 DUMPREG(HDMI_TG_VACT_ST3_H
);
660 DUMPREG(HDMI_TG_VACT_ST4_L
);
661 DUMPREG(HDMI_TG_VACT_ST4_H
);
662 DUMPREG(HDMI_TG_VSYNC_TOP_HDMI_L
);
663 DUMPREG(HDMI_TG_VSYNC_TOP_HDMI_H
);
664 DUMPREG(HDMI_TG_VSYNC_BOT_HDMI_L
);
665 DUMPREG(HDMI_TG_VSYNC_BOT_HDMI_H
);
666 DUMPREG(HDMI_TG_FIELD_TOP_HDMI_L
);
667 DUMPREG(HDMI_TG_FIELD_TOP_HDMI_H
);
668 DUMPREG(HDMI_TG_FIELD_BOT_HDMI_L
);
669 DUMPREG(HDMI_TG_FIELD_BOT_HDMI_H
);
672 DRM_DEBUG_KMS("%s: ---- PACKET REGISTERS ----\n", prefix
);
673 DUMPREG(HDMI_AVI_CON
);
674 DUMPREG(HDMI_AVI_HEADER0
);
675 DUMPREG(HDMI_AVI_HEADER1
);
676 DUMPREG(HDMI_AVI_HEADER2
);
677 DUMPREG(HDMI_AVI_CHECK_SUM
);
678 DUMPREG(HDMI_VSI_CON
);
679 DUMPREG(HDMI_VSI_HEADER0
);
680 DUMPREG(HDMI_VSI_HEADER1
);
681 DUMPREG(HDMI_VSI_HEADER2
);
682 for (i
= 0; i
< 7; ++i
)
683 DUMPREG(HDMI_VSI_DATA(i
));
688 static void hdmi_regs_dump(struct hdmi_context
*hdata
, char *prefix
)
690 if (hdata
->type
== HDMI_TYPE13
)
691 hdmi_v13_regs_dump(hdata
, prefix
);
693 hdmi_v14_regs_dump(hdata
, prefix
);
696 static u8
hdmi_chksum(struct hdmi_context
*hdata
,
697 u32 start
, u8 len
, u32 hdr_sum
)
701 /* hdr_sum : header0 + header1 + header2
702 * start : start address of packet byte1
703 * len : packet bytes - 1 */
704 for (i
= 0; i
< len
; ++i
)
705 hdr_sum
+= 0xff & hdmi_reg_read(hdata
, start
+ i
* 4);
707 /* return 2's complement of 8 bit hdr_sum */
708 return (u8
)(~(hdr_sum
& 0xff) + 1);
711 static void hdmi_reg_infoframe(struct hdmi_context
*hdata
,
712 union hdmi_infoframe
*infoframe
)
719 mod
= hdmi_reg_read(hdata
, HDMI_MODE_SEL
);
720 if (hdata
->dvi_mode
) {
721 hdmi_reg_writeb(hdata
, HDMI_VSI_CON
,
722 HDMI_VSI_CON_DO_NOT_TRANSMIT
);
723 hdmi_reg_writeb(hdata
, HDMI_AVI_CON
,
724 HDMI_AVI_CON_DO_NOT_TRANSMIT
);
725 hdmi_reg_writeb(hdata
, HDMI_AUI_CON
, HDMI_AUI_CON_NO_TRAN
);
729 switch (infoframe
->any
.type
) {
730 case HDMI_INFOFRAME_TYPE_AVI
:
731 hdmi_reg_writeb(hdata
, HDMI_AVI_CON
, HDMI_AVI_CON_EVERY_VSYNC
);
732 hdmi_reg_writeb(hdata
, HDMI_AVI_HEADER0
, infoframe
->any
.type
);
733 hdmi_reg_writeb(hdata
, HDMI_AVI_HEADER1
,
734 infoframe
->any
.version
);
735 hdmi_reg_writeb(hdata
, HDMI_AVI_HEADER2
, infoframe
->any
.length
);
736 hdr_sum
= infoframe
->any
.type
+ infoframe
->any
.version
+
737 infoframe
->any
.length
;
739 /* Output format zero hardcoded ,RGB YBCR selection */
740 hdmi_reg_writeb(hdata
, HDMI_AVI_BYTE(1), 0 << 5 |
741 AVI_ACTIVE_FORMAT_VALID
|
742 AVI_UNDERSCANNED_DISPLAY_VALID
);
745 * Set the aspect ratio as per the mode, mentioned in
746 * Table 9 AVI InfoFrame Data Byte 2 of CEA-861-D Standard
748 switch (hdata
->mode_conf
.aspect_ratio
) {
749 case HDMI_PICTURE_ASPECT_4_3
:
750 hdmi_reg_writeb(hdata
, HDMI_AVI_BYTE(2),
751 hdata
->mode_conf
.aspect_ratio
|
752 AVI_4_3_CENTER_RATIO
);
754 case HDMI_PICTURE_ASPECT_16_9
:
755 hdmi_reg_writeb(hdata
, HDMI_AVI_BYTE(2),
756 hdata
->mode_conf
.aspect_ratio
|
757 AVI_16_9_CENTER_RATIO
);
759 case HDMI_PICTURE_ASPECT_NONE
:
761 hdmi_reg_writeb(hdata
, HDMI_AVI_BYTE(2),
762 hdata
->mode_conf
.aspect_ratio
|
763 AVI_SAME_AS_PIC_ASPECT_RATIO
);
767 vic
= hdata
->mode_conf
.cea_video_id
;
768 hdmi_reg_writeb(hdata
, HDMI_AVI_BYTE(4), vic
);
770 chksum
= hdmi_chksum(hdata
, HDMI_AVI_BYTE(1),
771 infoframe
->any
.length
, hdr_sum
);
772 DRM_DEBUG_KMS("AVI checksum = 0x%x\n", chksum
);
773 hdmi_reg_writeb(hdata
, HDMI_AVI_CHECK_SUM
, chksum
);
775 case HDMI_INFOFRAME_TYPE_AUDIO
:
776 hdmi_reg_writeb(hdata
, HDMI_AUI_CON
, 0x02);
777 hdmi_reg_writeb(hdata
, HDMI_AUI_HEADER0
, infoframe
->any
.type
);
778 hdmi_reg_writeb(hdata
, HDMI_AUI_HEADER1
,
779 infoframe
->any
.version
);
780 hdmi_reg_writeb(hdata
, HDMI_AUI_HEADER2
, infoframe
->any
.length
);
781 hdr_sum
= infoframe
->any
.type
+ infoframe
->any
.version
+
782 infoframe
->any
.length
;
783 chksum
= hdmi_chksum(hdata
, HDMI_AUI_BYTE(1),
784 infoframe
->any
.length
, hdr_sum
);
785 DRM_DEBUG_KMS("AUI checksum = 0x%x\n", chksum
);
786 hdmi_reg_writeb(hdata
, HDMI_AUI_CHECK_SUM
, chksum
);
793 static int hdmi_initialize(struct exynos_drm_display
*display
,
794 struct drm_device
*drm_dev
)
796 struct hdmi_context
*hdata
= display
->ctx
;
798 hdata
->drm_dev
= drm_dev
;
803 static bool hdmi_is_connected(struct exynos_drm_display
*display
)
805 struct hdmi_context
*hdata
= display
->ctx
;
810 static struct edid
*hdmi_get_edid(struct exynos_drm_display
*display
,
811 struct drm_connector
*connector
)
813 struct edid
*raw_edid
;
814 struct hdmi_context
*hdata
= display
->ctx
;
816 if (!hdata
->ddc_port
)
817 return ERR_PTR(-ENODEV
);
819 raw_edid
= drm_get_edid(connector
, hdata
->ddc_port
->adapter
);
821 return ERR_PTR(-ENODEV
);
823 hdata
->dvi_mode
= !drm_detect_hdmi_monitor(raw_edid
);
824 DRM_DEBUG_KMS("%s : width[%d] x height[%d]\n",
825 (hdata
->dvi_mode
? "dvi monitor" : "hdmi monitor"),
826 raw_edid
->width_cm
, raw_edid
->height_cm
);
831 static int hdmi_find_phy_conf(struct hdmi_context
*hdata
, u32 pixel_clock
)
833 const struct hdmiphy_config
*confs
;
836 if (hdata
->type
== HDMI_TYPE13
) {
837 confs
= hdmiphy_v13_configs
;
838 count
= ARRAY_SIZE(hdmiphy_v13_configs
);
839 } else if (hdata
->type
== HDMI_TYPE14
) {
840 confs
= hdmiphy_v14_configs
;
841 count
= ARRAY_SIZE(hdmiphy_v14_configs
);
845 for (i
= 0; i
< count
; i
++)
846 if (confs
[i
].pixel_clock
== pixel_clock
)
849 DRM_DEBUG_KMS("Could not find phy config for %d\n", pixel_clock
);
853 static int hdmi_check_mode(struct exynos_drm_display
*display
,
854 struct drm_display_mode
*mode
)
856 struct hdmi_context
*hdata
= display
->ctx
;
859 DRM_DEBUG_KMS("xres=%d, yres=%d, refresh=%d, intl=%d clock=%d\n",
860 mode
->hdisplay
, mode
->vdisplay
, mode
->vrefresh
,
861 (mode
->flags
& DRM_MODE_FLAG_INTERLACE
) ? true :
862 false, mode
->clock
* 1000);
864 ret
= mixer_check_mode(mode
);
868 ret
= hdmi_find_phy_conf(hdata
, mode
->clock
* 1000);
874 static void hdmi_mode_fixup(struct exynos_drm_display
*display
,
875 struct drm_connector
*connector
,
876 const struct drm_display_mode
*mode
,
877 struct drm_display_mode
*adjusted_mode
)
879 struct drm_display_mode
*m
;
882 DRM_DEBUG_KMS("%s\n", __FILE__
);
884 drm_mode_set_crtcinfo(adjusted_mode
, 0);
886 mode_ok
= hdmi_check_mode(display
, adjusted_mode
);
888 /* just return if user desired mode exists. */
893 * otherwise, find the most suitable mode among modes and change it
896 list_for_each_entry(m
, &connector
->modes
, head
) {
897 mode_ok
= hdmi_check_mode(display
, m
);
900 DRM_INFO("desired mode doesn't exist so\n");
901 DRM_INFO("use the most suitable mode among modes.\n");
903 DRM_DEBUG_KMS("Adjusted Mode: [%d]x[%d] [%d]Hz\n",
904 m
->hdisplay
, m
->vdisplay
, m
->vrefresh
);
906 drm_mode_copy(adjusted_mode
, m
);
912 static void hdmi_set_acr(u32 freq
, u8
*acr
)
952 acr
[2] = cts
>> 8 & 0xff;
956 acr
[5] = n
>> 8 & 0xff;
960 static void hdmi_reg_acr(struct hdmi_context
*hdata
, u8
*acr
)
962 hdmi_reg_writeb(hdata
, HDMI_ACR_N0
, acr
[6]);
963 hdmi_reg_writeb(hdata
, HDMI_ACR_N1
, acr
[5]);
964 hdmi_reg_writeb(hdata
, HDMI_ACR_N2
, acr
[4]);
965 hdmi_reg_writeb(hdata
, HDMI_ACR_MCTS0
, acr
[3]);
966 hdmi_reg_writeb(hdata
, HDMI_ACR_MCTS1
, acr
[2]);
967 hdmi_reg_writeb(hdata
, HDMI_ACR_MCTS2
, acr
[1]);
968 hdmi_reg_writeb(hdata
, HDMI_ACR_CTS0
, acr
[3]);
969 hdmi_reg_writeb(hdata
, HDMI_ACR_CTS1
, acr
[2]);
970 hdmi_reg_writeb(hdata
, HDMI_ACR_CTS2
, acr
[1]);
972 if (hdata
->type
== HDMI_TYPE13
)
973 hdmi_reg_writeb(hdata
, HDMI_V13_ACR_CON
, 4);
975 hdmi_reg_writeb(hdata
, HDMI_ACR_CON
, 4);
978 static void hdmi_audio_init(struct hdmi_context
*hdata
)
980 u32 sample_rate
, bits_per_sample
, frame_size_code
;
981 u32 data_num
, bit_ch
, sample_frq
;
986 bits_per_sample
= 16;
989 switch (bits_per_sample
) {
1004 hdmi_set_acr(sample_rate
, acr
);
1005 hdmi_reg_acr(hdata
, acr
);
1007 hdmi_reg_writeb(hdata
, HDMI_I2S_MUX_CON
, HDMI_I2S_IN_DISABLE
1008 | HDMI_I2S_AUD_I2S
| HDMI_I2S_CUV_I2S_ENABLE
1009 | HDMI_I2S_MUX_ENABLE
);
1011 hdmi_reg_writeb(hdata
, HDMI_I2S_MUX_CH
, HDMI_I2S_CH0_EN
1012 | HDMI_I2S_CH1_EN
| HDMI_I2S_CH2_EN
);
1014 hdmi_reg_writeb(hdata
, HDMI_I2S_MUX_CUV
, HDMI_I2S_CUV_RL_EN
);
1016 sample_frq
= (sample_rate
== 44100) ? 0 :
1017 (sample_rate
== 48000) ? 2 :
1018 (sample_rate
== 32000) ? 3 :
1019 (sample_rate
== 96000) ? 0xa : 0x0;
1021 hdmi_reg_writeb(hdata
, HDMI_I2S_CLK_CON
, HDMI_I2S_CLK_DIS
);
1022 hdmi_reg_writeb(hdata
, HDMI_I2S_CLK_CON
, HDMI_I2S_CLK_EN
);
1024 val
= hdmi_reg_read(hdata
, HDMI_I2S_DSD_CON
) | 0x01;
1025 hdmi_reg_writeb(hdata
, HDMI_I2S_DSD_CON
, val
);
1027 /* Configuration I2S input ports. Configure I2S_PIN_SEL_0~4 */
1028 hdmi_reg_writeb(hdata
, HDMI_I2S_PIN_SEL_0
, HDMI_I2S_SEL_SCLK(5)
1029 | HDMI_I2S_SEL_LRCK(6));
1030 hdmi_reg_writeb(hdata
, HDMI_I2S_PIN_SEL_1
, HDMI_I2S_SEL_SDATA1(1)
1031 | HDMI_I2S_SEL_SDATA2(4));
1032 hdmi_reg_writeb(hdata
, HDMI_I2S_PIN_SEL_2
, HDMI_I2S_SEL_SDATA3(1)
1033 | HDMI_I2S_SEL_SDATA2(2));
1034 hdmi_reg_writeb(hdata
, HDMI_I2S_PIN_SEL_3
, HDMI_I2S_SEL_DSD(0));
1037 hdmi_reg_writeb(hdata
, HDMI_I2S_CON_1
, HDMI_I2S_SCLK_FALLING_EDGE
1038 | HDMI_I2S_L_CH_LOW_POL
);
1039 hdmi_reg_writeb(hdata
, HDMI_I2S_CON_2
, HDMI_I2S_MSB_FIRST_MODE
1040 | HDMI_I2S_SET_BIT_CH(bit_ch
)
1041 | HDMI_I2S_SET_SDATA_BIT(data_num
)
1042 | HDMI_I2S_BASIC_FORMAT
);
1044 /* Configure register related to CUV information */
1045 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_0
, HDMI_I2S_CH_STATUS_MODE_0
1046 | HDMI_I2S_2AUD_CH_WITHOUT_PREEMPH
1047 | HDMI_I2S_COPYRIGHT
1048 | HDMI_I2S_LINEAR_PCM
1049 | HDMI_I2S_CONSUMER_FORMAT
);
1050 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_1
, HDMI_I2S_CD_PLAYER
);
1051 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_2
, HDMI_I2S_SET_SOURCE_NUM(0));
1052 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_3
, HDMI_I2S_CLK_ACCUR_LEVEL_2
1053 | HDMI_I2S_SET_SMP_FREQ(sample_frq
));
1054 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_4
,
1055 HDMI_I2S_ORG_SMP_FREQ_44_1
1056 | HDMI_I2S_WORD_LEN_MAX24_24BITS
1057 | HDMI_I2S_WORD_LEN_MAX_24BITS
);
1059 hdmi_reg_writeb(hdata
, HDMI_I2S_CH_ST_CON
, HDMI_I2S_CH_STATUS_RELOAD
);
1062 static void hdmi_audio_control(struct hdmi_context
*hdata
, bool onoff
)
1064 if (hdata
->dvi_mode
)
1067 hdmi_reg_writeb(hdata
, HDMI_AUI_CON
, onoff
? 2 : 0);
1068 hdmi_reg_writemask(hdata
, HDMI_CON_0
, onoff
?
1069 HDMI_ASP_EN
: HDMI_ASP_DIS
, HDMI_ASP_MASK
);
1072 static void hdmi_conf_reset(struct hdmi_context
*hdata
)
1076 if (hdata
->type
== HDMI_TYPE13
)
1077 reg
= HDMI_V13_CORE_RSTOUT
;
1079 reg
= HDMI_CORE_RSTOUT
;
1081 /* resetting HDMI core */
1082 hdmi_reg_writemask(hdata
, reg
, 0, HDMI_CORE_SW_RSTOUT
);
1083 usleep_range(10000, 12000);
1084 hdmi_reg_writemask(hdata
, reg
, ~0, HDMI_CORE_SW_RSTOUT
);
1085 usleep_range(10000, 12000);
1088 static void hdmi_conf_init(struct hdmi_context
*hdata
)
1090 union hdmi_infoframe infoframe
;
1092 /* disable HPD interrupts from HDMI IP block, use GPIO instead */
1093 hdmi_reg_writemask(hdata
, HDMI_INTC_CON
, 0, HDMI_INTC_EN_GLOBAL
|
1094 HDMI_INTC_EN_HPD_PLUG
| HDMI_INTC_EN_HPD_UNPLUG
);
1096 /* choose HDMI mode */
1097 hdmi_reg_writemask(hdata
, HDMI_MODE_SEL
,
1098 HDMI_MODE_HDMI_EN
, HDMI_MODE_MASK
);
1099 /* disable bluescreen */
1100 hdmi_reg_writemask(hdata
, HDMI_CON_0
, 0, HDMI_BLUE_SCR_EN
);
1102 if (hdata
->dvi_mode
) {
1103 /* choose DVI mode */
1104 hdmi_reg_writemask(hdata
, HDMI_MODE_SEL
,
1105 HDMI_MODE_DVI_EN
, HDMI_MODE_MASK
);
1106 hdmi_reg_writeb(hdata
, HDMI_CON_2
,
1107 HDMI_VID_PREAMBLE_DIS
| HDMI_GUARD_BAND_DIS
);
1110 if (hdata
->type
== HDMI_TYPE13
) {
1111 /* choose bluescreen (fecal) color */
1112 hdmi_reg_writeb(hdata
, HDMI_V13_BLUE_SCREEN_0
, 0x12);
1113 hdmi_reg_writeb(hdata
, HDMI_V13_BLUE_SCREEN_1
, 0x34);
1114 hdmi_reg_writeb(hdata
, HDMI_V13_BLUE_SCREEN_2
, 0x56);
1116 /* enable AVI packet every vsync, fixes purple line problem */
1117 hdmi_reg_writeb(hdata
, HDMI_V13_AVI_CON
, 0x02);
1118 /* force RGB, look to CEA-861-D, table 7 for more detail */
1119 hdmi_reg_writeb(hdata
, HDMI_V13_AVI_BYTE(0), 0 << 5);
1120 hdmi_reg_writemask(hdata
, HDMI_CON_1
, 0x10 << 5, 0x11 << 5);
1122 hdmi_reg_writeb(hdata
, HDMI_V13_SPD_CON
, 0x02);
1123 hdmi_reg_writeb(hdata
, HDMI_V13_AUI_CON
, 0x02);
1124 hdmi_reg_writeb(hdata
, HDMI_V13_ACR_CON
, 0x04);
1126 infoframe
.any
.type
= HDMI_INFOFRAME_TYPE_AVI
;
1127 infoframe
.any
.version
= HDMI_AVI_VERSION
;
1128 infoframe
.any
.length
= HDMI_AVI_LENGTH
;
1129 hdmi_reg_infoframe(hdata
, &infoframe
);
1131 infoframe
.any
.type
= HDMI_INFOFRAME_TYPE_AUDIO
;
1132 infoframe
.any
.version
= HDMI_AUI_VERSION
;
1133 infoframe
.any
.length
= HDMI_AUI_LENGTH
;
1134 hdmi_reg_infoframe(hdata
, &infoframe
);
1136 /* enable AVI packet every vsync, fixes purple line problem */
1137 hdmi_reg_writemask(hdata
, HDMI_CON_1
, 2, 3 << 5);
1141 static void hdmi_v13_mode_apply(struct hdmi_context
*hdata
)
1143 const struct hdmi_tg_regs
*tg
= &hdata
->mode_conf
.conf
.v13_conf
.tg
;
1144 const struct hdmi_v13_core_regs
*core
=
1145 &hdata
->mode_conf
.conf
.v13_conf
.core
;
1148 /* setting core registers */
1149 hdmi_reg_writeb(hdata
, HDMI_H_BLANK_0
, core
->h_blank
[0]);
1150 hdmi_reg_writeb(hdata
, HDMI_H_BLANK_1
, core
->h_blank
[1]);
1151 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_0
, core
->v_blank
[0]);
1152 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_1
, core
->v_blank
[1]);
1153 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_2
, core
->v_blank
[2]);
1154 hdmi_reg_writeb(hdata
, HDMI_V13_H_V_LINE_0
, core
->h_v_line
[0]);
1155 hdmi_reg_writeb(hdata
, HDMI_V13_H_V_LINE_1
, core
->h_v_line
[1]);
1156 hdmi_reg_writeb(hdata
, HDMI_V13_H_V_LINE_2
, core
->h_v_line
[2]);
1157 hdmi_reg_writeb(hdata
, HDMI_VSYNC_POL
, core
->vsync_pol
[0]);
1158 hdmi_reg_writeb(hdata
, HDMI_INT_PRO_MODE
, core
->int_pro_mode
[0]);
1159 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_F_0
, core
->v_blank_f
[0]);
1160 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_F_1
, core
->v_blank_f
[1]);
1161 hdmi_reg_writeb(hdata
, HDMI_V13_V_BLANK_F_2
, core
->v_blank_f
[2]);
1162 hdmi_reg_writeb(hdata
, HDMI_V13_H_SYNC_GEN_0
, core
->h_sync_gen
[0]);
1163 hdmi_reg_writeb(hdata
, HDMI_V13_H_SYNC_GEN_1
, core
->h_sync_gen
[1]);
1164 hdmi_reg_writeb(hdata
, HDMI_V13_H_SYNC_GEN_2
, core
->h_sync_gen
[2]);
1165 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_1_0
, core
->v_sync_gen1
[0]);
1166 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_1_1
, core
->v_sync_gen1
[1]);
1167 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_1_2
, core
->v_sync_gen1
[2]);
1168 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_2_0
, core
->v_sync_gen2
[0]);
1169 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_2_1
, core
->v_sync_gen2
[1]);
1170 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_2_2
, core
->v_sync_gen2
[2]);
1171 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_3_0
, core
->v_sync_gen3
[0]);
1172 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_3_1
, core
->v_sync_gen3
[1]);
1173 hdmi_reg_writeb(hdata
, HDMI_V13_V_SYNC_GEN_3_2
, core
->v_sync_gen3
[2]);
1174 /* Timing generator registers */
1175 hdmi_reg_writeb(hdata
, HDMI_TG_H_FSZ_L
, tg
->h_fsz
[0]);
1176 hdmi_reg_writeb(hdata
, HDMI_TG_H_FSZ_H
, tg
->h_fsz
[1]);
1177 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_ST_L
, tg
->hact_st
[0]);
1178 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_ST_H
, tg
->hact_st
[1]);
1179 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_SZ_L
, tg
->hact_sz
[0]);
1180 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_SZ_H
, tg
->hact_sz
[1]);
1181 hdmi_reg_writeb(hdata
, HDMI_TG_V_FSZ_L
, tg
->v_fsz
[0]);
1182 hdmi_reg_writeb(hdata
, HDMI_TG_V_FSZ_H
, tg
->v_fsz
[1]);
1183 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_L
, tg
->vsync
[0]);
1184 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_H
, tg
->vsync
[1]);
1185 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC2_L
, tg
->vsync2
[0]);
1186 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC2_H
, tg
->vsync2
[1]);
1187 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST_L
, tg
->vact_st
[0]);
1188 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST_H
, tg
->vact_st
[1]);
1189 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_SZ_L
, tg
->vact_sz
[0]);
1190 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_SZ_H
, tg
->vact_sz
[1]);
1191 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_CHG_L
, tg
->field_chg
[0]);
1192 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_CHG_H
, tg
->field_chg
[1]);
1193 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST2_L
, tg
->vact_st2
[0]);
1194 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST2_H
, tg
->vact_st2
[1]);
1195 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_TOP_HDMI_L
, tg
->vsync_top_hdmi
[0]);
1196 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_TOP_HDMI_H
, tg
->vsync_top_hdmi
[1]);
1197 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_BOT_HDMI_L
, tg
->vsync_bot_hdmi
[0]);
1198 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_BOT_HDMI_H
, tg
->vsync_bot_hdmi
[1]);
1199 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_TOP_HDMI_L
, tg
->field_top_hdmi
[0]);
1200 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_TOP_HDMI_H
, tg
->field_top_hdmi
[1]);
1201 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_BOT_HDMI_L
, tg
->field_bot_hdmi
[0]);
1202 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_BOT_HDMI_H
, tg
->field_bot_hdmi
[1]);
1204 /* waiting for HDMIPHY's PLL to get to steady state */
1205 for (tries
= 100; tries
; --tries
) {
1206 u32 val
= hdmi_reg_read(hdata
, HDMI_V13_PHY_STATUS
);
1207 if (val
& HDMI_PHY_STATUS_READY
)
1209 usleep_range(1000, 2000);
1211 /* steady state not achieved */
1213 DRM_ERROR("hdmiphy's pll could not reach steady state.\n");
1214 hdmi_regs_dump(hdata
, "timing apply");
1217 clk_disable_unprepare(hdata
->res
.sclk_hdmi
);
1218 clk_set_parent(hdata
->res
.mout_hdmi
, hdata
->res
.sclk_hdmiphy
);
1219 clk_prepare_enable(hdata
->res
.sclk_hdmi
);
1221 /* enable HDMI and timing generator */
1222 hdmi_reg_writemask(hdata
, HDMI_CON_0
, ~0, HDMI_EN
);
1223 if (core
->int_pro_mode
[0])
1224 hdmi_reg_writemask(hdata
, HDMI_TG_CMD
, ~0, HDMI_TG_EN
|
1227 hdmi_reg_writemask(hdata
, HDMI_TG_CMD
, ~0, HDMI_TG_EN
);
1230 static void hdmi_v14_mode_apply(struct hdmi_context
*hdata
)
1232 const struct hdmi_tg_regs
*tg
= &hdata
->mode_conf
.conf
.v14_conf
.tg
;
1233 const struct hdmi_v14_core_regs
*core
=
1234 &hdata
->mode_conf
.conf
.v14_conf
.core
;
1237 /* setting core registers */
1238 hdmi_reg_writeb(hdata
, HDMI_H_BLANK_0
, core
->h_blank
[0]);
1239 hdmi_reg_writeb(hdata
, HDMI_H_BLANK_1
, core
->h_blank
[1]);
1240 hdmi_reg_writeb(hdata
, HDMI_V2_BLANK_0
, core
->v2_blank
[0]);
1241 hdmi_reg_writeb(hdata
, HDMI_V2_BLANK_1
, core
->v2_blank
[1]);
1242 hdmi_reg_writeb(hdata
, HDMI_V1_BLANK_0
, core
->v1_blank
[0]);
1243 hdmi_reg_writeb(hdata
, HDMI_V1_BLANK_1
, core
->v1_blank
[1]);
1244 hdmi_reg_writeb(hdata
, HDMI_V_LINE_0
, core
->v_line
[0]);
1245 hdmi_reg_writeb(hdata
, HDMI_V_LINE_1
, core
->v_line
[1]);
1246 hdmi_reg_writeb(hdata
, HDMI_H_LINE_0
, core
->h_line
[0]);
1247 hdmi_reg_writeb(hdata
, HDMI_H_LINE_1
, core
->h_line
[1]);
1248 hdmi_reg_writeb(hdata
, HDMI_HSYNC_POL
, core
->hsync_pol
[0]);
1249 hdmi_reg_writeb(hdata
, HDMI_VSYNC_POL
, core
->vsync_pol
[0]);
1250 hdmi_reg_writeb(hdata
, HDMI_INT_PRO_MODE
, core
->int_pro_mode
[0]);
1251 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F0_0
, core
->v_blank_f0
[0]);
1252 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F0_1
, core
->v_blank_f0
[1]);
1253 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F1_0
, core
->v_blank_f1
[0]);
1254 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F1_1
, core
->v_blank_f1
[1]);
1255 hdmi_reg_writeb(hdata
, HDMI_H_SYNC_START_0
, core
->h_sync_start
[0]);
1256 hdmi_reg_writeb(hdata
, HDMI_H_SYNC_START_1
, core
->h_sync_start
[1]);
1257 hdmi_reg_writeb(hdata
, HDMI_H_SYNC_END_0
, core
->h_sync_end
[0]);
1258 hdmi_reg_writeb(hdata
, HDMI_H_SYNC_END_1
, core
->h_sync_end
[1]);
1259 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_BEF_2_0
,
1260 core
->v_sync_line_bef_2
[0]);
1261 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_BEF_2_1
,
1262 core
->v_sync_line_bef_2
[1]);
1263 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_BEF_1_0
,
1264 core
->v_sync_line_bef_1
[0]);
1265 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_BEF_1_1
,
1266 core
->v_sync_line_bef_1
[1]);
1267 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_2_0
,
1268 core
->v_sync_line_aft_2
[0]);
1269 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_2_1
,
1270 core
->v_sync_line_aft_2
[1]);
1271 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_1_0
,
1272 core
->v_sync_line_aft_1
[0]);
1273 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_1_1
,
1274 core
->v_sync_line_aft_1
[1]);
1275 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_2_0
,
1276 core
->v_sync_line_aft_pxl_2
[0]);
1277 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_2_1
,
1278 core
->v_sync_line_aft_pxl_2
[1]);
1279 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_1_0
,
1280 core
->v_sync_line_aft_pxl_1
[0]);
1281 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_1_1
,
1282 core
->v_sync_line_aft_pxl_1
[1]);
1283 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F2_0
, core
->v_blank_f2
[0]);
1284 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F2_1
, core
->v_blank_f2
[1]);
1285 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F3_0
, core
->v_blank_f3
[0]);
1286 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F3_1
, core
->v_blank_f3
[1]);
1287 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F4_0
, core
->v_blank_f4
[0]);
1288 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F4_1
, core
->v_blank_f4
[1]);
1289 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F5_0
, core
->v_blank_f5
[0]);
1290 hdmi_reg_writeb(hdata
, HDMI_V_BLANK_F5_1
, core
->v_blank_f5
[1]);
1291 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_3_0
,
1292 core
->v_sync_line_aft_3
[0]);
1293 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_3_1
,
1294 core
->v_sync_line_aft_3
[1]);
1295 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_4_0
,
1296 core
->v_sync_line_aft_4
[0]);
1297 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_4_1
,
1298 core
->v_sync_line_aft_4
[1]);
1299 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_5_0
,
1300 core
->v_sync_line_aft_5
[0]);
1301 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_5_1
,
1302 core
->v_sync_line_aft_5
[1]);
1303 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_6_0
,
1304 core
->v_sync_line_aft_6
[0]);
1305 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_6_1
,
1306 core
->v_sync_line_aft_6
[1]);
1307 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_3_0
,
1308 core
->v_sync_line_aft_pxl_3
[0]);
1309 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_3_1
,
1310 core
->v_sync_line_aft_pxl_3
[1]);
1311 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_4_0
,
1312 core
->v_sync_line_aft_pxl_4
[0]);
1313 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_4_1
,
1314 core
->v_sync_line_aft_pxl_4
[1]);
1315 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_5_0
,
1316 core
->v_sync_line_aft_pxl_5
[0]);
1317 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_5_1
,
1318 core
->v_sync_line_aft_pxl_5
[1]);
1319 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_6_0
,
1320 core
->v_sync_line_aft_pxl_6
[0]);
1321 hdmi_reg_writeb(hdata
, HDMI_V_SYNC_LINE_AFT_PXL_6_1
,
1322 core
->v_sync_line_aft_pxl_6
[1]);
1323 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_1_0
, core
->vact_space_1
[0]);
1324 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_1_1
, core
->vact_space_1
[1]);
1325 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_2_0
, core
->vact_space_2
[0]);
1326 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_2_1
, core
->vact_space_2
[1]);
1327 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_3_0
, core
->vact_space_3
[0]);
1328 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_3_1
, core
->vact_space_3
[1]);
1329 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_4_0
, core
->vact_space_4
[0]);
1330 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_4_1
, core
->vact_space_4
[1]);
1331 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_5_0
, core
->vact_space_5
[0]);
1332 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_5_1
, core
->vact_space_5
[1]);
1333 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_6_0
, core
->vact_space_6
[0]);
1334 hdmi_reg_writeb(hdata
, HDMI_VACT_SPACE_6_1
, core
->vact_space_6
[1]);
1336 /* Timing generator registers */
1337 hdmi_reg_writeb(hdata
, HDMI_TG_H_FSZ_L
, tg
->h_fsz
[0]);
1338 hdmi_reg_writeb(hdata
, HDMI_TG_H_FSZ_H
, tg
->h_fsz
[1]);
1339 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_ST_L
, tg
->hact_st
[0]);
1340 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_ST_H
, tg
->hact_st
[1]);
1341 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_SZ_L
, tg
->hact_sz
[0]);
1342 hdmi_reg_writeb(hdata
, HDMI_TG_HACT_SZ_H
, tg
->hact_sz
[1]);
1343 hdmi_reg_writeb(hdata
, HDMI_TG_V_FSZ_L
, tg
->v_fsz
[0]);
1344 hdmi_reg_writeb(hdata
, HDMI_TG_V_FSZ_H
, tg
->v_fsz
[1]);
1345 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_L
, tg
->vsync
[0]);
1346 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_H
, tg
->vsync
[1]);
1347 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC2_L
, tg
->vsync2
[0]);
1348 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC2_H
, tg
->vsync2
[1]);
1349 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST_L
, tg
->vact_st
[0]);
1350 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST_H
, tg
->vact_st
[1]);
1351 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_SZ_L
, tg
->vact_sz
[0]);
1352 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_SZ_H
, tg
->vact_sz
[1]);
1353 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_CHG_L
, tg
->field_chg
[0]);
1354 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_CHG_H
, tg
->field_chg
[1]);
1355 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST2_L
, tg
->vact_st2
[0]);
1356 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST2_H
, tg
->vact_st2
[1]);
1357 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST3_L
, tg
->vact_st3
[0]);
1358 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST3_H
, tg
->vact_st3
[1]);
1359 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST4_L
, tg
->vact_st4
[0]);
1360 hdmi_reg_writeb(hdata
, HDMI_TG_VACT_ST4_H
, tg
->vact_st4
[1]);
1361 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_TOP_HDMI_L
, tg
->vsync_top_hdmi
[0]);
1362 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_TOP_HDMI_H
, tg
->vsync_top_hdmi
[1]);
1363 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_BOT_HDMI_L
, tg
->vsync_bot_hdmi
[0]);
1364 hdmi_reg_writeb(hdata
, HDMI_TG_VSYNC_BOT_HDMI_H
, tg
->vsync_bot_hdmi
[1]);
1365 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_TOP_HDMI_L
, tg
->field_top_hdmi
[0]);
1366 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_TOP_HDMI_H
, tg
->field_top_hdmi
[1]);
1367 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_BOT_HDMI_L
, tg
->field_bot_hdmi
[0]);
1368 hdmi_reg_writeb(hdata
, HDMI_TG_FIELD_BOT_HDMI_H
, tg
->field_bot_hdmi
[1]);
1369 hdmi_reg_writeb(hdata
, HDMI_TG_3D
, tg
->tg_3d
[0]);
1371 /* waiting for HDMIPHY's PLL to get to steady state */
1372 for (tries
= 100; tries
; --tries
) {
1373 u32 val
= hdmi_reg_read(hdata
, HDMI_PHY_STATUS_0
);
1374 if (val
& HDMI_PHY_STATUS_READY
)
1376 usleep_range(1000, 2000);
1378 /* steady state not achieved */
1380 DRM_ERROR("hdmiphy's pll could not reach steady state.\n");
1381 hdmi_regs_dump(hdata
, "timing apply");
1384 clk_disable_unprepare(hdata
->res
.sclk_hdmi
);
1385 clk_set_parent(hdata
->res
.mout_hdmi
, hdata
->res
.sclk_hdmiphy
);
1386 clk_prepare_enable(hdata
->res
.sclk_hdmi
);
1388 /* enable HDMI and timing generator */
1389 hdmi_reg_writemask(hdata
, HDMI_CON_0
, ~0, HDMI_EN
);
1390 if (core
->int_pro_mode
[0])
1391 hdmi_reg_writemask(hdata
, HDMI_TG_CMD
, ~0, HDMI_TG_EN
|
1394 hdmi_reg_writemask(hdata
, HDMI_TG_CMD
, ~0, HDMI_TG_EN
);
1397 static void hdmi_mode_apply(struct hdmi_context
*hdata
)
1399 if (hdata
->type
== HDMI_TYPE13
)
1400 hdmi_v13_mode_apply(hdata
);
1402 hdmi_v14_mode_apply(hdata
);
1405 static void hdmiphy_conf_reset(struct hdmi_context
*hdata
)
1410 clk_disable_unprepare(hdata
->res
.sclk_hdmi
);
1411 clk_set_parent(hdata
->res
.mout_hdmi
, hdata
->res
.sclk_pixel
);
1412 clk_prepare_enable(hdata
->res
.sclk_hdmi
);
1414 /* operation mode */
1418 if (hdata
->hdmiphy_port
)
1419 i2c_master_send(hdata
->hdmiphy_port
, buffer
, 2);
1421 if (hdata
->type
== HDMI_TYPE13
)
1422 reg
= HDMI_V13_PHY_RSTOUT
;
1424 reg
= HDMI_PHY_RSTOUT
;
1427 hdmi_reg_writemask(hdata
, reg
, ~0, HDMI_PHY_SW_RSTOUT
);
1428 usleep_range(10000, 12000);
1429 hdmi_reg_writemask(hdata
, reg
, 0, HDMI_PHY_SW_RSTOUT
);
1430 usleep_range(10000, 12000);
1433 static void hdmiphy_poweron(struct hdmi_context
*hdata
)
1435 if (hdata
->type
== HDMI_TYPE14
)
1436 hdmi_reg_writemask(hdata
, HDMI_PHY_CON_0
, 0,
1437 HDMI_PHY_POWER_OFF_EN
);
1440 static void hdmiphy_poweroff(struct hdmi_context
*hdata
)
1442 if (hdata
->type
== HDMI_TYPE14
)
1443 hdmi_reg_writemask(hdata
, HDMI_PHY_CON_0
, ~0,
1444 HDMI_PHY_POWER_OFF_EN
);
1447 static void hdmiphy_conf_apply(struct hdmi_context
*hdata
)
1449 const u8
*hdmiphy_data
;
1452 u8 read_buffer
[32] = {0, };
1456 if (!hdata
->hdmiphy_port
) {
1457 DRM_ERROR("hdmiphy is not attached\n");
1462 i
= hdmi_find_phy_conf(hdata
, hdata
->mode_conf
.pixel_clock
);
1464 DRM_ERROR("failed to find hdmiphy conf\n");
1468 if (hdata
->type
== HDMI_TYPE13
)
1469 hdmiphy_data
= hdmiphy_v13_configs
[i
].conf
;
1471 hdmiphy_data
= hdmiphy_v14_configs
[i
].conf
;
1473 memcpy(buffer
, hdmiphy_data
, 32);
1474 ret
= i2c_master_send(hdata
->hdmiphy_port
, buffer
, 32);
1476 DRM_ERROR("failed to configure HDMIPHY via I2C\n");
1480 usleep_range(10000, 12000);
1482 /* operation mode */
1483 operation
[0] = 0x1f;
1484 operation
[1] = 0x80;
1486 ret
= i2c_master_send(hdata
->hdmiphy_port
, operation
, 2);
1488 DRM_ERROR("failed to enable hdmiphy\n");
1492 ret
= i2c_master_recv(hdata
->hdmiphy_port
, read_buffer
, 32);
1494 DRM_ERROR("failed to read hdmiphy config\n");
1498 for (i
= 0; i
< ret
; i
++)
1499 DRM_DEBUG_KMS("hdmiphy[0x%02x] write[0x%02x] - "
1500 "recv [0x%02x]\n", i
, buffer
[i
], read_buffer
[i
]);
1503 static void hdmi_conf_apply(struct hdmi_context
*hdata
)
1505 hdmiphy_conf_reset(hdata
);
1506 hdmiphy_conf_apply(hdata
);
1508 mutex_lock(&hdata
->hdmi_mutex
);
1509 hdmi_conf_reset(hdata
);
1510 hdmi_conf_init(hdata
);
1511 mutex_unlock(&hdata
->hdmi_mutex
);
1513 hdmi_audio_init(hdata
);
1515 /* setting core registers */
1516 hdmi_mode_apply(hdata
);
1517 hdmi_audio_control(hdata
, true);
1519 hdmi_regs_dump(hdata
, "start");
1522 static void hdmi_set_reg(u8
*reg_pair
, int num_bytes
, u32 value
)
1525 BUG_ON(num_bytes
> 4);
1526 for (i
= 0; i
< num_bytes
; i
++)
1527 reg_pair
[i
] = (value
>> (8 * i
)) & 0xff;
1530 static void hdmi_v13_mode_set(struct hdmi_context
*hdata
,
1531 struct drm_display_mode
*m
)
1533 struct hdmi_v13_core_regs
*core
= &hdata
->mode_conf
.conf
.v13_conf
.core
;
1534 struct hdmi_tg_regs
*tg
= &hdata
->mode_conf
.conf
.v13_conf
.tg
;
1537 hdata
->mode_conf
.cea_video_id
=
1538 drm_match_cea_mode((struct drm_display_mode
*)m
);
1539 hdata
->mode_conf
.pixel_clock
= m
->clock
* 1000;
1540 hdata
->mode_conf
.aspect_ratio
= m
->picture_aspect_ratio
;
1542 hdmi_set_reg(core
->h_blank
, 2, m
->htotal
- m
->hdisplay
);
1543 hdmi_set_reg(core
->h_v_line
, 3, (m
->htotal
<< 12) | m
->vtotal
);
1545 val
= (m
->flags
& DRM_MODE_FLAG_NVSYNC
) ? 1 : 0;
1546 hdmi_set_reg(core
->vsync_pol
, 1, val
);
1548 val
= (m
->flags
& DRM_MODE_FLAG_INTERLACE
) ? 1 : 0;
1549 hdmi_set_reg(core
->int_pro_mode
, 1, val
);
1551 val
= (m
->hsync_start
- m
->hdisplay
- 2);
1552 val
|= ((m
->hsync_end
- m
->hdisplay
- 2) << 10);
1553 val
|= ((m
->flags
& DRM_MODE_FLAG_NHSYNC
) ? 1 : 0)<<20;
1554 hdmi_set_reg(core
->h_sync_gen
, 3, val
);
1557 * Quirk requirement for exynos HDMI IP design,
1558 * 2 pixels less than the actual calculation for hsync_start
1562 /* Following values & calculations differ for different type of modes */
1563 if (m
->flags
& DRM_MODE_FLAG_INTERLACE
) {
1564 /* Interlaced Mode */
1565 val
= ((m
->vsync_end
- m
->vdisplay
) / 2);
1566 val
|= ((m
->vsync_start
- m
->vdisplay
) / 2) << 12;
1567 hdmi_set_reg(core
->v_sync_gen1
, 3, val
);
1569 val
= m
->vtotal
/ 2;
1570 val
|= ((m
->vtotal
- m
->vdisplay
) / 2) << 11;
1571 hdmi_set_reg(core
->v_blank
, 3, val
);
1574 ((m
->vsync_end
- m
->vsync_start
) * 4) + 5) / 2;
1575 val
|= m
->vtotal
<< 11;
1576 hdmi_set_reg(core
->v_blank_f
, 3, val
);
1578 val
= ((m
->vtotal
/ 2) + 7);
1579 val
|= ((m
->vtotal
/ 2) + 2) << 12;
1580 hdmi_set_reg(core
->v_sync_gen2
, 3, val
);
1582 val
= ((m
->htotal
/ 2) + (m
->hsync_start
- m
->hdisplay
));
1583 val
|= ((m
->htotal
/ 2) +
1584 (m
->hsync_start
- m
->hdisplay
)) << 12;
1585 hdmi_set_reg(core
->v_sync_gen3
, 3, val
);
1587 hdmi_set_reg(tg
->vact_st
, 2, (m
->vtotal
- m
->vdisplay
) / 2);
1588 hdmi_set_reg(tg
->vact_sz
, 2, m
->vdisplay
/ 2);
1590 hdmi_set_reg(tg
->vact_st2
, 2, 0x249);/* Reset value + 1*/
1592 /* Progressive Mode */
1595 val
|= (m
->vtotal
- m
->vdisplay
) << 11;
1596 hdmi_set_reg(core
->v_blank
, 3, val
);
1598 hdmi_set_reg(core
->v_blank_f
, 3, 0);
1600 val
= (m
->vsync_end
- m
->vdisplay
);
1601 val
|= ((m
->vsync_start
- m
->vdisplay
) << 12);
1602 hdmi_set_reg(core
->v_sync_gen1
, 3, val
);
1604 hdmi_set_reg(core
->v_sync_gen2
, 3, 0x1001);/* Reset value */
1605 hdmi_set_reg(core
->v_sync_gen3
, 3, 0x1001);/* Reset value */
1606 hdmi_set_reg(tg
->vact_st
, 2, m
->vtotal
- m
->vdisplay
);
1607 hdmi_set_reg(tg
->vact_sz
, 2, m
->vdisplay
);
1608 hdmi_set_reg(tg
->vact_st2
, 2, 0x248); /* Reset value */
1611 /* Timing generator registers */
1612 hdmi_set_reg(tg
->cmd
, 1, 0x0);
1613 hdmi_set_reg(tg
->h_fsz
, 2, m
->htotal
);
1614 hdmi_set_reg(tg
->hact_st
, 2, m
->htotal
- m
->hdisplay
);
1615 hdmi_set_reg(tg
->hact_sz
, 2, m
->hdisplay
);
1616 hdmi_set_reg(tg
->v_fsz
, 2, m
->vtotal
);
1617 hdmi_set_reg(tg
->vsync
, 2, 0x1);
1618 hdmi_set_reg(tg
->vsync2
, 2, 0x233); /* Reset value */
1619 hdmi_set_reg(tg
->field_chg
, 2, 0x233); /* Reset value */
1620 hdmi_set_reg(tg
->vsync_top_hdmi
, 2, 0x1); /* Reset value */
1621 hdmi_set_reg(tg
->vsync_bot_hdmi
, 2, 0x233); /* Reset value */
1622 hdmi_set_reg(tg
->field_top_hdmi
, 2, 0x1); /* Reset value */
1623 hdmi_set_reg(tg
->field_bot_hdmi
, 2, 0x233); /* Reset value */
1624 hdmi_set_reg(tg
->tg_3d
, 1, 0x0); /* Not used */
1627 static void hdmi_v14_mode_set(struct hdmi_context
*hdata
,
1628 struct drm_display_mode
*m
)
1630 struct hdmi_tg_regs
*tg
= &hdata
->mode_conf
.conf
.v14_conf
.tg
;
1631 struct hdmi_v14_core_regs
*core
=
1632 &hdata
->mode_conf
.conf
.v14_conf
.core
;
1634 hdata
->mode_conf
.cea_video_id
=
1635 drm_match_cea_mode((struct drm_display_mode
*)m
);
1636 hdata
->mode_conf
.pixel_clock
= m
->clock
* 1000;
1637 hdata
->mode_conf
.aspect_ratio
= m
->picture_aspect_ratio
;
1639 hdmi_set_reg(core
->h_blank
, 2, m
->htotal
- m
->hdisplay
);
1640 hdmi_set_reg(core
->v_line
, 2, m
->vtotal
);
1641 hdmi_set_reg(core
->h_line
, 2, m
->htotal
);
1642 hdmi_set_reg(core
->hsync_pol
, 1,
1643 (m
->flags
& DRM_MODE_FLAG_NHSYNC
) ? 1 : 0);
1644 hdmi_set_reg(core
->vsync_pol
, 1,
1645 (m
->flags
& DRM_MODE_FLAG_NVSYNC
) ? 1 : 0);
1646 hdmi_set_reg(core
->int_pro_mode
, 1,
1647 (m
->flags
& DRM_MODE_FLAG_INTERLACE
) ? 1 : 0);
1650 * Quirk requirement for exynos 5 HDMI IP design,
1651 * 2 pixels less than the actual calculation for hsync_start
1655 /* Following values & calculations differ for different type of modes */
1656 if (m
->flags
& DRM_MODE_FLAG_INTERLACE
) {
1657 /* Interlaced Mode */
1658 hdmi_set_reg(core
->v_sync_line_bef_2
, 2,
1659 (m
->vsync_end
- m
->vdisplay
) / 2);
1660 hdmi_set_reg(core
->v_sync_line_bef_1
, 2,
1661 (m
->vsync_start
- m
->vdisplay
) / 2);
1662 hdmi_set_reg(core
->v2_blank
, 2, m
->vtotal
/ 2);
1663 hdmi_set_reg(core
->v1_blank
, 2, (m
->vtotal
- m
->vdisplay
) / 2);
1664 hdmi_set_reg(core
->v_blank_f0
, 2, m
->vtotal
- m
->vdisplay
/ 2);
1665 hdmi_set_reg(core
->v_blank_f1
, 2, m
->vtotal
);
1666 hdmi_set_reg(core
->v_sync_line_aft_2
, 2, (m
->vtotal
/ 2) + 7);
1667 hdmi_set_reg(core
->v_sync_line_aft_1
, 2, (m
->vtotal
/ 2) + 2);
1668 hdmi_set_reg(core
->v_sync_line_aft_pxl_2
, 2,
1669 (m
->htotal
/ 2) + (m
->hsync_start
- m
->hdisplay
));
1670 hdmi_set_reg(core
->v_sync_line_aft_pxl_1
, 2,
1671 (m
->htotal
/ 2) + (m
->hsync_start
- m
->hdisplay
));
1672 hdmi_set_reg(tg
->vact_st
, 2, (m
->vtotal
- m
->vdisplay
) / 2);
1673 hdmi_set_reg(tg
->vact_sz
, 2, m
->vdisplay
/ 2);
1674 hdmi_set_reg(tg
->vact_st2
, 2, m
->vtotal
- m
->vdisplay
/ 2);
1675 hdmi_set_reg(tg
->vsync2
, 2, (m
->vtotal
/ 2) + 1);
1676 hdmi_set_reg(tg
->vsync_bot_hdmi
, 2, (m
->vtotal
/ 2) + 1);
1677 hdmi_set_reg(tg
->field_bot_hdmi
, 2, (m
->vtotal
/ 2) + 1);
1678 hdmi_set_reg(tg
->vact_st3
, 2, 0x0);
1679 hdmi_set_reg(tg
->vact_st4
, 2, 0x0);
1681 /* Progressive Mode */
1682 hdmi_set_reg(core
->v_sync_line_bef_2
, 2,
1683 m
->vsync_end
- m
->vdisplay
);
1684 hdmi_set_reg(core
->v_sync_line_bef_1
, 2,
1685 m
->vsync_start
- m
->vdisplay
);
1686 hdmi_set_reg(core
->v2_blank
, 2, m
->vtotal
);
1687 hdmi_set_reg(core
->v1_blank
, 2, m
->vtotal
- m
->vdisplay
);
1688 hdmi_set_reg(core
->v_blank_f0
, 2, 0xffff);
1689 hdmi_set_reg(core
->v_blank_f1
, 2, 0xffff);
1690 hdmi_set_reg(core
->v_sync_line_aft_2
, 2, 0xffff);
1691 hdmi_set_reg(core
->v_sync_line_aft_1
, 2, 0xffff);
1692 hdmi_set_reg(core
->v_sync_line_aft_pxl_2
, 2, 0xffff);
1693 hdmi_set_reg(core
->v_sync_line_aft_pxl_1
, 2, 0xffff);
1694 hdmi_set_reg(tg
->vact_st
, 2, m
->vtotal
- m
->vdisplay
);
1695 hdmi_set_reg(tg
->vact_sz
, 2, m
->vdisplay
);
1696 hdmi_set_reg(tg
->vact_st2
, 2, 0x248); /* Reset value */
1697 hdmi_set_reg(tg
->vact_st3
, 2, 0x47b); /* Reset value */
1698 hdmi_set_reg(tg
->vact_st4
, 2, 0x6ae); /* Reset value */
1699 hdmi_set_reg(tg
->vsync2
, 2, 0x233); /* Reset value */
1700 hdmi_set_reg(tg
->vsync_bot_hdmi
, 2, 0x233); /* Reset value */
1701 hdmi_set_reg(tg
->field_bot_hdmi
, 2, 0x233); /* Reset value */
1704 /* Following values & calculations are same irrespective of mode type */
1705 hdmi_set_reg(core
->h_sync_start
, 2, m
->hsync_start
- m
->hdisplay
- 2);
1706 hdmi_set_reg(core
->h_sync_end
, 2, m
->hsync_end
- m
->hdisplay
- 2);
1707 hdmi_set_reg(core
->vact_space_1
, 2, 0xffff);
1708 hdmi_set_reg(core
->vact_space_2
, 2, 0xffff);
1709 hdmi_set_reg(core
->vact_space_3
, 2, 0xffff);
1710 hdmi_set_reg(core
->vact_space_4
, 2, 0xffff);
1711 hdmi_set_reg(core
->vact_space_5
, 2, 0xffff);
1712 hdmi_set_reg(core
->vact_space_6
, 2, 0xffff);
1713 hdmi_set_reg(core
->v_blank_f2
, 2, 0xffff);
1714 hdmi_set_reg(core
->v_blank_f3
, 2, 0xffff);
1715 hdmi_set_reg(core
->v_blank_f4
, 2, 0xffff);
1716 hdmi_set_reg(core
->v_blank_f5
, 2, 0xffff);
1717 hdmi_set_reg(core
->v_sync_line_aft_3
, 2, 0xffff);
1718 hdmi_set_reg(core
->v_sync_line_aft_4
, 2, 0xffff);
1719 hdmi_set_reg(core
->v_sync_line_aft_5
, 2, 0xffff);
1720 hdmi_set_reg(core
->v_sync_line_aft_6
, 2, 0xffff);
1721 hdmi_set_reg(core
->v_sync_line_aft_pxl_3
, 2, 0xffff);
1722 hdmi_set_reg(core
->v_sync_line_aft_pxl_4
, 2, 0xffff);
1723 hdmi_set_reg(core
->v_sync_line_aft_pxl_5
, 2, 0xffff);
1724 hdmi_set_reg(core
->v_sync_line_aft_pxl_6
, 2, 0xffff);
1726 /* Timing generator registers */
1727 hdmi_set_reg(tg
->cmd
, 1, 0x0);
1728 hdmi_set_reg(tg
->h_fsz
, 2, m
->htotal
);
1729 hdmi_set_reg(tg
->hact_st
, 2, m
->htotal
- m
->hdisplay
);
1730 hdmi_set_reg(tg
->hact_sz
, 2, m
->hdisplay
);
1731 hdmi_set_reg(tg
->v_fsz
, 2, m
->vtotal
);
1732 hdmi_set_reg(tg
->vsync
, 2, 0x1);
1733 hdmi_set_reg(tg
->field_chg
, 2, 0x233); /* Reset value */
1734 hdmi_set_reg(tg
->vsync_top_hdmi
, 2, 0x1); /* Reset value */
1735 hdmi_set_reg(tg
->field_top_hdmi
, 2, 0x1); /* Reset value */
1736 hdmi_set_reg(tg
->tg_3d
, 1, 0x0);
1739 static void hdmi_mode_set(struct exynos_drm_display
*display
,
1740 struct drm_display_mode
*mode
)
1742 struct hdmi_context
*hdata
= display
->ctx
;
1743 struct drm_display_mode
*m
= mode
;
1745 DRM_DEBUG_KMS("xres=%d, yres=%d, refresh=%d, intl=%s\n",
1746 m
->hdisplay
, m
->vdisplay
,
1747 m
->vrefresh
, (m
->flags
& DRM_MODE_FLAG_INTERLACE
) ?
1748 "INTERLACED" : "PROGERESSIVE");
1750 if (hdata
->type
== HDMI_TYPE13
)
1751 hdmi_v13_mode_set(hdata
, mode
);
1753 hdmi_v14_mode_set(hdata
, mode
);
1756 static void hdmi_get_max_resol(struct exynos_drm_display
*display
,
1757 unsigned int *width
, unsigned int *height
)
1760 *height
= MAX_HEIGHT
;
1763 static void hdmi_commit(struct exynos_drm_display
*display
)
1765 struct hdmi_context
*hdata
= display
->ctx
;
1767 mutex_lock(&hdata
->hdmi_mutex
);
1768 if (!hdata
->powered
) {
1769 mutex_unlock(&hdata
->hdmi_mutex
);
1772 mutex_unlock(&hdata
->hdmi_mutex
);
1774 hdmi_conf_apply(hdata
);
1777 static void hdmi_poweron(struct exynos_drm_display
*display
)
1779 struct hdmi_context
*hdata
= display
->ctx
;
1780 struct hdmi_resources
*res
= &hdata
->res
;
1782 mutex_lock(&hdata
->hdmi_mutex
);
1783 if (hdata
->powered
) {
1784 mutex_unlock(&hdata
->hdmi_mutex
);
1788 hdata
->powered
= true;
1790 mutex_unlock(&hdata
->hdmi_mutex
);
1792 if (regulator_bulk_enable(res
->regul_count
, res
->regul_bulk
))
1793 DRM_DEBUG_KMS("failed to enable regulator bulk\n");
1795 clk_prepare_enable(res
->hdmiphy
);
1796 clk_prepare_enable(res
->hdmi
);
1797 clk_prepare_enable(res
->sclk_hdmi
);
1799 hdmiphy_poweron(hdata
);
1800 hdmi_commit(display
);
1803 static void hdmi_poweroff(struct exynos_drm_display
*display
)
1805 struct hdmi_context
*hdata
= display
->ctx
;
1806 struct hdmi_resources
*res
= &hdata
->res
;
1808 mutex_lock(&hdata
->hdmi_mutex
);
1809 if (!hdata
->powered
)
1811 mutex_unlock(&hdata
->hdmi_mutex
);
1814 * The TV power domain needs any condition of hdmiphy to turn off and
1815 * its reset state seems to meet the condition.
1817 hdmiphy_conf_reset(hdata
);
1818 hdmiphy_poweroff(hdata
);
1820 clk_disable_unprepare(res
->sclk_hdmi
);
1821 clk_disable_unprepare(res
->hdmi
);
1822 clk_disable_unprepare(res
->hdmiphy
);
1823 regulator_bulk_disable(res
->regul_count
, res
->regul_bulk
);
1825 mutex_lock(&hdata
->hdmi_mutex
);
1827 hdata
->powered
= false;
1830 mutex_unlock(&hdata
->hdmi_mutex
);
1833 static void hdmi_dpms(struct exynos_drm_display
*display
, int mode
)
1835 struct hdmi_context
*hdata
= display
->ctx
;
1837 DRM_DEBUG_KMS("mode %d\n", mode
);
1840 case DRM_MODE_DPMS_ON
:
1841 if (pm_runtime_suspended(hdata
->dev
))
1842 pm_runtime_get_sync(hdata
->dev
);
1844 case DRM_MODE_DPMS_STANDBY
:
1845 case DRM_MODE_DPMS_SUSPEND
:
1846 case DRM_MODE_DPMS_OFF
:
1847 if (!pm_runtime_suspended(hdata
->dev
))
1848 pm_runtime_put_sync(hdata
->dev
);
1851 DRM_DEBUG_KMS("unknown dpms mode: %d\n", mode
);
1856 static struct exynos_drm_display_ops hdmi_display_ops
= {
1857 .initialize
= hdmi_initialize
,
1858 .is_connected
= hdmi_is_connected
,
1859 .get_max_resol
= hdmi_get_max_resol
,
1860 .get_edid
= hdmi_get_edid
,
1861 .check_mode
= hdmi_check_mode
,
1862 .mode_fixup
= hdmi_mode_fixup
,
1863 .mode_set
= hdmi_mode_set
,
1865 .commit
= hdmi_commit
,
1868 static struct exynos_drm_display hdmi_display
= {
1869 .type
= EXYNOS_DISPLAY_TYPE_HDMI
,
1870 .ops
= &hdmi_display_ops
,
1873 static irqreturn_t
hdmi_irq_thread(int irq
, void *arg
)
1875 struct hdmi_context
*hdata
= arg
;
1877 mutex_lock(&hdata
->hdmi_mutex
);
1878 hdata
->hpd
= gpio_get_value(hdata
->hpd_gpio
);
1879 mutex_unlock(&hdata
->hdmi_mutex
);
1882 drm_helper_hpd_irq_event(hdata
->drm_dev
);
1887 static int hdmi_resources_init(struct hdmi_context
*hdata
)
1889 struct device
*dev
= hdata
->dev
;
1890 struct hdmi_resources
*res
= &hdata
->res
;
1891 static char *supply
[] = {
1899 DRM_DEBUG_KMS("HDMI resource init\n");
1901 memset(res
, 0, sizeof(*res
));
1903 /* get clocks, power */
1904 res
->hdmi
= devm_clk_get(dev
, "hdmi");
1905 if (IS_ERR(res
->hdmi
)) {
1906 DRM_ERROR("failed to get clock 'hdmi'\n");
1909 res
->sclk_hdmi
= devm_clk_get(dev
, "sclk_hdmi");
1910 if (IS_ERR(res
->sclk_hdmi
)) {
1911 DRM_ERROR("failed to get clock 'sclk_hdmi'\n");
1914 res
->sclk_pixel
= devm_clk_get(dev
, "sclk_pixel");
1915 if (IS_ERR(res
->sclk_pixel
)) {
1916 DRM_ERROR("failed to get clock 'sclk_pixel'\n");
1919 res
->sclk_hdmiphy
= devm_clk_get(dev
, "sclk_hdmiphy");
1920 if (IS_ERR(res
->sclk_hdmiphy
)) {
1921 DRM_ERROR("failed to get clock 'sclk_hdmiphy'\n");
1924 res
->hdmiphy
= devm_clk_get(dev
, "hdmiphy");
1925 if (IS_ERR(res
->hdmiphy
)) {
1926 DRM_ERROR("failed to get clock 'hdmiphy'\n");
1929 res
->mout_hdmi
= devm_clk_get(dev
, "mout_hdmi");
1930 if (IS_ERR(res
->mout_hdmi
)) {
1931 DRM_ERROR("failed to get clock 'mout_hdmi'\n");
1935 clk_set_parent(res
->mout_hdmi
, res
->sclk_pixel
);
1937 res
->regul_bulk
= devm_kzalloc(dev
, ARRAY_SIZE(supply
) *
1938 sizeof(res
->regul_bulk
[0]), GFP_KERNEL
);
1939 if (!res
->regul_bulk
)
1941 for (i
= 0; i
< ARRAY_SIZE(supply
); ++i
) {
1942 res
->regul_bulk
[i
].supply
= supply
[i
];
1943 res
->regul_bulk
[i
].consumer
= NULL
;
1945 ret
= devm_regulator_bulk_get(dev
, ARRAY_SIZE(supply
), res
->regul_bulk
);
1947 DRM_ERROR("failed to get regulators\n");
1950 res
->regul_count
= ARRAY_SIZE(supply
);
1954 DRM_ERROR("HDMI resource init - failed\n");
1958 static struct s5p_hdmi_platform_data
*drm_hdmi_dt_parse_pdata
1959 (struct device
*dev
)
1961 struct device_node
*np
= dev
->of_node
;
1962 struct s5p_hdmi_platform_data
*pd
;
1965 pd
= devm_kzalloc(dev
, sizeof(*pd
), GFP_KERNEL
);
1969 if (!of_find_property(np
, "hpd-gpio", &value
)) {
1970 DRM_ERROR("no hpd gpio property found\n");
1974 pd
->hpd_gpio
= of_get_named_gpio(np
, "hpd-gpio", 0);
1982 static struct of_device_id hdmi_match_types
[] = {
1984 .compatible
= "samsung,exynos5-hdmi",
1985 .data
= (void *)HDMI_TYPE14
,
1987 .compatible
= "samsung,exynos4212-hdmi",
1988 .data
= (void *)HDMI_TYPE14
,
1994 static int hdmi_probe(struct platform_device
*pdev
)
1996 struct device
*dev
= &pdev
->dev
;
1997 struct hdmi_context
*hdata
;
1998 struct s5p_hdmi_platform_data
*pdata
;
1999 struct resource
*res
;
2000 const struct of_device_id
*match
;
2001 struct device_node
*ddc_node
, *phy_node
;
2007 pdata
= drm_hdmi_dt_parse_pdata(dev
);
2011 hdata
= devm_kzalloc(dev
, sizeof(struct hdmi_context
), GFP_KERNEL
);
2015 mutex_init(&hdata
->hdmi_mutex
);
2017 platform_set_drvdata(pdev
, &hdmi_display
);
2019 match
= of_match_node(hdmi_match_types
, dev
->of_node
);
2022 hdata
->type
= (enum hdmi_type
)match
->data
;
2024 hdata
->hpd_gpio
= pdata
->hpd_gpio
;
2027 ret
= hdmi_resources_init(hdata
);
2029 DRM_ERROR("hdmi_resources_init failed\n");
2033 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
2034 hdata
->regs
= devm_ioremap_resource(dev
, res
);
2035 if (IS_ERR(hdata
->regs
))
2036 return PTR_ERR(hdata
->regs
);
2038 ret
= devm_gpio_request(dev
, hdata
->hpd_gpio
, "HPD");
2040 DRM_ERROR("failed to request HPD gpio\n");
2044 /* DDC i2c driver */
2045 ddc_node
= of_parse_phandle(dev
->of_node
, "ddc", 0);
2047 DRM_ERROR("Failed to find ddc node in device tree\n");
2050 hdata
->ddc_port
= of_find_i2c_device_by_node(ddc_node
);
2051 if (!hdata
->ddc_port
) {
2052 DRM_ERROR("Failed to get ddc i2c client by node\n");
2056 /* hdmiphy i2c driver */
2057 phy_node
= of_parse_phandle(dev
->of_node
, "phy", 0);
2059 DRM_ERROR("Failed to find hdmiphy node in device tree\n");
2063 hdata
->hdmiphy_port
= of_find_i2c_device_by_node(phy_node
);
2064 if (!hdata
->hdmiphy_port
) {
2065 DRM_ERROR("Failed to get hdmi phy i2c client from node\n");
2070 hdata
->irq
= gpio_to_irq(hdata
->hpd_gpio
);
2071 if (hdata
->irq
< 0) {
2072 DRM_ERROR("failed to get GPIO irq\n");
2077 hdata
->hpd
= gpio_get_value(hdata
->hpd_gpio
);
2079 ret
= devm_request_threaded_irq(dev
, hdata
->irq
, NULL
,
2080 hdmi_irq_thread
, IRQF_TRIGGER_RISING
|
2081 IRQF_TRIGGER_FALLING
| IRQF_ONESHOT
,
2084 DRM_ERROR("failed to register hdmi interrupt\n");
2088 hdmi_display
.ctx
= hdata
;
2089 exynos_drm_display_register(&hdmi_display
);
2091 pm_runtime_enable(dev
);
2096 put_device(&hdata
->hdmiphy_port
->dev
);
2098 put_device(&hdata
->ddc_port
->dev
);
2102 static int hdmi_remove(struct platform_device
*pdev
)
2104 struct device
*dev
= &pdev
->dev
;
2105 struct exynos_drm_display
*display
= get_hdmi_display(dev
);
2106 struct hdmi_context
*hdata
= display
->ctx
;
2108 pm_runtime_disable(dev
);
2110 put_device(&hdata
->hdmiphy_port
->dev
);
2111 put_device(&hdata
->ddc_port
->dev
);
2116 #ifdef CONFIG_PM_SLEEP
2117 static int hdmi_suspend(struct device
*dev
)
2119 struct exynos_drm_display
*display
= get_hdmi_display(dev
);
2120 struct hdmi_context
*hdata
= display
->ctx
;
2122 disable_irq(hdata
->irq
);
2126 drm_helper_hpd_irq_event(hdata
->drm_dev
);
2128 if (pm_runtime_suspended(dev
)) {
2129 DRM_DEBUG_KMS("Already suspended\n");
2133 hdmi_poweroff(display
);
2138 static int hdmi_resume(struct device
*dev
)
2140 struct exynos_drm_display
*display
= get_hdmi_display(dev
);
2141 struct hdmi_context
*hdata
= display
->ctx
;
2143 hdata
->hpd
= gpio_get_value(hdata
->hpd_gpio
);
2145 enable_irq(hdata
->irq
);
2147 if (!pm_runtime_suspended(dev
)) {
2148 DRM_DEBUG_KMS("Already resumed\n");
2152 hdmi_poweron(display
);
2158 #ifdef CONFIG_PM_RUNTIME
2159 static int hdmi_runtime_suspend(struct device
*dev
)
2161 struct exynos_drm_display
*display
= get_hdmi_display(dev
);
2163 hdmi_poweroff(display
);
2168 static int hdmi_runtime_resume(struct device
*dev
)
2170 struct exynos_drm_display
*display
= get_hdmi_display(dev
);
2172 hdmi_poweron(display
);
2178 static const struct dev_pm_ops hdmi_pm_ops
= {
2179 SET_SYSTEM_SLEEP_PM_OPS(hdmi_suspend
, hdmi_resume
)
2180 SET_RUNTIME_PM_OPS(hdmi_runtime_suspend
, hdmi_runtime_resume
, NULL
)
2183 struct platform_driver hdmi_driver
= {
2184 .probe
= hdmi_probe
,
2185 .remove
= hdmi_remove
,
2187 .name
= "exynos-hdmi",
2188 .owner
= THIS_MODULE
,
2190 .of_match_table
= hdmi_match_types
,