On 10/13/2014 12:16 PM, Thierry Reding wrote: > From: YoungJun Cho <yj44.cho@xxxxxxxxxxx> > > This function can be used to set the maximum return packet size for a > MIPI DSI peripheral. > > Signed-off-by: YoungJun Cho <yj44.cho@xxxxxxxxxxx> > [treding: endianess, kerneldoc, return value] > Signed-off-by: Thierry Reding <treding@xxxxxxxxxx> > --- > drivers/gpu/drm/drm_mipi_dsi.c | 30 ++++++++++++++++++++++++++++++ > include/drm/drm_mipi_dsi.h | 2 ++ > 2 files changed, 32 insertions(+) > > diff --git a/drivers/gpu/drm/drm_mipi_dsi.c b/drivers/gpu/drm/drm_mipi_dsi.c > index 1702ffd07986..27fc6dac5e4a 100644 > --- a/drivers/gpu/drm/drm_mipi_dsi.c > +++ b/drivers/gpu/drm/drm_mipi_dsi.c > @@ -198,6 +198,36 @@ int mipi_dsi_detach(struct mipi_dsi_device *dsi) > } > EXPORT_SYMBOL(mipi_dsi_detach); > > +/* > + * mipi_dsi_set_maximum_return_packet_size() - specify the maximum size of the > + * the payload in a long packet transmitted from the peripheral back to the > + * host processor > + * @dsi: DSI peripheral device > + * @value: the maximum size of the payload > + * > + * Return: 0 on success or a negative error code on failure. > + */ > +int mipi_dsi_set_maximum_return_packet_size(struct mipi_dsi_device *dsi, > + u16 value) > +{ > + u8 tx[2] = { value & 0xff, value >> 8 }; > + struct mipi_dsi_msg msg; > + ssize_t err; > + > + memset(&msg, 0, sizeof(msg)); > + msg.channel = dsi->channel; > + msg.type = MIPI_DSI_SET_MAXIMUM_RETURN_PACKET_SIZE; > + msg.tx_len = sizeof(tx); > + msg.tx_buf = tx; An alternative (without tx variable) could be: __cpu_to_le16s(&value); msg.tx_len = sizeof(value); msg.tx_buf = &value; But it is just pico-optimization. > + > + err = dsi->host->ops->transfer(dsi->host, &msg); I guess the sequence: if (dsi->mode_flags & MIPI_DSI_MODE_LPM) msg.flags = MIPI_DSI_MSG_USE_LPM; should be before this callback. The same should be in all other helpers calling ops->transfer, so I guess it may be good to move it all to separate function, for example sth like: ... dsi_transfer(dsi, msg) { if (!ops || !ops->transfer) return -NOSYS; if (dsi->mode_flags & MIPI_DSI_MODE_LPM) msg.flags = MIPI_DSI_MSG_USE_LPM; return ops->transfer(dsi->host, msg); } Regards Andrzej > + if (err < 0) > + return err; > + > + return 0; > +} > +EXPORT_SYMBOL(mipi_dsi_set_maximum_return_packet_size); > + > /** > * mipi_dsi_dcs_write_buffer() - transmit a DCS command with payload > * @dsi: DSI peripheral device > diff --git a/include/drm/drm_mipi_dsi.h b/include/drm/drm_mipi_dsi.h > index 836cc2b677d0..ef50b5d0de57 100644 > --- a/include/drm/drm_mipi_dsi.h > +++ b/include/drm/drm_mipi_dsi.h > @@ -132,6 +132,8 @@ static inline struct mipi_dsi_device *to_mipi_dsi_device(struct device *dev) > > int mipi_dsi_attach(struct mipi_dsi_device *dsi); > int mipi_dsi_detach(struct mipi_dsi_device *dsi); > +int mipi_dsi_set_maximum_return_packet_size(struct mipi_dsi_device *dsi, > + u16 value); > ssize_t mipi_dsi_dcs_write_buffer(struct mipi_dsi_device *dsi, > const void *data, size_t len); > ssize_t mipi_dsi_dcs_write(struct mipi_dsi_device *dsi, u8 cmd, > _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel