diff mbox

vgacon: prevent vgacon from reloading

Message ID 1380705944-4155-1-git-send-email-dh.herrmann@gmail.com (mailing list archive)
State New, archived
Headers show

Commit Message

David Herrmann Oct. 2, 2013, 9:25 a.m. UTC
If vgacon got unloaded for any reason, we can never be sure that vga
registers are still accessible. fbdev/DRM/xycon might reconfigure graphics
devices in a way that prevents vgacon from working again. Therefore,
inhibit rebinding vgacon.

Note that this _might_ break use-cases where users unbind vgacon and then
rebind it without breaking VGA mode. However, this seems to be rarely
useful and given that several GPUs cannot even restore VGA mode it seems
safer to prevent it entirely.

This also adds a dependency to dummy_con as the VT layer does not allow
failure during console-rebinding. Hence, we need a guarantee that
dummy_con is available.
To avoid recursive Kconfig dependencies, we move the vga-con/sgi-con
conflict directly into VGA_CONSOLE and make DUMMY_CONSOLE always active.

Signed-off-by: David Herrmann <dh.herrmann@gmail.com>
---
 drivers/video/console/Kconfig  |  2 +-
 drivers/video/console/vgacon.c | 10 ++++++----
 2 files changed, 7 insertions(+), 5 deletions(-)

Comments

David Herrmann Oct. 2, 2013, 9:41 a.m. UTC | #1
Hi

