From: Varad Gautam <varad.gau...@collabora.com>

cirrus exposes one legacy primary plane tied to the crtc. convert this to
use the universal planes interface in preparation for atomic.

Signed-off-by: Varad Gautam <varad.gau...@collabora.com>
---
 drivers/gpu/drm/cirrus/cirrus_mode.c | 44 ++++++++++++++++++++++++++++++++++--
 1 file changed, 42 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/cirrus/cirrus_mode.c 
b/drivers/gpu/drm/cirrus/cirrus_mode.c
index 6032978a2797..2994dd391850 100644
--- a/drivers/gpu/drm/cirrus/cirrus_mode.c
+++ b/drivers/gpu/drm/cirrus/cirrus_mode.c
@@ -358,12 +358,29 @@ static const struct drm_crtc_helper_funcs 
cirrus_helper_funcs = {
        .load_lut = cirrus_crtc_load_lut,
 };
 
+static const uint32_t cirrus_plane_formats[] = {
+       DRM_FORMAT_XRGB8888,
+       DRM_FORMAT_ARGB8888,
+       DRM_FORMAT_RGB888,
+       DRM_FORMAT_RGB565,
+};
+
+static const struct drm_plane_funcs cirrus_plane_funcs = {
+       .update_plane   = drm_primary_helper_update,
+       .disable_plane  = drm_primary_helper_disable,
+       .destroy        = drm_primary_helper_destroy,
+};
+
+static const struct drm_plane_helper_funcs cirrus_plane_helper_funcs = {
+};
+
 /* CRTC setup */
 static void cirrus_crtc_init(struct drm_device *dev)
 {
        struct cirrus_device *cdev = dev->dev_private;
        struct cirrus_crtc *cirrus_crtc;
-       int i;
+       struct drm_plane *primary;
+       int i, ret;
 
        cirrus_crtc = kzalloc(sizeof(struct cirrus_crtc) +
                              (CIRRUSFB_CONN_LIMIT * sizeof(struct 
drm_connector *)),
@@ -372,8 +389,23 @@ static void cirrus_crtc_init(struct drm_device *dev)
        if (cirrus_crtc == NULL)
                return;
 
-       drm_crtc_init(dev, &cirrus_crtc->base, &cirrus_crtc_funcs);
+       primary = kzalloc(sizeof(*primary), GFP_KERNEL);
+       if (primary == NULL)
+               goto cleanup_crtc;
 
+       drm_plane_helper_add(primary, &cirrus_plane_helper_funcs);
+       ret = drm_universal_plane_init(dev, primary, 1,
+                                      &cirrus_plane_funcs,
+                                      cirrus_plane_formats,
+                                      ARRAY_SIZE(cirrus_plane_formats),
+                                      DRM_PLANE_TYPE_PRIMARY, NULL);
+       if (ret)
+               goto cleanup;
+
+       ret = drm_crtc_init_with_planes(dev, &cirrus_crtc->base, primary, NULL,
+                                       &cirrus_crtc_funcs, NULL);
+       if (ret)
+               goto cleanup;
        drm_mode_crtc_set_gamma_size(&cirrus_crtc->base, CIRRUS_LUT_SIZE);
        cdev->mode_info.crtc = cirrus_crtc;
 
@@ -384,6 +416,14 @@ static void cirrus_crtc_init(struct drm_device *dev)
        }
 
        drm_crtc_helper_add(&cirrus_crtc->base, &cirrus_helper_funcs);
+       return;
+
+cleanup:
+       drm_plane_cleanup(primary);
+       kfree(primary);
+cleanup_crtc:
+       kfree(cirrus_crtc);
+       return;
 }
 
 /** Sets the color ramps on behalf of fbcon */
-- 
2.13.1

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to