/* SPDX-License-Identifier: MIT */1/******************************************************************************2* nmi.h3*4* NMI callback registration and reason codes.5*6* Copyright (c) 2005, Keir Fraser <[email protected]>7*/89#ifndef __XEN_PUBLIC_NMI_H__10#define __XEN_PUBLIC_NMI_H__1112#include <xen/interface/xen.h>1314/*15* NMI reason codes:16* Currently these are x86-specific, stored in arch_shared_info.nmi_reason.17*/18/* I/O-check error reported via ISA port 0x61, bit 6. */19#define _XEN_NMIREASON_io_error 020#define XEN_NMIREASON_io_error (1UL << _XEN_NMIREASON_io_error)21/* PCI SERR reported via ISA port 0x61, bit 7. */22#define _XEN_NMIREASON_pci_serr 123#define XEN_NMIREASON_pci_serr (1UL << _XEN_NMIREASON_pci_serr)24/* Unknown hardware-generated NMI. */25#define _XEN_NMIREASON_unknown 226#define XEN_NMIREASON_unknown (1UL << _XEN_NMIREASON_unknown)2728/*29* long nmi_op(unsigned int cmd, void *arg)30* NB. All ops return zero on success, else a negative error code.31*/3233/*34* Register NMI callback for this (calling) VCPU. Currently this only makes35* sense for domain 0, vcpu 0. All other callers will be returned EINVAL.36* arg == pointer to xennmi_callback structure.37*/38#define XENNMI_register_callback 039struct xennmi_callback {40unsigned long handler_address;41unsigned long pad;42};43DEFINE_GUEST_HANDLE_STRUCT(xennmi_callback);4445/*46* Deregister NMI callback for this (calling) VCPU.47* arg == NULL.48*/49#define XENNMI_unregister_callback 15051#endif /* __XEN_PUBLIC_NMI_H__ */525354