drm/vc4: plane: Move planes creation to its own function
authorMaxime Ripard <maxime@cerno.tech>
Wed, 27 May 2020 15:47:47 +0000 (17:47 +0200)
committerMaxime Ripard <maxime@cerno.tech>
Wed, 10 Jun 2020 09:09:37 +0000 (11:09 +0200)
The planes so far were created as part of the CRTC binding code with
each planes created associated only to one CRTC. However, the hardware
in the vc4 doesn't really have such constraint and can be used with any
CRTC.

In order to rework this, let's first move the overlay and cursor planes
creation to a function of its own.

Reviewed-by: Eric Anholt <eric@anholt.net>
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Link: https://patchwork.freedesktop.org/patch/msgid/a378ea56214179f1f25fcd36ecc69511edd1e790.1590594512.git-series.maxime@cerno.tech
drivers/gpu/drm/vc4/vc4_crtc.c
drivers/gpu/drm/vc4/vc4_drv.h
drivers/gpu/drm/vc4/vc4_plane.c

index 1208258ad3b2b0620c0c79f4ab559850b82c7ebf..63560eb2bffba0132b7f90d517773e7ca37e606b 100644 (file)
@@ -1130,7 +1130,7 @@ static int vc4_crtc_bind(struct device *dev, struct device *master, void *data)
        struct drm_device *drm = dev_get_drvdata(master);
        struct vc4_crtc *vc4_crtc;
        struct drm_crtc *crtc;
-       struct drm_plane *primary_plane, *cursor_plane, *destroy_plane, *temp;
+       struct drm_plane *primary_plane, *destroy_plane, *temp;
        const struct of_device_id *match;
        int ret, i;
 
@@ -1178,34 +1178,9 @@ static int vc4_crtc_bind(struct device *dev, struct device *master, void *data)
         */
        drm_crtc_enable_color_mgmt(crtc, 0, true, crtc->gamma_size);
 
-       /* Set up some arbitrary number of planes.  We're not limited
-        * by a set number of physical registers, just the space in
-        * the HVS (16k) and how small an plane can be (28 bytes).
-        * However, each plane we set up takes up some memory, and
-        * increases the cost of looping over planes, which atomic
-        * modesetting does quite a bit.  As a result, we pick a
-        * modest number of planes to expose, that should hopefully
-        * still cover any sane usecase.
-        */
-       for (i = 0; i < 8; i++) {
-               struct drm_plane *plane =
-                       vc4_plane_init(drm, DRM_PLANE_TYPE_OVERLAY);
-
-               if (IS_ERR(plane))
-                       continue;
-
-               plane->possible_crtcs = drm_crtc_mask(crtc);
-       }
-
-       /* Set up the legacy cursor after overlay initialization,
-        * since we overlay planes on the CRTC in the order they were
-        * initialized.
-        */
-       cursor_plane = vc4_plane_init(drm, DRM_PLANE_TYPE_CURSOR);
-       if (!IS_ERR(cursor_plane)) {
-               cursor_plane->possible_crtcs = drm_crtc_mask(crtc);
-               crtc->cursor = cursor_plane;
-       }
+       ret = vc4_plane_create_additional_planes(drm, crtc);
+       if (ret)
+               goto err_destroy_planes;
 
        vc4_crtc_get_cob_allocation(vc4_crtc);
 
index 6f50a91e3933a1ef3f214fd7a433f31ba77c799e..bb3416e7624a214cbcc4bfe314c74cdb873cb950 100644 (file)
@@ -846,6 +846,8 @@ int vc4_kms_load(struct drm_device *dev);
 /* vc4_plane.c */
 struct drm_plane *vc4_plane_init(struct drm_device *dev,
                                 enum drm_plane_type type);
+int vc4_plane_create_additional_planes(struct drm_device *dev,
+                                      struct drm_crtc *crtc);
 u32 vc4_plane_write_dlist(struct drm_plane *plane, u32 __iomem *dlist);
 u32 vc4_plane_dlist_size(const struct drm_plane_state *state);
 void vc4_plane_async_set_fb(struct drm_plane *plane,
index 91e408f7a56eb5ef8dfed67bdc337036d5e58be2..ea559b3288f5528e56ebd88d26be9d906bc840bd 100644 (file)
@@ -1267,3 +1267,41 @@ struct drm_plane *vc4_plane_init(struct drm_device *dev,
 
        return plane;
 }
+
+int vc4_plane_create_additional_planes(struct drm_device *drm,
+                                      struct drm_crtc *crtc)
+{
+       struct drm_plane *cursor_plane;
+       unsigned int i;
+
+       /* Set up some arbitrary number of planes.  We're not limited
+        * by a set number of physical registers, just the space in
+        * the HVS (16k) and how small an plane can be (28 bytes).
+        * However, each plane we set up takes up some memory, and
+        * increases the cost of looping over planes, which atomic
+        * modesetting does quite a bit.  As a result, we pick a
+        * modest number of planes to expose, that should hopefully
+        * still cover any sane usecase.
+        */
+       for (i = 0; i < 8; i++) {
+               struct drm_plane *plane =
+                       vc4_plane_init(drm, DRM_PLANE_TYPE_OVERLAY);
+
+               if (IS_ERR(plane))
+                       continue;
+
+               plane->possible_crtcs = drm_crtc_mask(crtc);
+       }
+
+       /* Set up the legacy cursor after overlay initialization,
+        * since we overlay planes on the CRTC in the order they were
+        * initialized.
+        */
+       cursor_plane = vc4_plane_init(drm, DRM_PLANE_TYPE_CURSOR);
+       if (!IS_ERR(cursor_plane)) {
+               cursor_plane->possible_crtcs = drm_crtc_mask(crtc);
+               crtc->cursor = cursor_plane;
+       }
+
+       return 0;
+}