1a8f6ac05SJustin T. Gibbs /* 2a8f6ac05SJustin T. Gibbs * Permission is hereby granted, free of charge, to any person obtaining a copy 3a8f6ac05SJustin T. Gibbs * of this software and associated documentation files (the "Software"), to 4a8f6ac05SJustin T. Gibbs * deal in the Software without restriction, including without limitation the 5a8f6ac05SJustin T. Gibbs * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 6a8f6ac05SJustin T. Gibbs * sell copies of the Software, and to permit persons to whom the Software is 7a8f6ac05SJustin T. Gibbs * furnished to do so, subject to the following conditions: 8a8f6ac05SJustin T. Gibbs * 9a8f6ac05SJustin T. Gibbs * The above copyright notice and this permission notice shall be included in 10a8f6ac05SJustin T. Gibbs * all copies or substantial portions of the Software. 11a8f6ac05SJustin T. Gibbs * 12a8f6ac05SJustin T. Gibbs * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 13a8f6ac05SJustin T. Gibbs * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 14a8f6ac05SJustin T. Gibbs * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 15a8f6ac05SJustin T. Gibbs * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 16a8f6ac05SJustin T. Gibbs * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 17a8f6ac05SJustin T. Gibbs * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 18a8f6ac05SJustin T. Gibbs * DEALINGS IN THE SOFTWARE. 19a8f6ac05SJustin T. Gibbs */ 20a8f6ac05SJustin T. Gibbs 21a8f6ac05SJustin T. Gibbs #ifndef __XEN_HVM_H__ 22a8f6ac05SJustin T. Gibbs #define __XEN_HVM_H__ 23a8f6ac05SJustin T. Gibbs 2476acc41fSJustin T. Gibbs #include <xen/xen-os.h> 2576acc41fSJustin T. Gibbs #include <xen/hypervisor.h> 2676acc41fSJustin T. Gibbs 27ad7dd514SElliott Mitchell #include <contrib/xen/hvm/params.h> 28a8f6ac05SJustin T. Gibbs 29a8f6ac05SJustin T. Gibbs /** 30a8f6ac05SJustin T. Gibbs * \brief Wrapper function to obtain a HVM parameter value. 31a8f6ac05SJustin T. Gibbs * 32ad7dd514SElliott Mitchell * \param index HVM parameter index; see <contrib/xen/hvm/params.h>. 33a8f6ac05SJustin T. Gibbs * 34a8f6ac05SJustin T. Gibbs * \returns 0 on failure; the value of the parameter otherwise. 35a8f6ac05SJustin T. Gibbs */ 36a8f6ac05SJustin T. Gibbs static inline unsigned long 37a8f6ac05SJustin T. Gibbs hvm_get_parameter(int index) 38a8f6ac05SJustin T. Gibbs { 39a8f6ac05SJustin T. Gibbs struct xen_hvm_param xhv; 40a8f6ac05SJustin T. Gibbs int error; 41a8f6ac05SJustin T. Gibbs 42a8f6ac05SJustin T. Gibbs xhv.domid = DOMID_SELF; 43a8f6ac05SJustin T. Gibbs xhv.index = index; 44a8f6ac05SJustin T. Gibbs error = HYPERVISOR_hvm_op(HVMOP_get_param, &xhv); 45a8f6ac05SJustin T. Gibbs if (error) { 46a8f6ac05SJustin T. Gibbs printf("%s: error %d trying to get %d\n", __func__, 47a8f6ac05SJustin T. Gibbs error, index); 48a8f6ac05SJustin T. Gibbs return (0); 49a8f6ac05SJustin T. Gibbs } 50a8f6ac05SJustin T. Gibbs return (xhv.value); 51a8f6ac05SJustin T. Gibbs } 52a8f6ac05SJustin T. Gibbs 53a8f6ac05SJustin T. Gibbs /** The callback method types for Hypervisor event delivery to our domain. */ 54a8f6ac05SJustin T. Gibbs enum { 55a8f6ac05SJustin T. Gibbs HVM_CB_TYPE_GSI, 56a8f6ac05SJustin T. Gibbs HVM_CB_TYPE_PCI_INTX, 57a8f6ac05SJustin T. Gibbs HVM_CB_TYPE_VECTOR, 58a8f6ac05SJustin T. Gibbs HVM_CB_TYPE_MASK = 0xFF, 59a8f6ac05SJustin T. Gibbs HVM_CB_TYPE_SHIFT = 56 60a8f6ac05SJustin T. Gibbs }; 61a8f6ac05SJustin T. Gibbs 62a8f6ac05SJustin T. Gibbs /** Format for specifying a GSI type callback. */ 63a8f6ac05SJustin T. Gibbs enum { 64a8f6ac05SJustin T. Gibbs HVM_CB_GSI_GSI_MASK = 0xFFFFFFFF, 65a8f6ac05SJustin T. Gibbs HVM_CB_GSI_GSI_SHIFT = 0 66a8f6ac05SJustin T. Gibbs }; 67a8f6ac05SJustin T. Gibbs #define HVM_CALLBACK_GSI(gsi) \ 68a8f6ac05SJustin T. Gibbs (((uint64_t)HVM_CB_TYPE_GSI << HVM_CB_TYPE_SHIFT) \ 69a8f6ac05SJustin T. Gibbs | ((gsi) & HVM_CB_GSI_GSI_MASK) << HVM_CB_GSI_GSI_SHIFT) 70a8f6ac05SJustin T. Gibbs 71a8f6ac05SJustin T. Gibbs /** Format for specifying a virtual PCI interrupt line GSI style callback. */ 72a8f6ac05SJustin T. Gibbs enum { 73a8f6ac05SJustin T. Gibbs HVM_CB_PCI_INTX_INTPIN_MASK = 0x3, 74a8f6ac05SJustin T. Gibbs HVM_CB_PCI_INTX_INTPIN_SHIFT = 0, 75a8f6ac05SJustin T. Gibbs HVM_CB_PCI_INTX_SLOT_MASK = 0x1F, 76a8f6ac05SJustin T. Gibbs HVM_CB_PCI_INTX_SLOT_SHIFT = 11, 77a8f6ac05SJustin T. Gibbs }; 78a8f6ac05SJustin T. Gibbs #define HVM_CALLBACK_PCI_INTX(slot, pin) \ 79a8f6ac05SJustin T. Gibbs (((uint64_t)HVM_CB_TYPE_PCI_INTX << HVM_CB_TYPE_SHIFT) \ 80a8f6ac05SJustin T. Gibbs | (((slot) & HVM_CB_PCI_INTX_SLOT_MASK) << HVM_CB_PCI_INTX_SLOT_SHIFT) \ 81a8f6ac05SJustin T. Gibbs | (((pin) & HVM_CB_PCI_INTX_INTPIN_MASK) << HVM_CB_PCI_INTX_INTPIN_SHIFT)) 82a8f6ac05SJustin T. Gibbs 83a8f6ac05SJustin T. Gibbs /** Format for specifying a direct IDT vector injection style callback. */ 84a8f6ac05SJustin T. Gibbs enum { 85a8f6ac05SJustin T. Gibbs HVM_CB_VECTOR_VECTOR_MASK = 0xFFFFFFFF, 86a8f6ac05SJustin T. Gibbs HVM_CB_VECTOR_VECTOR_SHIFT = 0 87a8f6ac05SJustin T. Gibbs }; 88a8f6ac05SJustin T. Gibbs #define HVM_CALLBACK_VECTOR(vector) \ 89a8f6ac05SJustin T. Gibbs (((uint64_t)HVM_CB_TYPE_VECTOR << HVM_CB_TYPE_SHIFT) \ 90*6ac22dc3SAlan Robinson | (((vector) & HVM_CB_VECTOR_VECTOR_MASK) << HVM_CB_VECTOR_VECTOR_SHIFT)) 91a8f6ac05SJustin T. Gibbs 9207c2711fSRoger Pau Monné enum xen_hvm_init_type { 9307c2711fSRoger Pau Monné XEN_HVM_INIT_EARLY, 9407c2711fSRoger Pau Monné XEN_HVM_INIT_LATE, 9507c2711fSRoger Pau Monné XEN_HVM_INIT_CANCELLED_SUSPEND, 9607c2711fSRoger Pau Monné XEN_HVM_INIT_RESUME, 9707c2711fSRoger Pau Monné }; 9807c2711fSRoger Pau Monné 9907c2711fSRoger Pau Monné int xen_hvm_init_hypercall_stubs(enum xen_hvm_init_type); 100a8f6ac05SJustin T. Gibbs void xen_hvm_set_callback(device_t); 101a8f6ac05SJustin T. Gibbs void xen_hvm_suspend(void); 102428b7ca2SJustin T. Gibbs void xen_hvm_resume(bool suspend_cancelled); 103b0663c33SRoger Pau Monné 104b0663c33SRoger Pau Monné extern uint32_t hvm_start_flags; 105b0663c33SRoger Pau Monné 106a8f6ac05SJustin T. Gibbs #endif /* __XEN_HVM_H__ */ 107