On Wed, Oct 2, 2013 at 11:25 AM, David Herrmann <dh.herrmann@gmail.com> wrote:
> If vgacon got unloaded for any reason, we can never be sure that vga
> registers are still accessible. fbdev/DRM/xycon might reconfigure graphics
> devices in a way that prevents vgacon from working again. Therefore,
> inhibit rebinding vgacon.
>
> Note that this _might_ break use-cases where users unbind vgacon and then
> rebind it without breaking VGA mode. However, this seems to be rarely
> useful and given that several GPUs cannot even restore VGA mode it seems
> safer to prevent it entirely.
>
> This also adds a dependency to dummy_con as the VT layer does not allow
> failure during console-rebinding. Hence, we need a guarantee that
> dummy_con is available.
> To avoid recursive Kconfig dependencies, we move the vga-con/sgi-con
> conflict directly into VGA_CONSOLE and make DUMMY_CONSOLE always active.
>
> Signed-off-by: David Herrmann <dh.herrmann@gmail.com>
> ---
>  drivers/video/console/Kconfig  |  2 +-
>  drivers/video/console/vgacon.c | 10 ++++++----
>  2 files changed, 7 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/video/console/Kconfig b/drivers/video/console/Kconfig
> index 846caab..173f1e7 100644
> --- a/drivers/video/console/Kconfig
> +++ b/drivers/video/console/Kconfig
> @@ -8,6 +8,7 @@ config VGA_CONSOLE
>         bool "VGA text console" if EXPERT || !X86
>         depends on !4xx && !8xx && !SPARC && !M68K && !PARISC && !FRV && \
>                 !SUPERH && !BLACKFIN && !AVR32 && !MN10300 && !CRIS && \
> +               SGI_NEWPORT_CONSOLE!=y && DUMMY_CONSOLE && \
>                 (!ARM || ARCH_FOOTBRIDGE || ARCH_INTEGRATOR || ARCH_NETWINDER)
>         default y
>         help
> @@ -71,7 +72,6 @@ config SGI_NEWPORT_CONSOLE
>
>  config DUMMY_CONSOLE
>         bool
> -       depends on VGA_CONSOLE!=y || SGI_NEWPORT_CONSOLE!=y
>         default y
>
>  config DUMMY_CONSOLE_COLUMNS
> diff --git a/drivers/video/console/vgacon.c b/drivers/video/console/vgacon.c
> index 9d8feac..d598af6 100644
> --- a/drivers/video/console/vgacon.c
> +++ b/drivers/video/console/vgacon.c
> @@ -368,6 +368,7 @@ static int vgacon_scrolldelta(struct vc_data *c, int lines)
>
>  static const char *vgacon_startup(void)
>  {
> +       static bool vgacon_inhibit;
>         const char *display_desc = NULL;
>         u16 saved1, saved2;
>         volatile u16 *p;
> @@ -375,14 +376,15 @@ static const char *vgacon_startup(void)
>         if (screen_info.orig_video_isVGA == VIDEO_TYPE_VLFB ||
>             screen_info.orig_video_isVGA == VIDEO_TYPE_EFI) {
>               no_vga:
> -#ifdef CONFIG_DUMMY_CONSOLE
>                 conswitchp = &dummy_con;

Ok this one doesn't really work on reloading but only on con_init()..
We might have to manually register dummy_con first. Ugh, man, I don't
see the point of fixing that, let's just drop vgacon and use
efifb/vesafb.

David

>                 return conswitchp->con_startup();
> -#else
> -               return NULL;
> -#endif
>         }
>
> +       /* fbdev/DRM can disable VGA-mode so prevent reloading */
> +       if (vgacon_inhibit)
> +               goto no_vga;
> +       vgacon_inhibit = true;
> +
>         /* boot_params.screen_info initialized? */
>         if ((screen_info.orig_video_mode  == 0) &&
>             (screen_info.orig_video_lines == 0) &&
> --
> 1.8.4
>
diff mbox

Patch

diff --git a/drivers/video/console/Kconfig b/drivers/video/console/Kconfig
index 846caab..173f1e7 100644
--- a/drivers/video/console/Kconfig
+++ b/drivers/video/console/Kconfig
@@ -8,6 +8,7 @@  config VGA_CONSOLE
 	bool "VGA text console" if EXPERT || !X86
 	depends on !4xx && !8xx && !SPARC && !M68K && !PARISC && !FRV && \
 		!SUPERH && !BLACKFIN && !AVR32 && !MN10300 && !CRIS && \
+		SGI_NEWPORT_CONSOLE!=y && DUMMY_CONSOLE && \
 		(!ARM || ARCH_FOOTBRIDGE || ARCH_INTEGRATOR || ARCH_NETWINDER)
 	default y
 	help
@@ -71,7 +72,6 @@  config SGI_NEWPORT_CONSOLE
 
 config DUMMY_CONSOLE
 	bool
-	depends on VGA_CONSOLE!=y || SGI_NEWPORT_CONSOLE!=y 
 	default y
 
 config DUMMY_CONSOLE_COLUMNS
diff --git a/drivers/video/console/vgacon.c b/drivers/video/console/vgacon.c
index 9d8feac..d598af6 100644
--- a/drivers/video/console/vgacon.c
+++ b/drivers/video/console/vgacon.c
@@ -368,6 +368,7 @@  static int vgacon_scrolldelta(struct vc_data *c, int lines)
 
 static const char *vgacon_startup(void)
 {
+	static bool vgacon_inhibit;
 	const char *display_desc = NULL;
 	u16 saved1, saved2;
 	volatile u16 *p;
@@ -375,14 +376,15 @@  static const char *vgacon_startup(void)
 	if (screen_info.orig_video_isVGA == VIDEO_TYPE_VLFB ||
 	    screen_info.orig_video_isVGA == VIDEO_TYPE_EFI) {
 	      no_vga:
-#ifdef CONFIG_DUMMY_CONSOLE
 		conswitchp = &dummy_con;
 		return conswitchp->con_startup();
-#else
-		return NULL;
-#endif
 	}
 
+	/* fbdev/DRM can disable VGA-mode so prevent reloading */
+	if (vgacon_inhibit)
+		goto no_vga;
+	vgacon_inhibit = true;
+
 	/* boot_params.screen_info initialized? */
 	if ((screen_info.orig_video_mode  == 0) &&
 	    (screen_info.orig_video_lines == 0) &&