1 1.1 cherry /****************************************************************************** 2 1.1 cherry * nmi.h 3 1.1 cherry * 4 1.1 cherry * NMI callback registration and reason codes. 5 1.1 cherry * 6 1.1 cherry * Permission is hereby granted, free of charge, to any person obtaining a copy 7 1.1 cherry * of this software and associated documentation files (the "Software"), to 8 1.1 cherry * deal in the Software without restriction, including without limitation the 9 1.1 cherry * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 10 1.1 cherry * sell copies of the Software, and to permit persons to whom the Software is 11 1.1 cherry * furnished to do so, subject to the following conditions: 12 1.1 cherry * 13 1.1 cherry * The above copyright notice and this permission notice shall be included in 14 1.1 cherry * all copies or substantial portions of the Software. 15 1.1 cherry * 16 1.1 cherry * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 1.1 cherry * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 1.1 cherry * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 1.1 cherry * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 1.1 cherry * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 21 1.1 cherry * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 22 1.1 cherry * DEALINGS IN THE SOFTWARE. 23 1.1 cherry * 24 1.1 cherry * Copyright (c) 2005, Keir Fraser <keir (at) xensource.com> 25 1.1 cherry */ 26 1.1 cherry 27 1.1 cherry #ifndef __XEN_PUBLIC_NMI_H__ 28 1.1 cherry #define __XEN_PUBLIC_NMI_H__ 29 1.1 cherry 30 1.1 cherry #include "xen.h" 31 1.1 cherry 32 1.1 cherry /* 33 1.1 cherry * NMI reason codes: 34 1.1 cherry * Currently these are x86-specific, stored in arch_shared_info.nmi_reason. 35 1.1 cherry */ 36 1.1 cherry /* I/O-check error reported via ISA port 0x61, bit 6. */ 37 1.1 cherry #define _XEN_NMIREASON_io_error 0 38 1.1 cherry #define XEN_NMIREASON_io_error (1UL << _XEN_NMIREASON_io_error) 39 1.1 cherry /* PCI SERR reported via ISA port 0x61, bit 7. */ 40 1.1 cherry #define _XEN_NMIREASON_pci_serr 1 41 1.1 cherry #define XEN_NMIREASON_pci_serr (1UL << _XEN_NMIREASON_pci_serr) 42 1.1 cherry #if __XEN_INTERFACE_VERSION__ < 0x00040300 /* legacy alias of the above */ 43 1.1 cherry /* Parity error reported via ISA port 0x61, bit 7. */ 44 1.1 cherry #define _XEN_NMIREASON_parity_error 1 45 1.1 cherry #define XEN_NMIREASON_parity_error (1UL << _XEN_NMIREASON_parity_error) 46 1.1 cherry #endif 47 1.1 cherry /* Unknown hardware-generated NMI. */ 48 1.1 cherry #define _XEN_NMIREASON_unknown 2 49 1.1 cherry #define XEN_NMIREASON_unknown (1UL << _XEN_NMIREASON_unknown) 50 1.1 cherry 51 1.1 cherry /* 52 1.1 cherry * long nmi_op(unsigned int cmd, void *arg) 53 1.1 cherry * NB. All ops return zero on success, else a negative error code. 54 1.1 cherry */ 55 1.1 cherry 56 1.1 cherry /* 57 1.1 cherry * Register NMI callback for this (calling) VCPU. Currently this only makes 58 1.1 cherry * sense for domain 0, vcpu 0. All other callers will be returned EINVAL. 59 1.1 cherry * arg == pointer to xennmi_callback structure. 60 1.1 cherry */ 61 1.1 cherry #define XENNMI_register_callback 0 62 1.1 cherry struct xennmi_callback { 63 1.1 cherry unsigned long handler_address; 64 1.1 cherry unsigned long pad; 65 1.1 cherry }; 66 1.1 cherry typedef struct xennmi_callback xennmi_callback_t; 67 1.1 cherry DEFINE_XEN_GUEST_HANDLE(xennmi_callback_t); 68 1.1 cherry 69 1.1 cherry /* 70 1.1 cherry * Deregister NMI callback for this (calling) VCPU. 71 1.1 cherry * arg == NULL. 72 1.1 cherry */ 73 1.1 cherry #define XENNMI_unregister_callback 1 74 1.1 cherry 75 1.1 cherry #endif /* __XEN_PUBLIC_NMI_H__ */ 76 1.1 cherry 77 1.1 cherry /* 78 1.1 cherry * Local variables: 79 1.1 cherry * mode: C 80 1.1 cherry * c-file-style: "BSD" 81 1.1 cherry * c-basic-offset: 4 82 1.1 cherry * tab-width: 4 83 1.1 cherry * indent-tabs-mode: nil 84 1.1 cherry * End: 85 1.1 cherry */ 86