Commit 69c63e88 authored by Thomas Zimmermann's avatar Thomas Zimmermann

drm/mipi-dbi: Use shadow-plane mappings

Use the buffer mappings provided by shadow-plane helpers. As the
mappings are established while the commit can still fail, errors
are now reported correctly to callers.

v2:
	* use shadow-plane state directly (Noralf)
Signed-off-by: default avatarThomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: default avatarNoralf Trønnes <noralf@tronnes.org>
Tested-by: default avatarJavier Martinez Canillas <javierm@redhat.com>
Tested-by: Noralf Trønnes <noralf@tronnes.org> # drm/tiny/mi0283qt
Link: https://patchwork.freedesktop.org/patch/msgid/20221202125644.7917-8-tzimmermann@suse.de
parent e7caf04d
...@@ -321,12 +321,10 @@ EXPORT_SYMBOL(mipi_dbi_pipe_mode_valid); ...@@ -321,12 +321,10 @@ EXPORT_SYMBOL(mipi_dbi_pipe_mode_valid);
void mipi_dbi_pipe_update(struct drm_simple_display_pipe *pipe, void mipi_dbi_pipe_update(struct drm_simple_display_pipe *pipe,
struct drm_plane_state *old_state) struct drm_plane_state *old_state)
{ {
struct iosys_map map[DRM_FORMAT_MAX_PLANES] = { };
struct iosys_map data[DRM_FORMAT_MAX_PLANES] = { };
struct drm_plane_state *state = pipe->plane.state; struct drm_plane_state *state = pipe->plane.state;
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(state);
struct drm_framebuffer *fb = state->fb; struct drm_framebuffer *fb = state->fb;
struct drm_rect rect; struct drm_rect rect;
int ret;
if (!pipe->crtc.state->active) if (!pipe->crtc.state->active)
return; return;
...@@ -334,14 +332,8 @@ void mipi_dbi_pipe_update(struct drm_simple_display_pipe *pipe, ...@@ -334,14 +332,8 @@ void mipi_dbi_pipe_update(struct drm_simple_display_pipe *pipe,
if (WARN_ON(!fb)) if (WARN_ON(!fb))
return; return;
ret = drm_gem_fb_vmap(fb, map, data);
if (ret)
return;
if (drm_atomic_helper_damage_merged(old_state, state, &rect)) if (drm_atomic_helper_damage_merged(old_state, state, &rect))
mipi_dbi_fb_dirty(&data[0], fb, &rect); mipi_dbi_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
drm_gem_fb_vunmap(fb, map);
} }
EXPORT_SYMBOL(mipi_dbi_pipe_update); EXPORT_SYMBOL(mipi_dbi_pipe_update);
...@@ -362,6 +354,7 @@ void mipi_dbi_enable_flush(struct mipi_dbi_dev *dbidev, ...@@ -362,6 +354,7 @@ void mipi_dbi_enable_flush(struct mipi_dbi_dev *dbidev,
struct drm_crtc_state *crtc_state, struct drm_crtc_state *crtc_state,
struct drm_plane_state *plane_state) struct drm_plane_state *plane_state)
{ {
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(plane_state);
struct drm_framebuffer *fb = plane_state->fb; struct drm_framebuffer *fb = plane_state->fb;
struct drm_rect rect = { struct drm_rect rect = {
.x1 = 0, .x1 = 0,
...@@ -369,22 +362,14 @@ void mipi_dbi_enable_flush(struct mipi_dbi_dev *dbidev, ...@@ -369,22 +362,14 @@ void mipi_dbi_enable_flush(struct mipi_dbi_dev *dbidev,
.y1 = 0, .y1 = 0,
.y2 = fb->height, .y2 = fb->height,
}; };
struct iosys_map map[DRM_FORMAT_MAX_PLANES] = { }; int idx;
struct iosys_map data[DRM_FORMAT_MAX_PLANES] = { };
int idx, ret;
if (!drm_dev_enter(&dbidev->drm, &idx)) if (!drm_dev_enter(&dbidev->drm, &idx))
return; return;
ret = drm_gem_fb_vmap(fb, map, data); mipi_dbi_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
if (ret)
goto err_drm_dev_exit;
mipi_dbi_fb_dirty(&data[0], fb, &rect);
backlight_enable(dbidev->backlight); backlight_enable(dbidev->backlight);
drm_gem_fb_vunmap(fb, map);
err_drm_dev_exit:
drm_dev_exit(idx); drm_dev_exit(idx);
} }
EXPORT_SYMBOL(mipi_dbi_enable_flush); EXPORT_SYMBOL(mipi_dbi_enable_flush);
......
...@@ -164,19 +164,15 @@ static void ili9225_pipe_update(struct drm_simple_display_pipe *pipe, ...@@ -164,19 +164,15 @@ static void ili9225_pipe_update(struct drm_simple_display_pipe *pipe,
struct drm_plane_state *old_state) struct drm_plane_state *old_state)
{ {
struct drm_plane_state *state = pipe->plane.state; struct drm_plane_state *state = pipe->plane.state;
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(state);
struct drm_framebuffer *fb = state->fb; struct drm_framebuffer *fb = state->fb;
struct drm_gem_dma_object *dma_obj;
struct iosys_map src;
struct drm_rect rect; struct drm_rect rect;
if (!pipe->crtc.state->active) if (!pipe->crtc.state->active)
return; return;
dma_obj = drm_fb_dma_get_gem_obj(fb, 0);
iosys_map_set_vaddr(&src, dma_obj->vaddr);
if (drm_atomic_helper_damage_merged(old_state, state, &rect)) if (drm_atomic_helper_damage_merged(old_state, state, &rect))
ili9225_fb_dirty(&src, fb, &rect); ili9225_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
} }
static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe, static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe,
...@@ -184,6 +180,7 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -184,6 +180,7 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe,
struct drm_plane_state *plane_state) struct drm_plane_state *plane_state)
{ {
struct mipi_dbi_dev *dbidev = drm_to_mipi_dbi_dev(pipe->crtc.dev); struct mipi_dbi_dev *dbidev = drm_to_mipi_dbi_dev(pipe->crtc.dev);
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(plane_state);
struct drm_framebuffer *fb = plane_state->fb; struct drm_framebuffer *fb = plane_state->fb;
struct device *dev = pipe->crtc.dev->dev; struct device *dev = pipe->crtc.dev->dev;
struct mipi_dbi *dbi = &dbidev->dbi; struct mipi_dbi *dbi = &dbidev->dbi;
...@@ -193,8 +190,6 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -193,8 +190,6 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe,
.y1 = 0, .y1 = 0,
.y2 = fb->height, .y2 = fb->height,
}; };
struct drm_gem_dma_object *dma_obj;
struct iosys_map src;
int ret, idx; int ret, idx;
u8 am_id; u8 am_id;
...@@ -285,10 +280,7 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -285,10 +280,7 @@ static void ili9225_pipe_enable(struct drm_simple_display_pipe *pipe,
ili9225_command(dbi, ILI9225_DISPLAY_CONTROL_1, 0x1017); ili9225_command(dbi, ILI9225_DISPLAY_CONTROL_1, 0x1017);
dma_obj = drm_fb_dma_get_gem_obj(fb, 0); ili9225_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
iosys_map_set_vaddr(&src, dma_obj->vaddr);
ili9225_fb_dirty(&src, fb, &rect);
out_exit: out_exit:
drm_dev_exit(idx); drm_dev_exit(idx);
......
...@@ -153,19 +153,15 @@ static void st7586_pipe_update(struct drm_simple_display_pipe *pipe, ...@@ -153,19 +153,15 @@ static void st7586_pipe_update(struct drm_simple_display_pipe *pipe,
struct drm_plane_state *old_state) struct drm_plane_state *old_state)
{ {
struct drm_plane_state *state = pipe->plane.state; struct drm_plane_state *state = pipe->plane.state;
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(state);
struct drm_framebuffer *fb = state->fb; struct drm_framebuffer *fb = state->fb;
struct drm_gem_dma_object *dma_obj;
struct iosys_map src;
struct drm_rect rect; struct drm_rect rect;
if (!pipe->crtc.state->active) if (!pipe->crtc.state->active)
return; return;
dma_obj = drm_fb_dma_get_gem_obj(fb, 0);
iosys_map_set_vaddr(&src, dma_obj->vaddr);
if (drm_atomic_helper_damage_merged(old_state, state, &rect)) if (drm_atomic_helper_damage_merged(old_state, state, &rect))
st7586_fb_dirty(&src, fb, &rect); st7586_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
} }
static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe, static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe,
...@@ -173,6 +169,7 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -173,6 +169,7 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe,
struct drm_plane_state *plane_state) struct drm_plane_state *plane_state)
{ {
struct mipi_dbi_dev *dbidev = drm_to_mipi_dbi_dev(pipe->crtc.dev); struct mipi_dbi_dev *dbidev = drm_to_mipi_dbi_dev(pipe->crtc.dev);
struct drm_shadow_plane_state *shadow_plane_state = to_drm_shadow_plane_state(plane_state);
struct drm_framebuffer *fb = plane_state->fb; struct drm_framebuffer *fb = plane_state->fb;
struct mipi_dbi *dbi = &dbidev->dbi; struct mipi_dbi *dbi = &dbidev->dbi;
struct drm_rect rect = { struct drm_rect rect = {
...@@ -181,8 +178,6 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -181,8 +178,6 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe,
.y1 = 0, .y1 = 0,
.y2 = fb->height, .y2 = fb->height,
}; };
struct drm_gem_dma_object *dma_obj;
struct iosys_map src;
int idx, ret; int idx, ret;
u8 addr_mode; u8 addr_mode;
...@@ -242,10 +237,7 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe, ...@@ -242,10 +237,7 @@ static void st7586_pipe_enable(struct drm_simple_display_pipe *pipe,
msleep(100); msleep(100);
dma_obj = drm_fb_dma_get_gem_obj(fb, 0); st7586_fb_dirty(&shadow_plane_state->data[0], fb, &rect);
iosys_map_set_vaddr(&src, dma_obj->vaddr);
st7586_fb_dirty(&src, fb, &rect);
mipi_dbi_command(dbi, MIPI_DCS_SET_DISPLAY_ON); mipi_dbi_command(dbi, MIPI_DCS_SET_DISPLAY_ON);
out_exit: out_exit:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment