From d68b28699c69f5b4ac4b9981c8b2c15fb9549db3 Mon Sep 17 00:00:00 2001 From: Dave Stevenson Date: Tue, 20 Aug 2024 16:25:10 +0100 Subject: [PATCH 1/4] drm: Set non-desktop property to true for writeback and virtual connectors The non-desktop property "Indicates the output should be ignored for purposes of displaying a standard desktop environment or console." That sounds like it should be true for all writeback and virtual connectors as you shouldn't render a desktop to them, so set it by default. Signed-off-by: Dave Stevenson --- drivers/gpu/drm/drm_connector.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/drm_connector.c b/drivers/gpu/drm/drm_connector.c index 476ea750acf4a1..b8696651dedf82 100644 --- a/drivers/gpu/drm/drm_connector.c +++ b/drivers/gpu/drm/drm_connector.c @@ -361,7 +361,8 @@ static int __drm_connector_init(struct drm_device *dev, drm_object_attach_property(&connector->base, config->non_desktop_property, - 0); + (connector_type != DRM_MODE_CONNECTOR_VIRTUAL && + connector_type != DRM_MODE_CONNECTOR_WRITEBACK) ? 0 : 1; drm_object_attach_property(&connector->base, config->tile_property, 0); From 7fbf2c6857b341224c8c3e5492248b2f505098f2 Mon Sep 17 00:00:00 2001 From: Dave Stevenson Date: Fri, 21 Oct 2022 14:26:12 +0100 Subject: [PATCH 2/4] drm: Increase plane_mask to 64bit. The limit of 32 planes per DRM device is dictated by the use of planes_mask returning a u32. Change to a u64 such that 64 planes can be supported by a device. Signed-off-by: Dave Stevenson --- drivers/gpu/drm/drm_atomic.c | 2 +- drivers/gpu/drm/drm_framebuffer.c | 2 +- drivers/gpu/drm/drm_mode_config.c | 2 +- drivers/gpu/drm/drm_plane.c | 2 +- drivers/gpu/drm/imx/ipuv3/ipuv3-crtc.c | 2 +- include/drm/drm_crtc.h | 2 +- include/drm/drm_plane.h | 4 ++-- 7 files changed, 8 insertions(+), 8 deletions(-) diff --git a/drivers/gpu/drm/drm_atomic.c b/drivers/gpu/drm/drm_atomic.c index c277b198fa3fa2..c472c663bc139f 100644 --- a/drivers/gpu/drm/drm_atomic.c +++ b/drivers/gpu/drm/drm_atomic.c @@ -451,7 +451,7 @@ static void drm_atomic_crtc_print_state(struct drm_printer *p, drm_printf(p, "\tactive_changed=%d\n", state->active_changed); drm_printf(p, "\tconnectors_changed=%d\n", state->connectors_changed); drm_printf(p, "\tcolor_mgmt_changed=%d\n", state->color_mgmt_changed); - drm_printf(p, "\tplane_mask=%x\n", state->plane_mask); + drm_printf(p, "\tplane_mask=%llx\n", state->plane_mask); drm_printf(p, "\tconnector_mask=%x\n", state->connector_mask); drm_printf(p, "\tencoder_mask=%x\n", state->encoder_mask); drm_printf(p, "\tmode: " DRM_MODE_FMT "\n", DRM_MODE_ARG(&state->mode)); diff --git a/drivers/gpu/drm/drm_framebuffer.c b/drivers/gpu/drm/drm_framebuffer.c index 1955eaeba0ab7c..8e53a46b570874 100644 --- a/drivers/gpu/drm/drm_framebuffer.c +++ b/drivers/gpu/drm/drm_framebuffer.c @@ -959,7 +959,7 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) struct drm_connector *conn __maybe_unused; struct drm_connector_state *conn_state; int i, ret; - unsigned plane_mask; + u64 plane_mask; bool disable_crtcs = false; retry_disable: diff --git a/drivers/gpu/drm/drm_mode_config.c b/drivers/gpu/drm/drm_mode_config.c index 87eb591fe9b5b8..02d1f7afbbe2e3 100644 --- a/drivers/gpu/drm/drm_mode_config.c +++ b/drivers/gpu/drm/drm_mode_config.c @@ -636,7 +636,7 @@ void drm_mode_config_validate(struct drm_device *dev) struct drm_encoder *encoder; struct drm_crtc *crtc; struct drm_plane *plane; - u32 primary_with_crtc = 0, cursor_with_crtc = 0; + u64 primary_with_crtc = 0, cursor_with_crtc = 0; unsigned int num_primary = 0; if (!drm_core_check_feature(dev, DRIVER_MODESET)) diff --git a/drivers/gpu/drm/drm_plane.c b/drivers/gpu/drm/drm_plane.c index 311e179904a2ab..38901eb3a5ad2a 100644 --- a/drivers/gpu/drm/drm_plane.c +++ b/drivers/gpu/drm/drm_plane.c @@ -249,7 +249,7 @@ static int __drm_universal_plane_init(struct drm_device *dev, int ret; /* plane index is used with 32bit bitmasks */ - if (WARN_ON(config->num_total_plane >= 32)) + if (WARN_ON(config->num_total_plane >= 64)) return -EINVAL; /* diff --git a/drivers/gpu/drm/imx/ipuv3/ipuv3-crtc.c b/drivers/gpu/drm/imx/ipuv3/ipuv3-crtc.c index 89585b31b985e1..45213c228d3323 100644 --- a/drivers/gpu/drm/imx/ipuv3/ipuv3-crtc.c +++ b/drivers/gpu/drm/imx/ipuv3/ipuv3-crtc.c @@ -230,7 +230,7 @@ static int ipu_crtc_atomic_check(struct drm_crtc *crtc, { struct drm_crtc_state *crtc_state = drm_atomic_get_new_crtc_state(state, crtc); - u32 primary_plane_mask = drm_plane_mask(crtc->primary); + u64 primary_plane_mask = drm_plane_mask(crtc->primary); if (crtc_state->active && (primary_plane_mask & crtc_state->plane_mask) == 0) return -EINVAL; diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h index 8b48a1974da314..dd7ad1a44717e8 100644 --- a/include/drm/drm_crtc.h +++ b/include/drm/drm_crtc.h @@ -192,7 +192,7 @@ struct drm_crtc_state { * @plane_mask: Bitmask of drm_plane_mask(plane) of planes attached to * this CRTC. */ - u32 plane_mask; + u64 plane_mask; /** * @connector_mask: Bitmask of drm_connector_mask(connector) of diff --git a/include/drm/drm_plane.h b/include/drm/drm_plane.h index e4000d2f148d43..5cf70d548e29b8 100644 --- a/include/drm/drm_plane.h +++ b/include/drm/drm_plane.h @@ -915,9 +915,9 @@ static inline unsigned int drm_plane_index(const struct drm_plane *plane) * drm_plane_mask - find the mask of a registered plane * @plane: plane to find mask for */ -static inline u32 drm_plane_mask(const struct drm_plane *plane) +static inline u64 drm_plane_mask(const struct drm_plane *plane) { - return 1 << drm_plane_index(plane); + return 1ULL << drm_plane_index(plane); } struct drm_plane * drm_plane_from_index(struct drm_device *dev, int idx); From fa6c4a81bee4c4aee223735e31a7f2e8f9c8658b Mon Sep 17 00:00:00 2001 From: Dave Stevenson Date: Fri, 21 Oct 2022 14:27:45 +0100 Subject: [PATCH 3/4] drm/vc4: Increase number of overlay planes from 16 to 48 The HVS can accept an arbitrary number of planes, provided that the overall pixel read load is within limits, and the display list can fit into the dlist memory. Now that DRM will support 64 planes per device, increase the number of overlay planes from 16 to 48 so that the dlist complexity can be increased (eg 4x4 video wall on each of 3 displays). Signed-off-by: Dave Stevenson --- drivers/gpu/drm/drm_connector.c | 2 +- drivers/gpu/drm/vc4/vc4_plane.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/drm_connector.c b/drivers/gpu/drm/drm_connector.c index b8696651dedf82..09cd1df2d6c4a4 100644 --- a/drivers/gpu/drm/drm_connector.c +++ b/drivers/gpu/drm/drm_connector.c @@ -362,7 +362,7 @@ static int __drm_connector_init(struct drm_device *dev, drm_object_attach_property(&connector->base, config->non_desktop_property, (connector_type != DRM_MODE_CONNECTOR_VIRTUAL && - connector_type != DRM_MODE_CONNECTOR_WRITEBACK) ? 0 : 1; + connector_type != DRM_MODE_CONNECTOR_WRITEBACK) ? 0 : 1); drm_object_attach_property(&connector->base, config->tile_property, 0); diff --git a/drivers/gpu/drm/vc4/vc4_plane.c b/drivers/gpu/drm/vc4/vc4_plane.c index 2d1039aa2dcf03..96235f8d94da4f 100644 --- a/drivers/gpu/drm/vc4/vc4_plane.c +++ b/drivers/gpu/drm/vc4/vc4_plane.c @@ -2450,7 +2450,7 @@ struct drm_plane *vc4_plane_init(struct drm_device *dev, return plane; } -#define VC4_NUM_OVERLAY_PLANES 16 +#define VC4_NUM_OVERLAY_PLANES 48 int vc4_plane_create_additional_planes(struct drm_device *drm) { From 5225183c3901ab935c96ef062a08c9348984fd69 Mon Sep 17 00:00:00 2001 From: Dave Stevenson Date: Tue, 15 Aug 2023 15:44:34 +0100 Subject: [PATCH 4/4] drm/vc4: Assign 32 overlay planes to writeback only Instead of having 48 generic overlay planes, assign 32 to the writeback connector so that there is no ambiguity in wlroots when trying to find a plane for composition using the writeback connector vs display. Signed-off-by: Dave Stevenson --- drivers/gpu/drm/vc4/vc4_plane.c | 34 +++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/vc4/vc4_plane.c b/drivers/gpu/drm/vc4/vc4_plane.c index 96235f8d94da4f..bbdb531f494b73 100644 --- a/drivers/gpu/drm/vc4/vc4_plane.c +++ b/drivers/gpu/drm/vc4/vc4_plane.c @@ -2450,13 +2450,28 @@ struct drm_plane *vc4_plane_init(struct drm_device *dev, return plane; } -#define VC4_NUM_OVERLAY_PLANES 48 +#define VC4_NUM_OVERLAY_PLANES 16 +#define VC4_NUM_TXP_OVERLAY_PLANES 32 int vc4_plane_create_additional_planes(struct drm_device *drm) { struct drm_plane *cursor_plane; struct drm_crtc *crtc; unsigned int i; + struct drm_crtc *txp_crtc; + uint32_t non_txp_crtc_mask; + + drm_for_each_crtc(crtc, drm) { + struct vc4_crtc *vc4_crtc = to_vc4_crtc(crtc); + + if (vc4_crtc->feeds_txp) { + txp_crtc = crtc; + break; + } + } + + non_txp_crtc_mask = GENMASK(drm->mode_config.num_crtc - 1, 0) - + drm_crtc_mask(txp_crtc); /* Set up some arbitrary number of planes. We're not limited * by a set number of physical registers, just the space in @@ -2470,7 +2485,22 @@ int vc4_plane_create_additional_planes(struct drm_device *drm) for (i = 0; i < VC4_NUM_OVERLAY_PLANES; i++) { struct drm_plane *plane = vc4_plane_init(drm, DRM_PLANE_TYPE_OVERLAY, - GENMASK(drm->mode_config.num_crtc - 1, 0)); + non_txp_crtc_mask); + + if (IS_ERR(plane)) + continue; + + /* Create zpos property. Max of all the overlays + 1 primary + + * 1 cursor plane on a crtc. + */ + drm_plane_create_zpos_property(plane, i + 1, 1, + VC4_NUM_OVERLAY_PLANES + 1); + } + + for (i = 0; i < VC4_NUM_TXP_OVERLAY_PLANES; i++) { + struct drm_plane *plane = + vc4_plane_init(drm, DRM_PLANE_TYPE_OVERLAY, + drm_crtc_mask(txp_crtc)); if (IS_ERR(plane)) continue;