lede/target/linux/bcm27xx/patches-6.12/950-0658-drm-vc4-Do-not-include-writeback-conn-load-in-load-t.patch
=?UTF-8?q?=C3=81lvaro=20Fern=C3=A1ndez=20Rojas?= d81c03f05e bcm27xx: add 6.12 patches from RPi repo
These patches were generated from:
https://github.com/raspberrypi/linux/commits/rpi-6.12.y
With the following command:
git format-patch -N v6.12.27..HEAD
(HEAD -> 8d3206ee456a5ecdf9ddbfd8e5e231e4f0cd716e)

Exceptions:
- (def)configs patches
- github workflows patches
- applied & reverted patches
- readme patches
- wireless patches

Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
2025-06-20 17:01:06 +08:00

48 lines
1.7 KiB
Diff

From c1a3b676952a067df3a3e61df6f60c004b2abac6 Mon Sep 17 00:00:00 2001
From: Dave Stevenson <dave.stevenson@raspberrypi.com>
Date: Mon, 9 Sep 2024 17:28:00 +0100
Subject: [PATCH] drm/vc4: Do not include writeback conn load in load tracker
The transposer/writeback connector should be running with a
lower priority, so shouldn't be factored into the load
calculations.
Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com>
---
drivers/gpu/drm/vc4/vc4_kms.c | 17 +++++++++++++----
1 file changed, 13 insertions(+), 4 deletions(-)
--- a/drivers/gpu/drm/vc4/vc4_kms.c
+++ b/drivers/gpu/drm/vc4/vc4_kms.c
@@ -660,17 +660,26 @@ static int vc4_load_tracker_atomic_check
for_each_oldnew_plane_in_state(state, plane, old_plane_state,
new_plane_state, i) {
struct vc4_plane_state *vc4_plane_state;
+ struct vc4_crtc *vc4_crtc;
if (old_plane_state->fb && old_plane_state->crtc) {
vc4_plane_state = to_vc4_plane_state(old_plane_state);
- load_state->membus_load -= vc4_plane_state->membus_load;
- load_state->hvs_load -= vc4_plane_state->hvs_load;
+ vc4_crtc = to_vc4_crtc(old_plane_state->crtc);
+
+ if (!vc4_crtc->feeds_txp) {
+ load_state->membus_load -= vc4_plane_state->membus_load;
+ load_state->hvs_load -= vc4_plane_state->hvs_load;
+ }
}
if (new_plane_state->fb && new_plane_state->crtc) {
vc4_plane_state = to_vc4_plane_state(new_plane_state);
- load_state->membus_load += vc4_plane_state->membus_load;
- load_state->hvs_load += vc4_plane_state->hvs_load;
+ vc4_crtc = to_vc4_crtc(new_plane_state->crtc);
+
+ if (!vc4_crtc->feeds_txp) {
+ load_state->membus_load += vc4_plane_state->membus_load;
+ load_state->hvs_load += vc4_plane_state->hvs_load;
+ }
}
}