[PATCH 09/14] drm/cirrus: use universal plane interfaces for primary plane
Gabriel Krisman Bertazi
krisman at collabora.co.uk
Mon Sep 4 11:14:41 UTC 2017
Varad Gautam <varadgautam at gmail.com> writes:
> From: Varad Gautam <varad.gautam at 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.gautam at 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;
If this fails early enough, you can't call drm_plane_cleanup, otherwise
you'll hit an oops.
Otherwise, looks good. with the above change, please add:
Reviewed-by: Gabriel Krisman Bertazi <krisman at collabora.co.uk>
> +
> + 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 */
--
Gabriel Krisman Bertazi
More information about the dri-devel
mailing list