Skip to content

Commit e9c6da2

Browse files
Andrzej Hajdaboddob
authored andcommitted
drm/bridge/sii8620: add reading device capability registers
This functionality is necessary to implement MHL3 modes. 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-4-git-send-email-a.hajda@samsung.com
1 parent bb4954c commit e9c6da2

File tree

1 file changed

+35
-0
lines changed

1 file changed

+35
-0
lines changed

drivers/gpu/drm/bridge/sil-sii8620.c

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -286,6 +286,12 @@ static void sii8620_mt_msc_cmd_send(struct sii8620 *ctx,
286286
sii8620_write(ctx, REG_MSC_COMMAND_START,
287287
BIT_MSC_COMMAND_START_MSC_MSG);
288288
break;
289+
case MHL_READ_DEVCAP_REG:
290+
case MHL_READ_XDEVCAP_REG:
291+
sii8620_write(ctx, REG_MSC_CMD_OR_OFFSET, msg->reg[1]);
292+
sii8620_write(ctx, REG_MSC_COMMAND_START,
293+
BIT_MSC_COMMAND_START_READ_DEVCAP);
294+
break;
289295
default:
290296
dev_err(ctx->dev, "%s: command %#x not supported\n", __func__,
291297
msg->reg[0]);
@@ -455,6 +461,35 @@ static void sii8620_mt_read_devcap(struct sii8620 *ctx, bool xdevcap)
455461
msg->recv = sii8620_mt_read_devcap_recv;
456462
}
457463

464+
static void sii8620_mt_read_devcap_reg_recv(struct sii8620 *ctx,
465+
struct sii8620_mt_msg *msg)
466+
{
467+
u8 reg = msg->reg[0] & 0x7f;
468+
469+
if (msg->reg[0] & 0x80)
470+
ctx->xdevcap[reg] = msg->ret;
471+
else
472+
ctx->devcap[reg] = msg->ret;
473+
}
474+
475+
static void sii8620_mt_read_devcap_reg(struct sii8620 *ctx, u8 reg)
476+
{
477+
struct sii8620_mt_msg *msg = sii8620_mt_msg_new(ctx);
478+
479+
if (!msg)
480+
return;
481+
482+
msg->reg[0] = (reg & 0x80) ? MHL_READ_XDEVCAP_REG : MHL_READ_DEVCAP_REG;
483+
msg->reg[1] = reg;
484+
msg->send = sii8620_mt_msc_cmd_send;
485+
msg->recv = sii8620_mt_read_devcap_reg_recv;
486+
}
487+
488+
static inline void sii8620_mt_read_xdevcap_reg(struct sii8620 *ctx, u8 reg)
489+
{
490+
sii8620_mt_read_devcap_reg(ctx, reg | 0x80);
491+
}
492+
458493
static void sii8620_fetch_edid(struct sii8620 *ctx)
459494
{
460495
u8 lm_ddc, ddc_cmd, int3, cbus;

0 commit comments

Comments
 (0)