/*-1* SPDX-License-Identifier: BSD-2-Clause2*3* Copyright (c) 2012 NetApp, Inc.4* All rights reserved.5*6* Redistribution and use in source and binary forms, with or without7* modification, are permitted provided that the following conditions8* are met:9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11* 2. Redistributions in binary form must reproduce the above copyright12* notice, this list of conditions and the following disclaimer in the13* documentation and/or other materials provided with the distribution.14*15* THIS SOFTWARE IS PROVIDED BY NETAPP, INC ``AS IS'' AND16* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE17* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE18* ARE DISCLAIMED. IN NO EVENT SHALL NETAPP, INC OR CONTRIBUTORS BE LIABLE19* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL20* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS21* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)22* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT23* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY24* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF25* SUCH DAMAGE.26*/2728#ifndef _VMM_HOST_H_29#define _VMM_HOST_H_3031#ifndef _KERNEL32#error "no user-serviceable parts inside"33#endif3435struct xsave_limits {36int xsave_enabled;37uint64_t xcr0_allowed;38uint32_t xsave_max_size;39};4041void vmm_host_state_init(void);4243uint64_t vmm_get_host_pat(void);44uint64_t vmm_get_host_efer(void);45uint64_t vmm_get_host_cr0(void);46uint64_t vmm_get_host_cr4(void);47uint64_t vmm_get_host_xcr0(void);48uint64_t vmm_get_host_datasel(void);49uint64_t vmm_get_host_codesel(void);50uint64_t vmm_get_host_tsssel(void);51uint64_t vmm_get_host_fsbase(void);52uint64_t vmm_get_host_idtrbase(void);53const struct xsave_limits *vmm_get_xsave_limits(void);5455/*56* Inline access to host state that is used on every VM entry57*/58static __inline uint64_t59vmm_get_host_trbase(void)60{6162return ((uint64_t)PCPU_GET(tssp));63}6465static __inline uint64_t66vmm_get_host_gdtrbase(void)67{6869return ((uint64_t)*PCPU_PTR(gdt));70}7172static __inline uint64_t73vmm_get_host_gsbase(void)74{7576return ((uint64_t)get_pcpu());77}7879#endif808182