drm/bridge/sii8620: add HSIC initialization code
authorAndrzej Hajda <a.hajda@samsung.com>
Wed, 1 Feb 2017 07:47:50 +0000 (08:47 +0100)
committerArchit Taneja <architt@codeaurora.org>
Thu, 2 Feb 2017 09:45:30 +0000 (15:15 +0530)
In case of MHL3 HSIC should be initialized.

Signed-off-by: Andrzej Hajda <a.hajda@samsung.com>
Signed-off-by: Archit Taneja <architt@codeaurora.org>
Link: http://patchwork.freedesktop.org/patch/msgid/1485935272-17337-24-git-send-email-a.hajda@samsung.com
drivers/gpu/drm/bridge/sil-sii8620.c
drivers/gpu/drm/bridge/sil-sii8620.h

index a0c5499f898b20f22555b925f33725adf4e43d4c..5dd800d2e30367d7a2f5c96caa1834f8666eeea2 100644 (file)
@@ -489,12 +489,50 @@ static void sii8620_sink_detected(struct sii8620 *ctx, int ret)
                 sink_str[ctx->sink_type], sink_name);
 }
 
+static void sii8620_hsic_init(struct sii8620 *ctx)
+{
+       if (!sii8620_is_mhl3(ctx))
+               return;
+
+       sii8620_write(ctx, REG_FCGC,
+               BIT_FCGC_HSIC_HOSTMODE | BIT_FCGC_HSIC_ENABLE);
+       sii8620_setbits(ctx, REG_HRXCTRL3,
+               BIT_HRXCTRL3_HRX_STAY_RESET | BIT_HRXCTRL3_STATUS_EN, ~0);
+       sii8620_setbits(ctx, REG_TTXNUMB, MSK_TTXNUMB_TTX_NUMBPS, 4);
+       sii8620_setbits(ctx, REG_TRXCTRL, BIT_TRXCTRL_TRX_FROM_SE_COC, ~0);
+       sii8620_setbits(ctx, REG_HTXCTRL, BIT_HTXCTRL_HTX_DRVCONN1, 0);
+       sii8620_setbits(ctx, REG_KEEPER, MSK_KEEPER_MODE, VAL_KEEPER_MODE_HOST);
+       sii8620_write_seq_static(ctx,
+               REG_TDMLLCTL, 0,
+               REG_UTSRST, BIT_UTSRST_HRX_SRST | BIT_UTSRST_HTX_SRST |
+                       BIT_UTSRST_KEEPER_SRST | BIT_UTSRST_FC_SRST,
+               REG_UTSRST, BIT_UTSRST_HRX_SRST | BIT_UTSRST_HTX_SRST,
+               REG_HRXINTL, 0xff,
+               REG_HRXINTH, 0xff,
+               REG_TTXINTL, 0xff,
+               REG_TTXINTH, 0xff,
+               REG_TRXINTL, 0xff,
+               REG_TRXINTH, 0xff,
+               REG_HTXINTL, 0xff,
+               REG_HTXINTH, 0xff,
+               REG_FCINTR0, 0xff,
+               REG_FCINTR1, 0xff,
+               REG_FCINTR2, 0xff,
+               REG_FCINTR3, 0xff,
+               REG_FCINTR4, 0xff,
+               REG_FCINTR5, 0xff,
+               REG_FCINTR6, 0xff,
+               REG_FCINTR7, 0xff
+       );
+}
+
 static void sii8620_edid_read(struct sii8620 *ctx, int ret)
 {
        if (ret < 0)
                return;
 
        sii8620_set_upstream_edid(ctx);
+       sii8620_hsic_init(ctx);
        sii8620_enable_hpd(ctx);
 }
 
index 312b07f38a09f8714b06caa396cc2b5d61c4ce63..51ab540cf0920bf0015d4e6662ec9ce73e4087de 100644 (file)
 #define REG_TTXNUMB                            0x0116
 #define MSK_TTXNUMB_TTX_AFFCTRL_3_0            0xf0
 #define BIT_TTXNUMB_TTX_COM1_AT_SYNC_WAIT      BIT(3)
-#define MSK_TTXNUMB_TTX_NUMBPS_2_0             0x07
+#define MSK_TTXNUMB_TTX_NUMBPS                 0x07
 
 /* TDM TX NUMSPISYM, default value: 0x04 */
 #define REG_TTXSPINUMS                         0x0117
 
 /* HSIC Keeper, default value: 0x00 */
 #define REG_KEEPER                             0x0181
-#define MSK_KEEPER_KEEPER_MODE_1_0             0x03
+#define MSK_KEEPER_MODE                                0x03
+#define VAL_KEEPER_MODE_HOST                   0
+#define VAL_KEEPER_MODE_DEVICE                 2
 
 /* HSIC Flow Control General, default value: 0x02 */
 #define REG_FCGC                               0x0183
-#define BIT_FCGC_HSIC_FC_HOSTMODE              BIT(1)
-#define BIT_FCGC_HSIC_FC_ENABLE                        BIT(0)
+#define BIT_FCGC_HSIC_HOSTMODE                 BIT(1)
+#define BIT_FCGC_HSIC_ENABLE                   BIT(0)
 
 /* HSIC Flow Control CTR13, default value: 0xfc */
 #define REG_FCCTR13                            0x0191