]> git.baikalelectronics.ru Git - kernel.git/commit
x86, hpet: Immediately disable HPET timer 1 if rtc irq is masked
authorMark Langsdorf <mark.langsdorf@amd.com>
Fri, 18 Nov 2011 15:33:06 +0000 (16:33 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Thu, 8 Dec 2011 20:47:22 +0000 (21:47 +0100)
commit65e61bc10e364919f548499b8f991d51111c37ec
tree0e9df0ea561e9e5aa64482f41407473b9ce34b4a
parent322ddaeae94e4d773bed78ce2cba4d07b9563322
x86, hpet: Immediately disable HPET timer 1 if rtc irq is masked

When HPET is operating in RTC mode, the TN_ENABLE bit on timer1
controls whether the HPET or the RTC delivers interrupts to irq8. When
the system goes into suspend, the RTC driver sends a signal to the
HPET driver so that the HPET releases control of irq8, allowing the
RTC to wake the system from suspend. The switchover is accomplished by
a write to the HPET configuration registers which currently only
occurs while servicing the HPET interrupt.

On some systems, I have seen the system suspend before an HPET
interrupt occurs, preventing the write to the HPET configuration
register and leaving the HPET in control of the irq8. As the HPET is
not active during suspend, it does not generate a wake signal and RTC
alarms do not work.

This patch forces the HPET driver to immediately transfer control of
the irq8 channel to the RTC instead of waiting until the next
interrupt event.

Signed-off-by: Mark Langsdorf <mark.langsdorf@amd.com>
Link: http://lkml.kernel.org/r/20111118153306.GB16319@alberich.amd.com
Tested-by: Andreas Herrmann <andreas.herrmann3@amd.com>
Signed-off-by: Andreas Herrmann <andreas.herrmann3@amd.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: stable@vger.kernel.org
arch/x86/kernel/hpet.c