<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote gmail_quote_container"><div dir="ltr" class="gmail_attr">On Tue, Mar 25, 2025 at 11:34 AM Doug Anderson <<a href="mailto:dianders@chromium.org">dianders@chromium.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi,<br>
<br>
On Mon, Mar 24, 2025 at 1:31 PM Anusha Srivatsa <<a href="mailto:asrivats@redhat.com" target="_blank">asrivats@redhat.com</a>> wrote:<br>
><br>
> Move away from using deprecated API and use _multi<br>
> variants if available. Use mipi_dsi_msleep()<br>
> and mipi_dsi_usleep_range() instead of msleep()<br>
> and usleep_range() respectively.<br>
><br>
> Used Coccinelle to find the _multi variant APIs,<br>
> replacing mpi_dsi_msleep() where necessary and for returning<br>
> dsi_ctx.accum_err in these functions. mipi_dsi_dcs_write()<br>
> does not have a corresponding _multi() variant. Replacing it with<br>
> mipi_dsi_dcs_write_buffer_multi() instead. This change is manual<br>
><br>
> @rule_1@<br>
> identifier dsi_var;<br>
> identifier r;<br>
> identifier func;<br>
> type t;<br>
> position p;<br>
> expression dsi_device;<br>
> expression list es;<br>
> @@<br>
> t func(...) {<br>
> ...<br>
> struct mipi_dsi_device *dsi_var = dsi_device;<br>
> +struct mipi_dsi_multi_context dsi_ctx = { .dsi = dsi_var };<br>
> <+...<br>
> (<br>
> -r = mipi_dsi_dcs_nop(dsi_var)@p;<br>
> +mipi_dsi_dcs_nop_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_dcs_exit_sleep_mode(dsi_var)@p;<br>
> +mipi_dsi_dcs_exit_sleep_mode_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_dcs_enter_sleep_mode(dsi_var)@p;<br>
> +mipi_dsi_dcs_enter_sleep_mode_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_dcs_write_buffer(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_write_buffer_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_display_off(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_display_off_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_compression_mode_ext(dsi_var,es)@p;<br>
> +mipi_dsi_compression_mode_ext_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_compression_mode(dsi_var,es)@p;<br>
> +mipi_dsi_compression_mode_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_picture_parameter_set(dsi_var,es)@p;<br>
> +mipi_dsi_picture_parameter_set_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_display_on(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_display_on_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_tear_on(dsi_var)@p;<br>
> +mipi_dsi_dcs_set_tear_on_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_turn_on_peripheral(dsi_var)@p;<br>
> +mipi_dsi_turn_on_peripheral_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_dcs_soft_reset(dsi_var)@p;<br>
> +mipi_dsi_dcs_soft_reset_multi(&dsi_ctx);<br>
> |<br>
> -r = mipi_dsi_dcs_set_display_brightness(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_display_brightness_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_pixel_format(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_pixel_format_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_column_address(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_column_address_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_page_address(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_page_address_multi(&dsi_ctx,es);<br>
> |<br>
> -r = mipi_dsi_dcs_set_tear_scanline(dsi_var,es)@p;<br>
> +mipi_dsi_dcs_set_tear_scanline_multi(&dsi_ctx,es);<br>
> )<br>
> -if(r < 0) {<br>
> -...<br>
> -}<br>
> ...+><br>
> }<br>
><br>
> @rule_2@<br>
> identifier dsi_var;<br>
> identifier r;<br>
> identifier func;<br>
> type t;<br>
> position p;<br>
> expression dsi_device;<br>
> expression list es;<br>
> @@<br>
> t func(...) {<br>
> ...<br>
> struct mipi_dsi_multi_context dsi_ctx = { .dsi = dsi_var };<br>
> <+...<br>
> (<br>
> -r = msleep(es)@p;<br>
> +r = mipi_dsi_msleep(&dsi_ctx,es);<br>
> |<br>
> -msleep(es)@p;<br>
> +mipi_dsi_msleep(&dsi_ctx,es);<br>
> |<br>
> -r = usleep_range(es)@p;<br>
> +r = mipi_dsi_usleep_range(&dsi_ctx,es);<br>
> |<br>
> -usleep_range(es)@p;<br>
> +mipi_dsi_usleep_range(&dsi_ctx,es);<br>
> )<br>
> ...+><br>
> }<br>
><br>
> @rule_3@<br>
> identifier dsi_var;<br>
> identifier func;<br>
> type t;<br>
> position p;<br>
> expression list es;<br>
> @@<br>
> t func(...) {<br>
> ...<br>
> struct mipi_dsi_multi_context dsi_ctx = { .dsi = dsi_var };<br>
> ...<br>
> -return 0;<br>
> +return dsi_ctx.accum_err;<br>
> }<br>
<br>
This is the exact same script as last time, right? Rather than<br>
duplicate it, you can just reference the previous patch that already<br>
landed. You'd say something like:<br>
<br>
The Coccinelle script is the same as the one in commit c8ba07caaecc<br>
("drm/panel/synaptics-r63353: Use _multi variants")<br>
<br></blockquote><div>Hey Doug - Good idea.</div><div> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> v2: Use mipi_dsi_dcs_write_buffer_multi() in place of<br>
> mipi_dsi_dcs_write(). (Dmitry)<br>
><br>
> Cc: Maxime Ripard <<a href="mailto:mripard@kernel.org" target="_blank">mripard@kernel.org</a>><br>
> Cc: Dmitry Baryshkov <<a href="mailto:dmitry.baryshkov@linaro.org" target="_blank">dmitry.baryshkov@linaro.org</a>><br>
> Cc: Tejas Vipin <<a href="mailto:tejasvipin76@gmail.com" target="_blank">tejasvipin76@gmail.com</a>><br>
> Cc: Doug Anderson <<a href="mailto:dianders@chromium.org" target="_blank">dianders@chromium.org</a>><br>
> Signed-off-by: Anusha Srivatsa <<a href="mailto:asrivats@redhat.com" target="_blank">asrivats@redhat.com</a>><br>
> ---<br>
> Changes in v2:<br>
> - While mipi_dsi_dcs_write() does not have a corresponding _multi()<br>
> variant replace it with mipi_dsi_dcs_write_buffer_multi() to have all<br>
> APIs following _multi() usage for easier error handling<br>
><br>
> - Link to v1: <a href="https://lore.kernel.org/r/20250316-b4-panel-ls043t1le01-v1-1-ee38371b0ba0@redhat.com" rel="noreferrer" target="_blank">https://lore.kernel.org/r/20250316-b4-panel-ls043t1le01-v1-1-ee38371b0ba0@redhat.com</a><br>
> ---<br>
> drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c | 42 ++++++++++---------------<br>
> 1 file changed, 16 insertions(+), 26 deletions(-)<br>
><br>
> diff --git a/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c b/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c<br>
> index 729cbb0d8403ff7c0c4b9d21774909cc298904a2..e3dc99ff711e388660d6d39251876de8cec50dbc 100644<br>
> --- a/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c<br>
> +++ b/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c<br>
> @@ -36,60 +36,50 @@ static inline struct sharp_nt_panel *to_sharp_nt_panel(struct drm_panel *panel)<br>
> static int sharp_nt_panel_init(struct sharp_nt_panel *sharp_nt)<br>
> {<br>
> struct mipi_dsi_device *dsi = sharp_nt->dsi;<br>
> - int ret;<br>
> + struct mipi_dsi_multi_context dsi_ctx = { .dsi = dsi };<br>
><br>
> + static const u8 d[] = { 0xae, 0x03 };<br>
> dsi->mode_flags |= MIPI_DSI_MODE_LPM;<br>
><br>
> - ret = mipi_dsi_dcs_exit_sleep_mode(dsi);<br>
> - if (ret < 0)<br>
> - return ret;<br>
> + mipi_dsi_dcs_exit_sleep_mode_multi(&dsi_ctx);<br>
><br>
> - msleep(120);<br>
> + mipi_dsi_msleep(&dsi_ctx, 120);<br>
><br>
> /* Novatek two-lane operation */<br>
> - ret = mipi_dsi_dcs_write(dsi, 0xae, (u8[]){ 0x03 }, 1);<br>
> - if (ret < 0)<br>
> - return ret;<br>
> + mipi_dsi_dcs_write_buffer_multi(&dsi_ctx, d, ARRAY_SIZE(d));<br>
<br>
Can't the above just be:<br>
<br>
mipi_dsi_dcs_write_seq_multi(&dsi_ctx, 0xae, 0x03);<br>
<br>
?<br>
<br></blockquote><div>it can.... definitely simpler. </div><div><br></div><div>Anusha <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
-Doug<br>
<br>
</blockquote></div></div>