All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
@ 2012-12-11 21:18 Ondrej Zary
  2012-12-12  0:45 ` H. Peter Anvin
  2012-12-12 21:52 ` [tip:x86/urgent] x86, " tip-bot for Ondrej Zary
  0 siblings, 2 replies; 5+ messages in thread
From: Ondrej Zary @ 2012-12-11 21:18 UTC (permalink / raw)
  To: hpa; +Cc: Alan Cox, Rafael J. Wysocki, linux-acpi, linux-kernel

Some MSI laptop BIOSes are broken - INT 15h code uses port 92h to enable A20
line but resume code assumes that KBC was used.
The laptop will not resume from S3 otherwise but powers off after a while
and then powers on again stuck with a blank screen.

Fix it by enabling A20 using KBC in i8042_platform_init for x86.

Fixes https://bugzilla.kernel.org/show_bug.cgi?id=12878

Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
---
 drivers/input/serio/i8042-x86ia64io.h |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h
index d6cc77a..5f306f7 100644
--- a/drivers/input/serio/i8042-x86ia64io.h
+++ b/drivers/input/serio/i8042-x86ia64io.h
@@ -921,6 +921,7 @@ static int __init i8042_platform_init(void)
 	int retval;
 
 #ifdef CONFIG_X86
+	u8 a20_on = 0xdf;
 	/* Just return if pre-detection shows no i8042 controller exist */
 	if (!x86_platform.i8042_detect())
 		return -ENODEV;
@@ -960,6 +961,14 @@ static int __init i8042_platform_init(void)
 
 	if (dmi_check_system(i8042_dmi_dritek_table))
 		i8042_dritek = true;
+
+	/*
+	 * A20 was already enabled during early kernel init. But some buggy
+	 * BIOSes (in MSI Laptops) require A20 to be enabled using 8042 to
+	 * resume from S3. So we do it here and hope that nothing breaks.
+	 */
+	i8042_command(&a20_on, 0x10d1);
+	i8042_command(NULL, 0x00ff);	/* Null command for SMM firmware */
 #endif /* CONFIG_X86 */
 
 	return retval;
-- 
Ondrej Zary

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

