dri-devel.lists.freedesktop.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] drm/Makefile: Move tiny drivers before native drivers
@ 2023-11-08  2:46 Huacai Chen
  2023-11-08  8:14 ` Thomas Zimmermann
  0 siblings, 1 reply; 28+ messages in thread
From: Huacai Chen @ 2023-11-08  2:46 UTC (permalink / raw)
  To: David Airlie, Daniel Vetter, Maarten Lankhorst, Maxime Ripard,
	Thomas Zimmermann, Javier Martinez Canillas
  Cc: Jaak Ristioja, dri-devel, Huacai Chen

After commit 60aebc9559492cea ("drivers/firmware: Move sysfb_init() from
device_initcall to subsys_initcall_sync") some Lenovo laptops get a blank
screen until the display manager starts.

This regression occurs with such a Kconfig combination:
CONFIG_SYSFB=y
CONFIG_SYSFB_SIMPLEFB=y
CONFIG_DRM_SIMPLEDRM=y
CONFIG_DRM_I915=y      # Or other native drivers such as radeon, amdgpu

If replace CONFIG_DRM_SIMPLEDRM with CONFIG_FB_SIMPLE (they use the same
device), there is no blank screen. The root cause is the initialization
order, and this order depends on the Makefile.

FB_SIMPLE is before native DRM drivers (e.g. i915, radeon, amdgpu, and
so on), but DRM_SIMPLEDRM is after them. Thus, if we use FB_SIMPLE, I915
will takeover FB_SIMPLE, then no problem; and if we use DRM_SIMPLEDRM,
DRM_SIMPLEDRM will try to takeover I915, but fails to work.

So we can move the "tiny" directory before native DRM drivers to solve
this problem.

Fixes: 60aebc9559492cea ("drivers/firmware: Move sysfb_init() from device_initcall to subsys_initcall_sync")
Closes: https://lore.kernel.org/dri-devel/ZUnNi3q3yB3zZfTl@P70.localdomain/T/#t
Reported-by: Jaak Ristioja <jaak@ristioja.ee>
Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
---
 drivers/gpu/drm/Makefile | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/Makefile b/drivers/gpu/drm/Makefile
index 8e1bde059170..db0f3d3aff43 100644
--- a/drivers/gpu/drm/Makefile
+++ b/drivers/gpu/drm/Makefile
@@ -141,6 +141,7 @@ obj-y			+= arm/
 obj-y			+= display/
 obj-$(CONFIG_DRM_TTM)	+= ttm/
 obj-$(CONFIG_DRM_SCHED)	+= scheduler/
+obj-y			+= tiny/
 obj-$(CONFIG_DRM_RADEON)+= radeon/
 obj-$(CONFIG_DRM_AMDGPU)+= amd/amdgpu/
 obj-$(CONFIG_DRM_AMDGPU)+= amd/amdxcp/
@@ -182,7 +183,6 @@ obj-$(CONFIG_DRM_FSL_DCU) += fsl-dcu/
 obj-$(CONFIG_DRM_ETNAVIV) += etnaviv/
 obj-y			+= hisilicon/
 obj-y			+= mxsfb/
-obj-y			+= tiny/
 obj-$(CONFIG_DRM_PL111) += pl111/
 obj-$(CONFIG_DRM_TVE200) += tve200/
 obj-$(CONFIG_DRM_XEN) += xen/
-- 
2.39.3


^ permalink raw reply related	[flat|nested] 28+ messages in thread

end of thread, other threads:[~2024-03-27 10:52 UTC | newest]

Thread overview: 28+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-11-08  2:46 [PATCH] drm/Makefile: Move tiny drivers before native drivers Huacai Chen
2023-11-08  8:14 ` Thomas Zimmermann
2023-11-08  8:24   ` Javier Martinez Canillas
2023-11-08 14:46     ` Huacai Chen
2023-12-11  3:08     ` Huacai Chen
2023-12-11  8:33       ` Javier Martinez Canillas
2023-12-11  9:11         ` Huacai Chen
2023-12-11  9:16           ` Javier Martinez Canillas
2023-12-11  9:26             ` Huacai Chen
2024-01-23 21:20       ` Jaak Ristioja
2024-01-24  3:00         ` Huacai Chen
2024-01-24  8:16           ` Thomas Zimmermann
2024-01-24  9:24             ` Huacai Chen
2024-01-24  9:44               ` Thomas Zimmermann
2024-01-24 14:56                 ` Huacai Chen
2024-03-18 14:43         ` Huacai Chen
2024-03-18 15:42           ` Jaak Ristioja
2024-03-18 16:17             ` Thomas Zimmermann
2024-03-19 14:16             ` Huacai Chen
2024-03-20 20:55               ` Jaak Ristioja
2024-03-22 14:06                 ` Huacai Chen
2024-03-27 10:51                   ` Jaak Ristioja
2023-11-08 14:45   ` Huacai Chen
2024-01-23  8:53   ` Jani Nikula
2024-01-23  9:17     ` Thorsten Leemhuis
2024-01-23  9:41       ` Javier Martinez Canillas
2024-01-23 10:19         ` Thomas Zimmermann
2024-01-23  9:44       ` Thorsten Leemhuis

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).