drm/sun4i: Unify sun8i_*_layer structs
authorOndrej Jirman <megi@xff.cz>
Sat, 24 Feb 2024 15:05:58 +0000 (16:05 +0100)
committerMaxime Ripard <mripard@kernel.org>
Mon, 10 Jun 2024 10:44:40 +0000 (12:44 +0200)
These structs are identical, use a single struct to represent private
data for the DRM plane. This is a preparation for configuring layer
routing from the CRTC (mixer) instead of current approach of setting
up routing from individual layer's atomic_update callback.

Signed-off-by: Ondrej Jirman <megi@xff.cz>
Reviewed-by: Maxime Ripard <mripard@kernel.org>
Reviewed-by: Jernej Skrabec <jernej.skrabec@gmail.com>
Link: https://lore.kernel.org/r/20240224150604.3855534-2-megi@xff.cz
Signed-off-by: Maxime Ripard <mripard@kernel.org>
drivers/gpu/drm/sun4i/sun8i_mixer.c
drivers/gpu/drm/sun4i/sun8i_mixer.h
drivers/gpu/drm/sun4i/sun8i_ui_layer.c
drivers/gpu/drm/sun4i/sun8i_ui_layer.h
drivers/gpu/drm/sun4i/sun8i_vi_layer.c
drivers/gpu/drm/sun4i/sun8i_vi_layer.h

index 01382860aaeea1b0233befdb52acc9ae378ffe46..1e681314e379bc22e995d5d040e197c7d996429f 100644 (file)
@@ -271,7 +271,7 @@ static struct drm_plane **sun8i_layers_init(struct drm_device *drm,
                return ERR_PTR(-ENOMEM);
 
        for (i = 0; i < mixer->cfg->vi_num; i++) {
-               struct sun8i_vi_layer *layer;
+               struct sun8i_layer *layer;
 
                layer = sun8i_vi_layer_init_one(drm, mixer, i);
                if (IS_ERR(layer)) {
@@ -284,7 +284,7 @@ static struct drm_plane **sun8i_layers_init(struct drm_device *drm,
        }
 
        for (i = 0; i < mixer->cfg->ui_num; i++) {
-               struct sun8i_ui_layer *layer;
+               struct sun8i_layer *layer;
 
                layer = sun8i_ui_layer_init_one(drm, mixer, i);
                if (IS_ERR(layer)) {
index 85c94884fb9a4b54a9f3aaa9efff24031fef40e5..5a610ee30301b78085496a0b8c1c88f0ec21ccef 100644 (file)
@@ -9,6 +9,7 @@
 #include <linux/clk.h>
 #include <linux/regmap.h>
 #include <linux/reset.h>
+#include <drm/drm_plane.h>
 
 #include "sunxi_engine.h"
 
@@ -185,6 +186,19 @@ struct sun8i_mixer {
        struct clk                      *mod_clk;
 };
 
+struct sun8i_layer {
+       struct drm_plane        plane;
+       struct sun8i_mixer      *mixer;
+       int                     channel;
+       int                     overlay;
+};
+
+static inline struct sun8i_layer *
+plane_to_sun8i_layer(struct drm_plane *plane)
+{
+       return container_of(plane, struct sun8i_layer, plane);
+}
+
 static inline struct sun8i_mixer *
 engine_to_sun8i_mixer(struct sunxi_engine *engine)
 {
index ca75ca0835a636ba287a78124cafb09a2c8d5a45..248fbb606ede085fa069a95cea3709e9892562e2 100644 (file)
@@ -232,7 +232,7 @@ static int sun8i_ui_layer_atomic_check(struct drm_plane *plane,
 {
        struct drm_plane_state *new_plane_state = drm_atomic_get_new_plane_state(state,
                                                                                 plane);
-       struct sun8i_ui_layer *layer = plane_to_sun8i_ui_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_layer(plane);
        struct drm_crtc *crtc = new_plane_state->crtc;
        struct drm_crtc_state *crtc_state;
        int min_scale, max_scale;
@@ -264,7 +264,7 @@ static void sun8i_ui_layer_atomic_disable(struct drm_plane *plane,
 {
        struct drm_plane_state *old_state = drm_atomic_get_old_plane_state(state,
                                                                           plane);
-       struct sun8i_ui_layer *layer = plane_to_sun8i_ui_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_layer(plane);
        unsigned int old_zpos = old_state->normalized_zpos;
        struct sun8i_mixer *mixer = layer->mixer;
 
@@ -279,7 +279,7 @@ static void sun8i_ui_layer_atomic_update(struct drm_plane *plane,
                                                                           plane);
        struct drm_plane_state *new_state = drm_atomic_get_new_plane_state(state,
                                                                           plane);
-       struct sun8i_ui_layer *layer = plane_to_sun8i_ui_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_layer(plane);
        unsigned int zpos = new_state->normalized_zpos;
        unsigned int old_zpos = old_state->normalized_zpos;
        struct sun8i_mixer *mixer = layer->mixer;
@@ -345,13 +345,13 @@ static const uint64_t sun8i_layer_modifiers[] = {
        DRM_FORMAT_MOD_INVALID
 };
 
-struct sun8i_ui_layer *sun8i_ui_layer_init_one(struct drm_device *drm,
-                                              struct sun8i_mixer *mixer,
-                                              int index)
+struct sun8i_layer *sun8i_ui_layer_init_one(struct drm_device *drm,
+                                           struct sun8i_mixer *mixer,
+                                           int index)
 {
        enum drm_plane_type type = DRM_PLANE_TYPE_OVERLAY;
        int channel = mixer->cfg->vi_num + index;
-       struct sun8i_ui_layer *layer;
+       struct sun8i_layer *layer;
        unsigned int plane_cnt;
        int ret;
 
index e3e32ee1178d83ceab028c6a784342c73548cbc9..83892f6ff2112d4c511bcd4fd88f169604d7fc00 100644 (file)
 #define SUN8I_MIXER_CHAN_UI_LAYER_ATTR_ALPHA_MODE_COMBINED     ((2) << 1)
 
 struct sun8i_mixer;
+struct sun8i_layer;
 
-struct sun8i_ui_layer {
-       struct drm_plane        plane;
-       struct sun8i_mixer      *mixer;
-       int                     channel;
-       int                     overlay;
-};
-
-static inline struct sun8i_ui_layer *
-plane_to_sun8i_ui_layer(struct drm_plane *plane)
-{
-       return container_of(plane, struct sun8i_ui_layer, plane);
-}
-
-struct sun8i_ui_layer *sun8i_ui_layer_init_one(struct drm_device *drm,
-                                              struct sun8i_mixer *mixer,
-                                              int index);
+struct sun8i_layer *sun8i_ui_layer_init_one(struct drm_device *drm,
+                                           struct sun8i_mixer *mixer,
+                                           int index);
 #endif /* _SUN8I_UI_LAYER_H_ */
index f9c0a56d3a148efb287b5cd764bf1b3a9b697fe3..0c0f1ac80517f3c8cbc2c3d7b71191c61b9b13f2 100644 (file)
@@ -366,7 +366,7 @@ static int sun8i_vi_layer_atomic_check(struct drm_plane *plane,
 {
        struct drm_plane_state *new_plane_state = drm_atomic_get_new_plane_state(state,
                                                                                 plane);
-       struct sun8i_vi_layer *layer = plane_to_sun8i_vi_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_layer(plane);
        struct drm_crtc *crtc = new_plane_state->crtc;
        struct drm_crtc_state *crtc_state;
        int min_scale, max_scale;
@@ -398,7 +398,7 @@ static void sun8i_vi_layer_atomic_disable(struct drm_plane *plane,
 {
        struct drm_plane_state *old_state = drm_atomic_get_old_plane_state(state,
                                                                           plane);
-       struct sun8i_vi_layer *layer = plane_to_sun8i_vi_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_vi_layer(plane);
        unsigned int old_zpos = old_state->normalized_zpos;
        struct sun8i_mixer *mixer = layer->mixer;
 
@@ -413,7 +413,7 @@ static void sun8i_vi_layer_atomic_update(struct drm_plane *plane,
                                                                           plane);
        struct drm_plane_state *new_state = drm_atomic_get_new_plane_state(state,
                                                                           plane);
-       struct sun8i_vi_layer *layer = plane_to_sun8i_vi_layer(plane);
+       struct sun8i_layer *layer = plane_to_sun8i_layer(plane);
        unsigned int zpos = new_state->normalized_zpos;
        unsigned int old_zpos = old_state->normalized_zpos;
        struct sun8i_mixer *mixer = layer->mixer;
@@ -539,14 +539,14 @@ static const uint64_t sun8i_layer_modifiers[] = {
        DRM_FORMAT_MOD_INVALID
 };
 
-struct sun8i_vi_layer *sun8i_vi_layer_init_one(struct drm_device *drm,
-                                              struct sun8i_mixer *mixer,
-                                              int index)
+struct sun8i_layer *sun8i_vi_layer_init_one(struct drm_device *drm,
+                                           struct sun8i_mixer *mixer,
+                                           int index)
 {
        enum drm_plane_type type = DRM_PLANE_TYPE_OVERLAY;
        u32 supported_encodings, supported_ranges;
        unsigned int plane_cnt, format_count;
-       struct sun8i_vi_layer *layer;
+       struct sun8i_layer *layer;
        const u32 *formats;
        int ret;
 
index 48c399e1c86dcfc5d075ab8e22f0f5480d121e61..655440cdc78f6f58c3ad74c72e259b2bc45510ca 100644 (file)
 #define SUN8I_MIXER_CHAN_VI_DS_M(x)                    ((x) << 0)
 
 struct sun8i_mixer;
+struct sun8i_layer;
 
-struct sun8i_vi_layer {
-       struct drm_plane        plane;
-       struct sun8i_mixer      *mixer;
-       int                     channel;
-       int                     overlay;
-};
-
-static inline struct sun8i_vi_layer *
-plane_to_sun8i_vi_layer(struct drm_plane *plane)
-{
-       return container_of(plane, struct sun8i_vi_layer, plane);
-}
-
-struct sun8i_vi_layer *sun8i_vi_layer_init_one(struct drm_device *drm,
-                                              struct sun8i_mixer *mixer,
-                                              int index);
+struct sun8i_layer *sun8i_vi_layer_init_one(struct drm_device *drm,
+                                           struct sun8i_mixer *mixer,
+                                           int index);
 #endif /* _SUN8I_VI_LAYER_H_ */