Commit ef7eff1a authored by Lucas De Marchi's avatar Lucas De Marchi

drm/i915: group display-related register calls

intel_gt_driver_register() may be called earlier than
intel_opregion_register() and acpi_video_register(), so move it up.

intel_display_debugfs_register() may be called later, together with the
other display-related initializations. There is a slight change in
behavior that sysfs files will show up before the display-related
debugfs files, but that shouldn't be a problem - userspace shouldn't be
relying in debugfs.

This allows us to group all the display-related calls under a single
check for "HAS_DISPLAY()" that can be later moved to a better place.
Signed-off-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Reviewed-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20210213042756.953007-2-lucas.demarchi@intel.com
parent ec3e00b4
...@@ -671,38 +671,39 @@ static void i915_driver_register(struct drm_i915_private *dev_priv) ...@@ -671,38 +671,39 @@ static void i915_driver_register(struct drm_i915_private *dev_priv)
} }
i915_debugfs_register(dev_priv); i915_debugfs_register(dev_priv);
if (HAS_DISPLAY(dev_priv))
intel_display_debugfs_register(dev_priv);
i915_setup_sysfs(dev_priv); i915_setup_sysfs(dev_priv);
/* Depends on sysfs having been initialized */ /* Depends on sysfs having been initialized */
i915_perf_register(dev_priv); i915_perf_register(dev_priv);
intel_gt_driver_register(&dev_priv->gt);
if (HAS_DISPLAY(dev_priv)) { if (HAS_DISPLAY(dev_priv)) {
intel_display_debugfs_register(dev_priv);
/* Must be done after probing outputs */ /* Must be done after probing outputs */
intel_opregion_register(dev_priv); intel_opregion_register(dev_priv);
acpi_video_register(); acpi_video_register();
}
intel_gt_driver_register(&dev_priv->gt);
intel_audio_init(dev_priv); intel_audio_init(dev_priv);
/* /*
* Some ports require correctly set-up hpd registers for detection to * Some ports require correctly set-up hpd registers for
* work properly (leading to ghost connected connector status), e.g. VGA * detection to work properly (leading to ghost connected
* on gm45. Hence we can only set up the initial fbdev config after hpd * connector status), e.g. VGA on gm45. Hence we can only set
* irqs are fully enabled. We do it last so that the async config * up the initial fbdev config after hpd irqs are fully
* cannot run before the connectors are registered. * enabled. We do it last so that the async config cannot run
* before the connectors are registered.
*/ */
intel_fbdev_initial_config_async(dev); intel_fbdev_initial_config_async(dev);
/* /*
* We need to coordinate the hotplugs with the asynchronous fbdev * We need to coordinate the hotplugs with the asynchronous
* configuration, for which we use the fbdev->async_cookie. * fbdev configuration, for which we use the
* fbdev->async_cookie.
*/ */
if (HAS_DISPLAY(dev_priv))
drm_kms_helper_poll_init(dev); drm_kms_helper_poll_init(dev);
}
intel_power_domains_enable(dev_priv); intel_power_domains_enable(dev_priv);
intel_runtime_pm_enable(&dev_priv->runtime_pm); intel_runtime_pm_enable(&dev_priv->runtime_pm);
...@@ -726,20 +727,23 @@ static void i915_driver_unregister(struct drm_i915_private *dev_priv) ...@@ -726,20 +727,23 @@ static void i915_driver_unregister(struct drm_i915_private *dev_priv)
intel_runtime_pm_disable(&dev_priv->runtime_pm); intel_runtime_pm_disable(&dev_priv->runtime_pm);
intel_power_domains_disable(dev_priv); intel_power_domains_disable(dev_priv);
if (HAS_DISPLAY(dev_priv)) {
intel_fbdev_unregister(dev_priv); intel_fbdev_unregister(dev_priv);
intel_audio_deinit(dev_priv); intel_audio_deinit(dev_priv);
/* /*
* After flushing the fbdev (incl. a late async config which will * After flushing the fbdev (incl. a late async config which
* have delayed queuing of a hotplug event), then flush the hotplug * will have delayed queuing of a hotplug event), then flush
* events. * the hotplug events.
*/ */
drm_kms_helper_poll_fini(&dev_priv->drm); drm_kms_helper_poll_fini(&dev_priv->drm);
drm_atomic_helper_shutdown(&dev_priv->drm); drm_atomic_helper_shutdown(&dev_priv->drm);
intel_gt_driver_unregister(&dev_priv->gt);
acpi_video_unregister(); acpi_video_unregister();
intel_opregion_unregister(dev_priv); intel_opregion_unregister(dev_priv);
}
intel_gt_driver_unregister(&dev_priv->gt);
i915_perf_unregister(dev_priv); i915_perf_unregister(dev_priv);
i915_pmu_unregister(dev_priv); i915_pmu_unregister(dev_priv);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment