[PATCH v4 3/3] drm/bridge: add Silicon Image SiI8620 driver

Andrzej Hajda a.hajda at samsung.com
Mon Oct 10 07:31:03 UTC 2016


Hi Laurent,

Thanks for review.

On 07.10.2016 16:58, Laurent Pinchart wrote:
> Hi Andrzej,
>
> Thank you for the patch.
>
> On Friday 07 Oct 2016 09:02:42 Andrzej Hajda wrote:
>> SiI8620 transmitter converts eTMDS/HDMI signal to MHL 3.0.
>> It is controlled via I2C bus. Its interaction with other
>> devices in video pipeline is performed mainly on HW level.
>> The only interaction it does on device driver level is
>> filtering-out unsupported video modes, it exposes drm_bridge
>> interface to perform this operation.
>>
>> Signed-off-by: Andrzej Hajda <a.hajda at samsung.com>
>> ---
>> v4:
>>   - updated mhl.h location
>> v3:
>>   - modified driver description,
>>   - removed dummy bridge callbacks,
>>   - removed locking from driver remove function.
>> ---
>>  drivers/gpu/drm/bridge/Kconfig       |    7 +
>>  drivers/gpu/drm/bridge/Makefile      |    1 +
>>  drivers/gpu/drm/bridge/sil-sii8620.c | 1557 +++++++++++++++++++++++++++++++
>>  drivers/gpu/drm/bridge/sil-sii8620.h | 1517 ++++++++++++++++++++++++++++++
>>  4 files changed, 3082 insertions(+)
>>  create mode 100644 drivers/gpu/drm/bridge/sil-sii8620.c
>>  create mode 100644 drivers/gpu/drm/bridge/sil-sii8620.h
>>
>> diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig
>> index b590e67..e7fb179 100644
>> --- a/drivers/gpu/drm/bridge/Kconfig
>> +++ b/drivers/gpu/drm/bridge/Kconfig
>> @@ -50,6 +50,13 @@ config DRM_PARADE_PS8622
>>  	---help---
>>  	  Parade eDP-LVDS bridge chip driver.
>>
>> +config DRM_SIL_SII8620
>> +	tristate "Silicon Image SII8620 HDMI/MHL bridge"
>> +	depends on OF
>> +	select DRM_KMS_HELPER
> Shouldn't you depend on I2C ?

It is under DRM_BRIDGE, which depends on DRM, which
selects I2C.

>
>> +	help
>> +	  Silicon Image SII8620 HDMI/MHL bridge chip driver.
>> +
>>  config DRM_SII902X
>>  	tristate "Silicon Image sii902x RGB/HDMI bridge"
>>  	depends on OF
> [snip]
>
>> diff --git a/drivers/gpu/drm/bridge/sil-sii8620.c
>> b/drivers/gpu/drm/bridge/sil-sii8620.c new file mode 100644
>> index 0000000..7f053a5
>> --- /dev/null
>> +++ b/drivers/gpu/drm/bridge/sil-sii8620.c
> [snip]
>
>> +static void sii8620_write_buf(struct sii8620 *ctx, u16 addr, const u8 *buf,
>> +			      int len)
>> +{
>> +	struct device *dev = ctx->dev;
>> +	struct i2c_client *client = to_i2c_client(dev);
>> +	u8 data[2];
>> +	struct i2c_msg msg = {
>> +		.addr = sii8620_i2c_page[addr >> 8],
>> +		.flags = client->flags,
>> +		.len = len + 1,
>> +	};
>> +	int ret;
>> +
>> +	if (ctx->error)
>> +		return;
>> +
>> +	if (len > 1) {
>> +		msg.buf = kmalloc(len + 1, GFP_KERNEL);
> As len is 2 at most this seems overkill...

Hmm, it is used multiple times with bigger buffers, see
sii8620_set_dev_cap, or edid related code.

>
>> +		if (!msg.buf) {
>> +			ctx->error = -ENOMEM;
>> +			return;
>> +		}
>> +		memcpy(msg.buf + 1, buf, len);
>> +	} else {
>> +		msg.buf = data;
>> +		msg.buf[1] = *buf;
>> +	}
>> +
>> +	msg.buf[0] = addr;
>> +
>> +	ret = i2c_transfer(client->adapter, &msg, 1);
>> +	dev_dbg(dev, "write at %04x: %*ph, %d\n", addr, len, buf, ret);
>> +
>> +	if (ret != 1) {
>> +		dev_err(dev, "Write at %#06x of %*ph failed with code %d.\n",
>> +			addr, len, buf, ret);
>> +		ctx->error = ret ?: -EIO;
>> +	}
>> +
>> +	if (len > 1)
>> +		kfree(msg.buf);
>> +}
>> +
>> +#define sii8620_write(ctx, addr, arr...) \
>> +({\
>> +	u8 d[] = { arr }; \
>> +	sii8620_write_buf(ctx, addr, d, ARRAY_SIZE(d)); \
>> +})
>> +
>> +static void __sii8620_write_seq(struct sii8620 *ctx, u16 *seq, int len)
>> +{
>> +	int i;
>> +
>> +	for (i = 0; i < len; i += 2)
>> +		sii8620_write(ctx, seq[i], seq[i + 1]);
>> +}
>> +
>> +#define sii8620_write_seq(ctx, seq...) \
>> +({\
>> +	u16 d[] = { seq }; \
> You can make this const. Furthermore, given that there's quite a few calls to 
> this macro with lots of compile-time static arguments, a static const version 
> of the macro would be useful.

You are right.

>
>> +	__sii8620_write_seq(ctx, d, ARRAY_SIZE(d)); \
>> +})
> [snip]
>
>> +static const struct of_device_id sii8620_dt_match[] = {
>> +	{ .compatible = "sil,sii8620" },
>> +	{ },
>> +};
>> +MODULE_DEVICE_TABLE(of, sii8620_dt_match);
>> +
>> +static const struct i2c_device_id sii8620_id[] = {
>> +	{ "SII8620", 0 },
> Don't I2C IDs usually use lower case in the kernel ?

OK.

Regards
Andrzej

>
>> +	{ },
>> +};
>> +
>> +MODULE_DEVICE_TABLE(i2c, sii8620_id);




More information about the dri-devel mailing list