[PATCH 06/14] drm/imx: atomic phase 1: Use transitional atomic CRTC and plane helpers
Ying Liu
gnuiyl at gmail.com
Wed May 25 08:50:17 UTC 2016
On Tue, May 24, 2016 at 10:23 PM, Philipp Zabel <p.zabel at pengutronix.de> wrote:
> Am Dienstag, den 24.05.2016, 18:10 +0800 schrieb Liu Ying:
>> Use the drm_plane_helper_update/disable() and drm_helper_crtc_mode_set()
>> transistional atomic helpers. The crtc->mode_set_nofb callback is added
>> so that the primary plane is no longer tied to the CRTC. Check/update
>> logics are separated to make sure crtc->mode_set_nofb and plane->atomic_update
>> are always successful. Also, some necessary logics are tweaked for a smooth
>> transition.
>>
>> Signed-off-by: Liu Ying <gnuiyl at gmail.com>
>> ---
>> drivers/gpu/drm/imx/ipuv3-crtc.c | 173 +++++++------
>> drivers/gpu/drm/imx/ipuv3-plane.c | 516 +++++++++++++++++++++++---------------
>> drivers/gpu/drm/imx/ipuv3-plane.h | 14 +-
>> drivers/gpu/ipu-v3/ipu-dc.c | 5 +-
>> drivers/gpu/ipu-v3/ipu-di.c | 3 -
>> 5 files changed, 400 insertions(+), 311 deletions(-)
>>
> [...]
>> diff --git a/drivers/gpu/drm/imx/ipuv3-plane.c b/drivers/gpu/drm/imx/ipuv3-plane.c
>> index 30cedbb..4511b84 100644
>> --- a/drivers/gpu/drm/imx/ipuv3-plane.c
>> +++ b/drivers/gpu/drm/imx/ipuv3-plane.c
>> @@ -16,6 +16,7 @@
>> #include <drm/drmP.h>
>> #include <drm/drm_fb_cma_helper.h>
>> #include <drm/drm_gem_cma_helper.h>
>> +#include <drm/drm_plane_helper.h>
>>
>> #include "video/imx-ipu-v3.h"
>> #include "ipuv3-plane.h"
>> @@ -51,12 +52,15 @@ int ipu_plane_irq(struct ipu_plane *ipu_plane)
>> IPU_IRQ_EOF);
>> }
>>
>> -int ipu_plane_set_base(struct ipu_plane *ipu_plane, struct drm_framebuffer *fb,
>> - int x, int y)
>> +int ipu_plane_set_base(struct ipu_plane *ipu_plane, struct drm_framebuffer *fb)
>> {
>> - struct drm_gem_cma_object *cma_obj[3];
>> - unsigned long eba, ubo, vbo;
>> + struct drm_gem_cma_object *cma_obj[3], *old_cma_obj[3];
>> + struct drm_plane_state *state = ipu_plane->base.state;
>> + struct drm_framebuffer *old_fb = state->fb;
>> + unsigned long eba, ubo, vbo, old_eba, old_ubo, old_vbo;
>
> It looks to me like eba, ubo, vbo are good candidates to be put into a
> custom ipu_plane_state structure during check.
Yes for the first impression. I'll think about that more.
If the required change is too invasive and you accept, I'd like to
customize ipu_plane_state with another patch(set) after this one
is landed.
Regards,
Liu Ying
>
> regards
> Philipp
>
More information about the dri-devel
mailing list