/*-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#include <sys/pcpu.h>3233#ifndef _KERNEL34#error "no user-serviceable parts inside"35#endif3637struct xsave_limits {38int xsave_enabled;39uint64_t xcr0_allowed;40uint32_t xsave_max_size;41};4243void vmm_host_state_init(void);4445uint64_t vmm_get_host_pat(void);46uint64_t vmm_get_host_efer(void);47uint64_t vmm_get_host_cr0(void);48uint64_t vmm_get_host_cr4(void);49uint64_t vmm_get_host_xcr0(void);50uint64_t vmm_get_host_datasel(void);51uint64_t vmm_get_host_codesel(void);52uint64_t vmm_get_host_tsssel(void);53uint64_t vmm_get_host_fsbase(void);54uint64_t vmm_get_host_idtrbase(void);55const struct xsave_limits *vmm_get_xsave_limits(void);5657/*58* Inline access to host state that is used on every VM entry59*/60static __inline uint64_t61vmm_get_host_trbase(void)62{6364return ((uint64_t)PCPU_GET(tssp));65}6667static __inline uint64_t68vmm_get_host_gdtrbase(void)69{7071return ((uint64_t)*PCPU_PTR(gdt));72}7374static __inline uint64_t75vmm_get_host_gsbase(void)76{7778return ((uint64_t)get_pcpu());79}8081#endif828384