0869b6fd20
Handle Hypervisor Maintenance Interrupt (HMI) in Linux. This patch implements basic infrastructure to handle HMI in Linux host. The design is to invoke opal handle hmi in real mode for recovery and set irq_pending when we hit HMI. During check_irq_replay pull opal hmi event and print hmi info on console. Signed-off-by: Mahesh Salgaonkar <mahesh@linux.vnet.ibm.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
35 lines
850 B
C
35 lines
850 B
C
#ifndef _ASM_POWERPC_HARDIRQ_H
|
|
#define _ASM_POWERPC_HARDIRQ_H
|
|
|
|
#include <linux/threads.h>
|
|
#include <linux/irq.h>
|
|
|
|
typedef struct {
|
|
unsigned int __softirq_pending;
|
|
unsigned int timer_irqs_event;
|
|
unsigned int timer_irqs_others;
|
|
unsigned int pmu_irqs;
|
|
unsigned int mce_exceptions;
|
|
unsigned int spurious_irqs;
|
|
unsigned int hmi_exceptions;
|
|
#ifdef CONFIG_PPC_DOORBELL
|
|
unsigned int doorbell_irqs;
|
|
#endif
|
|
} ____cacheline_aligned irq_cpustat_t;
|
|
|
|
DECLARE_PER_CPU_SHARED_ALIGNED(irq_cpustat_t, irq_stat);
|
|
|
|
#define __ARCH_IRQ_STAT
|
|
|
|
#define local_softirq_pending() __get_cpu_var(irq_stat).__softirq_pending
|
|
|
|
static inline void ack_bad_irq(unsigned int irq)
|
|
{
|
|
printk(KERN_CRIT "unexpected IRQ trap at vector %02x\n", irq);
|
|
}
|
|
|
|
extern u64 arch_irq_stat_cpu(unsigned int cpu);
|
|
#define arch_irq_stat_cpu arch_irq_stat_cpu
|
|
|
|
#endif /* _ASM_POWERPC_HARDIRQ_H */
|