]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
drm/i915: Extract intel_plane_needs_physical()
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Mon, 6 May 2024 12:57:13 +0000 (15:57 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Fri, 10 May 2024 16:41:57 +0000 (19:41 +0300)
Pull the "does this plane need a physical address?" check into
a small helper.

Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240506125718.26001-5-ville.syrjala@linux.intel.com
Reviewed-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_atomic_plane.c
drivers/gpu/drm/i915/display/intel_atomic_plane.h
drivers/gpu/drm/i915/display/intel_fb_pin.c

index b083b985d170dde10580de5aa2d64e9c80ef3b41..27224ecdc94cd6eef72fd4643020fb35b5c7a6cb 100644 (file)
@@ -144,6 +144,14 @@ intel_plane_destroy_state(struct drm_plane *plane,
        kfree(plane_state);
 }
 
+bool intel_plane_needs_physical(struct intel_plane *plane)
+{
+       struct drm_i915_private *i915 = to_i915(plane->base.dev);
+
+       return plane->id == PLANE_CURSOR &&
+               DISPLAY_INFO(i915)->cursor_needs_physical;
+}
+
 unsigned int intel_adjusted_rate(const struct drm_rect *src,
                                 const struct drm_rect *dst,
                                 unsigned int rate)
index 191dad0efc8e6223d7e1700b598d64b050674ef7..e7a0699f17c8ddf20e89e082ec5aed4c65fd3e14 100644 (file)
@@ -66,5 +66,6 @@ int intel_plane_check_src_coordinates(struct intel_plane_state *plane_state);
 void intel_plane_set_invisible(struct intel_crtc_state *crtc_state,
                               struct intel_plane_state *plane_state);
 void intel_plane_helper_add(struct intel_plane *plane);
+bool intel_plane_needs_physical(struct intel_plane *plane);
 
 #endif /* __INTEL_ATOMIC_PLANE_H__ */
index 2b50c1946c63227675ef69333a1b329b50410329..5b71d94881841a9790b65c27b9ca35a02e9e3949 100644 (file)
@@ -11,6 +11,7 @@
 #include "gem/i915_gem_object.h"
 
 #include "i915_drv.h"
+#include "intel_atomic_plane.h"
 #include "intel_display_types.h"
 #include "intel_dpt.h"
 #include "intel_fb.h"
@@ -236,15 +237,11 @@ void intel_unpin_fb_vma(struct i915_vma *vma, unsigned long flags)
 int intel_plane_pin_fb(struct intel_plane_state *plane_state)
 {
        struct intel_plane *plane = to_intel_plane(plane_state->uapi.plane);
-       struct drm_i915_private *dev_priv = to_i915(plane->base.dev);
        struct drm_framebuffer *fb = plane_state->hw.fb;
        struct i915_vma *vma;
-       bool phys_cursor =
-               plane->id == PLANE_CURSOR &&
-               DISPLAY_INFO(dev_priv)->cursor_needs_physical;
 
        if (!intel_fb_uses_dpt(fb)) {
-               vma = intel_pin_and_fence_fb_obj(fb, phys_cursor,
+               vma = intel_pin_and_fence_fb_obj(fb, intel_plane_needs_physical(plane),
                                                 &plane_state->view.gtt,
                                                 intel_plane_uses_fence(plane_state),
                                                 &plane_state->flags);
@@ -259,7 +256,7 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state)
                 * will trigger might_sleep() even if it won't actually sleep,
                 * which is the case when the fb has already been pinned.
                 */
-               if (phys_cursor)
+               if (intel_plane_needs_physical(plane))
                        plane_state->phys_dma_addr =
                                i915_gem_object_get_dma_address(intel_fb_obj(fb), 0);
        } else {