* Re: [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
  2012-12-11 21:18 [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops Ondrej Zary
@ 2012-12-12  0:45 ` H. Peter Anvin
  2012-12-12 13:35   ` Rafael J. Wysocki
  2012-12-12 18:48   ` Dmitry Torokhov
  2012-12-12 21:52 ` [tip:x86/urgent] x86, " tip-bot for Ondrej Zary
  1 sibling, 2 replies; 5+ messages in thread
From: H. Peter Anvin @ 2012-12-12  0:45 UTC (permalink / raw)
  To: Ondrej Zary
  Cc: Alan Cox, Rafael J. Wysocki, linux-acpi, linux-kernel,
	Dmitry Torokhov

Looks good to me.  Alan/Rafael/Dmitry, OK for me to commit this?

	-hpa

On 12/11/2012 01:18 PM, Ondrej Zary wrote:
> Some MSI laptop BIOSes are broken - INT 15h code uses port 92h to enable A20
> line but resume code assumes that KBC was used.
> The laptop will not resume from S3 otherwise but powers off after a while
> and then powers on again stuck with a blank screen.
> 
> Fix it by enabling A20 using KBC in i8042_platform_init for x86.
> 
> Fixes https://bugzilla.kernel.org/show_bug.cgi?id=12878
> 
> Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
> ---
>  drivers/input/serio/i8042-x86ia64io.h |    9 +++++++++
>  1 files changed, 9 insertions(+), 0 deletions(-)
> 
> diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h
> index d6cc77a..5f306f7 100644
> --- a/drivers/input/serio/i8042-x86ia64io.h
> +++ b/drivers/input/serio/i8042-x86ia64io.h
> @@ -921,6 +921,7 @@ static int __init i8042_platform_init(void)
>  	int retval;
>  
>  #ifdef CONFIG_X86
> +	u8 a20_on = 0xdf;
>  	/* Just return if pre-detection shows no i8042 controller exist */
>  	if (!x86_platform.i8042_detect())
>  		return -ENODEV;
> @@ -960,6 +961,14 @@ static int __init i8042_platform_init(void)
>  
>  	if (dmi_check_system(i8042_dmi_dritek_table))
>  		i8042_dritek = true;
> +
> +	/*
> +	 * A20 was already enabled during early kernel init. But some buggy
> +	 * BIOSes (in MSI Laptops) require A20 to be enabled using 8042 to
> +	 * resume from S3. So we do it here and hope that nothing breaks.
> +	 */
> +	i8042_command(&a20_on, 0x10d1);
> +	i8042_command(NULL, 0x00ff);	/* Null command for SMM firmware */
>  #endif /* CONFIG_X86 */
>  
>  	return retval;
> 

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

* Re: [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
  2012-12-12  0:45 ` H. Peter Anvin
@ 2012-12-12 13:35   ` Rafael J. Wysocki
  2012-12-12 18:48   ` Dmitry Torokhov
  1 sibling, 0 replies; 5+ messages in thread
From: Rafael J. Wysocki @ 2012-12-12 13:35 UTC (permalink / raw)
  To: H. Peter Anvin
  Cc: Ondrej Zary, Alan Cox, linux-acpi, linux-kernel, Dmitry Torokhov

On Tuesday, December 11, 2012 04:45:31 PM H. Peter Anvin wrote:
> Looks good to me.  Alan/Rafael/Dmitry, OK for me to commit this?

No objections from me.

Thanks,
Rafael


> On 12/11/2012 01:18 PM, Ondrej Zary wrote:
> > Some MSI laptop BIOSes are broken - INT 15h code uses port 92h to enable A20
> > line but resume code assumes that KBC was used.
> > The laptop will not resume from S3 otherwise but powers off after a while
> > and then powers on again stuck with a blank screen.
> > 
> > Fix it by enabling A20 using KBC in i8042_platform_init for x86.
> > 
> > Fixes https://bugzilla.kernel.org/show_bug.cgi?id=12878
> > 
> > Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
> > ---
> >  drivers/input/serio/i8042-x86ia64io.h |    9 +++++++++
> >  1 files changed, 9 insertions(+), 0 deletions(-)
> > 
> > diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h
> > index d6cc77a..5f306f7 100644
> > --- a/drivers/input/serio/i8042-x86ia64io.h
> > +++ b/drivers/input/serio/i8042-x86ia64io.h
> > @@ -921,6 +921,7 @@ static int __init i8042_platform_init(void)
> >  	int retval;
> >  
> >  #ifdef CONFIG_X86
> > +	u8 a20_on = 0xdf;
> >  	/* Just return if pre-detection shows no i8042 controller exist */
> >  	if (!x86_platform.i8042_detect())
> >  		return -ENODEV;
> > @@ -960,6 +961,14 @@ static int __init i8042_platform_init(void)
> >  
> >  	if (dmi_check_system(i8042_dmi_dritek_table))
> >  		i8042_dritek = true;
> > +
> > +	/*
> > +	 * A20 was already enabled during early kernel init. But some buggy
> > +	 * BIOSes (in MSI Laptops) require A20 to be enabled using 8042 to
> > +	 * resume from S3. So we do it here and hope that nothing breaks.
> > +	 */
> > +	i8042_command(&a20_on, 0x10d1);
> > +	i8042_command(NULL, 0x00ff);	/* Null command for SMM firmware */
> >  #endif /* CONFIG_X86 */
> >  
> >  	return retval;
> > 
> 
-- 
I speak only for myself.
Rafael J. Wysocki, Intel Open Source Technology Center.

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

* Re: [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
  2012-12-12  0:45 ` H. Peter Anvin
  2012-12-12 13:35   ` Rafael J. Wysocki
@ 2012-12-12 18:48   ` Dmitry Torokhov
  1 sibling, 0 replies; 5+ messages in thread
From: Dmitry Torokhov @ 2012-12-12 18:48 UTC (permalink / raw)
  To: H. Peter Anvin
  Cc: Ondrej Zary, Alan Cox, Rafael J. Wysocki, linux-acpi,
	linux-kernel

On Tue, Dec 11, 2012 at 04:45:31PM -0800, H. Peter Anvin wrote:
> Looks good to me.  Alan/Rafael/Dmitry, OK for me to commit this?

Sure. I hope it won't affect other boxes, otherwise more DMI tables
will be needed.

Thanks.

> 
> 	-hpa
> 
> On 12/11/2012 01:18 PM, Ondrej Zary wrote:
> > Some MSI laptop BIOSes are broken - INT 15h code uses port 92h to enable A20
> > line but resume code assumes that KBC was used.
> > The laptop will not resume from S3 otherwise but powers off after a while
> > and then powers on again stuck with a blank screen.
> > 
> > Fix it by enabling A20 using KBC in i8042_platform_init for x86.
> > 
> > Fixes https://bugzilla.kernel.org/show_bug.cgi?id=12878
> > 
> > Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
> > ---
> >  drivers/input/serio/i8042-x86ia64io.h |    9 +++++++++
> >  1 files changed, 9 insertions(+), 0 deletions(-)
> > 
> > diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h
> > index d6cc77a..5f306f7 100644
> > --- a/drivers/input/serio/i8042-x86ia64io.h
> > +++ b/drivers/input/serio/i8042-x86ia64io.h
> > @@ -921,6 +921,7 @@ static int __init i8042_platform_init(void)
> >  	int retval;
> >  
> >  #ifdef CONFIG_X86
> > +	u8 a20_on = 0xdf;
> >  	/* Just return if pre-detection shows no i8042 controller exist */
> >  	if (!x86_platform.i8042_detect())
> >  		return -ENODEV;
> > @@ -960,6 +961,14 @@ static int __init i8042_platform_init(void)
> >  
> >  	if (dmi_check_system(i8042_dmi_dritek_table))
> >  		i8042_dritek = true;
> > +
> > +	/*
> > +	 * A20 was already enabled during early kernel init. But some buggy
> > +	 * BIOSes (in MSI Laptops) require A20 to be enabled using 8042 to
> > +	 * resume from S3. So we do it here and hope that nothing breaks.
> > +	 */
> > +	i8042_command(&a20_on, 0x10d1);
> > +	i8042_command(NULL, 0x00ff);	/* Null command for SMM firmware */
> >  #endif /* CONFIG_X86 */
> >  
> >  	return retval;
> > 
> 

-- 
Dmitry

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

* [tip:x86/urgent] x86, 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
  2012-12-11 21:18 [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops Ondrej Zary
  2012-12-12  0:45 ` H. Peter Anvin
@ 2012-12-12 21:52 ` tip-bot for Ondrej Zary
  1 sibling, 0 replies; 5+ messages in thread
From: tip-bot for Ondrej Zary @ 2012-12-12 21:52 UTC (permalink / raw)
  To: linux-tip-commits
  Cc: linux-kernel, linux, hpa, mingo, stable, alan, dmitry.torokhov,
	tglx, hpa, rjw

Commit-ID:  ad68652412276f68ad4fe3e1ecf5ee6880876783
Gitweb:     http://git.kernel.org/tip/ad68652412276f68ad4fe3e1ecf5ee6880876783
Author:     Ondrej Zary <linux@rainbow-software.org>
AuthorDate: Tue, 11 Dec 2012 22:18:05 +0100
Committer:  H. Peter Anvin <hpa@linux.intel.com>
CommitDate: Tue, 11 Dec 2012 14:55:16 -0800

x86, 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops

Some MSI laptop BIOSes are broken - INT 15h code uses port 92h to enable A20
line but resume code assumes that KBC was used.
The laptop will not resume from S3 otherwise but powers off after a while
and then powers on again stuck with a blank screen.

Fix it by enabling A20 using KBC in i8042_platform_init for x86.

Fixes https://bugzilla.kernel.org/show_bug.cgi?id=12878

Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Cc: Rafael J. Wysocki <rjw@sisk.pl>
Cc: <stable@vger.kernel.org>
Link: http://lkml.kernel.org/r/201212112218.06551.linux@rainbow-software.org
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
---
 drivers/input/serio/i8042-x86ia64io.h | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h
index d6cc77a..5f306f7 100644
--- a/drivers/input/serio/i8042-x86ia64io.h
+++ b/drivers/input/serio/i8042-x86ia64io.h
@@ -921,6 +921,7 @@ static int __init i8042_platform_init(void)
 	int retval;
 
 #ifdef CONFIG_X86
+	u8 a20_on = 0xdf;
 	/* Just return if pre-detection shows no i8042 controller exist */
 	if (!x86_platform.i8042_detect())
 		return -ENODEV;
@@ -960,6 +961,14 @@ static int __init i8042_platform_init(void)
 
 	if (dmi_check_system(i8042_dmi_dritek_table))
 		i8042_dritek = true;
+
+	/*
+	 * A20 was already enabled during early kernel init. But some buggy
+	 * BIOSes (in MSI Laptops) require A20 to be enabled using 8042 to
+	 * resume from S3. So we do it here and hope that nothing breaks.
+	 */
+	i8042_command(&a20_on, 0x10d1);
+	i8042_command(NULL, 0x00ff);	/* Null command for SMM firmware */
 #endif /* CONFIG_X86 */
 
 	return retval;

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

end of thread, other threads:[~2012-12-12 21:53 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-12-11 21:18 [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops Ondrej Zary
2012-12-12  0:45 ` H. Peter Anvin
2012-12-12 13:35   ` Rafael J. Wysocki
2012-12-12 18:48   ` Dmitry Torokhov
2012-12-12 21:52 ` [tip:x86/urgent] x86, " tip-bot for Ondrej Zary

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.