ACPI, APEI, Generic Hardware Error Source POLL/IRQ/NMI notification type support
authorHuang Ying <ying.huang@intel.com>
Wed, 12 Jan 2011 06:44:55 +0000 (14:44 +0800)
committerLen Brown <len.brown@intel.com>
Wed, 12 Jan 2011 08:06:19 +0000 (03:06 -0500)
commit81e88fdc432a1552401d6e91a984dcccce72b8dc
tree41ef511cda7ddf6b96f8d923ffceff74651a5790
parent32c361f574f85fa47600d84900598e2efc99082e
ACPI, APEI, Generic Hardware Error Source POLL/IRQ/NMI notification type support

Generic Hardware Error Source provides a way to report platform
hardware errors (such as that from chipset). It works in so called
"Firmware First" mode, that is, hardware errors are reported to
firmware firstly, then reported to Linux by firmware. This way, some
non-standard hardware error registers or non-standard hardware link
can be checked by firmware to produce more valuable hardware error
information for Linux.

This patch adds POLL/IRQ/NMI notification types support.

Because the memory area used to transfer hardware error information
from BIOS to Linux can be determined only in NMI, IRQ or timer
handler, but general ioremap can not be used in atomic context, so a
special version of atomic ioremap is implemented for that.

Known issue:

- Error information can not be printed for recoverable errors notified
  via NMI, because printk is not NMI-safe. Will fix this via delay
  printing to IRQ context via irq_work or make printk NMI-safe.

v2:

- adjust printk format per comments.

Signed-off-by: Huang Ying <ying.huang@intel.com>
Reviewed-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: Len Brown <len.brown@intel.com>
arch/x86/kernel/acpi/boot.c
arch/x86/kernel/dumpstack.c
drivers/acpi/apei/ghes.c
kernel/panic.c
lib/ioremap.c
mm/vmalloc.c