On 5/29/2026 4:46 AM, Sean Paul wrote:
On Mon, May 11, 2026 at 1:56 AM Chaitanya Kumar Borah
<[email protected]> wrote:

Take proper references for hw color blobs (degamma_lut, gamma_lut,
ctm, lut_3d) in intel_plane_duplicate_state() and drop them in
intel_plane_destroy_state().

v2:
- handle blobs in hw state clear

Fixes: 3b7476e786c2 ("drm/i915/color: Add framework to program PRE/POST CSC 
LUT")
Fixes: a78f1b6baf4d ("drm/i915/color: Add framework to program CSC")
Fixes: 65db7a1f9cf7 ("drm/i915/color: Add 3D LUT to color pipeline")

These are in 6.19+, you probably want cc stable as well.


Arggh, I missed it. Thank you for pointing it out. I will add it in the next rebase.

==
Chaitanya

Sean

Reviewed-by: Pranay Samala <[email protected]> #v1
Signed-off-by: Chaitanya Kumar Borah <[email protected]>
---
  drivers/gpu/drm/i915/display/intel_plane.c | 27 ++++++++++++++++++++++
  1 file changed, 27 insertions(+)

diff --git a/drivers/gpu/drm/i915/display/intel_plane.c 
b/drivers/gpu/drm/i915/display/intel_plane.c
index 559eef467dda..54b2c32473cc 100644
--- a/drivers/gpu/drm/i915/display/intel_plane.c
+++ b/drivers/gpu/drm/i915/display/intel_plane.c
@@ -145,6 +145,15 @@ intel_plane_duplicate_state(struct drm_plane *plane)
         if (intel_state->hw.fb)
                 drm_framebuffer_get(intel_state->hw.fb);

+       if (intel_state->hw.degamma_lut)
+               drm_property_blob_get(intel_state->hw.degamma_lut);
+       if (intel_state->hw.gamma_lut)
+               drm_property_blob_get(intel_state->hw.gamma_lut);
+       if (intel_state->hw.ctm)
+               drm_property_blob_get(intel_state->hw.ctm);
+       if (intel_state->hw.lut_3d)
+               drm_property_blob_get(intel_state->hw.lut_3d);
+
         return &intel_state->uapi;
  }

@@ -168,6 +177,16 @@ intel_plane_destroy_state(struct drm_plane *plane,
         __drm_atomic_helper_plane_destroy_state(&plane_state->uapi);
         if (plane_state->hw.fb)
                 drm_framebuffer_put(plane_state->hw.fb);
+
+       if (plane_state->hw.degamma_lut)
+               drm_property_blob_put(plane_state->hw.degamma_lut);
+       if (plane_state->hw.gamma_lut)
+               drm_property_blob_put(plane_state->hw.gamma_lut);
+       if (plane_state->hw.ctm)
+               drm_property_blob_put(plane_state->hw.ctm);
+       if (plane_state->hw.lut_3d)
+               drm_property_blob_put(plane_state->hw.lut_3d);
+
         kfree(plane_state);
  }

@@ -340,6 +359,14 @@ static void intel_plane_clear_hw_state(struct 
intel_plane_state *plane_state)
  {
         if (plane_state->hw.fb)
                 drm_framebuffer_put(plane_state->hw.fb);
+       if (plane_state->hw.degamma_lut)
+               drm_property_blob_put(plane_state->hw.degamma_lut);
+       if (plane_state->hw.gamma_lut)
+               drm_property_blob_put(plane_state->hw.gamma_lut);
+       if (plane_state->hw.ctm)
+               drm_property_blob_put(plane_state->hw.ctm);
+       if (plane_state->hw.lut_3d)
+               drm_property_blob_put(plane_state->hw.lut_3d);

         memset(&plane_state->hw, 0, sizeof(plane_state->hw));
  }
--
2.25.1


Reply via email to