]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/crtc: move crtc initialization loop to intel_crtc.c
authorJani Nikula <jani.nikula@intel.com>
Thu, 4 Dec 2025 14:32:35 +0000 (16:32 +0200)
committerJani Nikula <jani.nikula@intel.com>
Tue, 9 Dec 2025 12:43:25 +0000 (14:43 +0200)
intel_display_driver_probe_nogem() is too high of an abstraction level
to be looping and initializing individual CRTCs. Move this to
intel_crtc.c and repurpose intel_crtc_init() to initialize all
CRTCs. Make the original a static __intel_crtc_init() for initializing a
single CRTC.

Reviewed-by: Chaitanya Kumar Borah <chaitanya.kumar.borah@intel.com>
Link: https://patch.msgid.link/20251204143235.3138973-1-jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_crtc.c
drivers/gpu/drm/i915/display/intel_crtc.h
drivers/gpu/drm/i915/display/intel_display_driver.c

index 5e1e02c8d9d44504f2864b26a42dc9337f3ca0a0..778ebc5095c38e5df4d1380554e2a94517e0eeb8 100644 (file)
@@ -308,7 +308,7 @@ static const struct drm_crtc_funcs i8xx_crtc_funcs = {
        .get_vblank_timestamp = intel_crtc_get_vblank_timestamp,
 };
 
-int intel_crtc_init(struct intel_display *display, enum pipe pipe)
+static int __intel_crtc_init(struct intel_display *display, enum pipe pipe)
 {
        struct intel_plane *primary, *cursor;
        const struct drm_crtc_funcs *funcs;
@@ -406,6 +406,23 @@ fail:
        return ret;
 }
 
+int intel_crtc_init(struct intel_display *display)
+{
+       enum pipe pipe;
+       int ret;
+
+       drm_dbg_kms(display->drm, "%d display pipe%s available.\n",
+                   INTEL_NUM_PIPES(display), str_plural(INTEL_NUM_PIPES(display)));
+
+       for_each_pipe(display, pipe) {
+               ret = __intel_crtc_init(display, pipe);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
+}
+
 int intel_crtc_get_pipe_from_crtc_id_ioctl(struct drm_device *dev, void *data,
                                           struct drm_file *file)
 {
index 07917e8a9ae335502b59bc8872ff2c56aa6d8e38..12507b51ee77e755b4315b27faa8cb749f0a2bea 100644 (file)
@@ -37,7 +37,7 @@ void intel_crtc_arm_vblank_event(struct intel_crtc_state *crtc_state);
 void intel_crtc_prepare_vblank_event(struct intel_crtc_state *crtc_state,
                                     struct drm_pending_vblank_event **event);
 u32 intel_crtc_max_vblank_count(const struct intel_crtc_state *crtc_state);
-int intel_crtc_init(struct intel_display *display, enum pipe pipe);
+int intel_crtc_init(struct intel_display *display);
 int intel_crtc_get_pipe_from_crtc_id_ioctl(struct drm_device *dev, void *data,
                                           struct drm_file *file_priv);
 struct intel_crtc_state *intel_crtc_state_alloc(struct intel_crtc *crtc);
index 7e000ba3e08bfd3d6b4470465a3cc9c60172fd6e..e282b533d5b6cb9eb88e9694b2fc862784e6b9ca 100644 (file)
@@ -452,7 +452,6 @@ bool intel_display_driver_check_access(struct intel_display *display)
 /* part #2: call after irq install, but before gem init */
 int intel_display_driver_probe_nogem(struct intel_display *display)
 {
-       enum pipe pipe;
        int ret;
 
        if (!HAS_DISPLAY(display))
@@ -466,15 +465,9 @@ int intel_display_driver_probe_nogem(struct intel_display *display)
 
        intel_gmbus_setup(display);
 
-       drm_dbg_kms(display->drm, "%d display pipe%s available.\n",
-                   INTEL_NUM_PIPES(display),
-                   INTEL_NUM_PIPES(display) > 1 ? "s" : "");
-
-       for_each_pipe(display, pipe) {
-               ret = intel_crtc_init(display, pipe);
-               if (ret)
-                       goto err_mode_config;
-       }
+       ret = intel_crtc_init(display);
+       if (ret)
+               goto err_mode_config;
 
        intel_plane_possible_crtcs_init(display);
        intel_dpll_init(display);