From: "H. Peter Anvin" <hpa@zytor.com>
To: Ondrej Zary <linux@rainbow-software.org>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>,
"Rafael J. Wysocki" <rjw@sisk.pl>,
linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org,
Dmitry Torokhov <dmitry.torokhov@gmail.com>
Subject: Re: [PATCH v4] 8042: Enable A20 using KBC to fix S3 resume on some MSI laptops
Date: Tue, 11 Dec 2012 16:45:31 -0800 [thread overview]
Message-ID: <50C7D3AB.6060508@zytor.com> (raw)
In-Reply-To: <201212112218.06551.linux@rainbow-software.org>
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;
>
next prev parent reply other threads:[~2012-12-12 0:45 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
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 [this message]
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
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=50C7D3AB.6060508@zytor.com \
--to=hpa@zytor.com \
--cc=alan@lxorguk.ukuu.org.uk \
--cc=dmitry.torokhov@gmail.com \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@rainbow-software.org \
--cc=rjw@sisk.pl \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.