123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290 |
- /*
- * vti.h: prototype for generial vt related interface
- * Copyright (c) 2004, Intel Corporation.
- *
- * Xuefei Xu (Anthony Xu) (anthony.xu@intel.com)
- * Fred Yang (fred.yang@intel.com)
- * Kun Tian (Kevin Tian) (kevin.tian@intel.com)
- *
- * Copyright (c) 2007, Intel Corporation.
- * Zhang xiantao <xiantao.zhang@intel.com>
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms and conditions of the GNU General Public License,
- * version 2, as published by the Free Software Foundation.
- *
- * This program is distributed in the hope it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
- * Place - Suite 330, Boston, MA 02111-1307 USA.
- */
- #ifndef _KVM_VT_I_H
- #define _KVM_VT_I_H
- #ifndef __ASSEMBLY__
- #include <asm/page.h>
- #include <linux/kvm_host.h>
- /* define itr.i and itr.d in ia64_itr function */
- #define ITR 0x01
- #define DTR 0x02
- #define IaDTR 0x03
- #define IA64_TR_VMM 6 /*itr6, dtr6 : maps vmm code, vmbuffer*/
- #define IA64_TR_VM_DATA 7 /*dtr7 : maps current vm data*/
- #define RR6 (6UL<<61)
- #define RR7 (7UL<<61)
- /* config_options in pal_vp_init_env */
- #define VP_INITIALIZE 1UL
- #define VP_FR_PMC 1UL<<1
- #define VP_OPCODE 1UL<<8
- #define VP_CAUSE 1UL<<9
- #define VP_FW_ACC 1UL<<63
- /* init vp env with initializing vm_buffer */
- #define VP_INIT_ENV_INITALIZE (VP_INITIALIZE | VP_FR_PMC |\
- VP_OPCODE | VP_CAUSE | VP_FW_ACC)
- /* init vp env without initializing vm_buffer */
- #define VP_INIT_ENV VP_FR_PMC | VP_OPCODE | VP_CAUSE | VP_FW_ACC
- #define PAL_VP_CREATE 265
- /* Stacked Virt. Initializes a new VPD for the operation of
- * a new virtual processor in the virtual environment.
- */
- #define PAL_VP_ENV_INFO 266
- /*Stacked Virt. Returns the parameters needed to enter a virtual environment.*/
- #define PAL_VP_EXIT_ENV 267
- /*Stacked Virt. Allows a logical processor to exit a virtual environment.*/
- #define PAL_VP_INIT_ENV 268
- /*Stacked Virt. Allows a logical processor to enter a virtual environment.*/
- #define PAL_VP_REGISTER 269
- /*Stacked Virt. Register a different host IVT for the virtual processor.*/
- #define PAL_VP_RESUME 270
- /* Renamed from PAL_VP_RESUME */
- #define PAL_VP_RESTORE 270
- /*Stacked Virt. Resumes virtual processor operation on the logical processor.*/
- #define PAL_VP_SUSPEND 271
- /* Renamed from PAL_VP_SUSPEND */
- #define PAL_VP_SAVE 271
- /* Stacked Virt. Suspends operation for the specified virtual processor on
- * the logical processor.
- */
- #define PAL_VP_TERMINATE 272
- /* Stacked Virt. Terminates operation for the specified virtual processor.*/
- union vac {
- unsigned long value;
- struct {
- int a_int:1;
- int a_from_int_cr:1;
- int a_to_int_cr:1;
- int a_from_psr:1;
- int a_from_cpuid:1;
- int a_cover:1;
- int a_bsw:1;
- long reserved:57;
- };
- };
- union vdc {
- unsigned long value;
- struct {
- int d_vmsw:1;
- int d_extint:1;
- int d_ibr_dbr:1;
- int d_pmc:1;
- int d_to_pmd:1;
- int d_itm:1;
- long reserved:58;
- };
- };
- struct vpd {
- union vac vac;
- union vdc vdc;
- unsigned long virt_env_vaddr;
- unsigned long reserved1[29];
- unsigned long vhpi;
- unsigned long reserved2[95];
- unsigned long vgr[16];
- unsigned long vbgr[16];
- unsigned long vnat;
- unsigned long vbnat;
- unsigned long vcpuid[5];
- unsigned long reserved3[11];
- unsigned long vpsr;
- unsigned long vpr;
- unsigned long reserved4[76];
- union {
- unsigned long vcr[128];
- struct {
- unsigned long dcr;
- unsigned long itm;
- unsigned long iva;
- unsigned long rsv1[5];
- unsigned long pta;
- unsigned long rsv2[7];
- unsigned long ipsr;
- unsigned long isr;
- unsigned long rsv3;
- unsigned long iip;
- unsigned long ifa;
- unsigned long itir;
- unsigned long iipa;
- unsigned long ifs;
- unsigned long iim;
- unsigned long iha;
- unsigned long rsv4[38];
- unsigned long lid;
- unsigned long ivr;
- unsigned long tpr;
- unsigned long eoi;
- unsigned long irr[4];
- unsigned long itv;
- unsigned long pmv;
- unsigned long cmcv;
- unsigned long rsv5[5];
- unsigned long lrr0;
- unsigned long lrr1;
- unsigned long rsv6[46];
- };
- };
- unsigned long reserved5[128];
- unsigned long reserved6[3456];
- unsigned long vmm_avail[128];
- unsigned long reserved7[4096];
- };
- #define PAL_PROC_VM_BIT (1UL << 40)
- #define PAL_PROC_VMSW_BIT (1UL << 54)
- static inline s64 ia64_pal_vp_env_info(u64 *buffer_size,
- u64 *vp_env_info)
- {
- struct ia64_pal_retval iprv;
- PAL_CALL_STK(iprv, PAL_VP_ENV_INFO, 0, 0, 0);
- *buffer_size = iprv.v0;
- *vp_env_info = iprv.v1;
- return iprv.status;
- }
- static inline s64 ia64_pal_vp_exit_env(u64 iva)
- {
- struct ia64_pal_retval iprv;
- PAL_CALL_STK(iprv, PAL_VP_EXIT_ENV, (u64)iva, 0, 0);
- return iprv.status;
- }
- static inline s64 ia64_pal_vp_init_env(u64 config_options, u64 pbase_addr,
- u64 vbase_addr, u64 *vsa_base)
- {
- struct ia64_pal_retval iprv;
- PAL_CALL_STK(iprv, PAL_VP_INIT_ENV, config_options, pbase_addr,
- vbase_addr);
- *vsa_base = iprv.v0;
- return iprv.status;
- }
- static inline s64 ia64_pal_vp_restore(u64 *vpd, u64 pal_proc_vector)
- {
- struct ia64_pal_retval iprv;
- PAL_CALL_STK(iprv, PAL_VP_RESTORE, (u64)vpd, pal_proc_vector, 0);
- return iprv.status;
- }
- static inline s64 ia64_pal_vp_save(u64 *vpd, u64 pal_proc_vector)
- {
- struct ia64_pal_retval iprv;
- PAL_CALL_STK(iprv, PAL_VP_SAVE, (u64)vpd, pal_proc_vector, 0);
- return iprv.status;
- }
- #endif
- /*VPD field offset*/
- #define VPD_VAC_START_OFFSET 0
- #define VPD_VDC_START_OFFSET 8
- #define VPD_VHPI_START_OFFSET 256
- #define VPD_VGR_START_OFFSET 1024
- #define VPD_VBGR_START_OFFSET 1152
- #define VPD_VNAT_START_OFFSET 1280
- #define VPD_VBNAT_START_OFFSET 1288
- #define VPD_VCPUID_START_OFFSET 1296
- #define VPD_VPSR_START_OFFSET 1424
- #define VPD_VPR_START_OFFSET 1432
- #define VPD_VRSE_CFLE_START_OFFSET 1440
- #define VPD_VCR_START_OFFSET 2048
- #define VPD_VTPR_START_OFFSET 2576
- #define VPD_VRR_START_OFFSET 3072
- #define VPD_VMM_VAIL_START_OFFSET 31744
- /*Virtualization faults*/
- #define EVENT_MOV_TO_AR 1
- #define EVENT_MOV_TO_AR_IMM 2
- #define EVENT_MOV_FROM_AR 3
- #define EVENT_MOV_TO_CR 4
- #define EVENT_MOV_FROM_CR 5
- #define EVENT_MOV_TO_PSR 6
- #define EVENT_MOV_FROM_PSR 7
- #define EVENT_ITC_D 8
- #define EVENT_ITC_I 9
- #define EVENT_MOV_TO_RR 10
- #define EVENT_MOV_TO_DBR 11
- #define EVENT_MOV_TO_IBR 12
- #define EVENT_MOV_TO_PKR 13
- #define EVENT_MOV_TO_PMC 14
- #define EVENT_MOV_TO_PMD 15
- #define EVENT_ITR_D 16
- #define EVENT_ITR_I 17
- #define EVENT_MOV_FROM_RR 18
- #define EVENT_MOV_FROM_DBR 19
- #define EVENT_MOV_FROM_IBR 20
- #define EVENT_MOV_FROM_PKR 21
- #define EVENT_MOV_FROM_PMC 22
- #define EVENT_MOV_FROM_CPUID 23
- #define EVENT_SSM 24
- #define EVENT_RSM 25
- #define EVENT_PTC_L 26
- #define EVENT_PTC_G 27
- #define EVENT_PTC_GA 28
- #define EVENT_PTR_D 29
- #define EVENT_PTR_I 30
- #define EVENT_THASH 31
- #define EVENT_TTAG 32
- #define EVENT_TPA 33
- #define EVENT_TAK 34
- #define EVENT_PTC_E 35
- #define EVENT_COVER 36
- #define EVENT_RFI 37
- #define EVENT_BSW_0 38
- #define EVENT_BSW_1 39
- #define EVENT_VMSW 40
- /**PAL virtual services offsets */
- #define PAL_VPS_RESUME_NORMAL 0x0000
- #define PAL_VPS_RESUME_HANDLER 0x0400
- #define PAL_VPS_SYNC_READ 0x0800
- #define PAL_VPS_SYNC_WRITE 0x0c00
- #define PAL_VPS_SET_PENDING_INTERRUPT 0x1000
- #define PAL_VPS_THASH 0x1400
- #define PAL_VPS_TTAG 0x1800
- #define PAL_VPS_RESTORE 0x1c00
- #define PAL_VPS_SAVE 0x2000
- #endif/* _VT_I_H*/
|