Re: [RFC PATCH 3/3] drm/vkms: add overlay support

2021-02-23 Thread Melissa Wen
On 02/23, Daniel Vetter wrote:
> On Tue, Feb 23, 2021 at 11:21 AM Melissa Wen  wrote:
> >
> > On 02/22, Daniel Vetter wrote:
> > > On Sat, Feb 20, 2021 at 11:42:12AM -0300, Melissa Wen wrote:
> > > > Add support to overlay plane, in addition to primary and cursor
> > > > planes. In this approach, the plane composition still requires an
> > > > active primary plane and planes are composed associatively in the
> > > > order: (primary <- overlay) <- cursor
> > > >
> > > > It enables to run the following IGT tests successfully:
> > > > - kms_plane_cursor:
> > > >   - pipe-A-[overlay, primary, viewport]-size-[64, 128, 256]
> > > > - kms_atomic:
> > > >   - plane-overlay-legacy
> > > > and preserves the successful execution of kms_cursor_crc,
> > > > kms_writeback and kms_flip
> > > >
> > > > Signed-off-by: Melissa Wen 
> > > > ---
> > > >  drivers/gpu/drm/vkms/vkms_composer.c | 27 +--
> > > >  drivers/gpu/drm/vkms/vkms_drv.c  |  5 +
> > > >  drivers/gpu/drm/vkms/vkms_drv.h  |  1 +
> > > >  drivers/gpu/drm/vkms/vkms_output.c   | 17 +++--
> > > >  drivers/gpu/drm/vkms/vkms_plane.c| 20 +++-
> > > >  5 files changed, 53 insertions(+), 17 deletions(-)
> > > >
> > > > diff --git a/drivers/gpu/drm/vkms/vkms_composer.c 
> > > > b/drivers/gpu/drm/vkms/vkms_composer.c
> > > > index be8f1d33c645..2116da9b5a43 100644
> > > > --- a/drivers/gpu/drm/vkms/vkms_composer.c
> > > > +++ b/drivers/gpu/drm/vkms/vkms_composer.c
> > > > @@ -144,11 +144,12 @@ static void compose_planes(struct vkms_composer 
> > > > *primary_composer,
> > > >
> > > >  static int composite(void **vaddr_out,
> > > >  struct vkms_composer *primary_composer,
> > > > -struct vkms_composer *cursor_composer)
> > > > +struct vkms_crtc_state *crtc_state)
> > > >  {
> > > > struct drm_framebuffer *fb = _composer->fb;
> > > > struct drm_gem_object *gem_obj = drm_gem_fb_get_obj(fb, 0);
> > > > struct drm_gem_shmem_object *shmem_obj = 
> > > > to_drm_gem_shmem_obj(gem_obj);
> > > > +   int i;
> > > >
> > > > if (!*vaddr_out) {
> > > > *vaddr_out = kzalloc(shmem_obj->base.size, GFP_KERNEL);
> > > > @@ -163,8 +164,14 @@ static int composite(void **vaddr_out,
> > > >
> > > > memcpy(*vaddr_out, shmem_obj->vaddr, shmem_obj->base.size);
> > > >
> > > > -   if (cursor_composer)
> > > > -   compose_planes(primary_composer, cursor_composer, 
> > > > *vaddr_out);
> > > > +   /* If there are other planes besides primary, we consider the active
> > > > +* planes should be in z-order and compose them associatively:
> > > > +* ((primary <- overlay) <- cursor)
> > > > +*/
> > > > +   for (i = 1; i < crtc_state->num_active_planes; i++)
> > > > +   compose_planes(primary_composer,
> > > > +  crtc_state->active_planes[i]->composer,
> > > > +  *vaddr_out);
> > > >
> > > > return 0;
> > > >  }
> > > > @@ -186,7 +193,7 @@ void vkms_composer_worker(struct work_struct *work)
> > > > struct drm_crtc *crtc = crtc_state->base.crtc;
> > > > struct vkms_output *out = drm_crtc_to_vkms_output(crtc);
> > > > struct vkms_composer *primary_composer = NULL;
> > > > -   struct vkms_composer *cursor_composer = NULL;
> > > > +   struct vkms_plane_state *act_plane = NULL;
> > > > bool crc_pending, wb_pending;
> > > > void *vaddr_out = NULL;
> > > > u32 crc32 = 0;
> > > > @@ -210,11 +217,11 @@ void vkms_composer_worker(struct work_struct 
> > > > *work)
> > > > if (!crc_pending)
> > > > return;
> > > >
> > > > -   if (crtc_state->num_active_planes >= 1)
> > > > -   primary_composer = crtc_state->active_planes[0]->composer;
> > > > -
> > > > -   if (crtc_state->num_active_planes == 2)
> > > > -   cursor_composer = crtc_state->active_planes[1]->composer;
> > > > +   if (crtc_state->num_active_planes >= 1) {
> > > > +   act_plane = crtc_state->active_planes[0];
> > > > +   if (act_plane->base.plane->type == DRM_PLANE_TYPE_PRIMARY)
> > > > +   primary_composer = act_plane->composer;
> > > > +   }
> > > >
> > > > if (!primary_composer)
> > > > return;
> > > > @@ -222,7 +229,7 @@ void vkms_composer_worker(struct work_struct *work)
> > > > if (wb_pending)
> > > > vaddr_out = crtc_state->active_writeback;
> > > >
> > > > -   ret = composite(_out, primary_composer, cursor_composer);
> > > > +   ret = composite(_out, primary_composer, crtc_state);
> > > > if (ret) {
> > > > if (ret == -EINVAL && !wb_pending)
> > > > kfree(vaddr_out);
> > > > diff --git a/drivers/gpu/drm/vkms/vkms_drv.c 
> > > > b/drivers/gpu/drm/vkms/vkms_drv.c
> > > > index 2173b82606f6..027ffe759440 100644
> > > > --- a/drivers/gpu/drm/vkms/vkms_drv.c
> > > > +++ b/drivers/gpu/drm/vkms/vkms_drv.c
> > > > @@ -44,6 +44,10 @@ static bool enable_writeback = true;
> > > >  

Re: [RFC PATCH 3/3] drm/vkms: add overlay support

2021-02-23 Thread Daniel Vetter
On Tue, Feb 23, 2021 at 11:21 AM Melissa Wen  wrote:
>
> On 02/22, Daniel Vetter wrote:
> > On Sat, Feb 20, 2021 at 11:42:12AM -0300, Melissa Wen wrote:
> > > Add support to overlay plane, in addition to primary and cursor
> > > planes. In this approach, the plane composition still requires an
> > > active primary plane and planes are composed associatively in the
> > > order: (primary <- overlay) <- cursor
> > >
> > > It enables to run the following IGT tests successfully:
> > > - kms_plane_cursor:
> > >   - pipe-A-[overlay, primary, viewport]-size-[64, 128, 256]
> > > - kms_atomic:
> > >   - plane-overlay-legacy
> > > and preserves the successful execution of kms_cursor_crc,
> > > kms_writeback and kms_flip
> > >
> > > Signed-off-by: Melissa Wen 
> > > ---
> > >  drivers/gpu/drm/vkms/vkms_composer.c | 27 +--
> > >  drivers/gpu/drm/vkms/vkms_drv.c  |  5 +
> > >  drivers/gpu/drm/vkms/vkms_drv.h  |  1 +
> > >  drivers/gpu/drm/vkms/vkms_output.c   | 17 +++--
> > >  drivers/gpu/drm/vkms/vkms_plane.c| 20 +++-
> > >  5 files changed, 53 insertions(+), 17 deletions(-)
> > >
> > > diff --git a/drivers/gpu/drm/vkms/vkms_composer.c 
> > > b/drivers/gpu/drm/vkms/vkms_composer.c
> > > index be8f1d33c645..2116da9b5a43 100644
> > > --- a/drivers/gpu/drm/vkms/vkms_composer.c
> > > +++ b/drivers/gpu/drm/vkms/vkms_composer.c
> > > @@ -144,11 +144,12 @@ static void compose_planes(struct vkms_composer 
> > > *primary_composer,
> > >
> > >  static int composite(void **vaddr_out,
> > >  struct vkms_composer *primary_composer,
> > > -struct vkms_composer *cursor_composer)
> > > +struct vkms_crtc_state *crtc_state)
> > >  {
> > > struct drm_framebuffer *fb = _composer->fb;
> > > struct drm_gem_object *gem_obj = drm_gem_fb_get_obj(fb, 0);
> > > struct drm_gem_shmem_object *shmem_obj = 
> > > to_drm_gem_shmem_obj(gem_obj);
> > > +   int i;
> > >
> > > if (!*vaddr_out) {
> > > *vaddr_out = kzalloc(shmem_obj->base.size, GFP_KERNEL);
> > > @@ -163,8 +164,14 @@ static int composite(void **vaddr_out,
> > >
> > > memcpy(*vaddr_out, shmem_obj->vaddr, shmem_obj->base.size);
> > >
> > > -   if (cursor_composer)
> > > -   compose_planes(primary_composer, cursor_composer, *vaddr_out);
> > > +   /* If there are other planes besides primary, we consider the active
> > > +* planes should be in z-order and compose them associatively:
> > > +* ((primary <- overlay) <- cursor)
> > > +*/
> > > +   for (i = 1; i < crtc_state->num_active_planes; i++)
> > > +   compose_planes(primary_composer,
> > > +  crtc_state->active_planes[i]->composer,
> > > +  *vaddr_out);
> > >
> > > return 0;
> > >  }
> > > @@ -186,7 +193,7 @@ void vkms_composer_worker(struct work_struct *work)
> > > struct drm_crtc *crtc = crtc_state->base.crtc;
> > > struct vkms_output *out = drm_crtc_to_vkms_output(crtc);
> > > struct vkms_composer *primary_composer = NULL;
> > > -   struct vkms_composer *cursor_composer = NULL;
> > > +   struct vkms_plane_state *act_plane = NULL;
> > > bool crc_pending, wb_pending;
> > > void *vaddr_out = NULL;
> > > u32 crc32 = 0;
> > > @@ -210,11 +217,11 @@ void vkms_composer_worker(struct work_struct *work)
> > > if (!crc_pending)
> > > return;
> > >
> > > -   if (crtc_state->num_active_planes >= 1)
> > > -   primary_composer = crtc_state->active_planes[0]->composer;
> > > -
> > > -   if (crtc_state->num_active_planes == 2)
> > > -   cursor_composer = crtc_state->active_planes[1]->composer;
> > > +   if (crtc_state->num_active_planes >= 1) {
> > > +   act_plane = crtc_state->active_planes[0];
> > > +   if (act_plane->base.plane->type == DRM_PLANE_TYPE_PRIMARY)
> > > +   primary_composer = act_plane->composer;
> > > +   }
> > >
> > > if (!primary_composer)
> > > return;
> > > @@ -222,7 +229,7 @@ void vkms_composer_worker(struct work_struct *work)
> > > if (wb_pending)
> > > vaddr_out = crtc_state->active_writeback;
> > >
> > > -   ret = composite(_out, primary_composer, cursor_composer);
> > > +   ret = composite(_out, primary_composer, crtc_state);
> > > if (ret) {
> > > if (ret == -EINVAL && !wb_pending)
> > > kfree(vaddr_out);
> > > diff --git a/drivers/gpu/drm/vkms/vkms_drv.c 
> > > b/drivers/gpu/drm/vkms/vkms_drv.c
> > > index 2173b82606f6..027ffe759440 100644
> > > --- a/drivers/gpu/drm/vkms/vkms_drv.c
> > > +++ b/drivers/gpu/drm/vkms/vkms_drv.c
> > > @@ -44,6 +44,10 @@ static bool enable_writeback = true;
> > >  module_param_named(enable_writeback, enable_writeback, bool, 0444);
> > >  MODULE_PARM_DESC(enable_writeback, "Enable/Disable writeback connector 
> > > support");
> > >
> > > +static bool enable_overlay;
> > > +module_param_named(enable_overlay, 

Re: [RFC PATCH 3/3] drm/vkms: add overlay support

2021-02-23 Thread Melissa Wen
On 02/22, Daniel Vetter wrote:
> On Sat, Feb 20, 2021 at 11:42:12AM -0300, Melissa Wen wrote:
> > Add support to overlay plane, in addition to primary and cursor
> > planes. In this approach, the plane composition still requires an
> > active primary plane and planes are composed associatively in the
> > order: (primary <- overlay) <- cursor
> > 
> > It enables to run the following IGT tests successfully:
> > - kms_plane_cursor:
> >   - pipe-A-[overlay, primary, viewport]-size-[64, 128, 256]
> > - kms_atomic:
> >   - plane-overlay-legacy
> > and preserves the successful execution of kms_cursor_crc,
> > kms_writeback and kms_flip
> > 
> > Signed-off-by: Melissa Wen 
> > ---
> >  drivers/gpu/drm/vkms/vkms_composer.c | 27 +--
> >  drivers/gpu/drm/vkms/vkms_drv.c  |  5 +
> >  drivers/gpu/drm/vkms/vkms_drv.h  |  1 +
> >  drivers/gpu/drm/vkms/vkms_output.c   | 17 +++--
> >  drivers/gpu/drm/vkms/vkms_plane.c| 20 +++-
> >  5 files changed, 53 insertions(+), 17 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/vkms/vkms_composer.c 
> > b/drivers/gpu/drm/vkms/vkms_composer.c
> > index be8f1d33c645..2116da9b5a43 100644
> > --- a/drivers/gpu/drm/vkms/vkms_composer.c
> > +++ b/drivers/gpu/drm/vkms/vkms_composer.c
> > @@ -144,11 +144,12 @@ static void compose_planes(struct vkms_composer 
> > *primary_composer,
> >  
> >  static int composite(void **vaddr_out,
> >  struct vkms_composer *primary_composer,
> > -struct vkms_composer *cursor_composer)
> > +struct vkms_crtc_state *crtc_state)
> >  {
> > struct drm_framebuffer *fb = _composer->fb;
> > struct drm_gem_object *gem_obj = drm_gem_fb_get_obj(fb, 0);
> > struct drm_gem_shmem_object *shmem_obj = to_drm_gem_shmem_obj(gem_obj);
> > +   int i;
> >  
> > if (!*vaddr_out) {
> > *vaddr_out = kzalloc(shmem_obj->base.size, GFP_KERNEL);
> > @@ -163,8 +164,14 @@ static int composite(void **vaddr_out,
> >  
> > memcpy(*vaddr_out, shmem_obj->vaddr, shmem_obj->base.size);
> >  
> > -   if (cursor_composer)
> > -   compose_planes(primary_composer, cursor_composer, *vaddr_out);
> > +   /* If there are other planes besides primary, we consider the active
> > +* planes should be in z-order and compose them associatively:
> > +* ((primary <- overlay) <- cursor)
> > +*/
> > +   for (i = 1; i < crtc_state->num_active_planes; i++)
> > +   compose_planes(primary_composer,
> > +  crtc_state->active_planes[i]->composer,
> > +  *vaddr_out);
> >  
> > return 0;
> >  }
> > @@ -186,7 +193,7 @@ void vkms_composer_worker(struct work_struct *work)
> > struct drm_crtc *crtc = crtc_state->base.crtc;
> > struct vkms_output *out = drm_crtc_to_vkms_output(crtc);
> > struct vkms_composer *primary_composer = NULL;
> > -   struct vkms_composer *cursor_composer = NULL;
> > +   struct vkms_plane_state *act_plane = NULL;
> > bool crc_pending, wb_pending;
> > void *vaddr_out = NULL;
> > u32 crc32 = 0;
> > @@ -210,11 +217,11 @@ void vkms_composer_worker(struct work_struct *work)
> > if (!crc_pending)
> > return;
> >  
> > -   if (crtc_state->num_active_planes >= 1)
> > -   primary_composer = crtc_state->active_planes[0]->composer;
> > -
> > -   if (crtc_state->num_active_planes == 2)
> > -   cursor_composer = crtc_state->active_planes[1]->composer;
> > +   if (crtc_state->num_active_planes >= 1) {
> > +   act_plane = crtc_state->active_planes[0];
> > +   if (act_plane->base.plane->type == DRM_PLANE_TYPE_PRIMARY)
> > +   primary_composer = act_plane->composer;
> > +   }
> >  
> > if (!primary_composer)
> > return;
> > @@ -222,7 +229,7 @@ void vkms_composer_worker(struct work_struct *work)
> > if (wb_pending)
> > vaddr_out = crtc_state->active_writeback;
> >  
> > -   ret = composite(_out, primary_composer, cursor_composer);
> > +   ret = composite(_out, primary_composer, crtc_state);
> > if (ret) {
> > if (ret == -EINVAL && !wb_pending)
> > kfree(vaddr_out);
> > diff --git a/drivers/gpu/drm/vkms/vkms_drv.c 
> > b/drivers/gpu/drm/vkms/vkms_drv.c
> > index 2173b82606f6..027ffe759440 100644
> > --- a/drivers/gpu/drm/vkms/vkms_drv.c
> > +++ b/drivers/gpu/drm/vkms/vkms_drv.c
> > @@ -44,6 +44,10 @@ static bool enable_writeback = true;
> >  module_param_named(enable_writeback, enable_writeback, bool, 0444);
> >  MODULE_PARM_DESC(enable_writeback, "Enable/Disable writeback connector 
> > support");
> >  
> > +static bool enable_overlay;
> > +module_param_named(enable_overlay, enable_overlay, bool, 0444);
> > +MODULE_PARM_DESC(enable_overlay, "Enable/Disable overlay support");
> > +
> >  DEFINE_DRM_GEM_FOPS(vkms_driver_fops);
> >  
> >  static void vkms_release(struct drm_device *dev)
> > @@ -198,6 +202,7 @@ static int __init vkms_init(void)

Re: [RFC PATCH 3/3] drm/vkms: add overlay support

2021-02-22 Thread Daniel Vetter
On Sat, Feb 20, 2021 at 11:42:12AM -0300, Melissa Wen wrote:
> Add support to overlay plane, in addition to primary and cursor
> planes. In this approach, the plane composition still requires an
> active primary plane and planes are composed associatively in the
> order: (primary <- overlay) <- cursor
> 
> It enables to run the following IGT tests successfully:
> - kms_plane_cursor:
>   - pipe-A-[overlay, primary, viewport]-size-[64, 128, 256]
> - kms_atomic:
>   - plane-overlay-legacy
> and preserves the successful execution of kms_cursor_crc,
> kms_writeback and kms_flip
> 
> Signed-off-by: Melissa Wen 
> ---
>  drivers/gpu/drm/vkms/vkms_composer.c | 27 +--
>  drivers/gpu/drm/vkms/vkms_drv.c  |  5 +
>  drivers/gpu/drm/vkms/vkms_drv.h  |  1 +
>  drivers/gpu/drm/vkms/vkms_output.c   | 17 +++--
>  drivers/gpu/drm/vkms/vkms_plane.c| 20 +++-
>  5 files changed, 53 insertions(+), 17 deletions(-)
> 
> diff --git a/drivers/gpu/drm/vkms/vkms_composer.c 
> b/drivers/gpu/drm/vkms/vkms_composer.c
> index be8f1d33c645..2116da9b5a43 100644
> --- a/drivers/gpu/drm/vkms/vkms_composer.c
> +++ b/drivers/gpu/drm/vkms/vkms_composer.c
> @@ -144,11 +144,12 @@ static void compose_planes(struct vkms_composer 
> *primary_composer,
>  
>  static int composite(void **vaddr_out,
>struct vkms_composer *primary_composer,
> -  struct vkms_composer *cursor_composer)
> +  struct vkms_crtc_state *crtc_state)
>  {
>   struct drm_framebuffer *fb = _composer->fb;
>   struct drm_gem_object *gem_obj = drm_gem_fb_get_obj(fb, 0);
>   struct drm_gem_shmem_object *shmem_obj = to_drm_gem_shmem_obj(gem_obj);
> + int i;
>  
>   if (!*vaddr_out) {
>   *vaddr_out = kzalloc(shmem_obj->base.size, GFP_KERNEL);
> @@ -163,8 +164,14 @@ static int composite(void **vaddr_out,
>  
>   memcpy(*vaddr_out, shmem_obj->vaddr, shmem_obj->base.size);
>  
> - if (cursor_composer)
> - compose_planes(primary_composer, cursor_composer, *vaddr_out);
> + /* If there are other planes besides primary, we consider the active
> +  * planes should be in z-order and compose them associatively:
> +  * ((primary <- overlay) <- cursor)
> +  */
> + for (i = 1; i < crtc_state->num_active_planes; i++)
> + compose_planes(primary_composer,
> +crtc_state->active_planes[i]->composer,
> +*vaddr_out);
>  
>   return 0;
>  }
> @@ -186,7 +193,7 @@ void vkms_composer_worker(struct work_struct *work)
>   struct drm_crtc *crtc = crtc_state->base.crtc;
>   struct vkms_output *out = drm_crtc_to_vkms_output(crtc);
>   struct vkms_composer *primary_composer = NULL;
> - struct vkms_composer *cursor_composer = NULL;
> + struct vkms_plane_state *act_plane = NULL;
>   bool crc_pending, wb_pending;
>   void *vaddr_out = NULL;
>   u32 crc32 = 0;
> @@ -210,11 +217,11 @@ void vkms_composer_worker(struct work_struct *work)
>   if (!crc_pending)
>   return;
>  
> - if (crtc_state->num_active_planes >= 1)
> - primary_composer = crtc_state->active_planes[0]->composer;
> -
> - if (crtc_state->num_active_planes == 2)
> - cursor_composer = crtc_state->active_planes[1]->composer;
> + if (crtc_state->num_active_planes >= 1) {
> + act_plane = crtc_state->active_planes[0];
> + if (act_plane->base.plane->type == DRM_PLANE_TYPE_PRIMARY)
> + primary_composer = act_plane->composer;
> + }
>  
>   if (!primary_composer)
>   return;
> @@ -222,7 +229,7 @@ void vkms_composer_worker(struct work_struct *work)
>   if (wb_pending)
>   vaddr_out = crtc_state->active_writeback;
>  
> - ret = composite(_out, primary_composer, cursor_composer);
> + ret = composite(_out, primary_composer, crtc_state);
>   if (ret) {
>   if (ret == -EINVAL && !wb_pending)
>   kfree(vaddr_out);
> diff --git a/drivers/gpu/drm/vkms/vkms_drv.c b/drivers/gpu/drm/vkms/vkms_drv.c
> index 2173b82606f6..027ffe759440 100644
> --- a/drivers/gpu/drm/vkms/vkms_drv.c
> +++ b/drivers/gpu/drm/vkms/vkms_drv.c
> @@ -44,6 +44,10 @@ static bool enable_writeback = true;
>  module_param_named(enable_writeback, enable_writeback, bool, 0444);
>  MODULE_PARM_DESC(enable_writeback, "Enable/Disable writeback connector 
> support");
>  
> +static bool enable_overlay;
> +module_param_named(enable_overlay, enable_overlay, bool, 0444);
> +MODULE_PARM_DESC(enable_overlay, "Enable/Disable overlay support");
> +
>  DEFINE_DRM_GEM_FOPS(vkms_driver_fops);
>  
>  static void vkms_release(struct drm_device *dev)
> @@ -198,6 +202,7 @@ static int __init vkms_init(void)
>  
>   config->cursor = enable_cursor;
>   config->writeback = enable_writeback;
> + config->overlay = enable_overlay;
>  
>   return