KVM: ia64: remove
authorPaolo Bonzini <pbonzini@redhat.com>
Wed, 19 Nov 2014 15:22:52 +0000 (16:22 +0100)
committerPaolo Bonzini <pbonzini@redhat.com>
Thu, 20 Nov 2014 10:08:33 +0000 (11:08 +0100)
KVM for ia64 has been marked as broken not just once, but twice even,
and the last patch from the maintainer is now roughly 5 years old.
Time for it to rest in peace.

Acked-by: Gleb Natapov <gleb@kernel.org>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
31 files changed:
MAINTAINERS
arch/ia64/Kconfig
arch/ia64/Makefile
arch/ia64/include/asm/kvm_host.h [deleted file]
arch/ia64/include/asm/pvclock-abi.h [deleted file]
arch/ia64/include/uapi/asm/kvm.h [deleted file]
arch/ia64/kvm/Kconfig [deleted file]
arch/ia64/kvm/Makefile [deleted file]
arch/ia64/kvm/asm-offsets.c [deleted file]
arch/ia64/kvm/irq.h [deleted file]
arch/ia64/kvm/kvm-ia64.c [deleted file]
arch/ia64/kvm/kvm_fw.c [deleted file]
arch/ia64/kvm/kvm_lib.c [deleted file]
arch/ia64/kvm/kvm_minstate.h [deleted file]
arch/ia64/kvm/lapic.h [deleted file]
arch/ia64/kvm/memcpy.S [deleted file]
arch/ia64/kvm/memset.S [deleted file]
arch/ia64/kvm/misc.h [deleted file]
arch/ia64/kvm/mmio.c [deleted file]
arch/ia64/kvm/optvfault.S [deleted file]
arch/ia64/kvm/process.c [deleted file]
arch/ia64/kvm/trampoline.S [deleted file]
arch/ia64/kvm/vcpu.c [deleted file]
arch/ia64/kvm/vcpu.h [deleted file]
arch/ia64/kvm/vmm.c [deleted file]
arch/ia64/kvm/vmm_ivt.S [deleted file]
arch/ia64/kvm/vti.h [deleted file]
arch/ia64/kvm/vtlb.c [deleted file]
virt/kvm/ioapic.c
virt/kvm/ioapic.h
virt/kvm/irq_comm.c

index 3c6427190be2a4e821eb24cd9e9b0ca25086776a..0b8321afa35a0aba78709970c2335a189fc60e34 100644 (file)
@@ -5352,15 +5352,6 @@ S:       Supported
 F:     arch/powerpc/include/asm/kvm*
 F:     arch/powerpc/kvm/
 
-KERNEL VIRTUAL MACHINE For Itanium (KVM/IA64)
-M:     Xiantao Zhang <xiantao.zhang@intel.com>
-L:     kvm-ia64@vger.kernel.org
-W:     http://kvm.qumranet.com
-S:     Supported
-F:     Documentation/ia64/kvm.txt
-F:     arch/ia64/include/asm/kvm*
-F:     arch/ia64/kvm/
-
 KERNEL VIRTUAL MACHINE for s390 (KVM/s390)
 M:     Christian Borntraeger <borntraeger@de.ibm.com>
 M:     Cornelia Huck <cornelia.huck@de.ibm.com>
index c84c88bbbbd79abd66d7cd919bdd7507b0c26b07..11afe7ab19811278bb883b482f2e0865f22c6265 100644 (file)
@@ -21,7 +21,6 @@ config IA64
        select HAVE_DYNAMIC_FTRACE if (!ITANIUM)
        select HAVE_FUNCTION_TRACER
        select HAVE_DMA_ATTRS
-       select HAVE_KVM
        select TTY
        select HAVE_ARCH_TRACEHOOK
        select HAVE_DMA_API_DEBUG
@@ -640,8 +639,6 @@ source "security/Kconfig"
 
 source "crypto/Kconfig"
 
-source "arch/ia64/kvm/Kconfig"
-
 source "lib/Kconfig"
 
 config IOMMU_HELPER
index 5441b14994fccf46ebb6d6926186800b5ae11272..970d0bd99621b32eef163debccd8c2d41a970250 100644 (file)
@@ -53,7 +53,6 @@ core-$(CONFIG_IA64_HP_ZX1)    += arch/ia64/dig/
 core-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/dig/
 core-$(CONFIG_IA64_SGI_SN2)    += arch/ia64/sn/
 core-$(CONFIG_IA64_SGI_UV)     += arch/ia64/uv/
-core-$(CONFIG_KVM)             += arch/ia64/kvm/
 
 drivers-$(CONFIG_PCI)          += arch/ia64/pci/
 drivers-$(CONFIG_IA64_HP_SIM)  += arch/ia64/hp/sim/
diff --git a/arch/ia64/include/asm/kvm_host.h b/arch/ia64/include/asm/kvm_host.h
deleted file mode 100644 (file)
index 4729752..0000000
+++ /dev/null
@@ -1,609 +0,0 @@
-/*
- * kvm_host.h: used for kvm module, and hold ia64-specific sections.
- *
- * Copyright (C) 2007, Intel Corporation.
- *
- * Xiantao Zhang <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 __ASM_KVM_HOST_H
-#define __ASM_KVM_HOST_H
-
-#define KVM_USER_MEM_SLOTS 32
-
-#define KVM_COALESCED_MMIO_PAGE_OFFSET 1
-#define KVM_IRQCHIP_NUM_PINS  KVM_IOAPIC_NUM_PINS
-
-/* define exit reasons from vmm to kvm*/
-#define EXIT_REASON_VM_PANIC           0
-#define EXIT_REASON_MMIO_INSTRUCTION   1
-#define EXIT_REASON_PAL_CALL           2
-#define EXIT_REASON_SAL_CALL           3
-#define EXIT_REASON_SWITCH_RR6         4
-#define EXIT_REASON_VM_DESTROY         5
-#define EXIT_REASON_EXTERNAL_INTERRUPT 6
-#define EXIT_REASON_IPI                        7
-#define EXIT_REASON_PTC_G              8
-#define EXIT_REASON_DEBUG              20
-
-/*Define vmm address space and vm data space.*/
-#define KVM_VMM_SIZE (__IA64_UL_CONST(16)<<20)
-#define KVM_VMM_SHIFT 24
-#define KVM_VMM_BASE 0xD000000000000000
-#define VMM_SIZE (__IA64_UL_CONST(8)<<20)
-
-/*
- * Define vm_buffer, used by PAL Services, base address.
- * Note: vm_buffer is in the VMM-BLOCK, the size must be < 8M
- */
-#define KVM_VM_BUFFER_BASE (KVM_VMM_BASE + VMM_SIZE)
-#define KVM_VM_BUFFER_SIZE (__IA64_UL_CONST(8)<<20)
-
-/*
- * kvm guest's data area looks as follow:
- *
- *            +----------------------+ ------- KVM_VM_DATA_SIZE
- *           |     vcpu[n]'s data   |   |     ___________________KVM_STK_OFFSET
- *                   |                      |   |    /                   |
- *                   |        ..........    |   |   /vcpu's struct&stack |
- *                   |        ..........    |   |  /---------------------|---- 0
- *           |     vcpu[5]'s data   |   | /       vpd            |
- *           |     vcpu[4]'s data   |   |/-----------------------|
- *           |     vcpu[3]'s data   |   /         vtlb           |
- *           |     vcpu[2]'s data   |  /|------------------------|
- *           |     vcpu[1]'s data   |/  |         vhpt           |
- *           |     vcpu[0]'s data   |____________________________|
- *            +----------------------+  |
- *           |    memory dirty log  |   |
- *            +----------------------+  |
- *           |    vm's data struct  |   |
- *            +----------------------+  |
- *           |                      |   |
- *           |                      |   |
- *           |                      |   |
- *           |                      |   |
- *           |                      |   |
- *           |                      |   |
- *           |                      |   |
- *           |   vm's p2m table  |      |
- *           |                      |   |
- *            |                             |   |
- *           |                      |   |  |
- * vm's data->|                             |   |  |
- *           +----------------------+ ------- 0
- * To support large memory, needs to increase the size of p2m.
- * To support more vcpus, needs to ensure it has enough space to
- * hold vcpus' data.
- */
-
-#define KVM_VM_DATA_SHIFT      26
-#define KVM_VM_DATA_SIZE       (__IA64_UL_CONST(1) << KVM_VM_DATA_SHIFT)
-#define KVM_VM_DATA_BASE       (KVM_VMM_BASE + KVM_VM_DATA_SIZE)
-
-#define KVM_P2M_BASE           KVM_VM_DATA_BASE
-#define KVM_P2M_SIZE           (__IA64_UL_CONST(24) << 20)
-
-#define VHPT_SHIFT             16
-#define VHPT_SIZE              (__IA64_UL_CONST(1) << VHPT_SHIFT)
-#define VHPT_NUM_ENTRIES       (__IA64_UL_CONST(1) << (VHPT_SHIFT-5))
-
-#define VTLB_SHIFT             16
-#define VTLB_SIZE              (__IA64_UL_CONST(1) << VTLB_SHIFT)
-#define VTLB_NUM_ENTRIES       (1UL << (VHPT_SHIFT-5))
-
-#define VPD_SHIFT              16
-#define VPD_SIZE               (__IA64_UL_CONST(1) << VPD_SHIFT)
-
-#define VCPU_STRUCT_SHIFT      16
-#define VCPU_STRUCT_SIZE       (__IA64_UL_CONST(1) << VCPU_STRUCT_SHIFT)
-
-/*
- * This must match KVM_IA64_VCPU_STACK_{SHIFT,SIZE} arch/ia64/include/asm/kvm.h
- */
-#define KVM_STK_SHIFT          16
-#define KVM_STK_OFFSET         (__IA64_UL_CONST(1)<< KVM_STK_SHIFT)
-
-#define KVM_VM_STRUCT_SHIFT    19
-#define KVM_VM_STRUCT_SIZE     (__IA64_UL_CONST(1) << KVM_VM_STRUCT_SHIFT)
-
-#define KVM_MEM_DIRY_LOG_SHIFT 19
-#define KVM_MEM_DIRTY_LOG_SIZE (__IA64_UL_CONST(1) << KVM_MEM_DIRY_LOG_SHIFT)
-
-#ifndef __ASSEMBLY__
-
-/*Define the max vcpus and memory for Guests.*/
-#define KVM_MAX_VCPUS  (KVM_VM_DATA_SIZE - KVM_P2M_SIZE - KVM_VM_STRUCT_SIZE -\
-                       KVM_MEM_DIRTY_LOG_SIZE) / sizeof(struct kvm_vcpu_data)
-#define KVM_MAX_MEM_SIZE (KVM_P2M_SIZE >> 3 << PAGE_SHIFT)
-
-#define VMM_LOG_LEN 256
-
-#include <linux/types.h>
-#include <linux/mm.h>
-#include <linux/kvm.h>
-#include <linux/kvm_para.h>
-#include <linux/kvm_types.h>
-
-#include <asm/pal.h>
-#include <asm/sal.h>
-#include <asm/page.h>
-
-struct kvm_vcpu_data {
-       char vcpu_vhpt[VHPT_SIZE];
-       char vcpu_vtlb[VTLB_SIZE];
-       char vcpu_vpd[VPD_SIZE];
-       char vcpu_struct[VCPU_STRUCT_SIZE];
-};
-
-struct kvm_vm_data {
-       char kvm_p2m[KVM_P2M_SIZE];
-       char kvm_vm_struct[KVM_VM_STRUCT_SIZE];
-       char kvm_mem_dirty_log[KVM_MEM_DIRTY_LOG_SIZE];
-       struct kvm_vcpu_data vcpu_data[KVM_MAX_VCPUS];
-};
-
-#define VCPU_BASE(n)   (KVM_VM_DATA_BASE + \
-                               offsetof(struct kvm_vm_data, vcpu_data[n]))
-#define KVM_VM_BASE    (KVM_VM_DATA_BASE + \
-                               offsetof(struct kvm_vm_data, kvm_vm_struct))
-#define KVM_MEM_DIRTY_LOG_BASE KVM_VM_DATA_BASE + \
-                               offsetof(struct kvm_vm_data, kvm_mem_dirty_log)
-
-#define VHPT_BASE(n) (VCPU_BASE(n) + offsetof(struct kvm_vcpu_data, vcpu_vhpt))
-#define VTLB_BASE(n) (VCPU_BASE(n) + offsetof(struct kvm_vcpu_data, vcpu_vtlb))
-#define VPD_BASE(n)  (VCPU_BASE(n) + offsetof(struct kvm_vcpu_data, vcpu_vpd))
-#define VCPU_STRUCT_BASE(n)    (VCPU_BASE(n) + \
-                               offsetof(struct kvm_vcpu_data, vcpu_struct))
-
-/*IO section definitions*/
-#define IOREQ_READ      1
-#define IOREQ_WRITE     0
-
-#define STATE_IOREQ_NONE        0
-#define STATE_IOREQ_READY       1
-#define STATE_IOREQ_INPROCESS   2
-#define STATE_IORESP_READY      3
-
-/*Guest Physical address layout.*/
-#define GPFN_MEM        (0UL << 60) /* Guest pfn is normal mem */
-#define GPFN_FRAME_BUFFER   (1UL << 60) /* VGA framebuffer */
-#define GPFN_LOW_MMIO       (2UL << 60) /* Low MMIO range */
-#define GPFN_PIB        (3UL << 60) /* PIB base */
-#define GPFN_IOSAPIC        (4UL << 60) /* IOSAPIC base */
-#define GPFN_LEGACY_IO      (5UL << 60) /* Legacy I/O base */
-#define GPFN_GFW        (6UL << 60) /* Guest Firmware */
-#define GPFN_PHYS_MMIO      (7UL << 60) /* Directed MMIO Range */
-
-#define GPFN_IO_MASK        (7UL << 60) /* Guest pfn is I/O type */
-#define GPFN_INV_MASK       (1UL << 63) /* Guest pfn is invalid */
-#define INVALID_MFN       (~0UL)
-#define MEM_G   (1UL << 30)
-#define MEM_M   (1UL << 20)
-#define MMIO_START       (3 * MEM_G)
-#define MMIO_SIZE        (512 * MEM_M)
-#define VGA_IO_START     0xA0000UL
-#define VGA_IO_SIZE      0x20000
-#define LEGACY_IO_START  (MMIO_START + MMIO_SIZE)
-#define LEGACY_IO_SIZE   (64 * MEM_M)
-#define IO_SAPIC_START   0xfec00000UL
-#define IO_SAPIC_SIZE    0x100000
-#define PIB_START 0xfee00000UL
-#define PIB_SIZE 0x200000
-#define GFW_START        (4 * MEM_G - 16 * MEM_M)
-#define GFW_SIZE         (16 * MEM_M)
-
-/*Deliver mode, defined for ioapic.c*/
-#define dest_Fixed IOSAPIC_FIXED
-#define dest_LowestPrio IOSAPIC_LOWEST_PRIORITY
-
-#define NMI_VECTOR                     2
-#define ExtINT_VECTOR                  0
-#define NULL_VECTOR                    (-1)
-#define IA64_SPURIOUS_INT_VECTOR       0x0f
-
-#define VCPU_LID(v) (((u64)(v)->vcpu_id) << 24)
-
-/*
- *Delivery mode
- */
-#define SAPIC_DELIV_SHIFT      8
-#define SAPIC_FIXED            0x0
-#define SAPIC_LOWEST_PRIORITY  0x1
-#define SAPIC_PMI              0x2
-#define SAPIC_NMI              0x4
-#define SAPIC_INIT             0x5
-#define SAPIC_EXTINT           0x7
-
-/*
- * vcpu->requests bit members for arch
- */
-#define KVM_REQ_PTC_G          32
-#define KVM_REQ_RESUME         33
-
-struct kvm_mmio_req {
-       uint64_t addr;          /*  physical address            */
-       uint64_t size;          /*  size in bytes               */
-       uint64_t data;          /*  data (or paddr of data)     */
-       uint8_t state:4;
-       uint8_t dir:1;          /*  1=read, 0=write             */
-};
-
-/*Pal data struct */
-struct kvm_pal_call{
-       /*In area*/
-       uint64_t gr28;
-       uint64_t gr29;
-       uint64_t gr30;
-       uint64_t gr31;
-       /*Out area*/
-       struct ia64_pal_retval ret;
-};
-
-/* Sal data structure */
-struct kvm_sal_call{
-       /*In area*/
-       uint64_t in0;
-       uint64_t in1;
-       uint64_t in2;
-       uint64_t in3;
-       uint64_t in4;
-       uint64_t in5;
-       uint64_t in6;
-       uint64_t in7;
-       struct sal_ret_values ret;
-};
-
-/*Guest change rr6*/
-struct kvm_switch_rr6 {
-       uint64_t old_rr;
-       uint64_t new_rr;
-};
-
-union ia64_ipi_a{
-       unsigned long val;
-       struct {
-               unsigned long rv  : 3;
-               unsigned long ir  : 1;
-               unsigned long eid : 8;
-               unsigned long id  : 8;
-               unsigned long ib_base : 44;
-       };
-};
-
-union ia64_ipi_d {
-       unsigned long val;
-       struct {
-               unsigned long vector : 8;
-               unsigned long dm  : 3;
-               unsigned long ig  : 53;
-       };
-};
-
-/*ipi check exit data*/
-struct kvm_ipi_data{
-       union ia64_ipi_a addr;
-       union ia64_ipi_d data;
-};
-
-/*global purge data*/
-struct kvm_ptc_g {
-       unsigned long vaddr;
-       unsigned long rr;
-       unsigned long ps;
-       struct kvm_vcpu *vcpu;
-};
-
-/*Exit control data */
-struct exit_ctl_data{
-       uint32_t exit_reason;
-       uint32_t vm_status;
-       union {
-               struct kvm_mmio_req     ioreq;
-               struct kvm_pal_call     pal_data;
-               struct kvm_sal_call     sal_data;
-               struct kvm_switch_rr6   rr_data;
-               struct kvm_ipi_data     ipi_data;
-               struct kvm_ptc_g        ptc_g_data;
-       } u;
-};
-
-union pte_flags {
-       unsigned long val;
-       struct {
-               unsigned long p    :  1; /*0      */
-               unsigned long      :  1; /* 1     */
-               unsigned long ma   :  3; /* 2-4   */
-               unsigned long a    :  1; /* 5     */
-               unsigned long d    :  1; /* 6     */
-               unsigned long pl   :  2; /* 7-8   */
-               unsigned long ar   :  3; /* 9-11  */
-               unsigned long ppn  : 38; /* 12-49 */
-               unsigned long      :  2; /* 50-51 */
-               unsigned long ed   :  1; /* 52    */
-       };
-};
-
-union ia64_pta {
-       unsigned long val;
-       struct {
-               unsigned long ve : 1;
-               unsigned long reserved0 : 1;
-               unsigned long size : 6;
-               unsigned long vf : 1;
-               unsigned long reserved1 : 6;
-               unsigned long base : 49;
-       };
-};
-
-struct thash_cb {
-       /* THASH base information */
-       struct thash_data       *hash; /* hash table pointer */
-       union ia64_pta          pta;
-       int           num;
-};
-
-struct kvm_vcpu_stat {
-       u32 halt_wakeup;
-};
-
-struct kvm_vcpu_arch {
-       int launched;
-       int last_exit;
-       int last_run_cpu;
-       int vmm_tr_slot;
-       int vm_tr_slot;
-       int sn_rtc_tr_slot;
-
-#define KVM_MP_STATE_RUNNABLE          0
-#define KVM_MP_STATE_UNINITIALIZED     1
-#define KVM_MP_STATE_INIT_RECEIVED     2
-#define KVM_MP_STATE_HALTED            3
-       int mp_state;
-
-#define MAX_PTC_G_NUM                  3
-       int ptc_g_count;
-       struct kvm_ptc_g ptc_g_data[MAX_PTC_G_NUM];
-
-       /*halt timer to wake up sleepy vcpus*/
-       struct hrtimer hlt_timer;
-       long ht_active;
-
-       struct kvm_lapic *apic;    /* kernel irqchip context */
-       struct vpd *vpd;
-
-       /* Exit data for vmm_transition*/
-       struct exit_ctl_data exit_data;
-
-       cpumask_t cache_coherent_map;
-
-       unsigned long vmm_rr;
-       unsigned long host_rr6;
-       unsigned long psbits[8];
-       unsigned long cr_iipa;
-       unsigned long cr_isr;
-       unsigned long vsa_base;
-       unsigned long dirty_log_lock_pa;
-       unsigned long __gp;
-       /* TR and TC.  */
-       struct thash_data itrs[NITRS];
-       struct thash_data dtrs[NDTRS];
-       /* Bit is set if there is a tr/tc for the region.  */
-       unsigned char itr_regions;
-       unsigned char dtr_regions;
-       unsigned char tc_regions;
-       /* purge all */
-       unsigned long ptce_base;
-       unsigned long ptce_count[2];
-       unsigned long ptce_stride[2];
-       /* itc/itm */
-       unsigned long last_itc;
-       long itc_offset;
-       unsigned long itc_check;
-       unsigned long timer_check;
-       unsigned int timer_pending;
-       unsigned int timer_fired;
-
-       unsigned long vrr[8];
-       unsigned long ibr[8];
-       unsigned long dbr[8];
-       unsigned long insvc[4];         /* Interrupt in service.  */
-       unsigned long xtp;
-
-       unsigned long metaphysical_rr0; /* from kvm_arch (so is pinned) */
-       unsigned long metaphysical_rr4; /* from kvm_arch (so is pinned) */
-       unsigned long metaphysical_saved_rr0; /* from kvm_arch          */
-       unsigned long metaphysical_saved_rr4; /* from kvm_arch          */
-       unsigned long fp_psr;       /*used for lazy float register */
-       unsigned long saved_gp;
-       /*for phycial  emulation */
-       int mode_flags;
-       struct thash_cb vtlb;
-       struct thash_cb vhpt;
-       char irq_check;
-       char irq_new_pending;
-
-       unsigned long opcode;
-       unsigned long cause;
-       char log_buf[VMM_LOG_LEN];
-       union context host;
-       union context guest;
-
-       char mmio_data[8];
-};
-
-struct kvm_vm_stat {
-       u64 remote_tlb_flush;
-};
-
-struct kvm_sal_data {
-       unsigned long boot_ip;
-       unsigned long boot_gp;
-};
-
-struct kvm_arch_memory_slot {
-};
-
-struct kvm_arch {
-       spinlock_t dirty_log_lock;
-
-       unsigned long   vm_base;
-       unsigned long   metaphysical_rr0;
-       unsigned long   metaphysical_rr4;
-       unsigned long   vmm_init_rr;
-
-       int             is_sn2;
-
-       struct kvm_ioapic *vioapic;
-       struct kvm_vm_stat stat;
-       struct kvm_sal_data rdv_sal_data;
-
-       struct list_head assigned_dev_head;
-       struct iommu_domain *iommu_domain;
-       bool iommu_noncoherent;
-
-       unsigned long irq_sources_bitmap;
-       unsigned long irq_states[KVM_IOAPIC_NUM_PINS];
-};
-
-union cpuid3_t {
-       u64 value;
-       struct {
-               u64 number : 8;
-               u64 revision : 8;
-               u64 model : 8;
-               u64 family : 8;
-               u64 archrev : 8;
-               u64 rv : 24;
-       };
-};
-
-struct kvm_pt_regs {
-       /* The following registers are saved by SAVE_MIN: */
-       unsigned long b6;  /* scratch */
-       unsigned long b7;  /* scratch */
-
-       unsigned long ar_csd; /* used by cmp8xchg16 (scratch) */
-       unsigned long ar_ssd; /* reserved for future use (scratch) */
-
-       unsigned long r8;  /* scratch (return value register 0) */
-       unsigned long r9;  /* scratch (return value register 1) */
-       unsigned long r10; /* scratch (return value register 2) */
-       unsigned long r11; /* scratch (return value register 3) */
-
-       unsigned long cr_ipsr; /* interrupted task's psr */
-       unsigned long cr_iip;  /* interrupted task's instruction pointer */
-       unsigned long cr_ifs;  /* interrupted task's function state */
-
-       unsigned long ar_unat; /* interrupted task's NaT register (preserved) */
-       unsigned long ar_pfs;  /* prev function state  */
-       unsigned long ar_rsc;  /* RSE configuration */
-       /* The following two are valid only if cr_ipsr.cpl > 0: */
-       unsigned long ar_rnat;  /* RSE NaT */
-       unsigned long ar_bspstore; /* RSE bspstore */
-
-       unsigned long pr;  /* 64 predicate registers (1 bit each) */
-       unsigned long b0;  /* return pointer (bp) */
-       unsigned long loadrs;  /* size of dirty partition << 16 */
-
-       unsigned long r1;  /* the gp pointer */
-       unsigned long r12; /* interrupted task's memory stack pointer */
-       unsigned long r13; /* thread pointer */
-
-       unsigned long ar_fpsr;  /* floating point status (preserved) */
-       unsigned long r15;  /* scratch */
-
-       /* The remaining registers are NOT saved for system calls.  */
-       unsigned long r14;  /* scratch */
-       unsigned long r2;  /* scratch */
-       unsigned long r3;  /* scratch */
-       unsigned long r16;  /* scratch */
-       unsigned long r17;  /* scratch */
-       unsigned long r18;  /* scratch */
-       unsigned long r19;  /* scratch */
-       unsigned long r20;  /* scratch */
-       unsigned long r21;  /* scratch */
-       unsigned long r22;  /* scratch */
-       unsigned long r23;  /* scratch */
-       unsigned long r24;  /* scratch */
-       unsigned long r25;  /* scratch */
-       unsigned long r26;  /* scratch */
-       unsigned long r27;  /* scratch */
-       unsigned long r28;  /* scratch */
-       unsigned long r29;  /* scratch */
-       unsigned long r30;  /* scratch */
-       unsigned long r31;  /* scratch */
-       unsigned long ar_ccv;  /* compare/exchange value (scratch) */
-
-       /*
-        * Floating point registers that the kernel considers scratch:
-        */
-       struct ia64_fpreg f6;  /* scratch */
-       struct ia64_fpreg f7;  /* scratch */
-       struct ia64_fpreg f8;  /* scratch */
-       struct ia64_fpreg f9;  /* scratch */
-       struct ia64_fpreg f10;  /* scratch */
-       struct ia64_fpreg f11;  /* scratch */
-
-       unsigned long r4;  /* preserved */
-       unsigned long r5;  /* preserved */
-       unsigned long r6;  /* preserved */
-       unsigned long r7;  /* preserved */
-       unsigned long eml_unat;    /* used for emulating instruction */
-       unsigned long pad0;     /* alignment pad */
-};
-
-static inline struct kvm_pt_regs *vcpu_regs(struct kvm_vcpu *v)
-{
-       return (struct kvm_pt_regs *) ((unsigned long) v + KVM_STK_OFFSET) - 1;
-}
-
-typedef int kvm_vmm_entry(void);
-typedef void kvm_tramp_entry(union context *host, union context *guest);
-
-struct kvm_vmm_info{
-       struct module   *module;
-       kvm_vmm_entry   *vmm_entry;
-       kvm_tramp_entry *tramp_entry;
-       unsigned long   vmm_ivt;
-       unsigned long   patch_mov_ar;
-       unsigned long   patch_mov_ar_sn2;
-};
-
-int kvm_highest_pending_irq(struct kvm_vcpu *vcpu);
-int kvm_emulate_halt(struct kvm_vcpu *vcpu);
-int kvm_pal_emul(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run);
-void kvm_sal_emul(struct kvm_vcpu *vcpu);
-
-#define __KVM_HAVE_ARCH_VM_ALLOC 1
-struct kvm *kvm_arch_alloc_vm(void);
-void kvm_arch_free_vm(struct kvm *kvm);
-
-static inline void kvm_arch_sync_events(struct kvm *kvm) {}
-static inline void kvm_arch_vcpu_put(struct kvm_vcpu *vcpu) {}
-static inline void kvm_arch_sched_in(struct kvm_vcpu *vcpu) {}
-static inline void kvm_arch_free_memslot(struct kvm *kvm,
-               struct kvm_memory_slot *free, struct kvm_memory_slot *dont) {}
-static inline void kvm_arch_memslots_updated(struct kvm *kvm) {}
-static inline void kvm_arch_commit_memory_region(struct kvm *kvm,
-               struct kvm_userspace_memory_region *mem,
-               const struct kvm_memory_slot *old,
-               enum kvm_mr_change change) {}
-static inline void kvm_arch_hardware_unsetup(void) {}
-
-#endif /* __ASSEMBLY__*/
-
-#endif
diff --git a/arch/ia64/include/asm/pvclock-abi.h b/arch/ia64/include/asm/pvclock-abi.h
deleted file mode 100644 (file)
index 42b233b..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * same structure to x86's
- * Hopefully asm-x86/pvclock-abi.h would be moved to somewhere more generic.
- * For now, define same duplicated definitions.
- */
-
-#ifndef _ASM_IA64__PVCLOCK_ABI_H
-#define _ASM_IA64__PVCLOCK_ABI_H
-#ifndef __ASSEMBLY__
-
-/*
- * These structs MUST NOT be changed.
- * They are the ABI between hypervisor and guest OS.
- * KVM is using this.
- *
- * pvclock_vcpu_time_info holds the system time and the tsc timestamp
- * of the last update. So the guest can use the tsc delta to get a
- * more precise system time.  There is one per virtual cpu.
- *
- * pvclock_wall_clock references the point in time when the system
- * time was zero (usually boot time), thus the guest calculates the
- * current wall clock by adding the system time.
- *
- * Protocol for the "version" fields is: hypervisor raises it (making
- * it uneven) before it starts updating the fields and raises it again
- * (making it even) when it is done.  Thus the guest can make sure the
- * time values it got are consistent by checking the version before
- * and after reading them.
- */
-
-struct pvclock_vcpu_time_info {
-       u32   version;
-       u32   pad0;
-       u64   tsc_timestamp;
-       u64   system_time;
-       u32   tsc_to_system_mul;
-       s8    tsc_shift;
-       u8    pad[3];
-} __attribute__((__packed__)); /* 32 bytes */
-
-struct pvclock_wall_clock {
-       u32   version;
-       u32   sec;
-       u32   nsec;
-} __attribute__((__packed__));
-
-#endif /* __ASSEMBLY__ */
-#endif /* _ASM_IA64__PVCLOCK_ABI_H */
diff --git a/arch/ia64/include/uapi/asm/kvm.h b/arch/ia64/include/uapi/asm/kvm.h
deleted file mode 100644 (file)
index 99503c2..0000000
+++ /dev/null
@@ -1,268 +0,0 @@
-#ifndef __ASM_IA64_KVM_H
-#define __ASM_IA64_KVM_H
-
-/*
- * kvm structure definitions  for ia64
- *
- * Copyright (C) 2007 Xiantao Zhang <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.
- *
- */
-
-#include <linux/types.h>
-#include <linux/ioctl.h>
-
-/* Select x86 specific features in <linux/kvm.h> */
-#define __KVM_HAVE_IOAPIC
-#define __KVM_HAVE_IRQ_LINE
-
-/* Architectural interrupt line count. */
-#define KVM_NR_INTERRUPTS 256
-
-#define KVM_IOAPIC_NUM_PINS  48
-
-struct kvm_ioapic_state {
-       __u64 base_address;
-       __u32 ioregsel;
-       __u32 id;
-       __u32 irr;
-       __u32 pad;
-       union {
-               __u64 bits;
-               struct {
-                       __u8 vector;
-                       __u8 delivery_mode:3;
-                       __u8 dest_mode:1;
-                       __u8 delivery_status:1;
-                       __u8 polarity:1;
-                       __u8 remote_irr:1;
-                       __u8 trig_mode:1;
-                       __u8 mask:1;
-                       __u8 reserve:7;
-                       __u8 reserved[4];
-                       __u8 dest_id;
-               } fields;
-       } redirtbl[KVM_IOAPIC_NUM_PINS];
-};
-
-#define KVM_IRQCHIP_PIC_MASTER   0
-#define KVM_IRQCHIP_PIC_SLAVE    1
-#define KVM_IRQCHIP_IOAPIC       2
-#define KVM_NR_IRQCHIPS          3
-
-#define KVM_CONTEXT_SIZE       8*1024
-
-struct kvm_fpreg {
-       union {
-               unsigned long bits[2];
-               long double __dummy;    /* force 16-byte alignment */
-       } u;
-};
-
-union context {
-       /* 8K size */
-       char    dummy[KVM_CONTEXT_SIZE];
-       struct {
-               unsigned long       psr;
-               unsigned long       pr;
-               unsigned long       caller_unat;
-               unsigned long       pad;
-               unsigned long       gr[32];
-               unsigned long       ar[128];
-               unsigned long       br[8];
-               unsigned long       cr[128];
-               unsigned long       rr[8];
-               unsigned long       ibr[8];
-               unsigned long       dbr[8];
-               unsigned long       pkr[8];
-               struct kvm_fpreg   fr[128];
-       };
-};
-
-struct thash_data {
-       union {
-               struct {
-                       unsigned long p    :  1; /* 0 */
-                       unsigned long rv1  :  1; /* 1 */
-                       unsigned long ma   :  3; /* 2-4 */
-                       unsigned long a    :  1; /* 5 */
-                       unsigned long d    :  1; /* 6 */
-                       unsigned long pl   :  2; /* 7-8 */
-                       unsigned long ar   :  3; /* 9-11 */
-                       unsigned long ppn  : 38; /* 12-49 */
-                       unsigned long rv2  :  2; /* 50-51 */
-                       unsigned long ed   :  1; /* 52 */
-                       unsigned long ig1  : 11; /* 53-63 */
-               };
-               struct {
-                       unsigned long __rv1 : 53;     /* 0-52 */
-                       unsigned long contiguous : 1; /*53 */
-                       unsigned long tc : 1;         /* 54 TR or TC */
-                       unsigned long cl : 1;
-                       /* 55 I side or D side cache line */
-                       unsigned long len  :  4;      /* 56-59 */
-                       unsigned long io  : 1;  /* 60 entry is for io or not */
-                       unsigned long nomap : 1;
-                       /* 61 entry cann't be inserted into machine TLB.*/
-                       unsigned long checked : 1;
-                       /* 62 for VTLB/VHPT sanity check */
-                       unsigned long invalid : 1;
-                       /* 63 invalid entry */
-               };
-               unsigned long page_flags;
-       };                  /* same for VHPT and TLB */
-
-       union {
-               struct {
-                       unsigned long rv3  :  2;
-                       unsigned long ps   :  6;
-                       unsigned long key  : 24;
-                       unsigned long rv4  : 32;
-               };
-               unsigned long itir;
-       };
-       union {
-               struct {
-                       unsigned long ig2  :  12;
-                       unsigned long vpn  :  49;
-                       unsigned long vrn  :   3;
-               };
-               unsigned long ifa;
-               unsigned long vadr;
-               struct {
-                       unsigned long tag  :  63;
-                       unsigned long ti   :  1;
-               };
-               unsigned long etag;
-       };
-       union {
-               struct thash_data *next;
-               unsigned long rid;
-               unsigned long gpaddr;
-       };
-};
-
-#define        NITRS   8
-#define NDTRS  8
-
-struct saved_vpd {
-       unsigned long  vhpi;
-       unsigned long  vgr[16];
-       unsigned long  vbgr[16];
-       unsigned long  vnat;
-       unsigned long  vbnat;
-       unsigned long  vcpuid[5];
-       unsigned long  vpsr;
-       unsigned long  vpr;
-       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];
-               };
-       };
-};
-
-struct kvm_regs {
-       struct saved_vpd vpd;
-       /*Arch-regs*/
-       int mp_state;
-       unsigned long vmm_rr;
-       /* TR and TC.  */
-       struct thash_data itrs[NITRS];
-       struct thash_data dtrs[NDTRS];
-       /* Bit is set if there is a tr/tc for the region.  */
-       unsigned char itr_regions;
-       unsigned char dtr_regions;
-       unsigned char tc_regions;
-
-       char irq_check;
-       unsigned long saved_itc;
-       unsigned long itc_check;
-       unsigned long timer_check;
-       unsigned long timer_pending;
-       unsigned long last_itc;
-
-       unsigned long vrr[8];
-       unsigned long ibr[8];
-       unsigned long dbr[8];
-       unsigned long insvc[4];         /* Interrupt in service.  */
-       unsigned long xtp;
-
-       unsigned long metaphysical_rr0; /* from kvm_arch (so is pinned) */
-       unsigned long metaphysical_rr4; /* from kvm_arch (so is pinned) */
-       unsigned long metaphysical_saved_rr0; /* from kvm_arch          */
-       unsigned long metaphysical_saved_rr4; /* from kvm_arch          */
-       unsigned long fp_psr;       /*used for lazy float register */
-       unsigned long saved_gp;
-       /*for phycial  emulation */
-
-       union context saved_guest;
-
-       unsigned long reserved[64];     /* for future use */
-};
-
-struct kvm_sregs {
-};
-
-struct kvm_fpu {
-};
-
-#define KVM_IA64_VCPU_STACK_SHIFT      16
-#define KVM_IA64_VCPU_STACK_SIZE       (1UL << KVM_IA64_VCPU_STACK_SHIFT)
-
-struct kvm_ia64_vcpu_stack {
-       unsigned char stack[KVM_IA64_VCPU_STACK_SIZE];
-};
-
-struct kvm_debug_exit_arch {
-};
-
-/* for KVM_SET_GUEST_DEBUG */
-struct kvm_guest_debug_arch {
-};
-
-/* definition of registers in kvm_run */
-struct kvm_sync_regs {
-};
-
-#endif
diff --git a/arch/ia64/kvm/Kconfig b/arch/ia64/kvm/Kconfig
deleted file mode 100644 (file)
index 3d50ea9..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-#
-# KVM configuration
-#
-
-source "virt/kvm/Kconfig"
-
-menuconfig VIRTUALIZATION
-       bool "Virtualization"
-       depends on HAVE_KVM || IA64
-       default y
-       ---help---
-         Say Y here to get to see options for using your Linux host to run other
-         operating systems inside virtual machines (guests).
-         This option alone does not add any kernel code.
-
-         If you say N, all options in this submenu will be skipped and disabled.
-
-if VIRTUALIZATION
-
-config KVM
-       tristate "Kernel-based Virtual Machine (KVM) support"
-       depends on BROKEN
-       depends on HAVE_KVM && MODULES
-       depends on BROKEN
-       select PREEMPT_NOTIFIERS
-       select ANON_INODES
-       select HAVE_KVM_IRQCHIP
-       select HAVE_KVM_IRQFD
-       select HAVE_KVM_IRQ_ROUTING
-       select KVM_APIC_ARCHITECTURE
-       select KVM_MMIO
-       ---help---
-         Support hosting fully virtualized guest machines using hardware
-         virtualization extensions.  You will need a fairly recent
-         processor equipped with virtualization extensions. You will also
-         need to select one or more of the processor modules below.
-
-         This module provides access to the hardware capabilities through
-         a character device node named /dev/kvm.
-
-         To compile this as a module, choose M here: the module
-         will be called kvm.
-
-         If unsure, say N.
-
-config KVM_INTEL
-       tristate "KVM for Intel Itanium 2 processors support"
-       depends on KVM && m
-       ---help---
-         Provides support for KVM on Itanium 2 processors equipped with the VT
-         extensions.
-
-config KVM_DEVICE_ASSIGNMENT
-       bool "KVM legacy PCI device assignment support"
-       depends on KVM && PCI && IOMMU_API
-       default y
-       ---help---
-         Provide support for legacy PCI device assignment through KVM.  The
-         kernel now also supports a full featured userspace device driver
-         framework through VFIO, which supersedes much of this support.
-
-         If unsure, say Y.
-
-source drivers/vhost/Kconfig
-
-endif # VIRTUALIZATION
diff --git a/arch/ia64/kvm/Makefile b/arch/ia64/kvm/Makefile
deleted file mode 100644 (file)
index 18e45ec..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-#This Make file is to generate asm-offsets.h and build source.
-#
-
-#Generate asm-offsets.h for vmm module build
-offsets-file := asm-offsets.h
-
-always  := $(offsets-file)
-targets := $(offsets-file)
-targets += arch/ia64/kvm/asm-offsets.s
-
-# Default sed regexp - multiline due to syntax constraints
-define sed-y
-       "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}"
-endef
-
-quiet_cmd_offsets = GEN     $@
-define cmd_offsets
-       (set -e; \
-        echo "#ifndef __ASM_KVM_OFFSETS_H__"; \
-        echo "#define __ASM_KVM_OFFSETS_H__"; \
-        echo "/*"; \
-        echo " * DO NOT MODIFY."; \
-        echo " *"; \
-        echo " * This file was generated by Makefile"; \
-        echo " *"; \
-        echo " */"; \
-        echo ""; \
-        sed -ne $(sed-y) $<; \
-        echo ""; \
-        echo "#endif" ) > $@
-endef
-
-# We use internal rules to avoid the "is up to date" message from make
-arch/ia64/kvm/asm-offsets.s: arch/ia64/kvm/asm-offsets.c \
-                       $(wildcard $(srctree)/arch/ia64/include/asm/*.h)\
-                       $(wildcard $(srctree)/include/linux/*.h)
-       $(call if_changed_dep,cc_s_c)
-
-$(obj)/$(offsets-file): arch/ia64/kvm/asm-offsets.s
-       $(call cmd,offsets)
-
-FORCE : $(obj)/$(offsets-file)
-
-#
-# Makefile for Kernel-based Virtual Machine module
-#
-
-ccflags-y := -Ivirt/kvm -Iarch/ia64/kvm/
-asflags-y := -Ivirt/kvm -Iarch/ia64/kvm/
-KVM := ../../../virt/kvm
-
-common-objs = $(KVM)/kvm_main.o $(KVM)/ioapic.o \
-               $(KVM)/coalesced_mmio.o $(KVM)/irq_comm.o
-
-ifeq ($(CONFIG_KVM_DEVICE_ASSIGNMENT),y)
-common-objs += $(KVM)/assigned-dev.o $(KVM)/iommu.o
-endif
-
-kvm-objs := $(common-objs) kvm-ia64.o kvm_fw.o
-obj-$(CONFIG_KVM) += kvm.o
-
-CFLAGS_vcpu.o += -mfixed-range=f2-f5,f12-f127
-kvm-intel-objs = vmm.o vmm_ivt.o trampoline.o vcpu.o optvfault.o mmio.o \
-       vtlb.o process.o kvm_lib.o
-#Add link memcpy and memset to avoid possible structure assignment error
-kvm-intel-objs += memcpy.o memset.o
-obj-$(CONFIG_KVM_INTEL) += kvm-intel.o
diff --git a/arch/ia64/kvm/asm-offsets.c b/arch/ia64/kvm/asm-offsets.c
deleted file mode 100644 (file)
index 9324c87..0000000
+++ /dev/null
@@ -1,241 +0,0 @@
-/*
- * asm-offsets.c Generate definitions needed by assembly language modules.
- * This code generates raw asm output which is post-processed
- * to extract and format the required data.
- *
- * Anthony Xu    <anthony.xu@intel.com>
- * Xiantao Zhang <xiantao.zhang@intel.com>
- * Copyright (c) 2007 Intel Corporation  KVM support.
- *
- * 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.
- *
- */
-
-#include <linux/kvm_host.h>
-#include <linux/kbuild.h>
-
-#include "vcpu.h"
-
-void foo(void)
-{
-       DEFINE(VMM_TASK_SIZE, sizeof(struct kvm_vcpu));
-       DEFINE(VMM_PT_REGS_SIZE, sizeof(struct kvm_pt_regs));
-
-       BLANK();
-
-       DEFINE(VMM_VCPU_META_RR0_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.metaphysical_rr0));
-       DEFINE(VMM_VCPU_META_SAVED_RR0_OFFSET,
-                       offsetof(struct kvm_vcpu,
-                               arch.metaphysical_saved_rr0));
-       DEFINE(VMM_VCPU_VRR0_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.vrr[0]));
-       DEFINE(VMM_VPD_IRR0_OFFSET,
-                       offsetof(struct vpd, irr[0]));
-       DEFINE(VMM_VCPU_ITC_CHECK_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.itc_check));
-       DEFINE(VMM_VCPU_IRQ_CHECK_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.irq_check));
-       DEFINE(VMM_VPD_VHPI_OFFSET,
-                       offsetof(struct vpd, vhpi));
-       DEFINE(VMM_VCPU_VSA_BASE_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.vsa_base));
-       DEFINE(VMM_VCPU_VPD_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.vpd));
-       DEFINE(VMM_VCPU_IRQ_CHECK,
-                       offsetof(struct kvm_vcpu, arch.irq_check));
-       DEFINE(VMM_VCPU_TIMER_PENDING,
-                       offsetof(struct kvm_vcpu, arch.timer_pending));
-       DEFINE(VMM_VCPU_META_SAVED_RR0_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.metaphysical_saved_rr0));
-       DEFINE(VMM_VCPU_MODE_FLAGS_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.mode_flags));
-       DEFINE(VMM_VCPU_ITC_OFS_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.itc_offset));
-       DEFINE(VMM_VCPU_LAST_ITC_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.last_itc));
-       DEFINE(VMM_VCPU_SAVED_GP_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.saved_gp));
-
-       BLANK();
-
-       DEFINE(VMM_PT_REGS_B6_OFFSET,
-                               offsetof(struct kvm_pt_regs, b6));
-       DEFINE(VMM_PT_REGS_B7_OFFSET,
-                               offsetof(struct kvm_pt_regs, b7));
-       DEFINE(VMM_PT_REGS_AR_CSD_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_csd));
-       DEFINE(VMM_PT_REGS_AR_SSD_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_ssd));
-       DEFINE(VMM_PT_REGS_R8_OFFSET,
-                               offsetof(struct kvm_pt_regs, r8));
-       DEFINE(VMM_PT_REGS_R9_OFFSET,
-                               offsetof(struct kvm_pt_regs, r9));
-       DEFINE(VMM_PT_REGS_R10_OFFSET,
-                               offsetof(struct kvm_pt_regs, r10));
-       DEFINE(VMM_PT_REGS_R11_OFFSET,
-                               offsetof(struct kvm_pt_regs, r11));
-       DEFINE(VMM_PT_REGS_CR_IPSR_OFFSET,
-                               offsetof(struct kvm_pt_regs, cr_ipsr));
-       DEFINE(VMM_PT_REGS_CR_IIP_OFFSET,
-                               offsetof(struct kvm_pt_regs, cr_iip));
-       DEFINE(VMM_PT_REGS_CR_IFS_OFFSET,
-                               offsetof(struct kvm_pt_regs, cr_ifs));
-       DEFINE(VMM_PT_REGS_AR_UNAT_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_unat));
-       DEFINE(VMM_PT_REGS_AR_PFS_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_pfs));
-       DEFINE(VMM_PT_REGS_AR_RSC_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_rsc));
-       DEFINE(VMM_PT_REGS_AR_RNAT_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_rnat));
-
-       DEFINE(VMM_PT_REGS_AR_BSPSTORE_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_bspstore));
-       DEFINE(VMM_PT_REGS_PR_OFFSET,
-                               offsetof(struct kvm_pt_regs, pr));
-       DEFINE(VMM_PT_REGS_B0_OFFSET,
-                               offsetof(struct kvm_pt_regs, b0));
-       DEFINE(VMM_PT_REGS_LOADRS_OFFSET,
-                               offsetof(struct kvm_pt_regs, loadrs));
-       DEFINE(VMM_PT_REGS_R1_OFFSET,
-                               offsetof(struct kvm_pt_regs, r1));
-       DEFINE(VMM_PT_REGS_R12_OFFSET,
-                               offsetof(struct kvm_pt_regs, r12));
-       DEFINE(VMM_PT_REGS_R13_OFFSET,
-                               offsetof(struct kvm_pt_regs, r13));
-       DEFINE(VMM_PT_REGS_AR_FPSR_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_fpsr));
-       DEFINE(VMM_PT_REGS_R15_OFFSET,
-                               offsetof(struct kvm_pt_regs, r15));
-       DEFINE(VMM_PT_REGS_R14_OFFSET,
-                               offsetof(struct kvm_pt_regs, r14));
-       DEFINE(VMM_PT_REGS_R2_OFFSET,
-                               offsetof(struct kvm_pt_regs, r2));
-       DEFINE(VMM_PT_REGS_R3_OFFSET,
-                               offsetof(struct kvm_pt_regs, r3));
-       DEFINE(VMM_PT_REGS_R16_OFFSET,
-                               offsetof(struct kvm_pt_regs, r16));
-       DEFINE(VMM_PT_REGS_R17_OFFSET,
-                               offsetof(struct kvm_pt_regs, r17));
-       DEFINE(VMM_PT_REGS_R18_OFFSET,
-                               offsetof(struct kvm_pt_regs, r18));
-       DEFINE(VMM_PT_REGS_R19_OFFSET,
-                               offsetof(struct kvm_pt_regs, r19));
-       DEFINE(VMM_PT_REGS_R20_OFFSET,
-                               offsetof(struct kvm_pt_regs, r20));
-       DEFINE(VMM_PT_REGS_R21_OFFSET,
-                               offsetof(struct kvm_pt_regs, r21));
-       DEFINE(VMM_PT_REGS_R22_OFFSET,
-                               offsetof(struct kvm_pt_regs, r22));
-       DEFINE(VMM_PT_REGS_R23_OFFSET,
-                               offsetof(struct kvm_pt_regs, r23));
-       DEFINE(VMM_PT_REGS_R24_OFFSET,
-                               offsetof(struct kvm_pt_regs, r24));
-       DEFINE(VMM_PT_REGS_R25_OFFSET,
-                               offsetof(struct kvm_pt_regs, r25));
-       DEFINE(VMM_PT_REGS_R26_OFFSET,
-                               offsetof(struct kvm_pt_regs, r26));
-       DEFINE(VMM_PT_REGS_R27_OFFSET,
-                               offsetof(struct kvm_pt_regs, r27));
-       DEFINE(VMM_PT_REGS_R28_OFFSET,
-                               offsetof(struct kvm_pt_regs, r28));
-       DEFINE(VMM_PT_REGS_R29_OFFSET,
-                               offsetof(struct kvm_pt_regs, r29));
-       DEFINE(VMM_PT_REGS_R30_OFFSET,
-                               offsetof(struct kvm_pt_regs, r30));
-       DEFINE(VMM_PT_REGS_R31_OFFSET,
-                               offsetof(struct kvm_pt_regs, r31));
-       DEFINE(VMM_PT_REGS_AR_CCV_OFFSET,
-                               offsetof(struct kvm_pt_regs, ar_ccv));
-       DEFINE(VMM_PT_REGS_F6_OFFSET,
-                               offsetof(struct kvm_pt_regs, f6));
-       DEFINE(VMM_PT_REGS_F7_OFFSET,
-                               offsetof(struct kvm_pt_regs, f7));
-       DEFINE(VMM_PT_REGS_F8_OFFSET,
-                               offsetof(struct kvm_pt_regs, f8));
-       DEFINE(VMM_PT_REGS_F9_OFFSET,
-                               offsetof(struct kvm_pt_regs, f9));
-       DEFINE(VMM_PT_REGS_F10_OFFSET,
-                               offsetof(struct kvm_pt_regs, f10));
-       DEFINE(VMM_PT_REGS_F11_OFFSET,
-                               offsetof(struct kvm_pt_regs, f11));
-       DEFINE(VMM_PT_REGS_R4_OFFSET,
-                               offsetof(struct kvm_pt_regs, r4));
-       DEFINE(VMM_PT_REGS_R5_OFFSET,
-                               offsetof(struct kvm_pt_regs, r5));
-       DEFINE(VMM_PT_REGS_R6_OFFSET,
-                               offsetof(struct kvm_pt_regs, r6));
-       DEFINE(VMM_PT_REGS_R7_OFFSET,
-                               offsetof(struct kvm_pt_regs, r7));
-       DEFINE(VMM_PT_REGS_EML_UNAT_OFFSET,
-                               offsetof(struct kvm_pt_regs, eml_unat));
-       DEFINE(VMM_VCPU_IIPA_OFFSET,
-                               offsetof(struct kvm_vcpu, arch.cr_iipa));
-       DEFINE(VMM_VCPU_OPCODE_OFFSET,
-                               offsetof(struct kvm_vcpu, arch.opcode));
-       DEFINE(VMM_VCPU_CAUSE_OFFSET, offsetof(struct kvm_vcpu, arch.cause));
-       DEFINE(VMM_VCPU_ISR_OFFSET,
-                               offsetof(struct kvm_vcpu, arch.cr_isr));
-       DEFINE(VMM_PT_REGS_R16_SLOT,
-                               (((offsetof(struct kvm_pt_regs, r16)
-                               - sizeof(struct kvm_pt_regs)) >> 3) & 0x3f));
-       DEFINE(VMM_VCPU_MODE_FLAGS_OFFSET,
-                               offsetof(struct kvm_vcpu, arch.mode_flags));
-       DEFINE(VMM_VCPU_GP_OFFSET, offsetof(struct kvm_vcpu, arch.__gp));
-       BLANK();
-
-       DEFINE(VMM_VPD_BASE_OFFSET, offsetof(struct kvm_vcpu, arch.vpd));
-       DEFINE(VMM_VPD_VIFS_OFFSET, offsetof(struct vpd, ifs));
-       DEFINE(VMM_VLSAPIC_INSVC_BASE_OFFSET,
-                       offsetof(struct kvm_vcpu, arch.insvc[0]));
-       DEFINE(VMM_VPD_VPTA_OFFSET, offsetof(struct vpd, pta));
-       DEFINE(VMM_VPD_VPSR_OFFSET, offsetof(struct vpd, vpsr));
-
-       DEFINE(VMM_CTX_R4_OFFSET, offsetof(union context, gr[4]));
-       DEFINE(VMM_CTX_R5_OFFSET, offsetof(union context, gr[5]));
-       DEFINE(VMM_CTX_R12_OFFSET, offsetof(union context, gr[12]));
-       DEFINE(VMM_CTX_R13_OFFSET, offsetof(union context, gr[13]));
-       DEFINE(VMM_CTX_KR0_OFFSET, offsetof(union context, ar[0]));
-       DEFINE(VMM_CTX_KR1_OFFSET, offsetof(union context, ar[1]));
-       DEFINE(VMM_CTX_B0_OFFSET, offsetof(union context, br[0]));
-       DEFINE(VMM_CTX_B1_OFFSET, offsetof(union context, br[1]));
-       DEFINE(VMM_CTX_B2_OFFSET, offsetof(union context, br[2]));
-       DEFINE(VMM_CTX_RR0_OFFSET, offsetof(union context, rr[0]));
-       DEFINE(VMM_CTX_RSC_OFFSET, offsetof(union context, ar[16]));
-       DEFINE(VMM_CTX_BSPSTORE_OFFSET, offsetof(union context, ar[18]));
-       DEFINE(VMM_CTX_RNAT_OFFSET, offsetof(union context, ar[19]));
-       DEFINE(VMM_CTX_FCR_OFFSET, offsetof(union context, ar[21]));
-       DEFINE(VMM_CTX_EFLAG_OFFSET, offsetof(union context, ar[24]));
-       DEFINE(VMM_CTX_CFLG_OFFSET, offsetof(union context, ar[27]));
-       DEFINE(VMM_CTX_FSR_OFFSET, offsetof(union context, ar[28]));
-       DEFINE(VMM_CTX_FIR_OFFSET, offsetof(union context, ar[29]));
-       DEFINE(VMM_CTX_FDR_OFFSET, offsetof(union context, ar[30]));
-       DEFINE(VMM_CTX_UNAT_OFFSET, offsetof(union context, ar[36]));
-       DEFINE(VMM_CTX_FPSR_OFFSET, offsetof(union context, ar[40]));
-       DEFINE(VMM_CTX_PFS_OFFSET, offsetof(union context, ar[64]));
-       DEFINE(VMM_CTX_LC_OFFSET, offsetof(union context, ar[65]));
-       DEFINE(VMM_CTX_DCR_OFFSET, offsetof(union context, cr[0]));
-       DEFINE(VMM_CTX_IVA_OFFSET, offsetof(union context, cr[2]));
-       DEFINE(VMM_CTX_PTA_OFFSET, offsetof(union context, cr[8]));
-       DEFINE(VMM_CTX_IBR0_OFFSET, offsetof(union context, ibr[0]));
-       DEFINE(VMM_CTX_DBR0_OFFSET, offsetof(union context, dbr[0]));
-       DEFINE(VMM_CTX_F2_OFFSET, offsetof(union context, fr[2]));
-       DEFINE(VMM_CTX_F3_OFFSET, offsetof(union context, fr[3]));
-       DEFINE(VMM_CTX_F32_OFFSET, offsetof(union context, fr[32]));
-       DEFINE(VMM_CTX_F33_OFFSET, offsetof(union context, fr[33]));
-       DEFINE(VMM_CTX_PKR0_OFFSET, offsetof(union context, pkr[0]));
-       DEFINE(VMM_CTX_PSR_OFFSET, offsetof(union context, psr));
-       BLANK();
-}
diff --git a/arch/ia64/kvm/irq.h b/arch/ia64/kvm/irq.h
deleted file mode 100644 (file)
index c0785a7..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * irq.h: In-kernel interrupt controller related definitions
- * Copyright (c) 2008, Intel Corporation.
- *
- * 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.
- *
- * Authors:
- *   Xiantao Zhang <xiantao.zhang@intel.com>
- *
- */
-
-#ifndef __IRQ_H
-#define __IRQ_H
-
-#include "lapic.h"
-
-static inline int irqchip_in_kernel(struct kvm *kvm)
-{
-       return 1;
-}
-
-#endif
diff --git a/arch/ia64/kvm/kvm-ia64.c b/arch/ia64/kvm/kvm-ia64.c
deleted file mode 100644 (file)
index ec6b9ac..0000000
+++ /dev/null
@@ -1,1942 +0,0 @@
-/*
- * kvm_ia64.c: Basic KVM support On Itanium series processors
- *
- *
- *     Copyright (C) 2007, Intel Corporation.
- *     Xiantao Zhang  (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.
- *
- */
-
-#include <linux/module.h>
-#include <linux/errno.h>
-#include <linux/percpu.h>
-#include <linux/fs.h>
-#include <linux/slab.h>
-#include <linux/smp.h>
-#include <linux/kvm_host.h>
-#include <linux/kvm.h>
-#include <linux/bitops.h>
-#include <linux/hrtimer.h>
-#include <linux/uaccess.h>
-#include <linux/iommu.h>
-#include <linux/intel-iommu.h>
-#include <linux/pci.h>
-
-#include <asm/pgtable.h>
-#include <asm/gcc_intrin.h>
-#include <asm/pal.h>
-#include <asm/cacheflush.h>
-#include <asm/div64.h>
-#include <asm/tlb.h>
-#include <asm/elf.h>
-#include <asm/sn/addrs.h>
-#include <asm/sn/clksupport.h>
-#include <asm/sn/shub_mmr.h>
-
-#include "misc.h"
-#include "vti.h"
-#include "iodev.h"
-#include "ioapic.h"
-#include "lapic.h"
-#include "irq.h"
-
-static unsigned long kvm_vmm_base;
-static unsigned long kvm_vsa_base;
-static unsigned long kvm_vm_buffer;
-static unsigned long kvm_vm_buffer_size;
-unsigned long kvm_vmm_gp;
-
-static long vp_env_info;
-
-static struct kvm_vmm_info *kvm_vmm_info;
-
-static DEFINE_PER_CPU(struct kvm_vcpu *, last_vcpu);
-
-struct kvm_stats_debugfs_item debugfs_entries[] = {
-       { NULL }
-};
-
-static unsigned long kvm_get_itc(struct kvm_vcpu *vcpu)
-{
-#if defined(CONFIG_IA64_SGI_SN2) || defined(CONFIG_IA64_GENERIC)
-       if (vcpu->kvm->arch.is_sn2)
-               return rtc_time();
-       else
-#endif
-               return ia64_getreg(_IA64_REG_AR_ITC);
-}
-
-static void kvm_flush_icache(unsigned long start, unsigned long len)
-{
-       int l;
-
-       for (l = 0; l < (len + 32); l += 32)
-               ia64_fc((void *)(start + l));
-
-       ia64_sync_i();
-       ia64_srlz_i();
-}
-
-static void kvm_flush_tlb_all(void)
-{
-       unsigned long i, j, count0, count1, stride0, stride1, addr;
-       long flags;
-
-       addr    = local_cpu_data->ptce_base;
-       count0  = local_cpu_data->ptce_count[0];
-       count1  = local_cpu_data->ptce_count[1];
-       stride0 = local_cpu_data->ptce_stride[0];
-       stride1 = local_cpu_data->ptce_stride[1];
-
-       local_irq_save(flags);
-       for (i = 0; i < count0; ++i) {
-               for (j = 0; j < count1; ++j) {
-                       ia64_ptce(addr);
-                       addr += stride1;
-               }
-               addr += stride0;
-       }
-       local_irq_restore(flags);
-       ia64_srlz_i();                  /* srlz.i implies srlz.d */
-}
-
-long ia64_pal_vp_create(u64 *vpd, u64 *host_iva, u64 *opt_handler)
-{
-       struct ia64_pal_retval iprv;
-
-       PAL_CALL_STK(iprv, PAL_VP_CREATE, (u64)vpd, (u64)host_iva,
-                       (u64)opt_handler);
-
-       return iprv.status;
-}
-
-static  DEFINE_SPINLOCK(vp_lock);
-
-int kvm_arch_hardware_enable(void)
-{
-       long  status;
-       long  tmp_base;
-       unsigned long pte;
-       unsigned long saved_psr;
-       int slot;
-
-       pte = pte_val(mk_pte_phys(__pa(kvm_vmm_base), PAGE_KERNEL));
-       local_irq_save(saved_psr);
-       slot = ia64_itr_entry(0x3, KVM_VMM_BASE, pte, KVM_VMM_SHIFT);
-       local_irq_restore(saved_psr);
-       if (slot < 0)
-               return -EINVAL;
-
-       spin_lock(&vp_lock);
-       status = ia64_pal_vp_init_env(kvm_vsa_base ?
-                               VP_INIT_ENV : VP_INIT_ENV_INITALIZE,
-                       __pa(kvm_vm_buffer), KVM_VM_BUFFER_BASE, &tmp_base);
-       if (status != 0) {
-               spin_unlock(&vp_lock);
-               printk(KERN_WARNING"kvm: Failed to Enable VT Support!!!!\n");
-               return -EINVAL;
-       }
-
-       if (!kvm_vsa_base) {
-               kvm_vsa_base = tmp_base;
-               printk(KERN_INFO"kvm: kvm_vsa_base:0x%lx\n", kvm_vsa_base);
-       }
-       spin_unlock(&vp_lock);
-       ia64_ptr_entry(0x3, slot);
-
-       return 0;
-}
-
-void kvm_arch_hardware_disable(void)
-{
-
-       long status;
-       int slot;
-       unsigned long pte;
-       unsigned long saved_psr;
-       unsigned long host_iva = ia64_getreg(_IA64_REG_CR_IVA);
-
-       pte = pte_val(mk_pte_phys(__pa(kvm_vmm_base),
-                               PAGE_KERNEL));
-
-       local_irq_save(saved_psr);
-       slot = ia64_itr_entry(0x3, KVM_VMM_BASE, pte, KVM_VMM_SHIFT);
-       local_irq_restore(saved_psr);
-       if (slot < 0)
-               return;
-
-       status = ia64_pal_vp_exit_env(host_iva);
-       if (status)
-               printk(KERN_DEBUG"kvm: Failed to disable VT support! :%ld\n",
-                               status);
-       ia64_ptr_entry(0x3, slot);
-}
-
-void kvm_arch_check_processor_compat(void *rtn)
-{
-       *(int *)rtn = 0;
-}
-
-int kvm_vm_ioctl_check_extension(struct kvm *kvm, long ext)
-{
-
-       int r;
-
-       switch (ext) {
-       case KVM_CAP_IRQCHIP:
-       case KVM_CAP_MP_STATE:
-       case KVM_CAP_IRQ_INJECT_STATUS:
-       case KVM_CAP_IOAPIC_POLARITY_IGNORED:
-               r = 1;
-               break;
-       case KVM_CAP_COALESCED_MMIO:
-               r = KVM_COALESCED_MMIO_PAGE_OFFSET;
-               break;
-#ifdef CONFIG_KVM_DEVICE_ASSIGNMENT
-       case KVM_CAP_IOMMU:
-               r = iommu_present(&pci_bus_type);
-               break;
-#endif
-       default:
-               r = 0;
-       }
-       return r;
-
-}
-
-static int handle_vm_error(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       kvm_run->exit_reason = KVM_EXIT_UNKNOWN;
-       kvm_run->hw.hardware_exit_reason = 1;
-       return 0;
-}
-
-static int handle_mmio(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       struct kvm_mmio_req *p;
-       struct kvm_io_device *mmio_dev;
-       int r;
-
-       p = kvm_get_vcpu_ioreq(vcpu);
-
-       if ((p->addr & PAGE_MASK) == IOAPIC_DEFAULT_BASE_ADDRESS)
-               goto mmio;
-       vcpu->mmio_needed = 1;
-       vcpu->mmio_fragments[0].gpa = kvm_run->mmio.phys_addr = p->addr;
-       vcpu->mmio_fragments[0].len = kvm_run->mmio.len = p->size;
-       vcpu->mmio_is_write = kvm_run->mmio.is_write = !p->dir;
-
-       if (vcpu->mmio_is_write)
-               memcpy(vcpu->arch.mmio_data, &p->data, p->size);
-       memcpy(kvm_run->mmio.data, &p->data, p->size);
-       kvm_run->exit_reason = KVM_EXIT_MMIO;
-       return 0;
-mmio:
-       if (p->dir)
-               r = kvm_io_bus_read(vcpu->kvm, KVM_MMIO_BUS, p->addr,
-                                   p->size, &p->data);
-       else
-               r = kvm_io_bus_write(vcpu->kvm, KVM_MMIO_BUS, p->addr,
-                                    p->size, &p->data);
-       if (r)
-               printk(KERN_ERR"kvm: No iodevice found! addr:%lx\n", p->addr);
-       p->state = STATE_IORESP_READY;
-
-       return 1;
-}
-
-static int handle_pal_call(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-
-       if (p->exit_reason == EXIT_REASON_PAL_CALL)
-               return kvm_pal_emul(vcpu, kvm_run);
-       else {
-               kvm_run->exit_reason = KVM_EXIT_UNKNOWN;
-               kvm_run->hw.hardware_exit_reason = 2;
-               return 0;
-       }
-}
-
-static int handle_sal_call(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-
-       if (p->exit_reason == EXIT_REASON_SAL_CALL) {
-               kvm_sal_emul(vcpu);
-               return 1;
-       } else {
-               kvm_run->exit_reason = KVM_EXIT_UNKNOWN;
-               kvm_run->hw.hardware_exit_reason = 3;
-               return 0;
-       }
-
-}
-
-static int __apic_accept_irq(struct kvm_vcpu *vcpu, uint64_t vector)
-{
-       struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-
-       if (!test_and_set_bit(vector, &vpd->irr[0])) {
-               vcpu->arch.irq_new_pending = 1;
-               kvm_vcpu_kick(vcpu);
-               return 1;
-       }
-       return 0;
-}
-
-/*
- *  offset: address offset to IPI space.
- *  value:  deliver value.
- */
-static void vcpu_deliver_ipi(struct kvm_vcpu *vcpu, uint64_t dm,
-                               uint64_t vector)
-{
-       switch (dm) {
-       case SAPIC_FIXED:
-               break;
-       case SAPIC_NMI:
-               vector = 2;
-               break;
-       case SAPIC_EXTINT:
-               vector = 0;
-               break;
-       case SAPIC_INIT:
-       case SAPIC_PMI:
-       default:
-               printk(KERN_ERR"kvm: Unimplemented Deliver reserved IPI!\n");
-               return;
-       }
-       __apic_accept_irq(vcpu, vector);
-}
-
-static struct kvm_vcpu *lid_to_vcpu(struct kvm *kvm, unsigned long id,
-                       unsigned long eid)
-{
-       union ia64_lid lid;
-       int i;
-       struct kvm_vcpu *vcpu;
-
-       kvm_for_each_vcpu(i, vcpu, kvm) {
-               lid.val = VCPU_LID(vcpu);
-               if (lid.id == id && lid.eid == eid)
-                       return vcpu;
-       }
-
-       return NULL;
-}
-
-static int handle_ipi(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       struct exit_ctl_data *p = kvm_get_exit_data(vcpu);
-       struct kvm_vcpu *target_vcpu;
-       struct kvm_pt_regs *regs;
-       union ia64_ipi_a addr = p->u.ipi_data.addr;
-       union ia64_ipi_d data = p->u.ipi_data.data;
-
-       target_vcpu = lid_to_vcpu(vcpu->kvm, addr.id, addr.eid);
-       if (!target_vcpu)
-               return handle_vm_error(vcpu, kvm_run);
-
-       if (!target_vcpu->arch.launched) {
-               regs = vcpu_regs(target_vcpu);
-
-               regs->cr_iip = vcpu->kvm->arch.rdv_sal_data.boot_ip;
-               regs->r1 = vcpu->kvm->arch.rdv_sal_data.boot_gp;
-
-               target_vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;
-               if (waitqueue_active(&target_vcpu->wq))
-                       wake_up_interruptible(&target_vcpu->wq);
-       } else {
-               vcpu_deliver_ipi(target_vcpu, data.dm, data.vector);
-               if (target_vcpu != vcpu)
-                       kvm_vcpu_kick(target_vcpu);
-       }
-
-       return 1;
-}
-
-struct call_data {
-       struct kvm_ptc_g ptc_g_data;
-       struct kvm_vcpu *vcpu;
-};
-
-static void vcpu_global_purge(void *info)
-{
-       struct call_data *p = (struct call_data *)info;
-       struct kvm_vcpu *vcpu = p->vcpu;
-
-       if (test_bit(KVM_REQ_TLB_FLUSH, &vcpu->requests))
-               return;
-
-       set_bit(KVM_REQ_PTC_G, &vcpu->requests);
-       if (vcpu->arch.ptc_g_count < MAX_PTC_G_NUM) {
-               vcpu->arch.ptc_g_data[vcpu->arch.ptc_g_count++] =
-                                                       p->ptc_g_data;
-       } else {
-               clear_bit(KVM_REQ_PTC_G, &vcpu->requests);
-               vcpu->arch.ptc_g_count = 0;
-               set_bit(KVM_REQ_TLB_FLUSH, &vcpu->requests);
-       }
-}
-
-static int handle_global_purge(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       struct exit_ctl_data *p = kvm_get_exit_data(vcpu);
-       struct kvm *kvm = vcpu->kvm;
-       struct call_data call_data;
-       int i;
-       struct kvm_vcpu *vcpui;
-
-       call_data.ptc_g_data = p->u.ptc_g_data;
-
-       kvm_for_each_vcpu(i, vcpui, kvm) {
-               if (vcpui->arch.mp_state == KVM_MP_STATE_UNINITIALIZED ||
-                               vcpu == vcpui)
-                       continue;
-
-               if (waitqueue_active(&vcpui->wq))
-                       wake_up_interruptible(&vcpui->wq);
-
-               if (vcpui->cpu != -1) {
-                       call_data.vcpu = vcpui;
-                       smp_call_function_single(vcpui->cpu,
-                                       vcpu_global_purge, &call_data, 1);
-               } else
-                       printk(KERN_WARNING"kvm: Uninit vcpu received ipi!\n");
-
-       }
-       return 1;
-}
-
-static int handle_switch_rr6(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       return 1;
-}
-
-static int kvm_sn2_setup_mappings(struct kvm_vcpu *vcpu)
-{
-       unsigned long pte, rtc_phys_addr, map_addr;
-       int slot;
-
-       map_addr = KVM_VMM_BASE + (1UL << KVM_VMM_SHIFT);
-       rtc_phys_addr = LOCAL_MMR_OFFSET | SH_RTC;
-       pte = pte_val(mk_pte_phys(rtc_phys_addr, PAGE_KERNEL_UC));
-       slot = ia64_itr_entry(0x3, map_addr, pte, PAGE_SHIFT);
-       vcpu->arch.sn_rtc_tr_slot = slot;
-       if (slot < 0) {
-               printk(KERN_ERR "Mayday mayday! RTC mapping failed!\n");
-               slot = 0;
-       }
-       return slot;
-}
-
-int kvm_emulate_halt(struct kvm_vcpu *vcpu)
-{
-
-       ktime_t kt;
-       long itc_diff;
-       unsigned long vcpu_now_itc;
-       unsigned long expires;
-       struct hrtimer *p_ht = &vcpu->arch.hlt_timer;
-       unsigned long cyc_per_usec = local_cpu_data->cyc_per_usec;
-       struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-
-       if (irqchip_in_kernel(vcpu->kvm)) {
-
-               vcpu_now_itc = kvm_get_itc(vcpu) + vcpu->arch.itc_offset;
-
-               if (time_after(vcpu_now_itc, vpd->itm)) {
-                       vcpu->arch.timer_check = 1;
-                       return 1;
-               }
-               itc_diff = vpd->itm - vcpu_now_itc;
-               if (itc_diff < 0)
-                       itc_diff = -itc_diff;
-
-               expires = div64_u64(itc_diff, cyc_per_usec);
-               kt = ktime_set(0, 1000 * expires);
-
-               vcpu->arch.ht_active = 1;
-               hrtimer_start(p_ht, kt, HRTIMER_MODE_ABS);
-
-               vcpu->arch.mp_state = KVM_MP_STATE_HALTED;
-               kvm_vcpu_block(vcpu);
-               hrtimer_cancel(p_ht);
-               vcpu->arch.ht_active = 0;
-
-               if (test_and_clear_bit(KVM_REQ_UNHALT, &vcpu->requests) ||
-                               kvm_cpu_has_pending_timer(vcpu))
-                       if (vcpu->arch.mp_state == KVM_MP_STATE_HALTED)
-                               vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;
-
-               if (vcpu->arch.mp_state != KVM_MP_STATE_RUNNABLE)
-                       return -EINTR;
-               return 1;
-       } else {
-               printk(KERN_ERR"kvm: Unsupported userspace halt!");
-               return 0;
-       }
-}
-
-static int handle_vm_shutdown(struct kvm_vcpu *vcpu,
-               struct kvm_run *kvm_run)
-{
-       kvm_run->exit_reason = KVM_EXIT_SHUTDOWN;
-       return 0;
-}
-
-static int handle_external_interrupt(struct kvm_vcpu *vcpu,
-               struct kvm_run *kvm_run)
-{
-       return 1;
-}
-
-static int handle_vcpu_debug(struct kvm_vcpu *vcpu,
-                               struct kvm_run *kvm_run)
-{
-       printk("VMM: %s", vcpu->arch.log_buf);
-       return 1;
-}
-
-static int (*kvm_vti_exit_handlers[])(struct kvm_vcpu *vcpu,
-               struct kvm_run *kvm_run) = {
-       [EXIT_REASON_VM_PANIC]              = handle_vm_error,
-       [EXIT_REASON_MMIO_INSTRUCTION]      = handle_mmio,
-       [EXIT_REASON_PAL_CALL]              = handle_pal_call,
-       [EXIT_REASON_SAL_CALL]              = handle_sal_call,
-       [EXIT_REASON_SWITCH_RR6]            = handle_switch_rr6,
-       [EXIT_REASON_VM_DESTROY]            = handle_vm_shutdown,
-       [EXIT_REASON_EXTERNAL_INTERRUPT]    = handle_external_interrupt,
-       [EXIT_REASON_IPI]                   = handle_ipi,
-       [EXIT_REASON_PTC_G]                 = handle_global_purge,
-       [EXIT_REASON_DEBUG]                 = handle_vcpu_debug,
-
-};
-
-static const int kvm_vti_max_exit_handlers =
-               sizeof(kvm_vti_exit_handlers)/sizeof(*kvm_vti_exit_handlers);
-
-static uint32_t kvm_get_exit_reason(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p_exit_data;
-
-       p_exit_data = kvm_get_exit_data(vcpu);
-       return p_exit_data->exit_reason;
-}
-
-/*
- * The guest has exited.  See if we can fix it or if we need userspace
- * assistance.
- */
-static int kvm_handle_exit(struct kvm_run *kvm_run, struct kvm_vcpu *vcpu)
-{
-       u32 exit_reason = kvm_get_exit_reason(vcpu);
-       vcpu->arch.last_exit = exit_reason;
-
-       if (exit_reason < kvm_vti_max_exit_handlers
-                       && kvm_vti_exit_handlers[exit_reason])
-               return kvm_vti_exit_handlers[exit_reason](vcpu, kvm_run);
-       else {
-               kvm_run->exit_reason = KVM_EXIT_UNKNOWN;
-               kvm_run->hw.hardware_exit_reason = exit_reason;
-       }
-       return 0;
-}
-
-static inline void vti_set_rr6(unsigned long rr6)
-{
-       ia64_set_rr(RR6, rr6);
-       ia64_srlz_i();
-}
-
-static int kvm_insert_vmm_mapping(struct kvm_vcpu *vcpu)
-{
-       unsigned long pte;
-       struct kvm *kvm = vcpu->kvm;
-       int r;
-
-       /*Insert a pair of tr to map vmm*/
-       pte = pte_val(mk_pte_phys(__pa(kvm_vmm_base), PAGE_KERNEL));
-       r = ia64_itr_entry(0x3, KVM_VMM_BASE, pte, KVM_VMM_SHIFT);
-       if (r < 0)
-               goto out;
-       vcpu->arch.vmm_tr_slot = r;
-       /*Insert a pairt of tr to map data of vm*/
-       pte = pte_val(mk_pte_phys(__pa(kvm->arch.vm_base), PAGE_KERNEL));
-       r = ia64_itr_entry(0x3, KVM_VM_DATA_BASE,
-                                       pte, KVM_VM_DATA_SHIFT);
-       if (r < 0)
-               goto out;
-       vcpu->arch.vm_tr_slot = r;
-
-#if defined(CONFIG_IA64_SGI_SN2) || defined(CONFIG_IA64_GENERIC)
-       if (kvm->arch.is_sn2) {
-               r = kvm_sn2_setup_mappings(vcpu);
-               if (r < 0)
-                       goto out;
-       }
-#endif
-
-       r = 0;
-out:
-       return r;
-}
-
-static void kvm_purge_vmm_mapping(struct kvm_vcpu *vcpu)
-{
-       struct kvm *kvm = vcpu->kvm;
-       ia64_ptr_entry(0x3, vcpu->arch.vmm_tr_slot);
-       ia64_ptr_entry(0x3, vcpu->arch.vm_tr_slot);
-#if defined(CONFIG_IA64_SGI_SN2) || defined(CONFIG_IA64_GENERIC)
-       if (kvm->arch.is_sn2)
-               ia64_ptr_entry(0x3, vcpu->arch.sn_rtc_tr_slot);
-#endif
-}
-
-static int kvm_vcpu_pre_transition(struct kvm_vcpu *vcpu)
-{
-       unsigned long psr;
-       int r;
-       int cpu = smp_processor_id();
-
-       if (vcpu->arch.last_run_cpu != cpu ||
-                       per_cpu(last_vcpu, cpu) != vcpu) {
-               per_cpu(last_vcpu, cpu) = vcpu;
-               vcpu->arch.last_run_cpu = cpu;
-               kvm_flush_tlb_all();
-       }
-
-       vcpu->arch.host_rr6 = ia64_get_rr(RR6);
-       vti_set_rr6(vcpu->arch.vmm_rr);
-       local_irq_save(psr);
-       r = kvm_insert_vmm_mapping(vcpu);
-       local_irq_restore(psr);
-       return r;
-}
-
-static void kvm_vcpu_post_transition(struct kvm_vcpu *vcpu)
-{
-       kvm_purge_vmm_mapping(vcpu);
-       vti_set_rr6(vcpu->arch.host_rr6);
-}
-
-static int __vcpu_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       union context *host_ctx, *guest_ctx;
-       int r, idx;
-
-       idx = srcu_read_lock(&vcpu->kvm->srcu);
-
-again:
-       if (signal_pending(current)) {
-               r = -EINTR;
-               kvm_run->exit_reason = KVM_EXIT_INTR;
-               goto out;
-       }
-
-       preempt_disable();
-       local_irq_disable();
-
-       /*Get host and guest context with guest address space.*/
-       host_ctx = kvm_get_host_context(vcpu);
-       guest_ctx = kvm_get_guest_context(vcpu);
-
-       clear_bit(KVM_REQ_KICK, &vcpu->requests);
-
-       r = kvm_vcpu_pre_transition(vcpu);
-       if (r < 0)
-               goto vcpu_run_fail;
-
-       srcu_read_unlock(&vcpu->kvm->srcu, idx);
-       vcpu->mode = IN_GUEST_MODE;
-       kvm_guest_enter();
-
-       /*
-        * Transition to the guest
-        */
-       kvm_vmm_info->tramp_entry(host_ctx, guest_ctx);
-
-       kvm_vcpu_post_transition(vcpu);
-
-       vcpu->arch.launched = 1;
-       set_bit(KVM_REQ_KICK, &vcpu->requests);
-       local_irq_enable();
-
-       /*
-        * We must have an instruction between local_irq_enable() and
-        * kvm_guest_exit(), so the timer interrupt isn't delayed by
-        * the interrupt shadow.  The stat.exits increment will do nicely.
-        * But we need to prevent reordering, hence this barrier():
-        */
-       barrier();
-       kvm_guest_exit();
-       vcpu->mode = OUTSIDE_GUEST_MODE;
-       preempt_enable();
-
-       idx = srcu_read_lock(&vcpu->kvm->srcu);
-
-       r = kvm_handle_exit(kvm_run, vcpu);
-
-       if (r > 0) {
-               if (!need_resched())
-                       goto again;
-       }
-
-out:
-       srcu_read_unlock(&vcpu->kvm->srcu, idx);
-       if (r > 0) {
-               cond_resched();
-               idx = srcu_read_lock(&vcpu->kvm->srcu);
-               goto again;
-       }
-
-       return r;
-
-vcpu_run_fail:
-       local_irq_enable();
-       preempt_enable();
-       kvm_run->exit_reason = KVM_EXIT_FAIL_ENTRY;
-       goto out;
-}
-
-static void kvm_set_mmio_data(struct kvm_vcpu *vcpu)
-{
-       struct kvm_mmio_req *p = kvm_get_vcpu_ioreq(vcpu);
-
-       if (!vcpu->mmio_is_write)
-               memcpy(&p->data, vcpu->arch.mmio_data, 8);
-       p->state = STATE_IORESP_READY;
-}
-
-int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
-{
-       int r;
-       sigset_t sigsaved;
-
-       if (vcpu->sigset_active)
-               sigprocmask(SIG_SETMASK, &vcpu->sigset, &sigsaved);
-
-       if (unlikely(vcpu->arch.mp_state == KVM_MP_STATE_UNINITIALIZED)) {
-               kvm_vcpu_block(vcpu);
-               clear_bit(KVM_REQ_UNHALT, &vcpu->requests);
-               r = -EAGAIN;
-               goto out;
-       }
-
-       if (vcpu->mmio_needed) {
-               memcpy(vcpu->arch.mmio_data, kvm_run->mmio.data, 8);
-               kvm_set_mmio_data(vcpu);
-               vcpu->mmio_read_completed = 1;
-               vcpu->mmio_needed = 0;
-       }
-       r = __vcpu_run(vcpu, kvm_run);
-out:
-       if (vcpu->sigset_active)
-               sigprocmask(SIG_SETMASK, &sigsaved, NULL);
-
-       return r;
-}
-
-struct kvm *kvm_arch_alloc_vm(void)
-{
-
-       struct kvm *kvm;
-       uint64_t  vm_base;
-
-       BUG_ON(sizeof(struct kvm) > KVM_VM_STRUCT_SIZE);
-
-       vm_base = __get_free_pages(GFP_KERNEL, get_order(KVM_VM_DATA_SIZE));
-
-       if (!vm_base)
-               return NULL;
-
-       memset((void *)vm_base, 0, KVM_VM_DATA_SIZE);
-       kvm = (struct kvm *)(vm_base +
-                       offsetof(struct kvm_vm_data, kvm_vm_struct));
-       kvm->arch.vm_base = vm_base;
-       printk(KERN_DEBUG"kvm: vm's data area:0x%lx\n", vm_base);
-
-       return kvm;
-}
-
-struct kvm_ia64_io_range {
-       unsigned long start;
-       unsigned long size;
-       unsigned long type;
-};
-
-static const struct kvm_ia64_io_range io_ranges[] = {
-       {VGA_IO_START, VGA_IO_SIZE, GPFN_FRAME_BUFFER},
-       {MMIO_START, MMIO_SIZE, GPFN_LOW_MMIO},
-       {LEGACY_IO_START, LEGACY_IO_SIZE, GPFN_LEGACY_IO},
-       {IO_SAPIC_START, IO_SAPIC_SIZE, GPFN_IOSAPIC},
-       {PIB_START, PIB_SIZE, GPFN_PIB},
-};
-
-static void kvm_build_io_pmt(struct kvm *kvm)
-{
-       unsigned long i, j;
-
-       /* Mark I/O ranges */
-       for (i = 0; i < (sizeof(io_ranges) / sizeof(struct kvm_io_range));
-                                                       i++) {
-               for (j = io_ranges[i].start;
-                               j < io_ranges[i].start + io_ranges[i].size;
-                               j += PAGE_SIZE)
-                       kvm_set_pmt_entry(kvm, j >> PAGE_SHIFT,
-                                       io_ranges[i].type, 0);
-       }
-
-}
-
-/*Use unused rids to virtualize guest rid.*/
-#define GUEST_PHYSICAL_RR0     0x1739
-#define GUEST_PHYSICAL_RR4     0x2739
-#define VMM_INIT_RR            0x1660
-
-int kvm_arch_init_vm(struct kvm *kvm, unsigned long type)
-{
-       BUG_ON(!kvm);
-
-       if (type)
-               return -EINVAL;
-
-       kvm->arch.is_sn2 = ia64_platform_is("sn2");
-
-       kvm->arch.metaphysical_rr0 = GUEST_PHYSICAL_RR0;
-       kvm->arch.metaphysical_rr4 = GUEST_PHYSICAL_RR4;
-       kvm->arch.vmm_init_rr = VMM_INIT_RR;
-
-       /*
-        *Fill P2M entries for MMIO/IO ranges
-        */
-       kvm_build_io_pmt(kvm);
-
-       INIT_LIST_HEAD(&kvm->arch.assigned_dev_head);
-
-       /* Reserve bit 0 of irq_sources_bitmap for userspace irq source */
-       set_bit(KVM_USERSPACE_IRQ_SOURCE_ID, &kvm->arch.irq_sources_bitmap);
-
-       return 0;
-}
-
-static int kvm_vm_ioctl_get_irqchip(struct kvm *kvm,
-                                       struct kvm_irqchip *chip)
-{
-       int r;
-
-       r = 0;
-       switch (chip->chip_id) {
-       case KVM_IRQCHIP_IOAPIC:
-               r = kvm_get_ioapic(kvm, &chip->chip.ioapic);
-               break;
-       default:
-               r = -EINVAL;
-               break;
-       }
-       return r;
-}
-
-static int kvm_vm_ioctl_set_irqchip(struct kvm *kvm, struct kvm_irqchip *chip)
-{
-       int r;
-
-       r = 0;
-       switch (chip->chip_id) {
-       case KVM_IRQCHIP_IOAPIC:
-               r = kvm_set_ioapic(kvm, &chip->chip.ioapic);
-               break;
-       default:
-               r = -EINVAL;
-               break;
-       }
-       return r;
-}
-
-#define RESTORE_REGS(_x) vcpu->arch._x = regs->_x
-
-int kvm_arch_vcpu_ioctl_set_regs(struct kvm_vcpu *vcpu, struct kvm_regs *regs)
-{
-       struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-       int i;
-
-       for (i = 0; i < 16; i++) {
-               vpd->vgr[i] = regs->vpd.vgr[i];
-               vpd->vbgr[i] = regs->vpd.vbgr[i];
-       }
-       for (i = 0; i < 128; i++)
-               vpd->vcr[i] = regs->vpd.vcr[i];
-       vpd->vhpi = regs->vpd.vhpi;
-       vpd->vnat = regs->vpd.vnat;
-       vpd->vbnat = regs->vpd.vbnat;
-       vpd->vpsr = regs->vpd.vpsr;
-
-       vpd->vpr = regs->vpd.vpr;
-
-       memcpy(&vcpu->arch.guest, &regs->saved_guest, sizeof(union context));
-
-       RESTORE_REGS(mp_state);
-       RESTORE_REGS(vmm_rr);
-       memcpy(vcpu->arch.itrs, regs->itrs, sizeof(struct thash_data) * NITRS);
-       memcpy(vcpu->arch.dtrs, regs->dtrs, sizeof(struct thash_data) * NDTRS);
-       RESTORE_REGS(itr_regions);
-       RESTORE_REGS(dtr_regions);
-       RESTORE_REGS(tc_regions);
-       RESTORE_REGS(irq_check);
-       RESTORE_REGS(itc_check);
-       RESTORE_REGS(timer_check);
-       RESTORE_REGS(timer_pending);
-       RESTORE_REGS(last_itc);
-       for (i = 0; i < 8; i++) {
-               vcpu->arch.vrr[i] = regs->vrr[i];
-               vcpu->arch.ibr[i] = regs->ibr[i];
-               vcpu->arch.dbr[i] = regs->dbr[i];
-       }
-       for (i = 0; i < 4; i++)
-               vcpu->arch.insvc[i] = regs->insvc[i];
-       RESTORE_REGS(xtp);
-       RESTORE_REGS(metaphysical_rr0);
-       RESTORE_REGS(metaphysical_rr4);
-       RESTORE_REGS(metaphysical_saved_rr0);
-       RESTORE_REGS(metaphysical_saved_rr4);
-       RESTORE_REGS(fp_psr);
-       RESTORE_REGS(saved_gp);
-
-       vcpu->arch.irq_new_pending = 1;
-       vcpu->arch.itc_offset = regs->saved_itc - kvm_get_itc(vcpu);
-       set_bit(KVM_REQ_RESUME, &vcpu->requests);
-
-       return 0;
-}
-
-int kvm_vm_ioctl_irq_line(struct kvm *kvm, struct kvm_irq_level *irq_event,
-               bool line_status)
-{
-       if (!irqchip_in_kernel(kvm))
-               return -ENXIO;
-
-       irq_event->status = kvm_set_irq(kvm, KVM_USERSPACE_IRQ_SOURCE_ID,
-                                       irq_event->irq, irq_event->level,
-                                       line_status);
-       return 0;
-}
-
-long kvm_arch_vm_ioctl(struct file *filp,
-               unsigned int ioctl, unsigned long arg)
-{
-       struct kvm *kvm = filp->private_data;
-       void __user *argp = (void __user *)arg;
-       int r = -ENOTTY;
-
-       switch (ioctl) {
-       case KVM_CREATE_IRQCHIP:
-               r = -EFAULT;
-               r = kvm_ioapic_init(kvm);
-               if (r)
-                       goto out;
-               r = kvm_setup_default_irq_routing(kvm);
-               if (r) {
-                       mutex_lock(&kvm->slots_lock);
-                       kvm_ioapic_destroy(kvm);
-                       mutex_unlock(&kvm->slots_lock);
-                       goto out;
-               }
-               break;
-       case KVM_GET_IRQCHIP: {
-               /* 0: PIC master, 1: PIC slave, 2: IOAPIC */
-               struct kvm_irqchip chip;
-
-               r = -EFAULT;
-               if (copy_from_user(&chip, argp, sizeof chip))
-                               goto out;
-               r = -ENXIO;
-               if (!irqchip_in_kernel(kvm))
-                       goto out;
-               r = kvm_vm_ioctl_get_irqchip(kvm, &chip);
-               if (r)
-                       goto out;
-               r = -EFAULT;
-               if (copy_to_user(argp, &chip, sizeof chip))
-                               goto out;
-               r = 0;
-               break;
-               }
-       case KVM_SET_IRQCHIP: {
-               /* 0: PIC master, 1: PIC slave, 2: IOAPIC */
-               struct kvm_irqchip chip;
-
-               r = -EFAULT;
-               if (copy_from_user(&chip, argp, sizeof chip))
-                               goto out;
-               r = -ENXIO;
-               if (!irqchip_in_kernel(kvm))
-                       goto out;
-               r = kvm_vm_ioctl_set_irqchip(kvm, &chip);
-               if (r)
-                       goto out;
-               r = 0;
-               break;
-               }
-       default:
-               ;
-       }
-out:
-       return r;
-}
-
-int kvm_arch_vcpu_ioctl_set_sregs(struct kvm_vcpu *vcpu,
-               struct kvm_sregs *sregs)
-{
-       return -EINVAL;
-}
-
-int kvm_arch_vcpu_ioctl_get_sregs(struct kvm_vcpu *vcpu,
-               struct kvm_sregs *sregs)
-{
-       return -EINVAL;
-
-}
-int kvm_arch_vcpu_ioctl_translate(struct kvm_vcpu *vcpu,
-               struct kvm_translation *tr)
-{
-
-       return -EINVAL;
-}
-
-static int kvm_alloc_vmm_area(void)
-{
-       if (!kvm_vmm_base && (kvm_vm_buffer_size < KVM_VM_BUFFER_SIZE)) {
-               kvm_vmm_base = __get_free_pages(GFP_KERNEL,
-                               get_order(KVM_VMM_SIZE));
-               if (!kvm_vmm_base)
-                       return -ENOMEM;
-
-               memset((void *)kvm_vmm_base, 0, KVM_VMM_SIZE);
-               kvm_vm_buffer = kvm_vmm_base + VMM_SIZE;
-
-               printk(KERN_DEBUG"kvm:VMM's Base Addr:0x%lx, vm_buffer:0x%lx\n",
-                               kvm_vmm_base, kvm_vm_buffer);
-       }
-
-       return 0;
-}
-
-static void kvm_free_vmm_area(void)
-{
-       if (kvm_vmm_base) {
-               /*Zero this area before free to avoid bits leak!!*/
-               memset((void *)kvm_vmm_base, 0, KVM_VMM_SIZE);
-               free_pages(kvm_vmm_base, get_order(KVM_VMM_SIZE));
-               kvm_vmm_base  = 0;
-               kvm_vm_buffer = 0;
-               kvm_vsa_base = 0;
-       }
-}
-
-static int vti_init_vpd(struct kvm_vcpu *vcpu)
-{
-       int i;
-       union cpuid3_t cpuid3;
-       struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-
-       if (IS_ERR(vpd))
-               return PTR_ERR(vpd);
-
-       /* CPUID init */
-       for (i = 0; i < 5; i++)
-               vpd->vcpuid[i] = ia64_get_cpuid(i);
-
-       /* Limit the CPUID number to 5 */
-       cpuid3.value = vpd->vcpuid[3];
-       cpuid3.number = 4;      /* 5 - 1 */
-       vpd->vcpuid[3] = cpuid3.value;
-
-       /*Set vac and vdc fields*/
-       vpd->vac.a_from_int_cr = 1;
-       vpd->vac.a_to_int_cr = 1;
-       vpd->vac.a_from_psr = 1;
-       vpd->vac.a_from_cpuid = 1;
-       vpd->vac.a_cover = 1;
-       vpd->vac.a_bsw = 1;
-       vpd->vac.a_int = 1;
-       vpd->vdc.d_vmsw = 1;
-
-       /*Set virtual buffer*/
-       vpd->virt_env_vaddr = KVM_VM_BUFFER_BASE;
-
-       return 0;
-}
-
-static int vti_create_vp(struct kvm_vcpu *vcpu)
-{
-       long ret;
-       struct vpd *vpd = vcpu->arch.vpd;
-       unsigned long  vmm_ivt;
-
-       vmm_ivt = kvm_vmm_info->vmm_ivt;
-
-       printk(KERN_DEBUG "kvm: vcpu:%p,ivt: 0x%lx\n", vcpu, vmm_ivt);
-
-       ret = ia64_pal_vp_create((u64 *)vpd, (u64 *)vmm_ivt, 0);
-
-       if (ret) {
-               printk(KERN_ERR"kvm: ia64_pal_vp_create failed!\n");
-               return -EINVAL;
-       }
-       return 0;
-}
-
-static void init_ptce_info(struct kvm_vcpu *vcpu)
-{
-       ia64_ptce_info_t ptce = {0};
-
-       ia64_get_ptce(&ptce);
-       vcpu->arch.ptce_base = ptce.base;
-       vcpu->arch.ptce_count[0] = ptce.count[0];
-       vcpu->arch.ptce_count[1] = ptce.count[1];
-       vcpu->arch.ptce_stride[0] = ptce.stride[0];
-       vcpu->arch.ptce_stride[1] = ptce.stride[1];
-}
-
-static void kvm_migrate_hlt_timer(struct kvm_vcpu *vcpu)
-{
-       struct hrtimer *p_ht = &vcpu->arch.hlt_timer;
-
-       if (hrtimer_cancel(p_ht))
-               hrtimer_start_expires(p_ht, HRTIMER_MODE_ABS);
-}
-
-static enum hrtimer_restart hlt_timer_fn(struct hrtimer *data)
-{
-       struct kvm_vcpu *vcpu;
-       wait_queue_head_t *q;
-
-       vcpu  = container_of(data, struct kvm_vcpu, arch.hlt_timer);
-       q = &vcpu->wq;
-
-       if (vcpu->arch.mp_state != KVM_MP_STATE_HALTED)
-               goto out;
-
-       if (waitqueue_active(q))
-               wake_up_interruptible(q);
-
-out:
-       vcpu->arch.timer_fired = 1;
-       vcpu->arch.timer_check = 1;
-       return HRTIMER_NORESTART;
-}
-
-#define PALE_RESET_ENTRY    0x80000000ffffffb0UL
-
-bool kvm_vcpu_compatible(struct kvm_vcpu *vcpu)
-{
-       return irqchip_in_kernel(vcpu->kvm) == (vcpu->arch.apic != NULL);
-}
-
-int kvm_arch_vcpu_init(struct kvm_vcpu *vcpu)
-{
-       struct kvm_vcpu *v;
-       int r;
-       int i;
-       long itc_offset;
-       struct kvm *kvm = vcpu->kvm;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       union context *p_ctx = &vcpu->arch.guest;
-       struct kvm_vcpu *vmm_vcpu = to_guest(vcpu->kvm, vcpu);
-
-       /*Init vcpu context for first run.*/
-       if (IS_ERR(vmm_vcpu))
-               return PTR_ERR(vmm_vcpu);
-
-       if (kvm_vcpu_is_bsp(vcpu)) {
-               vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;
-
-               /*Set entry address for first run.*/
-               regs->cr_iip = PALE_RESET_ENTRY;
-
-               /*Initialize itc offset for vcpus*/
-               itc_offset = 0UL - kvm_get_itc(vcpu);
-               for (i = 0; i < KVM_MAX_VCPUS; i++) {
-                       v = (struct kvm_vcpu *)((char *)vcpu +
-                                       sizeof(struct kvm_vcpu_data) * i);
-                       v->arch.itc_offset = itc_offset;
-                       v->arch.last_itc = 0;
-               }
-       } else
-               vcpu->arch.mp_state = KVM_MP_STATE_UNINITIALIZED;
-
-       r = -ENOMEM;
-       vcpu->arch.apic = kzalloc(sizeof(struct kvm_lapic), GFP_KERNEL);
-       if (!vcpu->arch.apic)
-               goto out;
-       vcpu->arch.apic->vcpu = vcpu;
-
-       p_ctx->gr[1] = 0;
-       p_ctx->gr[12] = (unsigned long)((char *)vmm_vcpu + KVM_STK_OFFSET);
-       p_ctx->gr[13] = (unsigned long)vmm_vcpu;
-       p_ctx->psr = 0x1008522000UL;
-       p_ctx->ar[40] = FPSR_DEFAULT; /*fpsr*/
-       p_ctx->caller_unat = 0;
-       p_ctx->pr = 0x0;
-       p_ctx->ar[36] = 0x0; /*unat*/
-       p_ctx->ar[19] = 0x0; /*rnat*/
-       p_ctx->ar[18] = (unsigned long)vmm_vcpu +
-                               ((sizeof(struct kvm_vcpu)+15) & ~15);
-       p_ctx->ar[64] = 0x0; /*pfs*/
-       p_ctx->cr[0] = 0x7e04UL;
-       p_ctx->cr[2] = (unsigned long)kvm_vmm_info->vmm_ivt;
-       p_ctx->cr[8] = 0x3c;
-
-       /*Initialize region register*/
-       p_ctx->rr[0] = 0x30;
-       p_ctx->rr[1] = 0x30;
-       p_ctx->rr[2] = 0x30;
-       p_ctx->rr[3] = 0x30;
-       p_ctx->rr[4] = 0x30;
-       p_ctx->rr[5] = 0x30;
-       p_ctx->rr[7] = 0x30;
-
-       /*Initialize branch register 0*/
-       p_ctx->br[0] = *(unsigned long *)kvm_vmm_info->vmm_entry;
-
-       vcpu->arch.vmm_rr = kvm->arch.vmm_init_rr;
-       vcpu->arch.metaphysical_rr0 = kvm->arch.metaphysical_rr0;
-       vcpu->arch.metaphysical_rr4 = kvm->arch.metaphysical_rr4;
-
-       hrtimer_init(&vcpu->arch.hlt_timer, CLOCK_MONOTONIC, HRTIMER_MODE_ABS);
-       vcpu->arch.hlt_timer.function = hlt_timer_fn;
-
-       vcpu->arch.last_run_cpu = -1;
-       vcpu->arch.vpd = (struct vpd *)VPD_BASE(vcpu->vcpu_id);
-       vcpu->arch.vsa_base = kvm_vsa_base;
-       vcpu->arch.__gp = kvm_vmm_gp;
-       vcpu->arch.dirty_log_lock_pa = __pa(&kvm->arch.dirty_log_lock);
-       vcpu->arch.vhpt.hash = (struct thash_data *)VHPT_BASE(vcpu->vcpu_id);
-       vcpu->arch.vtlb.hash = (struct thash_data *)VTLB_BASE(vcpu->vcpu_id);
-       init_ptce_info(vcpu);
-
-       r = 0;
-out:
-       return r;
-}
-
-static int vti_vcpu_setup(struct kvm_vcpu *vcpu, int id)
-{
-       unsigned long psr;
-       int r;
-
-       local_irq_save(psr);
-       r = kvm_insert_vmm_mapping(vcpu);
-       local_irq_restore(psr);
-       if (r)
-               goto fail;
-       r = kvm_vcpu_init(vcpu, vcpu->kvm, id);
-       if (r)
-               goto fail;
-
-       r = vti_init_vpd(vcpu);
-       if (r) {
-               printk(KERN_DEBUG"kvm: vpd init error!!\n");
-               goto uninit;
-       }
-
-       r = vti_create_vp(vcpu);
-       if (r)
-               goto uninit;
-
-       kvm_purge_vmm_mapping(vcpu);
-
-       return 0;
-uninit:
-       kvm_vcpu_uninit(vcpu);
-fail:
-       return r;
-}
-
-struct kvm_vcpu *kvm_arch_vcpu_create(struct kvm *kvm,
-               unsigned int id)
-{
-       struct kvm_vcpu *vcpu;
-       unsigned long vm_base = kvm->arch.vm_base;
-       int r;
-       int cpu;
-
-       BUG_ON(sizeof(struct kvm_vcpu) > VCPU_STRUCT_SIZE/2);
-
-       r = -EINVAL;
-       if (id >= KVM_MAX_VCPUS) {
-               printk(KERN_ERR"kvm: Can't configure vcpus > %ld",
-                               KVM_MAX_VCPUS);
-               goto fail;
-       }
-
-       r = -ENOMEM;
-       if (!vm_base) {
-               printk(KERN_ERR"kvm: Create vcpu[%d] error!\n", id);
-               goto fail;
-       }
-       vcpu = (struct kvm_vcpu *)(vm_base + offsetof(struct kvm_vm_data,
-                                       vcpu_data[id].vcpu_struct));
-       vcpu->kvm = kvm;
-
-       cpu = get_cpu();
-       r = vti_vcpu_setup(vcpu, id);
-       put_cpu();
-
-       if (r) {
-               printk(KERN_DEBUG"kvm: vcpu_setup error!!\n");
-               goto fail;
-       }
-
-       return vcpu;
-fail:
-       return ERR_PTR(r);
-}
-
-int kvm_arch_vcpu_setup(struct kvm_vcpu *vcpu)
-{
-       return 0;
-}
-
-int kvm_arch_vcpu_postcreate(struct kvm_vcpu *vcpu)
-{
-       return 0;
-}
-
-int kvm_arch_vcpu_ioctl_get_fpu(struct kvm_vcpu *vcpu, struct kvm_fpu *fpu)
-{
-       return -EINVAL;
-}
-
-int kvm_arch_vcpu_ioctl_set_fpu(struct kvm_vcpu *vcpu, struct kvm_fpu *fpu)
-{
-       return -EINVAL;
-}
-
-int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu,
-                                       struct kvm_guest_debug *dbg)
-{
-       return -EINVAL;
-}
-
-void kvm_arch_free_vm(struct kvm *kvm)
-{
-       unsigned long vm_base = kvm->arch.vm_base;
-
-       if (vm_base) {
-               memset((void *)vm_base, 0, KVM_VM_DATA_SIZE);
-               free_pages(vm_base, get_order(KVM_VM_DATA_SIZE));
-       }
-
-}
-
-static void kvm_release_vm_pages(struct kvm *kvm)
-{
-       struct kvm_memslots *slots;
-       struct kvm_memory_slot *memslot;
-       int j;
-
-       slots = kvm_memslots(kvm);
-       kvm_for_each_memslot(memslot, slots) {
-               for (j = 0; j < memslot->npages; j++) {
-                       if (memslot->rmap[j])
-                               put_page((struct page *)memslot->rmap[j]);
-               }
-       }
-}
-
-void kvm_arch_destroy_vm(struct kvm *kvm)
-{
-       kvm_iommu_unmap_guest(kvm);
-       kvm_free_all_assigned_devices(kvm);
-       kfree(kvm->arch.vioapic);
-       kvm_release_vm_pages(kvm);
-}
-
-void kvm_arch_vcpu_load(struct kvm_vcpu *vcpu, int cpu)
-{
-       if (cpu != vcpu->cpu) {
-               vcpu->cpu = cpu;
-               if (vcpu->arch.ht_active)
-                       kvm_migrate_hlt_timer(vcpu);
-       }
-}
-
-#define SAVE_REGS(_x)  regs->_x = vcpu->arch._x
-
-int kvm_arch_vcpu_ioctl_get_regs(struct kvm_vcpu *vcpu, struct kvm_regs *regs)
-{
-       struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-       int i;
-
-       vcpu_load(vcpu);
-
-       for (i = 0; i < 16; i++) {
-               regs->vpd.vgr[i] = vpd->vgr[i];
-               regs->vpd.vbgr[i] = vpd->vbgr[i];
-       }
-       for (i = 0; i < 128; i++)
-               regs->vpd.vcr[i] = vpd->vcr[i];
-       regs->vpd.vhpi = vpd->vhpi;
-       regs->vpd.vnat = vpd->vnat;
-       regs->vpd.vbnat = vpd->vbnat;
-       regs->vpd.vpsr = vpd->vpsr;
-       regs->vpd.vpr = vpd->vpr;
-
-       memcpy(&regs->saved_guest, &vcpu->arch.guest, sizeof(union context));
-
-       SAVE_REGS(mp_state);
-       SAVE_REGS(vmm_rr);
-       memcpy(regs->itrs, vcpu->arch.itrs, sizeof(struct thash_data) * NITRS);
-       memcpy(regs->dtrs, vcpu->arch.dtrs, sizeof(struct thash_data) * NDTRS);
-       SAVE_REGS(itr_regions);
-       SAVE_REGS(dtr_regions);
-       SAVE_REGS(tc_regions);
-       SAVE_REGS(irq_check);
-       SAVE_REGS(itc_check);
-       SAVE_REGS(timer_check);
-       SAVE_REGS(timer_pending);
-       SAVE_REGS(last_itc);
-       for (i = 0; i < 8; i++) {
-               regs->vrr[i] = vcpu->arch.vrr[i];
-               regs->ibr[i] = vcpu->arch.ibr[i];
-               regs->dbr[i] = vcpu->arch.dbr[i];
-       }
-       for (i = 0; i < 4; i++)
-               regs->insvc[i] = vcpu->arch.insvc[i];
-       regs->saved_itc = vcpu->arch.itc_offset + kvm_get_itc(vcpu);
-       SAVE_REGS(xtp);
-       SAVE_REGS(metaphysical_rr0);
-       SAVE_REGS(metaphysical_rr4);
-       SAVE_REGS(metaphysical_saved_rr0);
-       SAVE_REGS(metaphysical_saved_rr4);
-       SAVE_REGS(fp_psr);
-       SAVE_REGS(saved_gp);
-
-       vcpu_put(vcpu);
-       return 0;
-}
-
-int kvm_arch_vcpu_ioctl_get_stack(struct kvm_vcpu *vcpu,
-                                 struct kvm_ia64_vcpu_stack *stack)
-{
-       memcpy(stack, vcpu, sizeof(struct kvm_ia64_vcpu_stack));
-       return 0;
-}
-
-int kvm_arch_vcpu_ioctl_set_stack(struct kvm_vcpu *vcpu,
-                                 struct kvm_ia64_vcpu_stack *stack)
-{
-       memcpy(vcpu + 1, &stack->stack[0] + sizeof(struct kvm_vcpu),
-              sizeof(struct kvm_ia64_vcpu_stack) - sizeof(struct kvm_vcpu));
-
-       vcpu->arch.exit_data = ((struct kvm_vcpu *)stack)->arch.exit_data;
-       return 0;
-}
-
-void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu)
-{
-
-       hrtimer_cancel(&vcpu->arch.hlt_timer);
-       kfree(vcpu->arch.apic);
-}
-
-long kvm_arch_vcpu_ioctl(struct file *filp,
-                        unsigned int ioctl, unsigned long arg)
-{
-       struct kvm_vcpu *vcpu = filp->private_data;
-       void __user *argp = (void __user *)arg;
-       struct kvm_ia64_vcpu_stack *stack = NULL;
-       long r;
-
-       switch (ioctl) {
-       case KVM_IA64_VCPU_GET_STACK: {
-               struct kvm_ia64_vcpu_stack __user *user_stack;
-               void __user *first_p = argp;
-
-               r = -EFAULT;
-               if (copy_from_user(&user_stack, first_p, sizeof(void *)))
-                       goto out;
-
-               if (!access_ok(VERIFY_WRITE, user_stack,
-                              sizeof(struct kvm_ia64_vcpu_stack))) {
-                       printk(KERN_INFO "KVM_IA64_VCPU_GET_STACK: "
-                              "Illegal user destination address for stack\n");
-                       goto out;
-               }
-               stack = kzalloc(sizeof(struct kvm_ia64_vcpu_stack), GFP_KERNEL);
-               if (!stack) {
-                       r = -ENOMEM;
-                       goto out;
-               }
-
-               r = kvm_arch_vcpu_ioctl_get_stack(vcpu, stack);
-               if (r)
-                       goto out;
-
-               if (copy_to_user(user_stack, stack,
-                                sizeof(struct kvm_ia64_vcpu_stack))) {
-                       r = -EFAULT;
-                       goto out;
-               }
-
-               break;
-       }
-       case KVM_IA64_VCPU_SET_STACK: {
-               struct kvm_ia64_vcpu_stack __user *user_stack;
-               void __user *first_p = argp;
-
-               r = -EFAULT;
-               if (copy_from_user(&user_stack, first_p, sizeof(void *)))
-                       goto out;
-
-               if (!access_ok(VERIFY_READ, user_stack,
-                           sizeof(struct kvm_ia64_vcpu_stack))) {
-                       printk(KERN_INFO "KVM_IA64_VCPU_SET_STACK: "
-                              "Illegal user address for stack\n");
-                       goto out;
-               }
-               stack = kmalloc(sizeof(struct kvm_ia64_vcpu_stack), GFP_KERNEL);
-               if (!stack) {
-                       r = -ENOMEM;
-                       goto out;
-               }
-               if (copy_from_user(stack, user_stack,
-                                  sizeof(struct kvm_ia64_vcpu_stack)))
-                       goto out;
-
-               r = kvm_arch_vcpu_ioctl_set_stack(vcpu, stack);
-               break;
-       }
-
-       default:
-               r = -EINVAL;
-       }
-
-out:
-       kfree(stack);
-       return r;
-}
-
-int kvm_arch_vcpu_fault(struct kvm_vcpu *vcpu, struct vm_fault *vmf)
-{
-       return VM_FAULT_SIGBUS;
-}
-
-int kvm_arch_create_memslot(struct kvm *kvm, struct kvm_memory_slot *slot,
-                           unsigned long npages)
-{
-       return 0;
-}
-
-int kvm_arch_prepare_memory_region(struct kvm *kvm,
-               struct kvm_memory_slot *memslot,
-               struct kvm_userspace_memory_region *mem,
-               enum kvm_mr_change change)
-{
-       unsigned long i;
-       unsigned long pfn;
-       int npages = memslot->npages;
-       unsigned long base_gfn = memslot->base_gfn;
-
-       if (base_gfn + npages > (KVM_MAX_MEM_SIZE >> PAGE_SHIFT))
-               return -ENOMEM;
-
-       for (i = 0; i < npages; i++) {
-               pfn = gfn_to_pfn(kvm, base_gfn + i);
-               if (!kvm_is_mmio_pfn(pfn)) {
-                       kvm_set_pmt_entry(kvm, base_gfn + i,
-                                       pfn << PAGE_SHIFT,
-                               _PAGE_AR_RWX | _PAGE_MA_WB);
-                       memslot->rmap[i] = (unsigned long)pfn_to_page(pfn);
-               } else {
-                       kvm_set_pmt_entry(kvm, base_gfn + i,
-                                       GPFN_PHYS_MMIO | (pfn << PAGE_SHIFT),
-                                       _PAGE_MA_UC);
-                       memslot->rmap[i] = 0;
-                       }
-       }
-
-       return 0;
-}
-
-void kvm_arch_flush_shadow_all(struct kvm *kvm)
-{
-       kvm_flush_remote_tlbs(kvm);
-}
-
-void kvm_arch_flush_shadow_memslot(struct kvm *kvm,
-                                  struct kvm_memory_slot *slot)
-{
-       kvm_arch_flush_shadow_all();
-}
-
-long kvm_arch_dev_ioctl(struct file *filp,
-                       unsigned int ioctl, unsigned long arg)
-{
-       return -EINVAL;
-}
-
-void kvm_arch_vcpu_destroy(struct kvm_vcpu *vcpu)
-{
-       kvm_vcpu_uninit(vcpu);
-}
-
-static int vti_cpu_has_kvm_support(void)
-{
-       long  avail = 1, status = 1, control = 1;
-       long ret;
-
-       ret = ia64_pal_proc_get_features(&avail, &status, &control, 0);
-       if (ret)
-               goto out;
-
-       if (!(avail & PAL_PROC_VM_BIT))
-               goto out;
-
-       printk(KERN_DEBUG"kvm: Hardware Supports VT\n");
-
-       ret = ia64_pal_vp_env_info(&kvm_vm_buffer_size, &vp_env_info);
-       if (ret)
-               goto out;
-       printk(KERN_DEBUG"kvm: VM Buffer Size:0x%lx\n", kvm_vm_buffer_size);
-
-       if (!(vp_env_info & VP_OPCODE)) {
-               printk(KERN_WARNING"kvm: No opcode ability on hardware, "
-                               "vm_env_info:0x%lx\n", vp_env_info);
-       }
-
-       return 1;
-out:
-       return 0;
-}
-
-
-/*
- * On SN2, the ITC isn't stable, so copy in fast path code to use the
- * SN2 RTC, replacing the ITC based default verion.
- */
-static void kvm_patch_vmm(struct kvm_vmm_info *vmm_info,
-                         struct module *module)
-{
-       unsigned long new_ar, new_ar_sn2;
-       unsigned long module_base;
-
-       if (!ia64_platform_is("sn2"))
-               return;
-
-       module_base = (unsigned long)module->module_core;
-
-       new_ar = kvm_vmm_base + vmm_info->patch_mov_ar - module_base;
-       new_ar_sn2 = kvm_vmm_base + vmm_info->patch_mov_ar_sn2 - module_base;
-
-       printk(KERN_INFO "kvm: Patching ITC emulation to use SGI SN2 RTC "
-              "as source\n");
-
-       /*
-        * Copy the SN2 version of mov_ar into place. They are both
-        * the same size, so 6 bundles is sufficient (6 * 0x10).
-        */
-       memcpy((void *)new_ar, (void *)new_ar_sn2, 0x60);
-}
-
-static int kvm_relocate_vmm(struct kvm_vmm_info *vmm_info,
-                           struct module *module)
-{
-       unsigned long module_base;
-       unsigned long vmm_size;
-
-       unsigned long vmm_offset, func_offset, fdesc_offset;
-       struct fdesc *p_fdesc;
-
-       BUG_ON(!module);
-
-       if (!kvm_vmm_base) {
-               printk("kvm: kvm area hasn't been initialized yet!!\n");
-               return -EFAULT;
-       }
-
-       /*Calculate new position of relocated vmm module.*/
-       module_base = (unsigned long)module->module_core;
-       vmm_size = module->core_size;
-       if (unlikely(vmm_size > KVM_VMM_SIZE))
-               return -EFAULT;
-
-       memcpy((void *)kvm_vmm_base, (void *)module_base, vmm_size);
-       kvm_patch_vmm(vmm_info, module);
-       kvm_flush_icache(kvm_vmm_base, vmm_size);
-
-       /*Recalculate kvm_vmm_info based on new VMM*/
-       vmm_offset = vmm_info->vmm_ivt - module_base;
-       kvm_vmm_info->vmm_ivt = KVM_VMM_BASE + vmm_offset;
-       printk(KERN_DEBUG"kvm: Relocated VMM's IVT Base Addr:%lx\n",
-                       kvm_vmm_info->vmm_ivt);
-
-       fdesc_offset = (unsigned long)vmm_info->vmm_entry - module_base;
-       kvm_vmm_info->vmm_entry = (kvm_vmm_entry *)(KVM_VMM_BASE +
-                                                       fdesc_offset);
-       func_offset = *(unsigned long *)vmm_info->vmm_entry - module_base;
-       p_fdesc = (struct fdesc *)(kvm_vmm_base + fdesc_offset);
-       p_fdesc->ip = KVM_VMM_BASE + func_offset;
-       p_fdesc->gp = KVM_VMM_BASE+(p_fdesc->gp - module_base);
-
-       printk(KERN_DEBUG"kvm: Relocated VMM's Init Entry Addr:%lx\n",
-                       KVM_VMM_BASE+func_offset);
-
-       fdesc_offset = (unsigned long)vmm_info->tramp_entry - module_base;
-       kvm_vmm_info->tramp_entry = (kvm_tramp_entry *)(KVM_VMM_BASE +
-                       fdesc_offset);
-       func_offset = *(unsigned long *)vmm_info->tramp_entry - module_base;
-       p_fdesc = (struct fdesc *)(kvm_vmm_base + fdesc_offset);
-       p_fdesc->ip = KVM_VMM_BASE + func_offset;
-       p_fdesc->gp = KVM_VMM_BASE + (p_fdesc->gp - module_base);
-
-       kvm_vmm_gp = p_fdesc->gp;
-
-       printk(KERN_DEBUG"kvm: Relocated VMM's Entry IP:%p\n",
-                                               kvm_vmm_info->vmm_entry);
-       printk(KERN_DEBUG"kvm: Relocated VMM's Trampoline Entry IP:0x%lx\n",
-                                               KVM_VMM_BASE + func_offset);
-
-       return 0;
-}
-
-int kvm_arch_init(void *opaque)
-{
-       int r;
-       struct kvm_vmm_info *vmm_info = (struct kvm_vmm_info *)opaque;
-
-       if (!vti_cpu_has_kvm_support()) {
-               printk(KERN_ERR "kvm: No Hardware Virtualization Support!\n");
-               r = -EOPNOTSUPP;
-               goto out;
-       }
-
-       if (kvm_vmm_info) {
-               printk(KERN_ERR "kvm: Already loaded VMM module!\n");
-               r = -EEXIST;
-               goto out;
-       }
-
-       r = -ENOMEM;
-       kvm_vmm_info = kzalloc(sizeof(struct kvm_vmm_info), GFP_KERNEL);
-       if (!kvm_vmm_info)
-               goto out;
-
-       if (kvm_alloc_vmm_area())
-               goto out_free0;
-
-       r = kvm_relocate_vmm(vmm_info, vmm_info->module);
-       if (r)
-               goto out_free1;
-
-       return 0;
-
-out_free1:
-       kvm_free_vmm_area();
-out_free0:
-       kfree(kvm_vmm_info);
-out:
-       return r;
-}
-
-void kvm_arch_exit(void)
-{
-       kvm_free_vmm_area();
-       kfree(kvm_vmm_info);
-       kvm_vmm_info = NULL;
-}
-
-static void kvm_ia64_sync_dirty_log(struct kvm *kvm,
-                                   struct kvm_memory_slot *memslot)
-{
-       int i;
-       long base;
-       unsigned long n;
-       unsigned long *dirty_bitmap = (unsigned long *)(kvm->arch.vm_base +
-                       offsetof(struct kvm_vm_data, kvm_mem_dirty_log));
-
-       n = kvm_dirty_bitmap_bytes(memslot);
-       base = memslot->base_gfn / BITS_PER_LONG;
-
-       spin_lock(&kvm->arch.dirty_log_lock);
-       for (i = 0; i < n/sizeof(long); ++i) {
-               memslot->dirty_bitmap[i] = dirty_bitmap[base + i];
-               dirty_bitmap[base + i] = 0;
-       }
-       spin_unlock(&kvm->arch.dirty_log_lock);
-}
-
-int kvm_vm_ioctl_get_dirty_log(struct kvm *kvm,
-               struct kvm_dirty_log *log)
-{
-       int r;
-       unsigned long n;
-       struct kvm_memory_slot *memslot;
-       int is_dirty = 0;
-
-       mutex_lock(&kvm->slots_lock);
-
-       r = -EINVAL;
-       if (log->slot >= KVM_USER_MEM_SLOTS)
-               goto out;
-
-       memslot = id_to_memslot(kvm->memslots, log->slot);
-       r = -ENOENT;
-       if (!memslot->dirty_bitmap)
-               goto out;
-
-       kvm_ia64_sync_dirty_log(kvm, memslot);
-       r = kvm_get_dirty_log(kvm, log, &is_dirty);
-       if (r)
-               goto out;
-
-       /* If nothing is dirty, don't bother messing with page tables. */
-       if (is_dirty) {
-               kvm_flush_remote_tlbs(kvm);
-               n = kvm_dirty_bitmap_bytes(memslot);
-               memset(memslot->dirty_bitmap, 0, n);
-       }
-       r = 0;
-out:
-       mutex_unlock(&kvm->slots_lock);
-       return r;
-}
-
-int kvm_arch_hardware_setup(void)
-{
-       return 0;
-}
-
-int kvm_apic_set_irq(struct kvm_vcpu *vcpu, struct kvm_lapic_irq *irq)
-{
-       return __apic_accept_irq(vcpu, irq->vector);
-}
-
-int kvm_apic_match_physical_addr(struct kvm_lapic *apic, u16 dest)
-{
-       return apic->vcpu->vcpu_id == dest;
-}
-
-int kvm_apic_match_logical_addr(struct kvm_lapic *apic, u8 mda)
-{
-       return 0;
-}
-
-int kvm_apic_compare_prio(struct kvm_vcpu *vcpu1, struct kvm_vcpu *vcpu2)
-{
-       return vcpu1->arch.xtp - vcpu2->arch.xtp;
-}
-
-int kvm_apic_match_dest(struct kvm_vcpu *vcpu, struct kvm_lapic *source,
-               int short_hand, int dest, int dest_mode)
-{
-       struct kvm_lapic *target = vcpu->arch.apic;
-       return (dest_mode == 0) ?
-               kvm_apic_match_physical_addr(target, dest) :
-               kvm_apic_match_logical_addr(target, dest);
-}
-
-static int find_highest_bits(int *dat)
-{
-       u32  bits, bitnum;
-       int i;
-
-       /* loop for all 256 bits */
-       for (i = 7; i >= 0 ; i--) {
-               bits = dat[i];
-               if (bits) {
-                       bitnum = fls(bits);
-                       return i * 32 + bitnum - 1;
-               }
-       }
-
-       return -1;
-}
-
-int kvm_highest_pending_irq(struct kvm_vcpu *vcpu)
-{
-    struct vpd *vpd = to_host(vcpu->kvm, vcpu->arch.vpd);
-
-    if (vpd->irr[0] & (1UL << NMI_VECTOR))
-               return NMI_VECTOR;
-    if (vpd->irr[0] & (1UL << ExtINT_VECTOR))
-               return ExtINT_VECTOR;
-
-    return find_highest_bits((int *)&vpd->irr[0]);
-}
-
-int kvm_cpu_has_pending_timer(struct kvm_vcpu *vcpu)
-{
-       return vcpu->arch.timer_fired;
-}
-
-int kvm_arch_vcpu_runnable(struct kvm_vcpu *vcpu)
-{
-       return (vcpu->arch.mp_state == KVM_MP_STATE_RUNNABLE) ||
-               (kvm_highest_pending_irq(vcpu) != -1);
-}
-
-int kvm_arch_vcpu_should_kick(struct kvm_vcpu *vcpu)
-{
-       return (!test_and_set_bit(KVM_REQ_KICK, &vcpu->requests));
-}
-
-int kvm_arch_vcpu_ioctl_get_mpstate(struct kvm_vcpu *vcpu,
-                                   struct kvm_mp_state *mp_state)
-{
-       mp_state->mp_state = vcpu->arch.mp_state;
-       return 0;
-}
-
-static int vcpu_reset(struct kvm_vcpu *vcpu)
-{
-       int r;
-       long psr;
-       local_irq_save(psr);
-       r = kvm_insert_vmm_mapping(vcpu);
-       local_irq_restore(psr);
-       if (r)
-               goto fail;
-
-       vcpu->arch.launched = 0;
-       kvm_arch_vcpu_uninit(vcpu);
-       r = kvm_arch_vcpu_init(vcpu);
-       if (r)
-               goto fail;
-
-       kvm_purge_vmm_mapping(vcpu);
-       r = 0;
-fail:
-       return r;
-}
-
-int kvm_arch_vcpu_ioctl_set_mpstate(struct kvm_vcpu *vcpu,
-                                   struct kvm_mp_state *mp_state)
-{
-       int r = 0;
-
-       vcpu->arch.mp_state = mp_state->mp_state;
-       if (vcpu->arch.mp_state == KVM_MP_STATE_UNINITIALIZED)
-               r = vcpu_reset(vcpu);
-       return r;
-}
diff --git a/arch/ia64/kvm/kvm_fw.c b/arch/ia64/kvm/kvm_fw.c
deleted file mode 100644 (file)
index cb548ee..0000000
+++ /dev/null
@@ -1,674 +0,0 @@
-/*
- * PAL/SAL call delegation
- *
- * Copyright (c) 2004 Li Susie <susie.li@intel.com>
- * Copyright (c) 2005 Yu Ke <ke.yu@intel.com>
- * Copyright (c) 2007 Xiantao Zhang <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.
- */
-
-#include <linux/kvm_host.h>
-#include <linux/smp.h>
-#include <asm/sn/addrs.h>
-#include <asm/sn/clksupport.h>
-#include <asm/sn/shub_mmr.h>
-
-#include "vti.h"
-#include "misc.h"
-
-#include <asm/pal.h>
-#include <asm/sal.h>
-#include <asm/tlb.h>
-
-/*
- * Handy macros to make sure that the PAL return values start out
- * as something meaningful.
- */
-#define INIT_PAL_STATUS_UNIMPLEMENTED(x)               \
-       {                                               \
-               x.status = PAL_STATUS_UNIMPLEMENTED;    \
-               x.v0 = 0;                               \
-               x.v1 = 0;                               \
-               x.v2 = 0;                               \
-       }
-
-#define INIT_PAL_STATUS_SUCCESS(x)                     \
-       {                                               \
-               x.status = PAL_STATUS_SUCCESS;          \
-               x.v0 = 0;                               \
-               x.v1 = 0;                               \
-               x.v2 = 0;                               \
-    }
-
-static void kvm_get_pal_call_data(struct kvm_vcpu *vcpu,
-               u64 *gr28, u64 *gr29, u64 *gr30, u64 *gr31) {
-       struct exit_ctl_data *p;
-
-       if (vcpu) {
-               p = &vcpu->arch.exit_data;
-               if (p->exit_reason == EXIT_REASON_PAL_CALL) {
-                       *gr28 = p->u.pal_data.gr28;
-                       *gr29 = p->u.pal_data.gr29;
-                       *gr30 = p->u.pal_data.gr30;
-                       *gr31 = p->u.pal_data.gr31;
-                       return ;
-               }
-       }
-       printk(KERN_DEBUG"Failed to get vcpu pal data!!!\n");
-}
-
-static void set_pal_result(struct kvm_vcpu *vcpu,
-               struct ia64_pal_retval result) {
-
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-       if (p->exit_reason == EXIT_REASON_PAL_CALL) {
-               p->u.pal_data.ret = result;
-               return ;
-       }
-       INIT_PAL_STATUS_UNIMPLEMENTED(p->u.pal_data.ret);
-}
-
-static void set_sal_result(struct kvm_vcpu *vcpu,
-               struct sal_ret_values result) {
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-       if (p->exit_reason == EXIT_REASON_SAL_CALL) {
-               p->u.sal_data.ret = result;
-               return ;
-       }
-       printk(KERN_WARNING"Failed to set sal result!!\n");
-}
-
-struct cache_flush_args {
-       u64 cache_type;
-       u64 operation;
-       u64 progress;
-       long status;
-};
-
-cpumask_t cpu_cache_coherent_map;
-
-static void remote_pal_cache_flush(void *data)
-{
-       struct cache_flush_args *args = data;
-       long status;
-       u64 progress = args->progress;
-
-       status = ia64_pal_cache_flush(args->cache_type, args->operation,
-                                       &progress, NULL);
-       if (status != 0)
-       args->status = status;
-}
-
-static struct ia64_pal_retval pal_cache_flush(struct kvm_vcpu *vcpu)
-{
-       u64 gr28, gr29, gr30, gr31;
-       struct ia64_pal_retval result = {0, 0, 0, 0};
-       struct cache_flush_args args = {0, 0, 0, 0};
-       long psr;
-
-       gr28 = gr29 = gr30 = gr31 = 0;
-       kvm_get_pal_call_data(vcpu, &gr28, &gr29, &gr30, &gr31);
-
-       if (gr31 != 0)
-               printk(KERN_ERR"vcpu:%p called cache_flush error!\n", vcpu);
-
-       /* Always call Host Pal in int=1 */
-       gr30 &= ~PAL_CACHE_FLUSH_CHK_INTRS;
-       args.cache_type = gr29;
-       args.operation = gr30;
-       smp_call_function(remote_pal_cache_flush,
-                               (void *)&args, 1);
-       if (args.status != 0)
-               printk(KERN_ERR"pal_cache_flush error!,"
-                               "status:0x%lx\n", args.status);
-       /*
-        * Call Host PAL cache flush
-        * Clear psr.ic when call PAL_CACHE_FLUSH
-        */
-       local_irq_save(psr);
-       result.status = ia64_pal_cache_flush(gr29, gr30, &result.v1,
-                                               &result.v0);
-       local_irq_restore(psr);
-       if (result.status != 0)
-               printk(KERN_ERR"vcpu:%p crashed due to cache_flush err:%ld"
-                               "in1:%lx,in2:%lx\n",
-                               vcpu, result.status, gr29, gr30);
-
-#if 0
-       if (gr29 == PAL_CACHE_TYPE_COHERENT) {
-               cpus_setall(vcpu->arch.cache_coherent_map);
-               cpu_clear(vcpu->cpu, vcpu->arch.cache_coherent_map);
-               cpus_setall(cpu_cache_coherent_map);
-               cpu_clear(vcpu->cpu, cpu_cache_coherent_map);
-       }
-#endif
-       return result;
-}
-
-struct ia64_pal_retval pal_cache_summary(struct kvm_vcpu *vcpu)
-{
-
-       struct ia64_pal_retval result;
-
-       PAL_CALL(result, PAL_CACHE_SUMMARY, 0, 0, 0);
-       return result;
-}
-
-static struct ia64_pal_retval pal_freq_base(struct kvm_vcpu *vcpu)
-{
-
-       struct ia64_pal_retval result;
-
-       PAL_CALL(result, PAL_FREQ_BASE, 0, 0, 0);
-
-       /*
-        * PAL_FREQ_BASE may not be implemented in some platforms,
-        * call SAL instead.
-        */
-       if (result.v0 == 0) {
-               result.status = ia64_sal_freq_base(SAL_FREQ_BASE_PLATFORM,
-                                                       &result.v0,
-                                                       &result.v1);
-               result.v2 = 0;
-       }
-
-       return result;
-}
-
-/*
- * On the SGI SN2, the ITC isn't stable. Emulation backed by the SN2
- * RTC is used instead. This function patches the ratios from SAL
- * to match the RTC before providing them to the guest.
- */
-static void sn2_patch_itc_freq_ratios(struct ia64_pal_retval *result)
-{
-       struct pal_freq_ratio *ratio;
-       unsigned long sal_freq, sal_drift, factor;
-
-       result->status = ia64_sal_freq_base(SAL_FREQ_BASE_PLATFORM,
-                                           &sal_freq, &sal_drift);
-       ratio = (struct pal_freq_ratio *)&result->v2;
-       factor = ((sal_freq * 3) + (sn_rtc_cycles_per_second / 2)) /
-               sn_rtc_cycles_per_second;
-
-       ratio->num = 3;
-       ratio->den = factor;
-}
-
-static struct ia64_pal_retval pal_freq_ratios(struct kvm_vcpu *vcpu)
-{
-       struct ia64_pal_retval result;
-
-       PAL_CALL(result, PAL_FREQ_RATIOS, 0, 0, 0);
-
-       if (vcpu->kvm->arch.is_sn2)
-               sn2_patch_itc_freq_ratios(&result);
-
-       return result;
-}
-
-static struct ia64_pal_retval pal_logical_to_physica(struct kvm_vcpu *vcpu)
-{
-       struct ia64_pal_retval result;
-
-       INIT_PAL_STATUS_UNIMPLEMENTED(result);
-       return result;
-}
-
-static struct ia64_pal_retval pal_platform_addr(struct kvm_vcpu *vcpu)
-{
-
-       struct ia64_pal_retval result;
-
-       INIT_PAL_STATUS_SUCCESS(result);
-       return result;
-}
-
-static struct ia64_pal_retval pal_proc_get_features(struct kvm_vcpu *vcpu)
-{
-
-       struct ia64_pal_retval result = {0, 0, 0, 0};
-       long in0, in1, in2, in3;
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       result.status = ia64_pal_proc_get_features(&result.v0, &result.v1,
-                       &result.v2, in2);
-
-       return result;
-}
-
-static struct ia64_pal_retval pal_register_info(struct kvm_vcpu *vcpu)
-{
-
-       struct ia64_pal_retval result = {0, 0, 0, 0};
-       long in0, in1, in2, in3;
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       result.status = ia64_pal_register_info(in1, &result.v1, &result.v2);
-
-       return result;
-}
-
-static struct ia64_pal_retval pal_cache_info(struct kvm_vcpu *vcpu)
-{
-
-       pal_cache_config_info_t ci;
-       long status;
-       unsigned long in0, in1, in2, in3, r9, r10;
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       status = ia64_pal_cache_config_info(in1, in2, &ci);
-       r9 = ci.pcci_info_1.pcci1_data;
-       r10 = ci.pcci_info_2.pcci2_data;
-       return ((struct ia64_pal_retval){status, r9, r10, 0});
-}
-
-#define GUEST_IMPL_VA_MSB      59
-#define GUEST_RID_BITS         18
-
-static struct ia64_pal_retval pal_vm_summary(struct kvm_vcpu *vcpu)
-{
-
-       pal_vm_info_1_u_t vminfo1;
-       pal_vm_info_2_u_t vminfo2;
-       struct ia64_pal_retval result;
-
-       PAL_CALL(result, PAL_VM_SUMMARY, 0, 0, 0);
-       if (!result.status) {
-               vminfo1.pvi1_val = result.v0;
-               vminfo1.pal_vm_info_1_s.max_itr_entry = 8;
-               vminfo1.pal_vm_info_1_s.max_dtr_entry = 8;
-               result.v0 = vminfo1.pvi1_val;
-               vminfo2.pal_vm_info_2_s.impl_va_msb = GUEST_IMPL_VA_MSB;
-               vminfo2.pal_vm_info_2_s.rid_size = GUEST_RID_BITS;
-               result.v1 = vminfo2.pvi2_val;
-       }
-
-       return result;
-}
-
-static struct ia64_pal_retval pal_vm_info(struct kvm_vcpu *vcpu)
-{
-       struct ia64_pal_retval result;
-       unsigned long in0, in1, in2, in3;
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-
-       result.status = ia64_pal_vm_info(in1, in2,
-                       (pal_tc_info_u_t *)&result.v1, &result.v2);
-
-       return result;
-}
-
-static  u64 kvm_get_pal_call_index(struct kvm_vcpu *vcpu)
-{
-       u64 index = 0;
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-       if (p->exit_reason == EXIT_REASON_PAL_CALL)
-               index = p->u.pal_data.gr28;
-
-       return index;
-}
-
-static void prepare_for_halt(struct kvm_vcpu *vcpu)
-{
-       vcpu->arch.timer_pending = 1;
-       vcpu->arch.timer_fired = 0;
-}
-
-static struct ia64_pal_retval pal_perf_mon_info(struct kvm_vcpu *vcpu)
-{
-       long status;
-       unsigned long in0, in1, in2, in3, r9;
-       unsigned long pm_buffer[16];
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       status = ia64_pal_perf_mon_info(pm_buffer,
-                               (pal_perf_mon_info_u_t *) &r9);
-       if (status != 0) {
-               printk(KERN_DEBUG"PAL_PERF_MON_INFO fails ret=%ld\n", status);
-       } else {
-               if (in1)
-                       memcpy((void *)in1, pm_buffer, sizeof(pm_buffer));
-               else {
-                       status = PAL_STATUS_EINVAL;
-                       printk(KERN_WARNING"Invalid parameters "
-                                               "for PAL call:0x%lx!\n", in0);
-               }
-       }
-       return (struct ia64_pal_retval){status, r9, 0, 0};
-}
-
-static struct ia64_pal_retval pal_halt_info(struct kvm_vcpu *vcpu)
-{
-       unsigned long in0, in1, in2, in3;
-       long status;
-       unsigned long res = 1000UL | (1000UL << 16) | (10UL << 32)
-                                       | (1UL << 61) | (1UL << 60);
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       if (in1) {
-               memcpy((void *)in1, &res, sizeof(res));
-               status = 0;
-       } else{
-               status = PAL_STATUS_EINVAL;
-               printk(KERN_WARNING"Invalid parameters "
-                                       "for PAL call:0x%lx!\n", in0);
-       }
-
-       return (struct ia64_pal_retval){status, 0, 0, 0};
-}
-
-static struct ia64_pal_retval pal_mem_attrib(struct kvm_vcpu *vcpu)
-{
-       unsigned long r9;
-       long status;
-
-       status = ia64_pal_mem_attrib(&r9);
-
-       return (struct ia64_pal_retval){status, r9, 0, 0};
-}
-
-static void remote_pal_prefetch_visibility(void *v)
-{
-       s64 trans_type = (s64)v;
-       ia64_pal_prefetch_visibility(trans_type);
-}
-
-static struct ia64_pal_retval pal_prefetch_visibility(struct kvm_vcpu *vcpu)
-{
-       struct ia64_pal_retval result = {0, 0, 0, 0};
-       unsigned long in0, in1, in2, in3;
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-       result.status = ia64_pal_prefetch_visibility(in1);
-       if (result.status == 0) {
-               /* Must be performed on all remote processors
-               in the coherence domain. */
-               smp_call_function(remote_pal_prefetch_visibility,
-                                       (void *)in1, 1);
-               /* Unnecessary on remote processor for other vcpus!*/
-               result.status = 1;
-       }
-       return result;
-}
-
-static void remote_pal_mc_drain(void *v)
-{
-       ia64_pal_mc_drain();
-}
-
-static struct ia64_pal_retval pal_get_brand_info(struct kvm_vcpu *vcpu)
-{
-       struct ia64_pal_retval result = {0, 0, 0, 0};
-       unsigned long in0, in1, in2, in3;
-
-       kvm_get_pal_call_data(vcpu, &in0, &in1, &in2, &in3);
-
-       if (in1 == 0 && in2) {
-               char brand_info[128];
-               result.status = ia64_pal_get_brand_info(brand_info);
-               if (result.status == PAL_STATUS_SUCCESS)
-                       memcpy((void *)in2, brand_info, 128);
-       } else {
-               result.status = PAL_STATUS_REQUIRES_MEMORY;
-               printk(KERN_WARNING"Invalid parameters for "
-                                       "PAL call:0x%lx!\n", in0);
-       }
-
-       return result;
-}
-
-int kvm_pal_emul(struct kvm_vcpu *vcpu, struct kvm_run *run)
-{
-
-       u64 gr28;
-       struct ia64_pal_retval result;
-       int ret = 1;
-
-       gr28 = kvm_get_pal_call_index(vcpu);
-       switch (gr28) {
-       case PAL_CACHE_FLUSH:
-               result = pal_cache_flush(vcpu);
-               break;
-       case PAL_MEM_ATTRIB:
-               result = pal_mem_attrib(vcpu);
-               break;
-       case PAL_CACHE_SUMMARY:
-               result = pal_cache_summary(vcpu);
-               break;
-       case PAL_PERF_MON_INFO:
-               result = pal_perf_mon_info(vcpu);
-               break;
-       case PAL_HALT_INFO:
-               result = pal_halt_info(vcpu);
-               break;
-       case PAL_HALT_LIGHT:
-       {
-               INIT_PAL_STATUS_SUCCESS(result);
-               prepare_for_halt(vcpu);
-               if (kvm_highest_pending_irq(vcpu) == -1)
-                       ret = kvm_emulate_halt(vcpu);
-       }
-               break;
-
-       case PAL_PREFETCH_VISIBILITY:
-               result = pal_prefetch_visibility(vcpu);
-               break;
-       case PAL_MC_DRAIN:
-               result.status = ia64_pal_mc_drain();
-               /* FIXME: All vcpus likely call PAL_MC_DRAIN.
-                  That causes the congestion. */
-               smp_call_function(remote_pal_mc_drain, NULL, 1);
-               break;
-
-       case PAL_FREQ_RATIOS:
-               result = pal_freq_ratios(vcpu);
-               break;
-
-       case PAL_FREQ_BASE:
-               result = pal_freq_base(vcpu);
-               break;
-
-       case PAL_LOGICAL_TO_PHYSICAL :
-               result = pal_logical_to_physica(vcpu);
-               break;
-
-       case PAL_VM_SUMMARY :
-               result = pal_vm_summary(vcpu);
-               break;
-
-       case PAL_VM_INFO :
-               result = pal_vm_info(vcpu);
-               break;
-       case PAL_PLATFORM_ADDR :
-               result = pal_platform_addr(vcpu);
-               break;
-       case PAL_CACHE_INFO:
-               result = pal_cache_info(vcpu);
-               break;
-       case PAL_PTCE_INFO:
-               INIT_PAL_STATUS_SUCCESS(result);
-               result.v1 = (1L << 32) | 1L;
-               break;
-       case PAL_REGISTER_INFO:
-               result = pal_register_info(vcpu);
-               break;
-       case PAL_VM_PAGE_SIZE:
-               result.status = ia64_pal_vm_page_size(&result.v0,
-                                                       &result.v1);
-               break;
-       case PAL_RSE_INFO:
-               result.status = ia64_pal_rse_info(&result.v0,
-                                       (pal_hints_u_t *)&result.v1);
-               break;
-       case PAL_PROC_GET_FEATURES:
-               result = pal_proc_get_features(vcpu);
-               break;
-       case PAL_DEBUG_INFO:
-               result.status = ia64_pal_debug_info(&result.v0,
-                                                       &result.v1);
-               break;
-       case PAL_VERSION:
-               result.status = ia64_pal_version(
-                               (pal_version_u_t *)&result.v0,
-                               (pal_version_u_t *)&result.v1);
-               break;
-       case PAL_FIXED_ADDR:
-               result.status = PAL_STATUS_SUCCESS;
-               result.v0 = vcpu->vcpu_id;
-               break;
-       case PAL_BRAND_INFO:
-               result = pal_get_brand_info(vcpu);
-               break;
-       case PAL_GET_PSTATE:
-       case PAL_CACHE_SHARED_INFO:
-               INIT_PAL_STATUS_UNIMPLEMENTED(result);
-               break;
-       default:
-               INIT_PAL_STATUS_UNIMPLEMENTED(result);
-               printk(KERN_WARNING"kvm: Unsupported pal call,"
-                                       " index:0x%lx\n", gr28);
-       }
-       set_pal_result(vcpu, result);
-       return ret;
-}
-
-static struct sal_ret_values sal_emulator(struct kvm *kvm,
-                               long index, unsigned long in1,
-                               unsigned long in2, unsigned long in3,
-                               unsigned long in4, unsigned long in5,
-                               unsigned long in6, unsigned long in7)
-{
-       unsigned long r9  = 0;
-       unsigned long r10 = 0;
-       long r11 = 0;
-       long status;
-
-       status = 0;
-       switch (index) {
-       case SAL_FREQ_BASE:
-               status = ia64_sal_freq_base(in1, &r9, &r10);
-               break;
-       case SAL_PCI_CONFIG_READ:
-               printk(KERN_WARNING"kvm: Not allowed to call here!"
-                       " SAL_PCI_CONFIG_READ\n");
-               break;
-       case SAL_PCI_CONFIG_WRITE:
-               printk(KERN_WARNING"kvm: Not allowed to call here!"
-                       " SAL_PCI_CONFIG_WRITE\n");
-               break;
-       case SAL_SET_VECTORS:
-               if (in1 == SAL_VECTOR_OS_BOOT_RENDEZ) {
-                       if (in4 != 0 || in5 != 0 || in6 != 0 || in7 != 0) {
-                               status = -2;
-                       } else {
-                               kvm->arch.rdv_sal_data.boot_ip = in2;
-                               kvm->arch.rdv_sal_data.boot_gp = in3;
-                       }
-                       printk("Rendvous called! iip:%lx\n\n", in2);
-               } else
-                       printk(KERN_WARNING"kvm: CALLED SAL_SET_VECTORS %lu."
-                                                       "ignored...\n", in1);
-               break;
-       case SAL_GET_STATE_INFO:
-               /* No more info.  */
-               status = -5;
-               r9 = 0;
-               break;
-       case SAL_GET_STATE_INFO_SIZE:
-               /* Return a dummy size.  */
-               status = 0;
-               r9 = 128;
-               break;
-       case SAL_CLEAR_STATE_INFO:
-               /* Noop.  */
-               break;
-       case SAL_MC_RENDEZ:
-               printk(KERN_WARNING
-                       "kvm: called SAL_MC_RENDEZ. ignored...\n");
-               break;
-       case SAL_MC_SET_PARAMS:
-               printk(KERN_WARNING
-                       "kvm: called  SAL_MC_SET_PARAMS.ignored!\n");
-               break;
-       case SAL_CACHE_FLUSH:
-               if (1) {
-                       /*Flush using SAL.
-                       This method is faster but has a side
-                       effect on other vcpu running on
-                       this cpu.  */
-                       status = ia64_sal_cache_flush(in1);
-               } else {
-                       /*Maybe need to implement the method
-                       without side effect!*/
-                       status = 0;
-               }
-               break;
-       case SAL_CACHE_INIT:
-               printk(KERN_WARNING
-                       "kvm: called SAL_CACHE_INIT.  ignored...\n");
-               break;
-       case SAL_UPDATE_PAL:
-               printk(KERN_WARNING
-                       "kvm: CALLED SAL_UPDATE_PAL.  ignored...\n");
-               break;
-       default:
-               printk(KERN_WARNING"kvm: called SAL_CALL with unknown index."
-                                               " index:%ld\n", index);
-               status = -1;
-               break;
-       }
-       return ((struct sal_ret_values) {status, r9, r10, r11});
-}
-
-static void kvm_get_sal_call_data(struct kvm_vcpu *vcpu, u64 *in0, u64 *in1,
-               u64 *in2, u64 *in3, u64 *in4, u64 *in5, u64 *in6, u64 *in7){
-
-       struct exit_ctl_data *p;
-
-       p = kvm_get_exit_data(vcpu);
-
-       if (p->exit_reason == EXIT_REASON_SAL_CALL) {
-               *in0 = p->u.sal_data.in0;
-               *in1 = p->u.sal_data.in1;
-               *in2 = p->u.sal_data.in2;
-               *in3 = p->u.sal_data.in3;
-               *in4 = p->u.sal_data.in4;
-               *in5 = p->u.sal_data.in5;
-               *in6 = p->u.sal_data.in6;
-               *in7 = p->u.sal_data.in7;
-               return ;
-       }
-       *in0 = 0;
-}
-
-void kvm_sal_emul(struct kvm_vcpu *vcpu)
-{
-
-       struct sal_ret_values result;
-       u64 index, in1, in2, in3, in4, in5, in6, in7;
-
-       kvm_get_sal_call_data(vcpu, &index, &in1, &in2,
-                       &in3, &in4, &in5, &in6, &in7);
-       result = sal_emulator(vcpu->kvm, index, in1, in2, in3,
-                                       in4, in5, in6, in7);
-       set_sal_result(vcpu, result);
-}
diff --git a/arch/ia64/kvm/kvm_lib.c b/arch/ia64/kvm/kvm_lib.c
deleted file mode 100644 (file)
index f1268b8..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-/*
- * kvm_lib.c: Compile some libraries for kvm-intel module.
- *
- *     Just include kernel's library, and disable symbols export.
- *     Copyright (C) 2008, Intel Corporation.
- *     Xiantao Zhang  (xiantao.zhang@intel.com)
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- *
- */
-#undef CONFIG_MODULES
-#include <linux/module.h>
-#undef CONFIG_KALLSYMS
-#undef EXPORT_SYMBOL
-#undef EXPORT_SYMBOL_GPL
-#define EXPORT_SYMBOL(sym)
-#define EXPORT_SYMBOL_GPL(sym)
-#include "../../../lib/vsprintf.c"
-#include "../../../lib/ctype.c"
diff --git a/arch/ia64/kvm/kvm_minstate.h b/arch/ia64/kvm/kvm_minstate.h
deleted file mode 100644 (file)
index b2bcaa2..0000000
+++ /dev/null
@@ -1,266 +0,0 @@
-/*
- *  kvm_minstate.h: min save macros
- *  Copyright (c) 2007, Intel Corporation.
- *
- *  Xuefei Xu (Anthony Xu) (Anthony.xu@intel.com)
- *  Xiantao Zhang (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.
- *
- */
-
-
-#include <asm/asmmacro.h>
-#include <asm/types.h>
-#include <asm/kregs.h>
-#include <asm/kvm_host.h>
-
-#include "asm-offsets.h"
-
-#define KVM_MINSTATE_START_SAVE_MIN                                            \
-       mov ar.rsc = 0;/* set enforced lazy mode, pl 0, little-endian, loadrs=0 */\
-       ;;                                                                      \
-       mov.m r28 = ar.rnat;                                                    \
-       addl r22 = VMM_RBS_OFFSET,r1;            /* compute base of RBS */      \
-       ;;                                                                      \
-       lfetch.fault.excl.nt1 [r22];                                            \
-       addl r1 = KVM_STK_OFFSET-VMM_PT_REGS_SIZE, r1;  \
-       mov r23 = ar.bspstore;                  /* save ar.bspstore */          \
-       ;;                                                                      \
-       mov ar.bspstore = r22;                          /* switch to kernel RBS */\
-       ;;                                                                      \
-       mov r18 = ar.bsp;                                                       \
-       mov ar.rsc = 0x3;     /* set eager mode, pl 0, little-endian, loadrs=0 */
-
-
-
-#define KVM_MINSTATE_END_SAVE_MIN                                              \
-       bsw.1;          /* switch back to bank 1 (must be last in insn group) */\
-       ;;
-
-
-#define PAL_VSA_SYNC_READ                                              \
-       /* begin to call pal vps sync_read */                           \
-{.mii;                                                                 \
-       add r25 = VMM_VPD_BASE_OFFSET, r21;                             \
-       nop 0x0;                                                        \
-       mov r24=ip;                                                     \
-       ;;                                                              \
-}                                                                      \
-{.mmb                                                                  \
-       add r24=0x20, r24;                                              \
-       ld8 r25 = [r25];      /* read vpd base */                       \
-       br.cond.sptk kvm_vps_sync_read;         /*call the service*/    \
-       ;;                                                              \
-};                                                                     \
-
-
-#define KVM_MINSTATE_GET_CURRENT(reg)   mov reg=r21
-
-/*
- * KVM_DO_SAVE_MIN switches to the kernel stacks (if necessary) and saves
- * the minimum state necessary that allows us to turn psr.ic back
- * on.
- *
- * Assumed state upon entry:
- *  psr.ic: off
- *  r31:       contains saved predicates (pr)
- *
- * Upon exit, the state is as follows:
- *  psr.ic: off
- *   r2 = points to &pt_regs.r16
- *   r8 = contents of ar.ccv
- *   r9 = contents of ar.csd
- *  r10 = contents of ar.ssd
- *  r11 = FPSR_DEFAULT
- *  r12 = kernel sp (kernel virtual address)
- *  r13 = points to current task_struct (kernel virtual address)
- *  p15 = TRUE if psr.i is set in cr.ipsr
- *  predicate registers (other than p2, p3, and p15), b6, r3, r14, r15:
- *       preserved
- *
- * Note that psr.ic is NOT turned on by this macro.  This is so that
- * we can pass interruption state as arguments to a handler.
- */
-
-
-#define PT(f) (VMM_PT_REGS_##f##_OFFSET)
-
-#define KVM_DO_SAVE_MIN(COVER,SAVE_IFS,EXTRA)                  \
-       KVM_MINSTATE_GET_CURRENT(r16);  /* M (or M;;I) */       \
-       mov r27 = ar.rsc;         /* M */                       \
-       mov r20 = r1;         /* A */                           \
-       mov r25 = ar.unat;        /* M */                       \
-       mov r29 = cr.ipsr;        /* M */                       \
-       mov r26 = ar.pfs;         /* I */                       \
-       mov r18 = cr.isr;                                       \
-       COVER;              /* B;; (or nothing) */              \
-       ;;                                                      \
-       tbit.z p0,p15 = r29,IA64_PSR_I_BIT;                     \
-       mov r1 = r16;                                           \
-/*     mov r21=r16;    */                                      \
-       /* switch from user to kernel RBS: */                   \
-       ;;                                                      \
-       invala;             /* M */                             \
-       SAVE_IFS;                                               \
-       ;;                                                      \
-       KVM_MINSTATE_START_SAVE_MIN                             \
-       adds r17 = 2*L1_CACHE_BYTES,r1;/* cache-line size */    \
-       adds r16 = PT(CR_IPSR),r1;                              \
-       ;;                                                      \
-       lfetch.fault.excl.nt1 [r17],L1_CACHE_BYTES;             \
-       st8 [r16] = r29;      /* save cr.ipsr */                \
-       ;;                                                      \
-       lfetch.fault.excl.nt1 [r17];                            \
-       tbit.nz p15,p0 = r29,IA64_PSR_I_BIT;                    \
-       mov r29 = b0                                            \
-       ;;                                                      \
-       adds r16 = PT(R8),r1; /* initialize first base pointer */\
-       adds r17 = PT(R9),r1; /* initialize second base pointer */\
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r8,16;                      \
-.mem.offset 8,0; st8.spill [r17] = r9,16;                      \
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r10,24;                     \
-.mem.offset 8,0; st8.spill [r17] = r11,24;                     \
-       ;;                                                      \
-       mov r9 = cr.iip;         /* M */                        \
-       mov r10 = ar.fpsr;        /* M */                       \
-       ;;                                                      \
-       st8 [r16] = r9,16;    /* save cr.iip */                 \
-       st8 [r17] = r30,16;   /* save cr.ifs */                 \
-       sub r18 = r18,r22;    /* r18=RSE.ndirty*8 */            \
-       ;;                                                      \
-       st8 [r16] = r25,16;   /* save ar.unat */                \
-       st8 [r17] = r26,16;    /* save ar.pfs */                \
-       shl r18 = r18,16;     /* calu ar.rsc used for "loadrs" */\
-       ;;                                                      \
-       st8 [r16] = r27,16;   /* save ar.rsc */                 \
-       st8 [r17] = r28,16;   /* save ar.rnat */                \
-       ;;          /* avoid RAW on r16 & r17 */                \
-       st8 [r16] = r23,16;   /* save ar.bspstore */            \
-       st8 [r17] = r31,16;   /* save predicates */             \
-       ;;                                                      \
-       st8 [r16] = r29,16;   /* save b0 */                     \
-       st8 [r17] = r18,16;   /* save ar.rsc value for "loadrs" */\
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r20,16;/* save original r1 */  \
-.mem.offset 8,0; st8.spill [r17] = r12,16;                     \
-       adds r12 = -16,r1;    /* switch to kernel memory stack */  \
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r13,16;                     \
-.mem.offset 8,0; st8.spill [r17] = r10,16;     /* save ar.fpsr */\
-       mov r13 = r21;   /* establish `current' */              \
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r15,16;                     \
-.mem.offset 8,0; st8.spill [r17] = r14,16;                     \
-       ;;                                                      \
-.mem.offset 0,0; st8.spill [r16] = r2,16;                      \
-.mem.offset 8,0; st8.spill [r17] = r3,16;                      \
-       adds r2 = VMM_PT_REGS_R16_OFFSET,r1;                    \
-        ;;                                                     \
-       adds r16 = VMM_VCPU_IIPA_OFFSET,r13;                    \
-       adds r17 = VMM_VCPU_ISR_OFFSET,r13;                     \
-       mov r26 = cr.iipa;                                      \
-       mov r27 = cr.isr;                                       \
-       ;;                                                      \
-       st8 [r16] = r26;                                        \
-       st8 [r17] = r27;                                        \
-       ;;                                                      \
-       EXTRA;                                                  \
-       mov r8 = ar.ccv;                                        \
-       mov r9 = ar.csd;                                        \
-       mov r10 = ar.ssd;                                       \
-       movl r11 = FPSR_DEFAULT;   /* L-unit */                 \
-       adds r17 = VMM_VCPU_GP_OFFSET,r13;                      \
-       ;;                                                      \
-       ld8 r1 = [r17];/* establish kernel global pointer */    \
-       ;;                                                      \
-       PAL_VSA_SYNC_READ                                       \
-       KVM_MINSTATE_END_SAVE_MIN
-
-/*
- * SAVE_REST saves the remainder of pt_regs (with psr.ic on).
- *
- * Assumed state upon entry:
- *  psr.ic: on
- *  r2: points to &pt_regs.f6
- *  r3: points to &pt_regs.f7
- *  r8: contents of ar.ccv
- *  r9: contents of ar.csd
- *  r10:       contents of ar.ssd
- *  r11:       FPSR_DEFAULT
- *
- * Registers r14 and r15 are guaranteed not to be touched by SAVE_REST.
- */
-#define KVM_SAVE_REST                          \
-.mem.offset 0,0; st8.spill [r2] = r16,16;      \
-.mem.offset 8,0; st8.spill [r3] = r17,16;      \
-       ;;                              \
-.mem.offset 0,0; st8.spill [r2] = r18,16;      \
-.mem.offset 8,0; st8.spill [r3] = r19,16;      \
-       ;;                              \
-.mem.offset 0,0; st8.spill [r2] = r20,16;      \
-.mem.offset 8,0; st8.spill [r3] = r21,16;      \
-       mov r18=b6;                     \
-       ;;                              \
-.mem.offset 0,0; st8.spill [r2] = r22,16;      \
-.mem.offset 8,0; st8.spill [r3] = r23,16;      \
-       mov r19 = b7;                           \
-       ;;                                      \
-.mem.offset 0,0; st8.spill [r2] = r24,16;      \
-.mem.offset 8,0; st8.spill [r3] = r25,16;      \
-       ;;                                      \
-.mem.offset 0,0; st8.spill [r2] = r26,16;      \
-.mem.offset 8,0; st8.spill [r3] = r27,16;      \
-       ;;                                      \
-.mem.offset 0,0; st8.spill [r2] = r28,16;      \
-.mem.offset 8,0; st8.spill [r3] = r29,16;      \
-       ;;                                      \
-.mem.offset 0,0; st8.spill [r2] = r30,16;      \
-.mem.offset 8,0; st8.spill [r3] = r31,32;      \
-       ;;                                      \
-       mov ar.fpsr = r11;                      \
-       st8 [r2] = r8,8;                        \
-       adds r24 = PT(B6)-PT(F7),r3;            \
-       adds r25 = PT(B7)-PT(F7),r3;            \
-       ;;                                      \
-       st8 [r24] = r18,16;       /* b6 */      \
-       st8 [r25] = r19,16;       /* b7 */      \
-       adds r2 = PT(R4)-PT(F6),r2;             \
-       adds r3 = PT(R5)-PT(F7),r3;             \
-       ;;                                      \
-       st8 [r24] = r9; /* ar.csd */            \
-       st8 [r25] = r10;        /* ar.ssd */    \
-       ;;                                      \
-       mov r18 = ar.unat;                      \
-       adds r19 = PT(EML_UNAT)-PT(R4),r2;      \
-       ;;                                      \
-       st8 [r19] = r18; /* eml_unat */         \
-
-
-#define KVM_SAVE_EXTRA                         \
-.mem.offset 0,0; st8.spill [r2] = r4,16;       \
-.mem.offset 8,0; st8.spill [r3] = r5,16;       \
-       ;;                                      \
-.mem.offset 0,0; st8.spill [r2] = r6,16;       \
-.mem.offset 8,0; st8.spill [r3] = r7;          \
-       ;;                                      \
-       mov r26 = ar.unat;                      \
-       ;;                                      \
-       st8 [r2] = r26;/* eml_unat */           \
-
-#define KVM_SAVE_MIN_WITH_COVER                KVM_DO_SAVE_MIN(cover, mov r30 = cr.ifs,)
-#define KVM_SAVE_MIN_WITH_COVER_R19    KVM_DO_SAVE_MIN(cover, mov r30 = cr.ifs, mov r15 = r19)
-#define KVM_SAVE_MIN                   KVM_DO_SAVE_MIN(     , mov r30 = r0, )
diff --git a/arch/ia64/kvm/lapic.h b/arch/ia64/kvm/lapic.h
deleted file mode 100644 (file)
index c5f92a9..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-#ifndef __KVM_IA64_LAPIC_H
-#define __KVM_IA64_LAPIC_H
-
-#include <linux/kvm_host.h>
-
-/*
- * vlsapic
- */
-struct kvm_lapic{
-       struct kvm_vcpu *vcpu;
-       uint64_t insvc[4];
-       uint64_t vhpi;
-       uint8_t xtp;
-       uint8_t pal_init_pending;
-       uint8_t pad[2];
-};
-
-int kvm_create_lapic(struct kvm_vcpu *vcpu);
-void kvm_free_lapic(struct kvm_vcpu *vcpu);
-
-int kvm_apic_match_physical_addr(struct kvm_lapic *apic, u16 dest);
-int kvm_apic_match_logical_addr(struct kvm_lapic *apic, u8 mda);
-int kvm_apic_match_dest(struct kvm_vcpu *vcpu, struct kvm_lapic *source,
-               int short_hand, int dest, int dest_mode);
-int kvm_apic_compare_prio(struct kvm_vcpu *vcpu1, struct kvm_vcpu *vcpu2);
-int kvm_apic_set_irq(struct kvm_vcpu *vcpu, struct kvm_lapic_irq *irq);
-#define kvm_apic_present(x) (true)
-#define kvm_lapic_enabled(x) (true)
-
-#endif
diff --git a/arch/ia64/kvm/memcpy.S b/arch/ia64/kvm/memcpy.S
deleted file mode 100644 (file)
index c04cdbe..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../lib/memcpy.S"
diff --git a/arch/ia64/kvm/memset.S b/arch/ia64/kvm/memset.S
deleted file mode 100644 (file)
index 83c3066..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../lib/memset.S"
diff --git a/arch/ia64/kvm/misc.h b/arch/ia64/kvm/misc.h
deleted file mode 100644 (file)
index dd979e0..0000000
+++ /dev/null
@@ -1,94 +0,0 @@
-#ifndef __KVM_IA64_MISC_H
-#define __KVM_IA64_MISC_H
-
-#include <linux/kvm_host.h>
-/*
- * misc.h
- *     Copyright (C) 2007, Intel Corporation.
- *     Xiantao Zhang  (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.
- *
- */
-
-/*
- *Return p2m base address at host side!
- */
-static inline uint64_t *kvm_host_get_pmt(struct kvm *kvm)
-{
-       return (uint64_t *)(kvm->arch.vm_base +
-                               offsetof(struct kvm_vm_data, kvm_p2m));
-}
-
-static inline void kvm_set_pmt_entry(struct kvm *kvm, gfn_t gfn,
-               u64 paddr, u64 mem_flags)
-{
-       uint64_t *pmt_base = kvm_host_get_pmt(kvm);
-       unsigned long pte;
-
-       pte = PAGE_ALIGN(paddr) | mem_flags;
-       pmt_base[gfn] = pte;
-}
-
-/*Function for translating host address to guest address*/
-
-static inline void *to_guest(struct kvm *kvm, void *addr)
-{
-       return (void *)((unsigned long)(addr) - kvm->arch.vm_base +
-                       KVM_VM_DATA_BASE);
-}
-
-/*Function for translating guest address to host address*/
-
-static inline void *to_host(struct kvm *kvm, void *addr)
-{
-       return (void *)((unsigned long)addr - KVM_VM_DATA_BASE
-                       + kvm->arch.vm_base);
-}
-
-/* Get host context of the vcpu */
-static inline union context *kvm_get_host_context(struct kvm_vcpu *vcpu)
-{
-       union context *ctx = &vcpu->arch.host;
-       return to_guest(vcpu->kvm, ctx);
-}
-
-/* Get guest context of the vcpu */
-static inline union context *kvm_get_guest_context(struct kvm_vcpu *vcpu)
-{
-       union context *ctx = &vcpu->arch.guest;
-       return  to_guest(vcpu->kvm, ctx);
-}
-
-/* kvm get exit data from gvmm! */
-static inline struct exit_ctl_data *kvm_get_exit_data(struct kvm_vcpu *vcpu)
-{
-       return &vcpu->arch.exit_data;
-}
-
-/*kvm get vcpu ioreq for kvm module!*/
-static inline struct kvm_mmio_req *kvm_get_vcpu_ioreq(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p_ctl_data;
-
-       if (vcpu) {
-               p_ctl_data = kvm_get_exit_data(vcpu);
-               if (p_ctl_data->exit_reason == EXIT_REASON_MMIO_INSTRUCTION)
-                       return &p_ctl_data->u.ioreq;
-       }
-
-       return NULL;
-}
-
-#endif
diff --git a/arch/ia64/kvm/mmio.c b/arch/ia64/kvm/mmio.c
deleted file mode 100644 (file)
index f1e17d3..0000000
+++ /dev/null
@@ -1,336 +0,0 @@
-/*
- * mmio.c: MMIO emulation components.
- * Copyright (c) 2004, Intel Corporation.
- *  Yaozu Dong (Eddie Dong) (Eddie.dong@intel.com)
- *  Kun Tian (Kevin Tian) (Kevin.tian@intel.com)
- *
- * Copyright (c) 2007 Intel Corporation  KVM support.
- * Xuefei Xu (Anthony Xu) (anthony.xu@intel.com)
- * Xiantao Zhang  (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.
- *
- */
-
-#include <linux/kvm_host.h>
-
-#include "vcpu.h"
-
-static void vlsapic_write_xtp(struct kvm_vcpu *v, uint8_t val)
-{
-       VLSAPIC_XTP(v) = val;
-}
-
-/*
- * LSAPIC OFFSET
- */
-#define PIB_LOW_HALF(ofst)     !(ofst & (1 << 20))
-#define PIB_OFST_INTA          0x1E0000
-#define PIB_OFST_XTP           0x1E0008
-
-/*
- * execute write IPI op.
- */
-static void vlsapic_write_ipi(struct kvm_vcpu *vcpu,
-                                       uint64_t addr, uint64_t data)
-{
-       struct exit_ctl_data *p = &current_vcpu->arch.exit_data;
-       unsigned long psr;
-
-       local_irq_save(psr);
-
-       p->exit_reason = EXIT_REASON_IPI;
-       p->u.ipi_data.addr.val = addr;
-       p->u.ipi_data.data.val = data;
-       vmm_transition(current_vcpu);
-
-       local_irq_restore(psr);
-
-}
-
-void lsapic_write(struct kvm_vcpu *v, unsigned long addr,
-                       unsigned long length, unsigned long val)
-{
-       addr &= (PIB_SIZE - 1);
-
-       switch (addr) {
-       case PIB_OFST_INTA:
-               panic_vm(v, "Undefined write on PIB INTA\n");
-               break;
-       case PIB_OFST_XTP:
-               if (length == 1) {
-                       vlsapic_write_xtp(v, val);
-               } else {
-                       panic_vm(v, "Undefined write on PIB XTP\n");
-               }
-               break;
-       default:
-               if (PIB_LOW_HALF(addr)) {
-                       /*Lower half */
-                       if (length != 8)
-                               panic_vm(v, "Can't LHF write with size %ld!\n",
-                                               length);
-                       else
-                               vlsapic_write_ipi(v, addr, val);
-               } else {   /*Upper half */
-                       panic_vm(v, "IPI-UHF write %lx\n", addr);
-               }
-               break;
-       }
-}
-
-unsigned long lsapic_read(struct kvm_vcpu *v, unsigned long addr,
-               unsigned long length)
-{
-       uint64_t result = 0;
-
-       addr &= (PIB_SIZE - 1);
-
-       switch (addr) {
-       case PIB_OFST_INTA:
-               if (length == 1) /* 1 byte load */
-                       ; /* There is no i8259, there is no INTA access*/
-               else
-                       panic_vm(v, "Undefined read on PIB INTA\n");
-
-               break;
-       case PIB_OFST_XTP:
-               if (length == 1) {
-                       result = VLSAPIC_XTP(v);
-               } else {
-                       panic_vm(v, "Undefined read on PIB XTP\n");
-               }
-               break;
-       default:
-               panic_vm(v, "Undefined addr access for lsapic!\n");
-               break;
-       }
-       return result;
-}
-
-static void mmio_access(struct kvm_vcpu *vcpu, u64 src_pa, u64 *dest,
-                                       u16 s, int ma, int dir)
-{
-       unsigned long iot;
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-       unsigned long psr;
-
-       iot = __gpfn_is_io(src_pa >> PAGE_SHIFT);
-
-       local_irq_save(psr);
-
-       /*Intercept the access for PIB range*/
-       if (iot == GPFN_PIB) {
-               if (!dir)
-                       lsapic_write(vcpu, src_pa, s, *dest);
-               else
-                       *dest = lsapic_read(vcpu, src_pa, s);
-               goto out;
-       }
-       p->exit_reason = EXIT_REASON_MMIO_INSTRUCTION;
-       p->u.ioreq.addr = src_pa;
-       p->u.ioreq.size = s;
-       p->u.ioreq.dir = dir;
-       if (dir == IOREQ_WRITE)
-               p->u.ioreq.data = *dest;
-       p->u.ioreq.state = STATE_IOREQ_READY;
-       vmm_transition(vcpu);
-
-       if (p->u.ioreq.state == STATE_IORESP_READY) {
-               if (dir == IOREQ_READ)
-                       /* it's necessary to ensure zero extending */
-                       *dest = p->u.ioreq.data & (~0UL >> (64-(s*8)));
-       } else
-               panic_vm(vcpu, "Unhandled mmio access returned!\n");
-out:
-       local_irq_restore(psr);
-       return ;
-}
-
-/*
-   dir 1: read 0:write
-   inst_type 0:integer 1:floating point
- */
-#define SL_INTEGER     0       /* store/load interger*/
-#define SL_FLOATING    1       /* store/load floating*/
-
-void emulate_io_inst(struct kvm_vcpu *vcpu, u64 padr, u64 ma)
-{
-       struct kvm_pt_regs *regs;
-       IA64_BUNDLE bundle;
-       int slot, dir = 0;
-       int inst_type = -1;
-       u16 size = 0;
-       u64 data, slot1a, slot1b, temp, update_reg;
-       s32 imm;
-       INST64 inst;
-
-       regs = vcpu_regs(vcpu);
-
-       if (fetch_code(vcpu, regs->cr_iip, &bundle)) {
-               /* if fetch code fail, return and try again */
-               return;
-       }
-       slot = ((struct ia64_psr *)&(regs->cr_ipsr))->ri;
-       if (!slot)
-               inst.inst = bundle.slot0;
-       else if (slot == 1) {
-               slot1a = bundle.slot1a;
-               slot1b = bundle.slot1b;
-               inst.inst = slot1a + (slot1b << 18);
-       } else if (slot == 2)
-               inst.inst = bundle.slot2;
-
-       /* Integer Load/Store */
-       if (inst.M1.major == 4 && inst.M1.m == 0 && inst.M1.x == 0) {
-               inst_type = SL_INTEGER;
-               size = (inst.M1.x6 & 0x3);
-               if ((inst.M1.x6 >> 2) > 0xb) {
-                       /*write*/
-                       dir = IOREQ_WRITE;
-                       data = vcpu_get_gr(vcpu, inst.M4.r2);
-               } else if ((inst.M1.x6 >> 2) < 0xb) {
-                       /*read*/
-                       dir = IOREQ_READ;
-               }
-       } else if (inst.M2.major == 4 && inst.M2.m == 1 && inst.M2.x == 0) {
-               /* Integer Load + Reg update */
-               inst_type = SL_INTEGER;
-               dir = IOREQ_READ;
-               size = (inst.M2.x6 & 0x3);
-               temp = vcpu_get_gr(vcpu, inst.M2.r3);
-               update_reg = vcpu_get_gr(vcpu, inst.M2.r2);
-               temp += update_reg;
-               vcpu_set_gr(vcpu, inst.M2.r3, temp, 0);
-       } else if (inst.M3.major == 5) {
-               /*Integer Load/Store + Imm update*/
-               inst_type = SL_INTEGER;
-               size = (inst.M3.x6&0x3);
-               if ((inst.M5.x6 >> 2) > 0xb) {
-                       /*write*/
-                       dir = IOREQ_WRITE;
-                       data = vcpu_get_gr(vcpu, inst.M5.r2);
-                       temp = vcpu_get_gr(vcpu, inst.M5.r3);
-                       imm = (inst.M5.s << 31) | (inst.M5.i << 30) |
-                               (inst.M5.imm7 << 23);
-                       temp += imm >> 23;
-                       vcpu_set_gr(vcpu, inst.M5.r3, temp, 0);
-
-               } else if ((inst.M3.x6 >> 2) < 0xb) {
-                       /*read*/
-                       dir = IOREQ_READ;
-                       temp = vcpu_get_gr(vcpu, inst.M3.r3);
-                       imm = (inst.M3.s << 31) | (inst.M3.i << 30) |
-                               (inst.M3.imm7 << 23);
-                       temp += imm >> 23;
-                       vcpu_set_gr(vcpu, inst.M3.r3, temp, 0);
-
-               }
-       } else if (inst.M9.major == 6 && inst.M9.x6 == 0x3B
-                               && inst.M9.m == 0 && inst.M9.x == 0) {
-               /* Floating-point spill*/
-               struct ia64_fpreg v;
-
-               inst_type = SL_FLOATING;
-               dir = IOREQ_WRITE;
-               vcpu_get_fpreg(vcpu, inst.M9.f2, &v);
-               /* Write high word. FIXME: this is a kludge!  */
-               v.u.bits[1] &= 0x3ffff;
-               mmio_access(vcpu, padr + 8, (u64 *)&v.u.bits[1], 8,
-                           ma, IOREQ_WRITE);
-               data = v.u.bits[0];
-               size = 3;
-       } else if (inst.M10.major == 7 && inst.M10.x6 == 0x3B) {
-               /* Floating-point spill + Imm update */
-               struct ia64_fpreg v;
-
-               inst_type = SL_FLOATING;
-               dir = IOREQ_WRITE;
-               vcpu_get_fpreg(vcpu, inst.M10.f2, &v);
-               temp = vcpu_get_gr(vcpu, inst.M10.r3);
-               imm = (inst.M10.s << 31) | (inst.M10.i << 30) |
-                       (inst.M10.imm7 << 23);
-               temp += imm >> 23;
-               vcpu_set_gr(vcpu, inst.M10.r3, temp, 0);
-
-               /* Write high word.FIXME: this is a kludge!  */
-               v.u.bits[1] &= 0x3ffff;
-               mmio_access(vcpu, padr + 8, (u64 *)&v.u.bits[1],
-                           8, ma, IOREQ_WRITE);
-               data = v.u.bits[0];
-               size = 3;
-       } else if (inst.M10.major == 7 && inst.M10.x6 == 0x31) {
-               /* Floating-point stf8 + Imm update */
-               struct ia64_fpreg v;
-               inst_type = SL_FLOATING;
-               dir = IOREQ_WRITE;
-               size = 3;
-               vcpu_get_fpreg(vcpu, inst.M10.f2, &v);
-               data = v.u.bits[0]; /* Significand.  */
-               temp = vcpu_get_gr(vcpu, inst.M10.r3);
-               imm = (inst.M10.s << 31) | (inst.M10.i << 30) |
-                       (inst.M10.imm7 << 23);
-               temp += imm >> 23;
-               vcpu_set_gr(vcpu, inst.M10.r3, temp, 0);
-       } else if (inst.M15.major == 7 && inst.M15.x6 >= 0x2c
-                       && inst.M15.x6 <= 0x2f) {
-               temp = vcpu_get_gr(vcpu, inst.M15.r3);
-               imm = (inst.M15.s << 31) | (inst.M15.i << 30) |
-                       (inst.M15.imm7 << 23);
-               temp += imm >> 23;
-               vcpu_set_gr(vcpu, inst.M15.r3, temp, 0);
-
-               vcpu_increment_iip(vcpu);
-               return;
-       } else if (inst.M12.major == 6 && inst.M12.m == 1
-                       && inst.M12.x == 1 && inst.M12.x6 == 1) {
-               /* Floating-point Load Pair + Imm ldfp8 M12*/
-               struct ia64_fpreg v;
-
-               inst_type = SL_FLOATING;
-               dir = IOREQ_READ;
-               size = 8;     /*ldfd*/
-               mmio_access(vcpu, padr, &data, size, ma, dir);
-               v.u.bits[0] = data;
-               v.u.bits[1] = 0x1003E;
-               vcpu_set_fpreg(vcpu, inst.M12.f1, &v);
-               padr += 8;
-               mmio_access(vcpu, padr, &data, size, ma, dir);
-               v.u.bits[0] = data;
-               v.u.bits[1] = 0x1003E;
-               vcpu_set_fpreg(vcpu, inst.M12.f2, &v);
-               padr += 8;
-               vcpu_set_gr(vcpu, inst.M12.r3, padr, 0);
-               vcpu_increment_iip(vcpu);
-               return;
-       } else {
-               inst_type = -1;
-               panic_vm(vcpu, "Unsupported MMIO access instruction! "
-                               "Bunld[0]=0x%lx, Bundle[1]=0x%lx\n",
-                               bundle.i64[0], bundle.i64[1]);
-       }
-
-       size = 1 << size;
-       if (dir == IOREQ_WRITE) {
-               mmio_access(vcpu, padr, &data, size, ma, dir);
-       } else {
-               mmio_access(vcpu, padr, &data, size, ma, dir);
-               if (inst_type == SL_INTEGER)
-                       vcpu_set_gr(vcpu, inst.M1.r1, data, 0);
-               else
-                       panic_vm(vcpu, "Unsupported instruction type!\n");
-
-       }
-       vcpu_increment_iip(vcpu);
-}
diff --git a/arch/ia64/kvm/optvfault.S b/arch/ia64/kvm/optvfault.S
deleted file mode 100644 (file)
index f793be3..0000000
+++ /dev/null
@@ -1,1090 +0,0 @@
-/*
- * arch/ia64/kvm/optvfault.S
- * optimize virtualization fault handler
- *
- * Copyright (C) 2006 Intel Co
- *     Xuefei Xu (Anthony Xu) <anthony.xu@intel.com>
- * Copyright (C) 2008 Intel Co
- *      Add the support for Tukwila processors.
- *     Xiantao Zhang <xiantao.zhang@intel.com>
- */
-
-#include <asm/asmmacro.h>
-#include <asm/processor.h>
-#include <asm/kvm_host.h>
-
-#include "vti.h"
-#include "asm-offsets.h"
-
-#define ACCE_MOV_FROM_AR
-#define ACCE_MOV_FROM_RR
-#define ACCE_MOV_TO_RR
-#define ACCE_RSM
-#define ACCE_SSM
-#define ACCE_MOV_TO_PSR
-#define ACCE_THASH
-
-#define VMX_VPS_SYNC_READ                      \
-       add r16=VMM_VPD_BASE_OFFSET,r21;        \
-       mov r17 = b0;                           \
-       mov r18 = r24;                          \
-       mov r19 = r25;                          \
-       mov r20 = r31;                          \
-       ;;                                      \
-{.mii;                                         \
-       ld8 r16 = [r16];                        \
-       nop 0x0;                                \
-       mov r24 = ip;                           \
-       ;;                                      \
-};                                             \
-{.mmb;                                         \
-       add r24=0x20, r24;                      \
-       mov r25 =r16;                           \
-       br.sptk.many kvm_vps_sync_read;         \
-};                                             \
-       mov b0 = r17;                           \
-       mov r24 = r18;                          \
-       mov r25 = r19;                          \
-       mov r31 = r20
-
-ENTRY(kvm_vps_entry)
-       adds r29 = VMM_VCPU_VSA_BASE_OFFSET,r21
-       ;;
-       ld8 r29 = [r29]
-       ;;
-       add r29 = r29, r30
-       ;;
-       mov b0 = r29
-       br.sptk.many b0
-END(kvm_vps_entry)
-
-/*
- *     Inputs:
- *     r24 : return address
- *     r25 : vpd
- *     r29 : scratch
- *
- */
-GLOBAL_ENTRY(kvm_vps_sync_read)
-       movl r30 = PAL_VPS_SYNC_READ
-       ;;
-       br.sptk.many kvm_vps_entry
-END(kvm_vps_sync_read)
-
-/*
- *     Inputs:
- *     r24 : return address
- *     r25 : vpd
- *     r29 : scratch
- *
- */
-GLOBAL_ENTRY(kvm_vps_sync_write)
-       movl r30 = PAL_VPS_SYNC_WRITE
-       ;;
-       br.sptk.many kvm_vps_entry
-END(kvm_vps_sync_write)
-
-/*
- *     Inputs:
- *     r23 : pr
- *     r24 : guest b0
- *     r25 : vpd
- *
- */
-GLOBAL_ENTRY(kvm_vps_resume_normal)
-       movl r30 = PAL_VPS_RESUME_NORMAL
-       ;;
-       mov pr=r23,-2
-       br.sptk.many kvm_vps_entry
-END(kvm_vps_resume_normal)
-
-/*
- *     Inputs:
- *     r23 : pr
- *     r24 : guest b0
- *     r25 : vpd
- *     r17 : isr
- */
-GLOBAL_ENTRY(kvm_vps_resume_handler)
-       movl r30 = PAL_VPS_RESUME_HANDLER
-       ;;
-       ld8 r26=[r25]
-       shr r17=r17,IA64_ISR_IR_BIT
-       ;;
-       dep r26=r17,r26,63,1   // bit 63 of r26 indicate whether enable CFLE
-       mov pr=r23,-2
-       br.sptk.many kvm_vps_entry
-END(kvm_vps_resume_handler)
-
-//mov r1=ar3
-GLOBAL_ENTRY(kvm_asm_mov_from_ar)
-#ifndef ACCE_MOV_FROM_AR
-       br.many kvm_virtualization_fault_back
-#endif
-       add r18=VMM_VCPU_ITC_OFS_OFFSET, r21
-       add r16=VMM_VCPU_LAST_ITC_OFFSET,r21
-       extr.u r17=r25,6,7
-       ;;
-       ld8 r18=[r18]
-       mov r19=ar.itc
-       mov r24=b0
-       ;;
-       add r19=r19,r18
-       addl r20=@gprel(asm_mov_to_reg),gp
-       ;;
-       st8 [r16] = r19
-       adds r30=kvm_resume_to_guest-asm_mov_to_reg,r20
-       shladd r17=r17,4,r20
-       ;;
-       mov b0=r17
-       br.sptk.few b0
-       ;;
-END(kvm_asm_mov_from_ar)
-
-/*
- * Special SGI SN2 optimized version of mov_from_ar using the SN2 RTC
- * clock as it's source for emulating the ITC. This version will be
- * copied on top of the original version if the host is determined to
- * be an SN2.
- */
-GLOBAL_ENTRY(kvm_asm_mov_from_ar_sn2)
-       add r18=VMM_VCPU_ITC_OFS_OFFSET, r21
-       movl r19 = (KVM_VMM_BASE+(1<<KVM_VMM_SHIFT))
-
-       add r16=VMM_VCPU_LAST_ITC_OFFSET,r21
-       extr.u r17=r25,6,7
-       mov r24=b0
-       ;;
-       ld8 r18=[r18]
-       ld8 r19=[r19]
-       addl r20=@gprel(asm_mov_to_reg),gp
-       ;;
-       add r19=r19,r18
-       shladd r17=r17,4,r20
-       ;;
-       adds r30=kvm_resume_to_guest-asm_mov_to_reg,r20
-       st8 [r16] = r19
-       mov b0=r17
-       br.sptk.few b0
-       ;;
-END(kvm_asm_mov_from_ar_sn2)
-
-
-
-// mov r1=rr[r3]
-GLOBAL_ENTRY(kvm_asm_mov_from_rr)
-#ifndef ACCE_MOV_FROM_RR
-       br.many kvm_virtualization_fault_back
-#endif
-       extr.u r16=r25,20,7
-       extr.u r17=r25,6,7
-       addl r20=@gprel(asm_mov_from_reg),gp
-       ;;
-       adds r30=kvm_asm_mov_from_rr_back_1-asm_mov_from_reg,r20
-       shladd r16=r16,4,r20
-       mov r24=b0
-       ;;
-       add r27=VMM_VCPU_VRR0_OFFSET,r21
-       mov b0=r16
-       br.many b0
-       ;;
-kvm_asm_mov_from_rr_back_1:
-       adds r30=kvm_resume_to_guest-asm_mov_from_reg,r20
-       adds r22=asm_mov_to_reg-asm_mov_from_reg,r20
-       shr.u r26=r19,61
-       ;;
-       shladd r17=r17,4,r22
-       shladd r27=r26,3,r27
-       ;;
-       ld8 r19=[r27]
-       mov b0=r17
-       br.many b0
-END(kvm_asm_mov_from_rr)
-
-
-// mov rr[r3]=r2
-GLOBAL_ENTRY(kvm_asm_mov_to_rr)
-#ifndef ACCE_MOV_TO_RR
-       br.many kvm_virtualization_fault_back
-#endif
-       extr.u r16=r25,20,7
-       extr.u r17=r25,13,7
-       addl r20=@gprel(asm_mov_from_reg),gp
-       ;;
-       adds r30=kvm_asm_mov_to_rr_back_1-asm_mov_from_reg,r20
-       shladd r16=r16,4,r20
-       mov r22=b0
-       ;;
-       add r27=VMM_VCPU_VRR0_OFFSET,r21
-       mov b0=r16
-       br.many b0
-       ;;
-kvm_asm_mov_to_rr_back_1:
-       adds r30=kvm_asm_mov_to_rr_back_2-asm_mov_from_reg,r20
-       shr.u r23=r19,61
-       shladd r17=r17,4,r20
-       ;;
-       //if rr6, go back
-       cmp.eq p6,p0=6,r23
-       mov b0=r22
-       (p6) br.cond.dpnt.many kvm_virtualization_fault_back
-       ;;
-       mov r28=r19
-       mov b0=r17
-       br.many b0
-kvm_asm_mov_to_rr_back_2:
-       adds r30=kvm_resume_to_guest-asm_mov_from_reg,r20
-       shladd r27=r23,3,r27
-       ;; // vrr.rid<<4 |0xe
-       st8 [r27]=r19
-       mov b0=r30
-       ;;
-       extr.u r16=r19,8,26
-       extr.u r18 =r19,2,6
-       mov r17 =0xe
-       ;;
-       shladd r16 = r16, 4, r17
-       extr.u r19 =r19,0,8
-       ;;
-       shl r16 = r16,8
-       ;;
-       add r19 = r19, r16
-       ;; //set ve 1
-       dep r19=-1,r19,0,1
-       cmp.lt p6,p0=14,r18
-       ;;
-       (p6) mov r18=14
-       ;;
-       (p6) dep r19=r18,r19,2,6
-       ;;
-       cmp.eq p6,p0=0,r23
-       ;;
-       cmp.eq.or p6,p0=4,r23
-       ;;
-       adds r16=VMM_VCPU_MODE_FLAGS_OFFSET,r21
-       (p6) adds r17=VMM_VCPU_META_SAVED_RR0_OFFSET,r21
-       ;;
-       ld4 r16=[r16]
-       cmp.eq p7,p0=r0,r0
-       (p6) shladd r17=r23,1,r17
-       ;;
-       (p6) st8 [r17]=r19
-       (p6) tbit.nz p6,p7=r16,0
-       ;;
-       (p7) mov rr[r28]=r19
-       mov r24=r22
-       br.many b0
-END(kvm_asm_mov_to_rr)
-
-
-//rsm
-GLOBAL_ENTRY(kvm_asm_rsm)
-#ifndef ACCE_RSM
-       br.many kvm_virtualization_fault_back
-#endif
-       VMX_VPS_SYNC_READ
-       ;;
-       extr.u r26=r25,6,21
-       extr.u r27=r25,31,2
-       ;;
-       extr.u r28=r25,36,1
-       dep r26=r27,r26,21,2
-       ;;
-       add r17=VPD_VPSR_START_OFFSET,r16
-       add r22=VMM_VCPU_MODE_FLAGS_OFFSET,r21
-       //r26 is imm24
-       dep r26=r28,r26,23,1
-       ;;
-       ld8 r18=[r17]
-       movl r28=IA64_PSR_IC+IA64_PSR_I+IA64_PSR_DT+IA64_PSR_SI
-       ld4 r23=[r22]
-       sub r27=-1,r26
-       mov r24=b0
-       ;;
-       mov r20=cr.ipsr
-       or r28=r27,r28
-       and r19=r18,r27
-       ;;
-       st8 [r17]=r19
-       and r20=r20,r28
-       /* Comment it out due to short of fp lazy alorgithm support
-       adds r27=IA64_VCPU_FP_PSR_OFFSET,r21
-       ;;
-       ld8 r27=[r27]
-       ;;
-       tbit.nz p8,p0= r27,IA64_PSR_DFH_BIT
-       ;;
-       (p8) dep r20=-1,r20,IA64_PSR_DFH_BIT,1
-       */
-       ;;
-       mov cr.ipsr=r20
-       tbit.nz p6,p0=r23,0
-       ;;
-       tbit.z.or p6,p0=r26,IA64_PSR_DT_BIT
-       (p6) br.dptk kvm_resume_to_guest_with_sync
-       ;;
-       add r26=VMM_VCPU_META_RR0_OFFSET,r21
-       add r27=VMM_VCPU_META_RR0_OFFSET+8,r21
-       dep r23=-1,r23,0,1
-       ;;
-       ld8 r26=[r26]
-       ld8 r27=[r27]
-       st4 [r22]=r23
-       dep.z r28=4,61,3
-       ;;
-       mov rr[r0]=r26
-       ;;
-       mov rr[r28]=r27
-       ;;
-       srlz.d
-       br.many kvm_resume_to_guest_with_sync
-END(kvm_asm_rsm)
-
-
-//ssm
-GLOBAL_ENTRY(kvm_asm_ssm)
-#ifndef ACCE_SSM
-       br.many kvm_virtualization_fault_back
-#endif
-       VMX_VPS_SYNC_READ
-       ;;
-       extr.u r26=r25,6,21
-       extr.u r27=r25,31,2
-       ;;
-       extr.u r28=r25,36,1
-       dep r26=r27,r26,21,2
-       ;;  //r26 is imm24
-       add r27=VPD_VPSR_START_OFFSET,r16
-       dep r26=r28,r26,23,1
-       ;;  //r19 vpsr
-       ld8 r29=[r27]
-       mov r24=b0
-       ;;
-       add r22=VMM_VCPU_MODE_FLAGS_OFFSET,r21
-       mov r20=cr.ipsr
-       or r19=r29,r26
-       ;;
-       ld4 r23=[r22]
-       st8 [r27]=r19
-       or r20=r20,r26
-       ;;
-       mov cr.ipsr=r20
-       movl r28=IA64_PSR_DT+IA64_PSR_RT+IA64_PSR_IT
-       ;;
-       and r19=r28,r19
-       tbit.z p6,p0=r23,0
-       ;;
-       cmp.ne.or p6,p0=r28,r19
-       (p6) br.dptk kvm_asm_ssm_1
-       ;;
-       add r26=VMM_VCPU_META_SAVED_RR0_OFFSET,r21
-       add r27=VMM_VCPU_META_SAVED_RR0_OFFSET+8,r21
-       dep r23=0,r23,0,1
-       ;;
-       ld8 r26=[r26]
-       ld8 r27=[r27]
-       st4 [r22]=r23
-       dep.z r28=4,61,3
-       ;;
-       mov rr[r0]=r26
-       ;;
-       mov rr[r28]=r27
-       ;;
-       srlz.d
-       ;;
-kvm_asm_ssm_1:
-       tbit.nz p6,p0=r29,IA64_PSR_I_BIT
-       ;;
-       tbit.z.or p6,p0=r19,IA64_PSR_I_BIT
-       (p6) br.dptk kvm_resume_to_guest_with_sync
-       ;;
-       add r29=VPD_VTPR_START_OFFSET,r16
-       add r30=VPD_VHPI_START_OFFSET,r16
-       ;;
-       ld8 r29=[r29]
-       ld8 r30=[r30]
-       ;;
-       extr.u r17=r29,4,4
-       extr.u r18=r29,16,1
-       ;;
-       dep r17=r18,r17,4,1
-       ;;
-       cmp.gt p6,p0=r30,r17
-       (p6) br.dpnt.few kvm_asm_dispatch_vexirq
-       br.many kvm_resume_to_guest_with_sync
-END(kvm_asm_ssm)
-
-
-//mov psr.l=r2
-GLOBAL_ENTRY(kvm_asm_mov_to_psr)
-#ifndef ACCE_MOV_TO_PSR
-       br.many kvm_virtualization_fault_back
-#endif
-       VMX_VPS_SYNC_READ
-       ;;
-       extr.u r26=r25,13,7 //r2
-       addl r20=@gprel(asm_mov_from_reg),gp
-       ;;
-       adds r30=kvm_asm_mov_to_psr_back-asm_mov_from_reg,r20
-       shladd r26=r26,4,r20
-       mov r24=b0
-       ;;
-       add r27=VPD_VPSR_START_OFFSET,r16
-       mov b0=r26
-       br.many b0
-       ;;
-kvm_asm_mov_to_psr_back:
-       ld8 r17=[r27]
-       add r22=VMM_VCPU_MODE_FLAGS_OFFSET,r21
-       dep r19=0,r19,32,32
-       ;;
-       ld4 r23=[r22]
-       dep r18=0,r17,0,32
-       ;;
-       add r30=r18,r19
-       movl r28=IA64_PSR_DT+IA64_PSR_RT+IA64_PSR_IT
-       ;;
-       st8 [r27]=r30
-       and r27=r28,r30
-       and r29=r28,r17
-       ;;
-       cmp.eq p5,p0=r29,r27
-       cmp.eq p6,p7=r28,r27
-       (p5) br.many kvm_asm_mov_to_psr_1
-       ;;
-       //virtual to physical
-       (p7) add r26=VMM_VCPU_META_RR0_OFFSET,r21
-       (p7) add r27=VMM_VCPU_META_RR0_OFFSET+8,r21
-       (p7) dep r23=-1,r23,0,1
-       ;;
-       //physical to virtual
-       (p6) add r26=VMM_VCPU_META_SAVED_RR0_OFFSET,r21
-       (p6) add r27=VMM_VCPU_META_SAVED_RR0_OFFSET+8,r21
-       (p6) dep r23=0,r23,0,1
-       ;;
-       ld8 r26=[r26]
-       ld8 r27=[r27]
-       st4 [r22]=r23
-       dep.z r28=4,61,3
-       ;;
-       mov rr[r0]=r26
-       ;;
-       mov rr[r28]=r27
-       ;;
-       srlz.d
-       ;;
-kvm_asm_mov_to_psr_1:
-       mov r20=cr.ipsr
-       movl r28=IA64_PSR_IC+IA64_PSR_I+IA64_PSR_DT+IA64_PSR_SI+IA64_PSR_RT
-       ;;
-       or r19=r19,r28
-       dep r20=0,r20,0,32
-       ;;
-       add r20=r19,r20
-       mov b0=r24
-       ;;
-       /* Comment it out due to short of fp lazy algorithm support
-       adds r27=IA64_VCPU_FP_PSR_OFFSET,r21
-       ;;
-       ld8 r27=[r27]
-       ;;
-       tbit.nz p8,p0=r27,IA64_PSR_DFH_BIT
-       ;;
-       (p8) dep r20=-1,r20,IA64_PSR_DFH_BIT,1
-       ;;
-       */
-       mov cr.ipsr=r20
-       cmp.ne p6,p0=r0,r0
-       ;;
-       tbit.nz.or p6,p0=r17,IA64_PSR_I_BIT
-       tbit.z.or p6,p0=r30,IA64_PSR_I_BIT
-       (p6) br.dpnt.few kvm_resume_to_guest_with_sync
-       ;;
-       add r29=VPD_VTPR_START_OFFSET,r16
-       add r30=VPD_VHPI_START_OFFSET,r16
-       ;;
-       ld8 r29=[r29]
-       ld8 r30=[r30]
-       ;;
-       extr.u r17=r29,4,4
-       extr.u r18=r29,16,1
-       ;;
-       dep r17=r18,r17,4,1
-       ;;
-       cmp.gt p6,p0=r30,r17
-       (p6) br.dpnt.few kvm_asm_dispatch_vexirq
-       br.many kvm_resume_to_guest_with_sync
-END(kvm_asm_mov_to_psr)
-
-
-ENTRY(kvm_asm_dispatch_vexirq)
-//increment iip
-       mov r17 = b0
-       mov r18 = r31
-{.mii
-       add r25=VMM_VPD_BASE_OFFSET,r21
-       nop 0x0
-       mov r24 = ip
-       ;;
-}
-{.mmb
-       add r24 = 0x20, r24
-       ld8 r25 = [r25]
-       br.sptk.many kvm_vps_sync_write
-}
-       mov b0 =r17
-       mov r16=cr.ipsr
-       mov r31 = r18
-       mov r19 = 37
-       ;;
-       extr.u r17=r16,IA64_PSR_RI_BIT,2
-       tbit.nz p6,p7=r16,IA64_PSR_RI_BIT+1
-       ;;
-       (p6) mov r18=cr.iip
-       (p6) mov r17=r0
-       (p7) add r17=1,r17
-       ;;
-       (p6) add r18=0x10,r18
-       dep r16=r17,r16,IA64_PSR_RI_BIT,2
-       ;;
-       (p6) mov cr.iip=r18
-       mov cr.ipsr=r16
-       mov r30 =1
-       br.many kvm_dispatch_vexirq
-END(kvm_asm_dispatch_vexirq)
-
-// thash
-// TODO: add support when pta.vf = 1
-GLOBAL_ENTRY(kvm_asm_thash)
-#ifndef ACCE_THASH
-       br.many kvm_virtualization_fault_back
-#endif
-       extr.u r17=r25,20,7             // get r3 from opcode in r25
-       extr.u r18=r25,6,7              // get r1 from opcode in r25
-       addl r20=@gprel(asm_mov_from_reg),gp
-       ;;
-       adds r30=kvm_asm_thash_back1-asm_mov_from_reg,r20
-       shladd r17=r17,4,r20    // get addr of MOVE_FROM_REG(r17)
-       adds r16=VMM_VPD_BASE_OFFSET,r21        // get vcpu.arch.priveregs
-       ;;
-       mov r24=b0
-       ;;
-       ld8 r16=[r16]           // get VPD addr
-       mov b0=r17
-       br.many b0                      // r19 return value
-       ;;
-kvm_asm_thash_back1:
-       shr.u r23=r19,61                // get RR number
-       adds r28=VMM_VCPU_VRR0_OFFSET,r21       // get vcpu->arch.vrr[0]'s addr
-       adds r16=VMM_VPD_VPTA_OFFSET,r16        // get vpta
-       ;;
-       shladd r27=r23,3,r28    // get vcpu->arch.vrr[r23]'s addr
-       ld8 r17=[r16]           // get PTA
-       mov r26=1
-       ;;
-       extr.u r29=r17,2,6      // get pta.size
-       ld8 r28=[r27]           // get vcpu->arch.vrr[r23]'s value
-       ;;
-       mov b0=r24
-       //Fallback to C if pta.vf is set
-       tbit.nz p6,p0=r17, 8
-       ;;
-       (p6) mov r24=EVENT_THASH
-       (p6) br.cond.dpnt.many kvm_virtualization_fault_back
-       extr.u r28=r28,2,6      // get rr.ps
-       shl r22=r26,r29         // 1UL << pta.size
-       ;;
-       shr.u r23=r19,r28       // vaddr >> rr.ps
-       adds r26=3,r29          // pta.size + 3
-       shl r27=r17,3           // pta << 3
-       ;;
-       shl r23=r23,3           // (vaddr >> rr.ps) << 3
-       shr.u r27=r27,r26       // (pta << 3) >> (pta.size+3)
-       movl r16=7<<61
-       ;;
-       adds r22=-1,r22         // (1UL << pta.size) - 1
-       shl r27=r27,r29         // ((pta<<3)>>(pta.size+3))<<pta.size
-       and r19=r19,r16         // vaddr & VRN_MASK
-       ;;
-       and r22=r22,r23         // vhpt_offset
-       or r19=r19,r27 // (vadr&VRN_MASK)|(((pta<<3)>>(pta.size + 3))<<pta.size)
-       adds r26=asm_mov_to_reg-asm_mov_from_reg,r20
-       ;;
-       or r19=r19,r22          // calc pval
-       shladd r17=r18,4,r26
-       adds r30=kvm_resume_to_guest-asm_mov_from_reg,r20
-       ;;
-       mov b0=r17
-       br.many b0
-END(kvm_asm_thash)
-
-#define MOV_TO_REG0    \
-{;                     \
-       nop.b 0x0;              \
-       nop.b 0x0;              \
-       nop.b 0x0;              \
-       ;;                      \
-};
-
-
-#define MOV_TO_REG(n)  \
-{;                     \
-       mov r##n##=r19; \
-       mov b0=r30;     \
-       br.sptk.many b0;        \
-       ;;                      \
-};
-
-
-#define MOV_FROM_REG(n)        \
-{;                             \
-       mov r19=r##n##;         \
-       mov b0=r30;             \
-       br.sptk.many b0;                \
-       ;;                              \
-};
-
-
-#define MOV_TO_BANK0_REG(n)                    \
-ENTRY_MIN_ALIGN(asm_mov_to_bank0_reg##n##);    \
-{;                                             \
-       mov r26=r2;                             \
-       mov r2=r19;                             \
-       bsw.1;                                  \
-       ;;                                              \
-};                                             \
-{;                                             \
-       mov r##n##=r2;                          \
-       nop.b 0x0;                                      \
-       bsw.0;                                  \
-       ;;                                              \
-};                                             \
-{;                                             \
-       mov r2=r26;                             \
-       mov b0=r30;                             \
-       br.sptk.many b0;                                \
-       ;;                                              \
-};                                             \
-END(asm_mov_to_bank0_reg##n##)
-
-
-#define MOV_FROM_BANK0_REG(n)                  \
-ENTRY_MIN_ALIGN(asm_mov_from_bank0_reg##n##);  \
-{;                                             \
-       mov r26=r2;                             \
-       nop.b 0x0;                                      \
-       bsw.1;                                  \
-       ;;                                              \
-};                                             \
-{;                                             \
-       mov r2=r##n##;                          \
-       nop.b 0x0;                                      \
-       bsw.0;                                  \
-       ;;                                              \
-};                                             \
-{;                                             \
-       mov r19=r2;                             \
-       mov r2=r26;                             \
-       mov b0=r30;                             \
-};                                             \
-{;                                             \
-       nop.b 0x0;                                      \
-       nop.b 0x0;                                      \
-       br.sptk.many b0;                                \
-       ;;                                              \
-};                                             \
-END(asm_mov_from_bank0_reg##n##)
-
-
-#define JMP_TO_MOV_TO_BANK0_REG(n)             \
-{;                                             \
-       nop.b 0x0;                                      \
-       nop.b 0x0;                                      \
-       br.sptk.many asm_mov_to_bank0_reg##n##; \
-       ;;                                              \
-}
-
-
-#define JMP_TO_MOV_FROM_BANK0_REG(n)           \
-{;                                             \
-       nop.b 0x0;                                      \
-       nop.b 0x0;                                      \
-       br.sptk.many asm_mov_from_bank0_reg##n##;       \
-       ;;                                              \
-}
-
-
-MOV_FROM_BANK0_REG(16)
-MOV_FROM_BANK0_REG(17)
-MOV_FROM_BANK0_REG(18)
-MOV_FROM_BANK0_REG(19)
-MOV_FROM_BANK0_REG(20)
-MOV_FROM_BANK0_REG(21)
-MOV_FROM_BANK0_REG(22)
-MOV_FROM_BANK0_REG(23)
-MOV_FROM_BANK0_REG(24)
-MOV_FROM_BANK0_REG(25)
-MOV_FROM_BANK0_REG(26)
-MOV_FROM_BANK0_REG(27)
-MOV_FROM_BANK0_REG(28)
-MOV_FROM_BANK0_REG(29)
-MOV_FROM_BANK0_REG(30)
-MOV_FROM_BANK0_REG(31)
-
-
-// mov from reg table
-ENTRY(asm_mov_from_reg)
-       MOV_FROM_REG(0)
-       MOV_FROM_REG(1)
-       MOV_FROM_REG(2)
-       MOV_FROM_REG(3)
-       MOV_FROM_REG(4)
-       MOV_FROM_REG(5)
-       MOV_FROM_REG(6)
-       MOV_FROM_REG(7)
-       MOV_FROM_REG(8)
-       MOV_FROM_REG(9)
-       MOV_FROM_REG(10)
-       MOV_FROM_REG(11)
-       MOV_FROM_REG(12)
-       MOV_FROM_REG(13)
-       MOV_FROM_REG(14)
-       MOV_FROM_REG(15)
-       JMP_TO_MOV_FROM_BANK0_REG(16)
-       JMP_TO_MOV_FROM_BANK0_REG(17)
-       JMP_TO_MOV_FROM_BANK0_REG(18)
-       JMP_TO_MOV_FROM_BANK0_REG(19)
-       JMP_TO_MOV_FROM_BANK0_REG(20)
-       JMP_TO_MOV_FROM_BANK0_REG(21)
-       JMP_TO_MOV_FROM_BANK0_REG(22)
-       JMP_TO_MOV_FROM_BANK0_REG(23)
-       JMP_TO_MOV_FROM_BANK0_REG(24)
-       JMP_TO_MOV_FROM_BANK0_REG(25)
-       JMP_TO_MOV_FROM_BANK0_REG(26)
-       JMP_TO_MOV_FROM_BANK0_REG(27)
-       JMP_TO_MOV_FROM_BANK0_REG(28)
-       JMP_TO_MOV_FROM_BANK0_REG(29)
-       JMP_TO_MOV_FROM_BANK0_REG(30)
-       JMP_TO_MOV_FROM_BANK0_REG(31)
-       MOV_FROM_REG(32)
-       MOV_FROM_REG(33)
-       MOV_FROM_REG(34)
-       MOV_FROM_REG(35)
-       MOV_FROM_REG(36)
-       MOV_FROM_REG(37)
-       MOV_FROM_REG(38)
-       MOV_FROM_REG(39)
-       MOV_FROM_REG(40)
-       MOV_FROM_REG(41)
-       MOV_FROM_REG(42)
-       MOV_FROM_REG(43)
-       MOV_FROM_REG(44)
-       MOV_FROM_REG(45)
-       MOV_FROM_REG(46)
-       MOV_FROM_REG(47)
-       MOV_FROM_REG(48)
-       MOV_FROM_REG(49)
-       MOV_FROM_REG(50)
-       MOV_FROM_REG(51)
-       MOV_FROM_REG(52)
-       MOV_FROM_REG(53)
-       MOV_FROM_REG(54)
-       MOV_FROM_REG(55)
-       MOV_FROM_REG(56)
-       MOV_FROM_REG(57)
-       MOV_FROM_REG(58)
-       MOV_FROM_REG(59)
-       MOV_FROM_REG(60)
-       MOV_FROM_REG(61)
-       MOV_FROM_REG(62)
-       MOV_FROM_REG(63)
-       MOV_FROM_REG(64)
-       MOV_FROM_REG(65)
-       MOV_FROM_REG(66)
-       MOV_FROM_REG(67)
-       MOV_FROM_REG(68)
-       MOV_FROM_REG(69)
-       MOV_FROM_REG(70)
-       MOV_FROM_REG(71)
-       MOV_FROM_REG(72)
-       MOV_FROM_REG(73)
-       MOV_FROM_REG(74)
-       MOV_FROM_REG(75)
-       MOV_FROM_REG(76)
-       MOV_FROM_REG(77)
-       MOV_FROM_REG(78)
-       MOV_FROM_REG(79)
-       MOV_FROM_REG(80)
-       MOV_FROM_REG(81)
-       MOV_FROM_REG(82)
-       MOV_FROM_REG(83)
-       MOV_FROM_REG(84)
-       MOV_FROM_REG(85)
-       MOV_FROM_REG(86)
-       MOV_FROM_REG(87)
-       MOV_FROM_REG(88)
-       MOV_FROM_REG(89)
-       MOV_FROM_REG(90)
-       MOV_FROM_REG(91)
-       MOV_FROM_REG(92)
-       MOV_FROM_REG(93)
-       MOV_FROM_REG(94)
-       MOV_FROM_REG(95)
-       MOV_FROM_REG(96)
-       MOV_FROM_REG(97)
-       MOV_FROM_REG(98)
-       MOV_FROM_REG(99)
-       MOV_FROM_REG(100)
-       MOV_FROM_REG(101)
-       MOV_FROM_REG(102)
-       MOV_FROM_REG(103)
-       MOV_FROM_REG(104)
-       MOV_FROM_REG(105)
-       MOV_FROM_REG(106)
-       MOV_FROM_REG(107)
-       MOV_FROM_REG(108)
-       MOV_FROM_REG(109)
-       MOV_FROM_REG(110)
-       MOV_FROM_REG(111)
-       MOV_FROM_REG(112)
-       MOV_FROM_REG(113)
-       MOV_FROM_REG(114)
-       MOV_FROM_REG(115)
-       MOV_FROM_REG(116)
-       MOV_FROM_REG(117)
-       MOV_FROM_REG(118)
-       MOV_FROM_REG(119)
-       MOV_FROM_REG(120)
-       MOV_FROM_REG(121)
-       MOV_FROM_REG(122)
-       MOV_FROM_REG(123)
-       MOV_FROM_REG(124)
-       MOV_FROM_REG(125)
-       MOV_FROM_REG(126)
-       MOV_FROM_REG(127)
-END(asm_mov_from_reg)
-
-
-/* must be in bank 0
- * parameter:
- * r31: pr
- * r24: b0
- */
-ENTRY(kvm_resume_to_guest_with_sync)
-       adds r19=VMM_VPD_BASE_OFFSET,r21
-       mov r16 = r31
-       mov r17 = r24
-       ;;
-{.mii
-       ld8 r25 =[r19]
-       nop 0x0
-       mov r24 = ip
-       ;;
-}
-{.mmb
-       add r24 =0x20, r24
-       nop 0x0
-       br.sptk.many kvm_vps_sync_write
-}
-
-       mov r31 = r16
-       mov r24 =r17
-       ;;
-       br.sptk.many kvm_resume_to_guest
-END(kvm_resume_to_guest_with_sync)
-
-ENTRY(kvm_resume_to_guest)
-       adds r16 = VMM_VCPU_SAVED_GP_OFFSET,r21
-       ;;
-       ld8 r1 =[r16]
-       adds r20 = VMM_VCPU_VSA_BASE_OFFSET,r21
-       ;;
-       mov r16=cr.ipsr
-       ;;
-       ld8 r20 = [r20]
-       adds r19=VMM_VPD_BASE_OFFSET,r21
-       ;;
-       ld8 r25=[r19]
-       extr.u r17=r16,IA64_PSR_RI_BIT,2
-       tbit.nz p6,p7=r16,IA64_PSR_RI_BIT+1
-       ;;
-       (p6) mov r18=cr.iip
-       (p6) mov r17=r0
-       ;;
-       (p6) add r18=0x10,r18
-       (p7) add r17=1,r17
-       ;;
-       (p6) mov cr.iip=r18
-       dep r16=r17,r16,IA64_PSR_RI_BIT,2
-       ;;
-       mov cr.ipsr=r16
-       adds r19= VPD_VPSR_START_OFFSET,r25
-       add r28=PAL_VPS_RESUME_NORMAL,r20
-       add r29=PAL_VPS_RESUME_HANDLER,r20
-       ;;
-       ld8 r19=[r19]
-       mov b0=r29
-       mov r27=cr.isr
-       ;;
-       tbit.z p6,p7 = r19,IA64_PSR_IC_BIT              // p7=vpsr.ic
-       shr r27=r27,IA64_ISR_IR_BIT
-       ;;
-       (p6) ld8 r26=[r25]
-       (p7) mov b0=r28
-       ;;
-       (p6) dep r26=r27,r26,63,1
-       mov pr=r31,-2
-       br.sptk.many b0             // call pal service
-       ;;
-END(kvm_resume_to_guest)
-
-
-MOV_TO_BANK0_REG(16)
-MOV_TO_BANK0_REG(17)
-MOV_TO_BANK0_REG(18)
-MOV_TO_BANK0_REG(19)
-MOV_TO_BANK0_REG(20)
-MOV_TO_BANK0_REG(21)
-MOV_TO_BANK0_REG(22)
-MOV_TO_BANK0_REG(23)
-MOV_TO_BANK0_REG(24)
-MOV_TO_BANK0_REG(25)
-MOV_TO_BANK0_REG(26)
-MOV_TO_BANK0_REG(27)
-MOV_TO_BANK0_REG(28)
-MOV_TO_BANK0_REG(29)
-MOV_TO_BANK0_REG(30)
-MOV_TO_BANK0_REG(31)
-
-
-// mov to reg table
-ENTRY(asm_mov_to_reg)
-       MOV_TO_REG0
-       MOV_TO_REG(1)
-       MOV_TO_REG(2)
-       MOV_TO_REG(3)
-       MOV_TO_REG(4)
-       MOV_TO_REG(5)
-       MOV_TO_REG(6)
-       MOV_TO_REG(7)
-       MOV_TO_REG(8)
-       MOV_TO_REG(9)
-       MOV_TO_REG(10)
-       MOV_TO_REG(11)
-       MOV_TO_REG(12)
-       MOV_TO_REG(13)
-       MOV_TO_REG(14)
-       MOV_TO_REG(15)
-       JMP_TO_MOV_TO_BANK0_REG(16)
-       JMP_TO_MOV_TO_BANK0_REG(17)
-       JMP_TO_MOV_TO_BANK0_REG(18)
-       JMP_TO_MOV_TO_BANK0_REG(19)
-       JMP_TO_MOV_TO_BANK0_REG(20)
-       JMP_TO_MOV_TO_BANK0_REG(21)
-       JMP_TO_MOV_TO_BANK0_REG(22)
-       JMP_TO_MOV_TO_BANK0_REG(23)
-       JMP_TO_MOV_TO_BANK0_REG(24)
-       JMP_TO_MOV_TO_BANK0_REG(25)
-       JMP_TO_MOV_TO_BANK0_REG(26)
-       JMP_TO_MOV_TO_BANK0_REG(27)
-       JMP_TO_MOV_TO_BANK0_REG(28)
-       JMP_TO_MOV_TO_BANK0_REG(29)
-       JMP_TO_MOV_TO_BANK0_REG(30)
-       JMP_TO_MOV_TO_BANK0_REG(31)
-       MOV_TO_REG(32)
-       MOV_TO_REG(33)
-       MOV_TO_REG(34)
-       MOV_TO_REG(35)
-       MOV_TO_REG(36)
-       MOV_TO_REG(37)
-       MOV_TO_REG(38)
-       MOV_TO_REG(39)
-       MOV_TO_REG(40)
-       MOV_TO_REG(41)
-       MOV_TO_REG(42)
-       MOV_TO_REG(43)
-       MOV_TO_REG(44)
-       MOV_TO_REG(45)
-       MOV_TO_REG(46)
-       MOV_TO_REG(47)
-       MOV_TO_REG(48)
-       MOV_TO_REG(49)
-       MOV_TO_REG(50)
-       MOV_TO_REG(51)
-       MOV_TO_REG(52)
-       MOV_TO_REG(53)
-       MOV_TO_REG(54)
-       MOV_TO_REG(55)
-       MOV_TO_REG(56)
-       MOV_TO_REG(57)
-       MOV_TO_REG(58)
-       MOV_TO_REG(59)
-       MOV_TO_REG(60)
-       MOV_TO_REG(61)
-       MOV_TO_REG(62)
-       MOV_TO_REG(63)
-       MOV_TO_REG(64)
-       MOV_TO_REG(65)
-       MOV_TO_REG(66)
-       MOV_TO_REG(67)
-       MOV_TO_REG(68)
-       MOV_TO_REG(69)
-       MOV_TO_REG(70)
-       MOV_TO_REG(71)
-       MOV_TO_REG(72)
-       MOV_TO_REG(73)
-       MOV_TO_REG(74)
-       MOV_TO_REG(75)
-       MOV_TO_REG(76)
-       MOV_TO_REG(77)
-       MOV_TO_REG(78)
-       MOV_TO_REG(79)
-       MOV_TO_REG(80)
-       MOV_TO_REG(81)
-       MOV_TO_REG(82)
-       MOV_TO_REG(83)
-       MOV_TO_REG(84)
-       MOV_TO_REG(85)
-       MOV_TO_REG(86)
-       MOV_TO_REG(87)
-       MOV_TO_REG(88)
-       MOV_TO_REG(89)
-       MOV_TO_REG(90)
-       MOV_TO_REG(91)
-       MOV_TO_REG(92)
-       MOV_TO_REG(93)
-       MOV_TO_REG(94)
-       MOV_TO_REG(95)
-       MOV_TO_REG(96)
-       MOV_TO_REG(97)
-       MOV_TO_REG(98)
-       MOV_TO_REG(99)
-       MOV_TO_REG(100)
-       MOV_TO_REG(101)
-       MOV_TO_REG(102)
-       MOV_TO_REG(103)
-       MOV_TO_REG(104)
-       MOV_TO_REG(105)
-       MOV_TO_REG(106)
-       MOV_TO_REG(107)
-       MOV_TO_REG(108)
-       MOV_TO_REG(109)
-       MOV_TO_REG(110)
-       MOV_TO_REG(111)
-       MOV_TO_REG(112)
-       MOV_TO_REG(113)
-       MOV_TO_REG(114)
-       MOV_TO_REG(115)
-       MOV_TO_REG(116)
-       MOV_TO_REG(117)
-       MOV_TO_REG(118)
-       MOV_TO_REG(119)
-       MOV_TO_REG(120)
-       MOV_TO_REG(121)
-       MOV_TO_REG(122)
-       MOV_TO_REG(123)
-       MOV_TO_REG(124)
-       MOV_TO_REG(125)
-       MOV_TO_REG(126)
-       MOV_TO_REG(127)
-END(asm_mov_to_reg)
diff --git a/arch/ia64/kvm/process.c b/arch/ia64/kvm/process.c
deleted file mode 100644 (file)
index b039874..0000000
+++ /dev/null
@@ -1,1024 +0,0 @@
-/*
- * process.c: handle interruption inject for guests.
- * Copyright (c) 2005, Intel Corporation.
- *
- * 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.
- *
- *     Shaofan Li (Susue Li) <susie.li@intel.com>
- *     Xiaoyan Feng (Fleming Feng)  <fleming.feng@intel.com>
- *     Xuefei Xu (Anthony Xu) (Anthony.xu@intel.com)
- *     Xiantao Zhang (xiantao.zhang@intel.com)
- */
-#include "vcpu.h"
-
-#include <asm/pal.h>
-#include <asm/sal.h>
-#include <asm/fpswa.h>
-#include <asm/kregs.h>
-#include <asm/tlb.h>
-
-fpswa_interface_t *vmm_fpswa_interface;
-
-#define IA64_VHPT_TRANS_VECTOR                 0x0000
-#define IA64_INST_TLB_VECTOR                   0x0400
-#define IA64_DATA_TLB_VECTOR                   0x0800
-#define IA64_ALT_INST_TLB_VECTOR               0x0c00
-#define IA64_ALT_DATA_TLB_VECTOR               0x1000
-#define IA64_DATA_NESTED_TLB_VECTOR            0x1400
-#define IA64_INST_KEY_MISS_VECTOR              0x1800
-#define IA64_DATA_KEY_MISS_VECTOR              0x1c00
-#define IA64_DIRTY_BIT_VECTOR                  0x2000
-#define IA64_INST_ACCESS_BIT_VECTOR            0x2400
-#define IA64_DATA_ACCESS_BIT_VECTOR            0x2800
-#define IA64_BREAK_VECTOR                      0x2c00
-#define IA64_EXTINT_VECTOR                     0x3000
-#define IA64_PAGE_NOT_PRESENT_VECTOR           0x5000
-#define IA64_KEY_PERMISSION_VECTOR             0x5100
-#define IA64_INST_ACCESS_RIGHTS_VECTOR         0x5200
-#define IA64_DATA_ACCESS_RIGHTS_VECTOR         0x5300
-#define IA64_GENEX_VECTOR                      0x5400
-#define IA64_DISABLED_FPREG_VECTOR             0x5500
-#define IA64_NAT_CONSUMPTION_VECTOR            0x5600
-#define IA64_SPECULATION_VECTOR                0x5700 /* UNUSED */
-#define IA64_DEBUG_VECTOR                      0x5900
-#define IA64_UNALIGNED_REF_VECTOR              0x5a00
-#define IA64_UNSUPPORTED_DATA_REF_VECTOR       0x5b00
-#define IA64_FP_FAULT_VECTOR                   0x5c00
-#define IA64_FP_TRAP_VECTOR                    0x5d00
-#define IA64_LOWERPRIV_TRANSFER_TRAP_VECTOR    0x5e00
-#define IA64_TAKEN_BRANCH_TRAP_VECTOR          0x5f00
-#define IA64_SINGLE_STEP_TRAP_VECTOR           0x6000
-
-/* SDM vol2 5.5 - IVA based interruption handling */
-#define INITIAL_PSR_VALUE_AT_INTERRUPTION (IA64_PSR_UP | IA64_PSR_MFL |\
-                       IA64_PSR_MFH | IA64_PSR_PK | IA64_PSR_DT |      \
-                       IA64_PSR_RT | IA64_PSR_MC|IA64_PSR_IT)
-
-#define DOMN_PAL_REQUEST    0x110000
-#define DOMN_SAL_REQUEST    0x110001
-
-static u64 vec2off[68] = {0x0, 0x400, 0x800, 0xc00, 0x1000, 0x1400, 0x1800,
-       0x1c00, 0x2000, 0x2400, 0x2800, 0x2c00, 0x3000, 0x3400, 0x3800, 0x3c00,
-       0x4000, 0x4400, 0x4800, 0x4c00, 0x5000, 0x5100, 0x5200, 0x5300, 0x5400,
-       0x5500, 0x5600, 0x5700, 0x5800, 0x5900, 0x5a00, 0x5b00, 0x5c00, 0x5d00,
-       0x5e00, 0x5f00, 0x6000, 0x6100, 0x6200, 0x6300, 0x6400, 0x6500, 0x6600,
-       0x6700, 0x6800, 0x6900, 0x6a00, 0x6b00, 0x6c00, 0x6d00, 0x6e00, 0x6f00,
-       0x7000, 0x7100, 0x7200, 0x7300, 0x7400, 0x7500, 0x7600, 0x7700, 0x7800,
-       0x7900, 0x7a00, 0x7b00, 0x7c00, 0x7d00, 0x7e00, 0x7f00
-};
-
-static void collect_interruption(struct kvm_vcpu *vcpu)
-{
-       u64 ipsr;
-       u64 vdcr;
-       u64 vifs;
-       unsigned long vpsr;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       vpsr = vcpu_get_psr(vcpu);
-       vcpu_bsw0(vcpu);
-       if (vpsr & IA64_PSR_IC) {
-
-               /* Sync mpsr id/da/dd/ss/ed bits to vipsr
-                * since after guest do rfi, we still want these bits on in
-                * mpsr
-                */
-
-               ipsr = regs->cr_ipsr;
-               vpsr = vpsr | (ipsr & (IA64_PSR_ID | IA64_PSR_DA
-                                       | IA64_PSR_DD | IA64_PSR_SS
-                                       | IA64_PSR_ED));
-               vcpu_set_ipsr(vcpu, vpsr);
-
-               /* Currently, for trap, we do not advance IIP to next
-                * instruction. That's because we assume caller already
-                * set up IIP correctly
-                */
-
-               vcpu_set_iip(vcpu , regs->cr_iip);
-
-               /* set vifs.v to zero */
-               vifs = VCPU(vcpu, ifs);
-               vifs &= ~IA64_IFS_V;
-               vcpu_set_ifs(vcpu, vifs);
-
-               vcpu_set_iipa(vcpu, VMX(vcpu, cr_iipa));
-       }
-
-       vdcr = VCPU(vcpu, dcr);
-
-       /* Set guest psr
-        * up/mfl/mfh/pk/dt/rt/mc/it keeps unchanged
-        * be: set to the value of dcr.be
-        * pp: set to the value of dcr.pp
-        */
-       vpsr &= INITIAL_PSR_VALUE_AT_INTERRUPTION;
-       vpsr |= (vdcr & IA64_DCR_BE);
-
-       /* VDCR pp bit position is different from VPSR pp bit */
-       if (vdcr & IA64_DCR_PP) {
-               vpsr |= IA64_PSR_PP;
-       } else {
-               vpsr &= ~IA64_PSR_PP;
-       }
-
-       vcpu_set_psr(vcpu, vpsr);
-
-}
-
-void inject_guest_interruption(struct kvm_vcpu *vcpu, u64 vec)
-{
-       u64 viva;
-       struct kvm_pt_regs *regs;
-       union ia64_isr pt_isr;
-
-       regs = vcpu_regs(vcpu);
-
-       /* clear cr.isr.ir (incomplete register frame)*/
-       pt_isr.val = VMX(vcpu, cr_isr);
-       pt_isr.ir = 0;
-       VMX(vcpu, cr_isr) = pt_isr.val;
-
-       collect_interruption(vcpu);
-
-       viva = vcpu_get_iva(vcpu);
-       regs->cr_iip = viva + vec;
-}
-
-static u64 vcpu_get_itir_on_fault(struct kvm_vcpu *vcpu, u64 ifa)
-{
-       union ia64_rr rr, rr1;
-
-       rr.val = vcpu_get_rr(vcpu, ifa);
-       rr1.val = 0;
-       rr1.ps = rr.ps;
-       rr1.rid = rr.rid;
-       return (rr1.val);
-}
-
-/*
- * Set vIFA & vITIR & vIHA, when vPSR.ic =1
- * Parameter:
- *  set_ifa: if true, set vIFA
- *  set_itir: if true, set vITIR
- *  set_iha: if true, set vIHA
- */
-void set_ifa_itir_iha(struct kvm_vcpu *vcpu, u64 vadr,
-               int set_ifa, int set_itir, int set_iha)
-{
-       long vpsr;
-       u64 value;
-
-       vpsr = VCPU(vcpu, vpsr);
-       /* Vol2, Table 8-1 */
-       if (vpsr & IA64_PSR_IC) {
-               if (set_ifa)
-                       vcpu_set_ifa(vcpu, vadr);
-               if (set_itir) {
-                       value = vcpu_get_itir_on_fault(vcpu, vadr);
-                       vcpu_set_itir(vcpu, value);
-               }
-
-               if (set_iha) {
-                       value = vcpu_thash(vcpu, vadr);
-                       vcpu_set_iha(vcpu, value);
-               }
-       }
-}
-
-/*
- * Data TLB Fault
- *  @ Data TLB vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void dtlb_fault(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       /* If vPSR.ic, IFA, ITIR, IHA */
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 1);
-       inject_guest_interruption(vcpu, IA64_DATA_TLB_VECTOR);
-}
-
-/*
- * Instruction TLB Fault
- *  @ Instruction TLB vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void itlb_fault(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       /* If vPSR.ic, IFA, ITIR, IHA */
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 1);
-       inject_guest_interruption(vcpu, IA64_INST_TLB_VECTOR);
-}
-
-/*
- * Data Nested TLB Fault
- *  @ Data Nested TLB Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void nested_dtlb(struct kvm_vcpu *vcpu)
-{
-       inject_guest_interruption(vcpu, IA64_DATA_NESTED_TLB_VECTOR);
-}
-
-/*
- * Alternate Data TLB Fault
- *  @ Alternate Data TLB vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void alt_dtlb(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 0);
-       inject_guest_interruption(vcpu, IA64_ALT_DATA_TLB_VECTOR);
-}
-
-/*
- * Data TLB Fault
- *  @ Data TLB vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void alt_itlb(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 0);
-       inject_guest_interruption(vcpu, IA64_ALT_INST_TLB_VECTOR);
-}
-
-/* Deal with:
- *  VHPT Translation Vector
- */
-static void _vhpt_fault(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       /* If vPSR.ic, IFA, ITIR, IHA*/
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 1);
-       inject_guest_interruption(vcpu, IA64_VHPT_TRANS_VECTOR);
-}
-
-/*
- * VHPT Instruction Fault
- *  @ VHPT Translation vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void ivhpt_fault(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       _vhpt_fault(vcpu, vadr);
-}
-
-/*
- * VHPT Data Fault
- *  @ VHPT Translation vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void dvhpt_fault(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       _vhpt_fault(vcpu, vadr);
-}
-
-/*
- * Deal with:
- *  General Exception vector
- */
-void _general_exception(struct kvm_vcpu *vcpu)
-{
-       inject_guest_interruption(vcpu, IA64_GENEX_VECTOR);
-}
-
-/*
- * Illegal Operation Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void illegal_op(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-
-/*
- * Illegal Dependency Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void illegal_dep(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-
-/*
- * Reserved Register/Field Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void rsv_reg_field(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-/*
- * Privileged Operation Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-
-void privilege_op(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-
-/*
- * Unimplement Data Address Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void unimpl_daddr(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-
-/*
- * Privileged Register Fault
- *  @ General Exception Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void privilege_reg(struct kvm_vcpu *vcpu)
-{
-       _general_exception(vcpu);
-}
-
-/* Deal with
- *  Nat consumption vector
- * Parameter:
- *  vaddr: Optional, if t == REGISTER
- */
-static void _nat_consumption_fault(struct kvm_vcpu *vcpu, u64 vadr,
-                                               enum tlb_miss_type t)
-{
-       /* If vPSR.ic && t == DATA/INST, IFA */
-       if (t == DATA || t == INSTRUCTION) {
-               /* IFA */
-               set_ifa_itir_iha(vcpu, vadr, 1, 0, 0);
-       }
-
-       inject_guest_interruption(vcpu, IA64_NAT_CONSUMPTION_VECTOR);
-}
-
-/*
- * Instruction Nat Page Consumption Fault
- *  @ Nat Consumption Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void inat_page_consumption(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       _nat_consumption_fault(vcpu, vadr, INSTRUCTION);
-}
-
-/*
- * Register Nat Consumption Fault
- *  @ Nat Consumption Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void rnat_consumption(struct kvm_vcpu *vcpu)
-{
-       _nat_consumption_fault(vcpu, 0, REGISTER);
-}
-
-/*
- * Data Nat Page Consumption Fault
- *  @ Nat Consumption Vector
- * Refer to SDM Vol2 Table 5-6 & 8-1
- */
-void dnat_page_consumption(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       _nat_consumption_fault(vcpu, vadr, DATA);
-}
-
-/* Deal with
- *  Page not present vector
- */
-static void __page_not_present(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       /* If vPSR.ic, IFA, ITIR */
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 0);
-       inject_guest_interruption(vcpu, IA64_PAGE_NOT_PRESENT_VECTOR);
-}
-
-void data_page_not_present(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       __page_not_present(vcpu, vadr);
-}
-
-void inst_page_not_present(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       __page_not_present(vcpu, vadr);
-}
-
-/* Deal with
- *  Data access rights vector
- */
-void data_access_rights(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       /* If vPSR.ic, IFA, ITIR */
-       set_ifa_itir_iha(vcpu, vadr, 1, 1, 0);
-       inject_guest_interruption(vcpu, IA64_DATA_ACCESS_RIGHTS_VECTOR);
-}
-
-fpswa_ret_t vmm_fp_emulate(int fp_fault, void *bundle, unsigned long *ipsr,
-               unsigned long *fpsr, unsigned long *isr, unsigned long *pr,
-               unsigned long *ifs, struct kvm_pt_regs *regs)
-{
-       fp_state_t fp_state;
-       fpswa_ret_t ret;
-       struct kvm_vcpu *vcpu = current_vcpu;
-
-       uint64_t old_rr7 = ia64_get_rr(7UL<<61);
-
-       if (!vmm_fpswa_interface)
-               return (fpswa_ret_t) {-1, 0, 0, 0};
-
-       memset(&fp_state, 0, sizeof(fp_state_t));
-
-       /*
-        * compute fp_state.  only FP registers f6 - f11 are used by the
-        * vmm, so set those bits in the mask and set the low volatile
-        * pointer to point to these registers.
-        */
-       fp_state.bitmask_low64 = 0xfc0;  /* bit6..bit11 */
-
-       fp_state.fp_state_low_volatile = (fp_state_low_volatile_t *) &regs->f6;
-
-   /*
-        * unsigned long (*EFI_FPSWA) (
-        *      unsigned long    trap_type,
-        *      void             *Bundle,
-        *      unsigned long    *pipsr,
-        *      unsigned long    *pfsr,
-        *      unsigned long    *pisr,
-        *      unsigned long    *ppreds,
-        *      unsigned long    *pifs,
-        *      void             *fp_state);
-        */
-       /*Call host fpswa interface directly to virtualize
-        *guest fpswa request!
-        */
-       ia64_set_rr(7UL << 61, vcpu->arch.host.rr[7]);
-       ia64_srlz_d();
-
-       ret = (*vmm_fpswa_interface->fpswa) (fp_fault, bundle,
-                       ipsr, fpsr, isr, pr, ifs, &fp_state);
-       ia64_set_rr(7UL << 61, old_rr7);
-       ia64_srlz_d();
-       return ret;
-}
-
-/*
- * Handle floating-point assist faults and traps for domain.
- */
-unsigned long vmm_handle_fpu_swa(int fp_fault, struct kvm_pt_regs *regs,
-                                       unsigned long isr)
-{
-       struct kvm_vcpu *v = current_vcpu;
-       IA64_BUNDLE bundle;
-       unsigned long fault_ip;
-       fpswa_ret_t ret;
-
-       fault_ip = regs->cr_iip;
-       /*
-        * When the FP trap occurs, the trapping instruction is completed.
-        * If ipsr.ri == 0, there is the trapping instruction in previous
-        * bundle.
-        */
-       if (!fp_fault && (ia64_psr(regs)->ri == 0))
-               fault_ip -= 16;
-
-       if (fetch_code(v, fault_ip, &bundle))
-               return -EAGAIN;
-
-       if (!bundle.i64[0] && !bundle.i64[1])
-               return -EACCES;
-
-       ret = vmm_fp_emulate(fp_fault, &bundle, &regs->cr_ipsr, &regs->ar_fpsr,
-                       &isr, &regs->pr, &regs->cr_ifs, regs);
-       return ret.status;
-}
-
-void reflect_interruption(u64 ifa, u64 isr, u64 iim,
-               u64 vec, struct kvm_pt_regs *regs)
-{
-       u64 vector;
-       int status ;
-       struct kvm_vcpu *vcpu = current_vcpu;
-       u64 vpsr = VCPU(vcpu, vpsr);
-
-       vector = vec2off[vec];
-
-       if (!(vpsr & IA64_PSR_IC) && (vector != IA64_DATA_NESTED_TLB_VECTOR)) {
-               panic_vm(vcpu, "Interruption with vector :0x%lx occurs "
-                                               "with psr.ic = 0\n", vector);
-               return;
-       }
-
-       switch (vec) {
-       case 32:        /*IA64_FP_FAULT_VECTOR*/
-               status = vmm_handle_fpu_swa(1, regs, isr);
-               if (!status) {
-                       vcpu_increment_iip(vcpu);
-                       return;
-               } else if (-EAGAIN == status)
-                       return;
-               break;
-       case 33:        /*IA64_FP_TRAP_VECTOR*/
-               status = vmm_handle_fpu_swa(0, regs, isr);
-               if (!status)
-                       return ;
-               break;
-       }
-
-       VCPU(vcpu, isr) = isr;
-       VCPU(vcpu, iipa) = regs->cr_iip;
-       if (vector == IA64_BREAK_VECTOR || vector == IA64_SPECULATION_VECTOR)
-               VCPU(vcpu, iim) = iim;
-       else
-               set_ifa_itir_iha(vcpu, ifa, 1, 1, 1);
-
-       inject_guest_interruption(vcpu, vector);
-}
-
-static unsigned long kvm_trans_pal_call_args(struct kvm_vcpu *vcpu,
-                                               unsigned long arg)
-{
-       struct thash_data *data;
-       unsigned long gpa, poff;
-
-       if (!is_physical_mode(vcpu)) {
-               /* Depends on caller to provide the DTR or DTC mapping.*/
-               data = vtlb_lookup(vcpu, arg, D_TLB);
-               if (data)
-                       gpa = data->page_flags & _PAGE_PPN_MASK;
-               else {
-                       data = vhpt_lookup(arg);
-                       if (!data)
-                               return 0;
-                       gpa = data->gpaddr & _PAGE_PPN_MASK;
-               }
-
-               poff = arg & (PSIZE(data->ps) - 1);
-               arg = PAGEALIGN(gpa, data->ps) | poff;
-       }
-       arg = kvm_gpa_to_mpa(arg << 1 >> 1);
-
-       return (unsigned long)__va(arg);
-}
-
-static void set_pal_call_data(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-       unsigned long gr28 = vcpu_get_gr(vcpu, 28);
-       unsigned long gr29 = vcpu_get_gr(vcpu, 29);
-       unsigned long gr30 = vcpu_get_gr(vcpu, 30);
-
-       /*FIXME:For static and stacked convention, firmware
-        * has put the parameters in gr28-gr31 before
-        * break to vmm  !!*/
-
-       switch (gr28) {
-       case PAL_PERF_MON_INFO:
-       case PAL_HALT_INFO:
-               p->u.pal_data.gr29 =  kvm_trans_pal_call_args(vcpu, gr29);
-               p->u.pal_data.gr30 = vcpu_get_gr(vcpu, 30);
-               break;
-       case PAL_BRAND_INFO:
-               p->u.pal_data.gr29 = gr29;
-               p->u.pal_data.gr30 = kvm_trans_pal_call_args(vcpu, gr30);
-               break;
-       default:
-               p->u.pal_data.gr29 = gr29;
-               p->u.pal_data.gr30 = vcpu_get_gr(vcpu, 30);
-       }
-       p->u.pal_data.gr28 = gr28;
-       p->u.pal_data.gr31 = vcpu_get_gr(vcpu, 31);
-
-       p->exit_reason = EXIT_REASON_PAL_CALL;
-}
-
-static void get_pal_call_result(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-
-       if (p->exit_reason == EXIT_REASON_PAL_CALL) {
-               vcpu_set_gr(vcpu, 8, p->u.pal_data.ret.status, 0);
-               vcpu_set_gr(vcpu, 9, p->u.pal_data.ret.v0, 0);
-               vcpu_set_gr(vcpu, 10, p->u.pal_data.ret.v1, 0);
-               vcpu_set_gr(vcpu, 11, p->u.pal_data.ret.v2, 0);
-       } else
-               panic_vm(vcpu, "Mis-set for exit reason!\n");
-}
-
-static void set_sal_call_data(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-
-       p->u.sal_data.in0 = vcpu_get_gr(vcpu, 32);
-       p->u.sal_data.in1 = vcpu_get_gr(vcpu, 33);
-       p->u.sal_data.in2 = vcpu_get_gr(vcpu, 34);
-       p->u.sal_data.in3 = vcpu_get_gr(vcpu, 35);
-       p->u.sal_data.in4 = vcpu_get_gr(vcpu, 36);
-       p->u.sal_data.in5 = vcpu_get_gr(vcpu, 37);
-       p->u.sal_data.in6 = vcpu_get_gr(vcpu, 38);
-       p->u.sal_data.in7 = vcpu_get_gr(vcpu, 39);
-       p->exit_reason = EXIT_REASON_SAL_CALL;
-}
-
-static void get_sal_call_result(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-
-       if (p->exit_reason == EXIT_REASON_SAL_CALL) {
-               vcpu_set_gr(vcpu, 8, p->u.sal_data.ret.r8, 0);
-               vcpu_set_gr(vcpu, 9, p->u.sal_data.ret.r9, 0);
-               vcpu_set_gr(vcpu, 10, p->u.sal_data.ret.r10, 0);
-               vcpu_set_gr(vcpu, 11, p->u.sal_data.ret.r11, 0);
-       } else
-               panic_vm(vcpu, "Mis-set for exit reason!\n");
-}
-
-void  kvm_ia64_handle_break(unsigned long ifa, struct kvm_pt_regs *regs,
-               unsigned long isr, unsigned long iim)
-{
-       struct kvm_vcpu *v = current_vcpu;
-       long psr;
-
-       if (ia64_psr(regs)->cpl == 0) {
-               /* Allow hypercalls only when cpl = 0.  */
-               if (iim == DOMN_PAL_REQUEST) {
-                       local_irq_save(psr);
-                       set_pal_call_data(v);
-                       vmm_transition(v);
-                       get_pal_call_result(v);
-                       vcpu_increment_iip(v);
-                       local_irq_restore(psr);
-                       return;
-               } else if (iim == DOMN_SAL_REQUEST) {
-                       local_irq_save(psr);
-                       set_sal_call_data(v);
-                       vmm_transition(v);
-                       get_sal_call_result(v);
-                       vcpu_increment_iip(v);
-                       local_irq_restore(psr);
-                       return;
-               }
-       }
-       reflect_interruption(ifa, isr, iim, 11, regs);
-}
-
-void check_pending_irq(struct kvm_vcpu *vcpu)
-{
-       int  mask, h_pending, h_inservice;
-       u64 isr;
-       unsigned long  vpsr;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       h_pending = highest_pending_irq(vcpu);
-       if (h_pending == NULL_VECTOR) {
-               update_vhpi(vcpu, NULL_VECTOR);
-               return;
-       }
-       h_inservice = highest_inservice_irq(vcpu);
-
-       vpsr = VCPU(vcpu, vpsr);
-       mask = irq_masked(vcpu, h_pending, h_inservice);
-       if ((vpsr & IA64_PSR_I) && IRQ_NO_MASKED == mask) {
-               isr = vpsr & IA64_PSR_RI;
-               update_vhpi(vcpu, h_pending);
-               reflect_interruption(0, isr, 0, 12, regs); /* EXT IRQ */
-       } else if (mask == IRQ_MASKED_BY_INSVC) {
-               if (VCPU(vcpu, vhpi))
-                       update_vhpi(vcpu, NULL_VECTOR);
-       } else {
-               /* masked by vpsr.i or vtpr.*/
-               update_vhpi(vcpu, h_pending);
-       }
-}
-
-static void generate_exirq(struct kvm_vcpu *vcpu)
-{
-       unsigned  vpsr;
-       uint64_t isr;
-
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       vpsr = VCPU(vcpu, vpsr);
-       isr = vpsr & IA64_PSR_RI;
-       if (!(vpsr & IA64_PSR_IC))
-               panic_vm(vcpu, "Trying to inject one IRQ with psr.ic=0\n");
-       reflect_interruption(0, isr, 0, 12, regs); /* EXT IRQ */
-}
-
-void vhpi_detection(struct kvm_vcpu *vcpu)
-{
-       uint64_t    threshold, vhpi;
-       union ia64_tpr       vtpr;
-       struct ia64_psr vpsr;
-
-       vpsr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-       vtpr.val = VCPU(vcpu, tpr);
-
-       threshold = ((!vpsr.i) << 5) | (vtpr.mmi << 4) | vtpr.mic;
-       vhpi = VCPU(vcpu, vhpi);
-       if (vhpi > threshold) {
-               /* interrupt actived*/
-               generate_exirq(vcpu);
-       }
-}
-
-void leave_hypervisor_tail(void)
-{
-       struct kvm_vcpu *v = current_vcpu;
-
-       if (VMX(v, timer_check)) {
-               VMX(v, timer_check) = 0;
-               if (VMX(v, itc_check)) {
-                       if (vcpu_get_itc(v) > VCPU(v, itm)) {
-                               if (!(VCPU(v, itv) & (1 << 16))) {
-                                       vcpu_pend_interrupt(v, VCPU(v, itv)
-                                                       & 0xff);
-                                       VMX(v, itc_check) = 0;
-                               } else {
-                                       v->arch.timer_pending = 1;
-                               }
-                               VMX(v, last_itc) = VCPU(v, itm) + 1;
-                       }
-               }
-       }
-
-       rmb();
-       if (v->arch.irq_new_pending) {
-               v->arch.irq_new_pending = 0;
-               VMX(v, irq_check) = 0;
-               check_pending_irq(v);
-               return;
-       }
-       if (VMX(v, irq_check)) {
-               VMX(v, irq_check) = 0;
-               vhpi_detection(v);
-       }
-}
-
-static inline void handle_lds(struct kvm_pt_regs *regs)
-{
-       regs->cr_ipsr |= IA64_PSR_ED;
-}
-
-void physical_tlb_miss(struct kvm_vcpu *vcpu, unsigned long vadr, int type)
-{
-       unsigned long pte;
-       union ia64_rr rr;
-
-       rr.val = ia64_get_rr(vadr);
-       pte =  vadr & _PAGE_PPN_MASK;
-       pte = pte | PHY_PAGE_WB;
-       thash_vhpt_insert(vcpu, pte, (u64)(rr.ps << 2), vadr, type);
-       return;
-}
-
-void kvm_page_fault(u64 vadr , u64 vec, struct kvm_pt_regs *regs)
-{
-       unsigned long vpsr;
-       int type;
-
-       u64 vhpt_adr, gppa, pteval, rr, itir;
-       union ia64_isr misr;
-       union ia64_pta vpta;
-       struct thash_data *data;
-       struct kvm_vcpu *v = current_vcpu;
-
-       vpsr = VCPU(v, vpsr);
-       misr.val = VMX(v, cr_isr);
-
-       type = vec;
-
-       if (is_physical_mode(v) && (!(vadr << 1 >> 62))) {
-               if (vec == 2) {
-                       if (__gpfn_is_io((vadr << 1) >> (PAGE_SHIFT + 1))) {
-                               emulate_io_inst(v, ((vadr << 1) >> 1), 4);
-                               return;
-                       }
-               }
-               physical_tlb_miss(v, vadr, type);
-               return;
-       }
-       data = vtlb_lookup(v, vadr, type);
-       if (data != 0) {
-               if (type == D_TLB) {
-                       gppa = (vadr & ((1UL << data->ps) - 1))
-                               + (data->ppn >> (data->ps - 12) << data->ps);
-                       if (__gpfn_is_io(gppa >> PAGE_SHIFT)) {
-                               if (data->pl >= ((regs->cr_ipsr >>
-                                               IA64_PSR_CPL0_BIT) & 3))
-                                       emulate_io_inst(v, gppa, data->ma);
-                               else {
-                                       vcpu_set_isr(v, misr.val);
-                                       data_access_rights(v, vadr);
-                               }
-                               return ;
-                       }
-               }
-               thash_vhpt_insert(v, data->page_flags, data->itir, vadr, type);
-
-       } else if (type == D_TLB) {
-               if (misr.sp) {
-                       handle_lds(regs);
-                       return;
-               }
-
-               rr = vcpu_get_rr(v, vadr);
-               itir = rr & (RR_RID_MASK | RR_PS_MASK);
-
-               if (!vhpt_enabled(v, vadr, misr.rs ? RSE_REF : DATA_REF)) {
-                       if (vpsr & IA64_PSR_IC) {
-                               vcpu_set_isr(v, misr.val);
-                               alt_dtlb(v, vadr);
-                       } else {
-                               nested_dtlb(v);
-                       }
-                       return ;
-               }
-
-               vpta.val = vcpu_get_pta(v);
-               /* avoid recursively walking (short format) VHPT */
-
-               vhpt_adr = vcpu_thash(v, vadr);
-               if (!guest_vhpt_lookup(vhpt_adr, &pteval)) {
-                       /* VHPT successfully read.  */
-                       if (!(pteval & _PAGE_P)) {
-                               if (vpsr & IA64_PSR_IC) {
-                                       vcpu_set_isr(v, misr.val);
-                                       dtlb_fault(v, vadr);
-                               } else {
-                                       nested_dtlb(v);
-                               }
-                       } else if ((pteval & _PAGE_MA_MASK) != _PAGE_MA_ST) {
-                               thash_purge_and_insert(v, pteval, itir,
-                                                               vadr, D_TLB);
-                       } else if (vpsr & IA64_PSR_IC) {
-                               vcpu_set_isr(v, misr.val);
-                               dtlb_fault(v, vadr);
-                       } else {
-                               nested_dtlb(v);
-                       }
-               } else {
-                       /* Can't read VHPT.  */
-                       if (vpsr & IA64_PSR_IC) {
-                               vcpu_set_isr(v, misr.val);
-                               dvhpt_fault(v, vadr);
-                       } else {
-                               nested_dtlb(v);
-                       }
-               }
-       } else if (type == I_TLB) {
-               if (!(vpsr & IA64_PSR_IC))
-                       misr.ni = 1;
-               if (!vhpt_enabled(v, vadr, INST_REF)) {
-                       vcpu_set_isr(v, misr.val);
-                       alt_itlb(v, vadr);
-                       return;
-               }
-
-               vpta.val = vcpu_get_pta(v);
-
-               vhpt_adr = vcpu_thash(v, vadr);
-               if (!guest_vhpt_lookup(vhpt_adr, &pteval)) {
-                       /* VHPT successfully read.  */
-                       if (pteval & _PAGE_P) {
-                               if ((pteval & _PAGE_MA_MASK) == _PAGE_MA_ST) {
-                                       vcpu_set_isr(v, misr.val);
-                                       itlb_fault(v, vadr);
-                                       return ;
-                               }
-                               rr = vcpu_get_rr(v, vadr);
-                               itir = rr & (RR_RID_MASK | RR_PS_MASK);
-                               thash_purge_and_insert(v, pteval, itir,
-                                                       vadr, I_TLB);
-                       } else {
-                               vcpu_set_isr(v, misr.val);
-                               inst_page_not_present(v, vadr);
-                       }
-               } else {
-                       vcpu_set_isr(v, misr.val);
-                       ivhpt_fault(v, vadr);
-               }
-       }
-}
-
-void kvm_vexirq(struct kvm_vcpu *vcpu)
-{
-       u64 vpsr, isr;
-       struct kvm_pt_regs *regs;
-
-       regs = vcpu_regs(vcpu);
-       vpsr = VCPU(vcpu, vpsr);
-       isr = vpsr & IA64_PSR_RI;
-       reflect_interruption(0, isr, 0, 12, regs); /*EXT IRQ*/
-}
-
-void kvm_ia64_handle_irq(struct kvm_vcpu *v)
-{
-       struct exit_ctl_data *p = &v->arch.exit_data;
-       long psr;
-
-       local_irq_save(psr);
-       p->exit_reason = EXIT_REASON_EXTERNAL_INTERRUPT;
-       vmm_transition(v);
-       local_irq_restore(psr);
-
-       VMX(v, timer_check) = 1;
-
-}
-
-static void ptc_ga_remote_func(struct kvm_vcpu *v, int pos)
-{
-       u64 oldrid, moldrid, oldpsbits, vaddr;
-       struct kvm_ptc_g *p = &v->arch.ptc_g_data[pos];
-       vaddr = p->vaddr;
-
-       oldrid = VMX(v, vrr[0]);
-       VMX(v, vrr[0]) = p->rr;
-       oldpsbits = VMX(v, psbits[0]);
-       VMX(v, psbits[0]) = VMX(v, psbits[REGION_NUMBER(vaddr)]);
-       moldrid = ia64_get_rr(0x0);
-       ia64_set_rr(0x0, vrrtomrr(p->rr));
-       ia64_srlz_d();
-
-       vaddr = PAGEALIGN(vaddr, p->ps);
-       thash_purge_entries_remote(v, vaddr, p->ps);
-
-       VMX(v, vrr[0]) = oldrid;
-       VMX(v, psbits[0]) = oldpsbits;
-       ia64_set_rr(0x0, moldrid);
-       ia64_dv_serialize_data();
-}
-
-static void vcpu_do_resume(struct kvm_vcpu *vcpu)
-{
-       /*Re-init VHPT and VTLB once from resume*/
-       vcpu->arch.vhpt.num = VHPT_NUM_ENTRIES;
-       thash_init(&vcpu->arch.vhpt, VHPT_SHIFT);
-       vcpu->arch.vtlb.num = VTLB_NUM_ENTRIES;
-       thash_init(&vcpu->arch.vtlb, VTLB_SHIFT);
-
-       ia64_set_pta(vcpu->arch.vhpt.pta.val);
-}
-
-static void vmm_sanity_check(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-
-       if (!vmm_sanity && p->exit_reason != EXIT_REASON_DEBUG) {
-               panic_vm(vcpu, "Failed to do vmm sanity check,"
-                       "it maybe caused by crashed vmm!!\n\n");
-       }
-}
-
-static void kvm_do_resume_op(struct kvm_vcpu *vcpu)
-{
-       vmm_sanity_check(vcpu); /*Guarantee vcpu running on healthy vmm!*/
-
-       if (test_and_clear_bit(KVM_REQ_RESUME, &vcpu->requests)) {
-               vcpu_do_resume(vcpu);
-               return;
-       }
-
-       if (unlikely(test_and_clear_bit(KVM_REQ_TLB_FLUSH, &vcpu->requests))) {
-               thash_purge_all(vcpu);
-               return;
-       }
-
-       if (test_and_clear_bit(KVM_REQ_PTC_G, &vcpu->requests)) {
-               while (vcpu->arch.ptc_g_count > 0)
-                       ptc_ga_remote_func(vcpu, --vcpu->arch.ptc_g_count);
-       }
-}
-
-void vmm_transition(struct kvm_vcpu *vcpu)
-{
-       ia64_call_vsa(PAL_VPS_SAVE, (unsigned long)vcpu->arch.vpd,
-                       1, 0, 0, 0, 0, 0);
-       vmm_trampoline(&vcpu->arch.guest, &vcpu->arch.host);
-       ia64_call_vsa(PAL_VPS_RESTORE, (unsigned long)vcpu->arch.vpd,
-                                               1, 0, 0, 0, 0, 0);
-       kvm_do_resume_op(vcpu);
-}
-
-void vmm_panic_handler(u64 vec)
-{
-       struct kvm_vcpu *vcpu = current_vcpu;
-       vmm_sanity = 0;
-       panic_vm(vcpu, "Unexpected interruption occurs in VMM, vector:0x%lx\n",
-                       vec2off[vec]);
-}
diff --git a/arch/ia64/kvm/trampoline.S b/arch/ia64/kvm/trampoline.S
deleted file mode 100644 (file)
index 30897d4..0000000
+++ /dev/null
@@ -1,1038 +0,0 @@
-/* Save all processor states
- *
- * Copyright (c) 2007 Fleming Feng <fleming.feng@intel.com>
- * Copyright (c) 2007 Anthony Xu   <anthony.xu@intel.com>
- */
-
-#include <asm/asmmacro.h>
-#include "asm-offsets.h"
-
-
-#define CTX(name)    VMM_CTX_##name##_OFFSET
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_BRANCH_REGS                        \
-       add     r2 = CTX(B0),r32;               \
-       add     r3 = CTX(B1),r32;               \
-       mov     r16 = b0;                       \
-       mov     r17 = b1;                       \
-       ;;                                      \
-       st8     [r2]=r16,16;                    \
-       st8     [r3]=r17,16;                    \
-       ;;                                      \
-       mov     r16 = b2;                       \
-       mov     r17 = b3;                       \
-       ;;                                      \
-       st8     [r2]=r16,16;                    \
-       st8     [r3]=r17,16;                    \
-       ;;                                      \
-       mov     r16 = b4;                       \
-       mov     r17 = b5;                       \
-       ;;                                      \
-       st8     [r2]=r16;                       \
-       st8     [r3]=r17;                       \
-       ;;
-
-       /*
-        *      r33:            context_t base address
-        */
-#define        RESTORE_BRANCH_REGS                     \
-       add     r2 = CTX(B0),r33;               \
-       add     r3 = CTX(B1),r33;               \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     b0 = r16;                       \
-       mov     b1 = r17;                       \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     b2 = r16;                       \
-       mov     b3 = r17;                       \
-       ;;                                      \
-       ld8     r16=[r2];                       \
-       ld8     r17=[r3];                       \
-       ;;                                      \
-       mov     b4=r16;                         \
-       mov     b5=r17;                         \
-       ;;
-
-
-       /*
-        *      r32: context_t base address
-        *      bsw == 1
-        *      Save all bank1 general registers, r4 ~ r7
-        */
-#define        SAVE_GENERAL_REGS                       \
-       add     r2=CTX(R4),r32;                 \
-       add     r3=CTX(R5),r32;                 \
-       ;;                                      \
-.mem.offset 0,0;                               \
-       st8.spill       [r2]=r4,16;             \
-.mem.offset 8,0;                               \
-       st8.spill       [r3]=r5,16;             \
-       ;;                                      \
-.mem.offset 0,0;                               \
-       st8.spill       [r2]=r6,48;             \
-.mem.offset 8,0;                               \
-       st8.spill       [r3]=r7,48;             \
-       ;;                                      \
-.mem.offset 0,0;                               \
-    st8.spill    [r2]=r12;                     \
-.mem.offset 8,0;                               \
-    st8.spill    [r3]=r13;                     \
-    ;;
-
-       /*
-        *      r33: context_t base address
-        *      bsw == 1
-        */
-#define        RESTORE_GENERAL_REGS                    \
-       add     r2=CTX(R4),r33;                 \
-       add     r3=CTX(R5),r33;                 \
-       ;;                                      \
-       ld8.fill        r4=[r2],16;             \
-       ld8.fill        r5=[r3],16;             \
-       ;;                                      \
-       ld8.fill        r6=[r2],48;             \
-       ld8.fill        r7=[r3],48;             \
-       ;;                                      \
-       ld8.fill    r12=[r2];                   \
-       ld8.fill    r13 =[r3];                  \
-       ;;
-
-
-
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_KERNEL_REGS                        \
-       add     r2 = CTX(KR0),r32;              \
-       add     r3 = CTX(KR1),r32;              \
-       mov     r16 = ar.k0;                    \
-       mov     r17 = ar.k1;                    \
-       ;;                                      \
-       st8     [r2] = r16,16;                  \
-       st8     [r3] = r17,16;                  \
-       ;;                                      \
-       mov     r16 = ar.k2;                    \
-       mov     r17 = ar.k3;                    \
-       ;;                                      \
-       st8     [r2] = r16,16;                  \
-       st8     [r3] = r17,16;                  \
-       ;;                                      \
-       mov     r16 = ar.k4;                    \
-       mov     r17 = ar.k5;                    \
-       ;;                                      \
-       st8     [r2] = r16,16;                  \
-       st8     [r3] = r17,16;                  \
-       ;;                                      \
-       mov     r16 = ar.k6;                    \
-       mov     r17 = ar.k7;                    \
-       ;;                                      \
-       st8     [r2] = r16;                     \
-       st8     [r3] = r17;                     \
-       ;;
-
-
-
-       /*
-        *      r33:            context_t base address
-        */
-#define        RESTORE_KERNEL_REGS                     \
-       add     r2 = CTX(KR0),r33;              \
-       add     r3 = CTX(KR1),r33;              \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     ar.k0=r16;                      \
-       mov     ar.k1=r17;                      \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     ar.k2=r16;                      \
-       mov     ar.k3=r17;                      \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     ar.k4=r16;                      \
-       mov     ar.k5=r17;                      \
-       ;;                                      \
-       ld8     r16=[r2],16;                    \
-       ld8     r17=[r3],16;                    \
-       ;;                                      \
-       mov     ar.k6=r16;                      \
-       mov     ar.k7=r17;                      \
-       ;;
-
-
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_APP_REGS                           \
-       add  r2 = CTX(BSPSTORE),r32;            \
-       mov  r16 = ar.bspstore;                 \
-       ;;                                      \
-       st8  [r2] = r16,CTX(RNAT)-CTX(BSPSTORE);\
-       mov  r16 = ar.rnat;                     \
-       ;;                                      \
-       st8  [r2] = r16,CTX(FCR)-CTX(RNAT);     \
-       mov  r16 = ar.fcr;                      \
-       ;;                                      \
-       st8  [r2] = r16,CTX(EFLAG)-CTX(FCR);    \
-       mov  r16 = ar.eflag;                    \
-       ;;                                      \
-       st8  [r2] = r16,CTX(CFLG)-CTX(EFLAG);   \
-       mov  r16 = ar.cflg;                     \
-       ;;                                      \
-       st8  [r2] = r16,CTX(FSR)-CTX(CFLG);     \
-       mov  r16 = ar.fsr;                      \
-       ;;                                      \
-       st8  [r2] = r16,CTX(FIR)-CTX(FSR);      \
-       mov  r16 = ar.fir;                      \
-       ;;                                      \
-       st8  [r2] = r16,CTX(FDR)-CTX(FIR);      \
-       mov  r16 = ar.fdr;                      \
-       ;;                                      \
-       st8  [r2] = r16,CTX(UNAT)-CTX(FDR);     \
-       mov  r16 = ar.unat;                     \
-       ;;                                      \
-       st8  [r2] = r16,CTX(FPSR)-CTX(UNAT);    \
-       mov  r16 = ar.fpsr;                     \
-       ;;                                      \
-       st8  [r2] = r16,CTX(PFS)-CTX(FPSR);     \
-       mov  r16 = ar.pfs;                      \
-       ;;                                      \
-       st8  [r2] = r16,CTX(LC)-CTX(PFS);       \
-       mov  r16 = ar.lc;                       \
-       ;;                                      \
-       st8  [r2] = r16;                        \
-       ;;
-
-       /*
-        *      r33:            context_t base address
-        */
-#define        RESTORE_APP_REGS                        \
-       add  r2=CTX(BSPSTORE),r33;              \
-       ;;                                      \
-       ld8  r16=[r2],CTX(RNAT)-CTX(BSPSTORE);  \
-       ;;                                      \
-       mov  ar.bspstore=r16;                   \
-       ld8  r16=[r2],CTX(FCR)-CTX(RNAT);       \
-       ;;                                      \
-       mov  ar.rnat=r16;                       \
-       ld8  r16=[r2],CTX(EFLAG)-CTX(FCR);      \
-       ;;                                      \
-       mov  ar.fcr=r16;                        \
-       ld8  r16=[r2],CTX(CFLG)-CTX(EFLAG);     \
-       ;;                                      \
-       mov  ar.eflag=r16;                      \
-       ld8  r16=[r2],CTX(FSR)-CTX(CFLG);       \
-       ;;                                      \
-       mov  ar.cflg=r16;                       \
-       ld8  r16=[r2],CTX(FIR)-CTX(FSR);        \
-       ;;                                      \
-       mov  ar.fsr=r16;                        \
-       ld8  r16=[r2],CTX(FDR)-CTX(FIR);        \
-       ;;                                      \
-       mov  ar.fir=r16;                        \
-       ld8  r16=[r2],CTX(UNAT)-CTX(FDR);       \
-       ;;                                      \
-       mov  ar.fdr=r16;                        \
-       ld8  r16=[r2],CTX(FPSR)-CTX(UNAT);      \
-       ;;                                      \
-       mov  ar.unat=r16;                       \
-       ld8  r16=[r2],CTX(PFS)-CTX(FPSR);       \
-       ;;                                      \
-       mov  ar.fpsr=r16;                       \
-       ld8  r16=[r2],CTX(LC)-CTX(PFS);         \
-       ;;                                      \
-       mov  ar.pfs=r16;                        \
-       ld8  r16=[r2];                          \
-       ;;                                      \
-       mov  ar.lc=r16;                         \
-       ;;
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_CTL_REGS                           \
-       add     r2 = CTX(DCR),r32;              \
-       mov     r16 = cr.dcr;                   \
-       ;;                                      \
-       st8     [r2] = r16,CTX(IVA)-CTX(DCR);   \
-       ;;                                      \
-       mov     r16 = cr.iva;                   \
-       ;;                                      \
-       st8     [r2] = r16,CTX(PTA)-CTX(IVA);   \
-       ;;                                      \
-       mov r16 = cr.pta;                       \
-       ;;                                      \
-       st8 [r2] = r16 ;                        \
-       ;;
-
-       /*
-        *      r33:            context_t base address
-        */
-#define        RESTORE_CTL_REGS                                \
-       add     r2 = CTX(DCR),r33;                      \
-       ;;                                              \
-       ld8     r16 = [r2],CTX(IVA)-CTX(DCR);           \
-       ;;                                              \
-       mov     cr.dcr = r16;                           \
-       dv_serialize_data;                              \
-       ;;                                              \
-       ld8     r16 = [r2],CTX(PTA)-CTX(IVA);           \
-       ;;                                              \
-       mov     cr.iva = r16;                           \
-       dv_serialize_data;                              \
-       ;;                                              \
-       ld8 r16 = [r2];                                 \
-       ;;                                              \
-       mov cr.pta = r16;                               \
-       dv_serialize_data;                              \
-       ;;
-
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_REGION_REGS                        \
-       add     r2=CTX(RR0),r32;                \
-       mov     r16=rr[r0];                     \
-       dep.z   r18=1,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       mov     r17=rr[r18];                    \
-       dep.z   r18=2,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r17,8;                     \
-       mov     r16=rr[r18];                    \
-       dep.z   r18=3,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       mov     r17=rr[r18];                    \
-       dep.z   r18=4,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r17,8;                     \
-       mov     r16=rr[r18];                    \
-       dep.z   r18=5,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       mov     r17=rr[r18];                    \
-       dep.z   r18=7,61,3;                     \
-       ;;                                      \
-       st8     [r2]=r17,16;                    \
-       mov     r16=rr[r18];                    \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       ;;
-
-       /*
-        *      r33:context_t base address
-        */
-#define        RESTORE_REGION_REGS     \
-       add     r2=CTX(RR0),r33;\
-       mov r18=r0;             \
-       ;;                      \
-       ld8     r20=[r2],8;     \
-       ;;      /* rr0 */       \
-       ld8     r21=[r2],8;     \
-       ;;      /* rr1 */       \
-       ld8     r22=[r2],8;     \
-       ;;      /* rr2 */       \
-       ld8     r23=[r2],8;     \
-       ;;      /* rr3 */       \
-       ld8     r24=[r2],8;     \
-       ;;      /* rr4 */       \
-       ld8     r25=[r2],16;    \
-       ;;      /* rr5 */       \
-       ld8     r27=[r2];       \
-       ;;      /* rr7 */       \
-       mov rr[r18]=r20;        \
-       dep.z   r18=1,61,3;     \
-       ;;  /* rr1 */           \
-       mov rr[r18]=r21;        \
-       dep.z   r18=2,61,3;     \
-       ;;  /* rr2 */           \
-       mov rr[r18]=r22;        \
-       dep.z   r18=3,61,3;     \
-       ;;  /* rr3 */           \
-       mov rr[r18]=r23;        \
-       dep.z   r18=4,61,3;     \
-       ;;  /* rr4 */           \
-       mov rr[r18]=r24;        \
-       dep.z   r18=5,61,3;     \
-       ;;  /* rr5 */           \
-       mov rr[r18]=r25;        \
-       dep.z   r18=7,61,3;     \
-       ;;  /* rr7 */           \
-       mov rr[r18]=r27;        \
-       ;;                      \
-       srlz.i;                 \
-       ;;
-
-
-
-       /*
-        *      r32:    context_t base address
-        *      r36~r39:scratch registers
-        */
-#define        SAVE_DEBUG_REGS                         \
-       add     r2=CTX(IBR0),r32;               \
-       add     r3=CTX(DBR0),r32;               \
-       mov     r16=ibr[r0];                    \
-       mov     r17=dbr[r0];                    \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=1,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=2,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=2,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=3,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=4,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=5,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=6,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       add     r18=7,r0;                       \
-       ;;                                      \
-       mov     r16=ibr[r18];                   \
-       mov     r17=dbr[r18];                   \
-       ;;                                      \
-       st8     [r2]=r16,8;                     \
-       st8     [r3]=r17,8;                     \
-       ;;
-
-
-/*
- *      r33:    point to context_t structure
- *      ar.lc are corrupted.
- */
-#define RESTORE_DEBUG_REGS                     \
-       add     r2=CTX(IBR0),r33;               \
-       add     r3=CTX(DBR0),r33;               \
-       mov r16=7;                              \
-       mov r17=r0;                             \
-       ;;                                      \
-       mov ar.lc = r16;                        \
-       ;;                                      \
-1:                                             \
-       ld8 r18=[r2],8;                         \
-       ld8 r19=[r3],8;                         \
-       ;;                                      \
-       mov ibr[r17]=r18;                       \
-       mov dbr[r17]=r19;                       \
-       ;;                                      \
-       srlz.i;                                 \
-       ;;                                      \
-       add r17=1,r17;                          \
-       br.cloop.sptk 1b;                       \
-       ;;
-
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_FPU_LOW                            \
-       add     r2=CTX(F2),r32;                 \
-       add     r3=CTX(F3),r32;                 \
-       ;;                                      \
-       stf.spill.nta   [r2]=f2,32;             \
-       stf.spill.nta   [r3]=f3,32;             \
-       ;;                                      \
-       stf.spill.nta   [r2]=f4,32;             \
-       stf.spill.nta   [r3]=f5,32;             \
-       ;;                                      \
-       stf.spill.nta   [r2]=f6,32;             \
-       stf.spill.nta   [r3]=f7,32;             \
-       ;;                                      \
-       stf.spill.nta   [r2]=f8,32;             \
-       stf.spill.nta   [r3]=f9,32;             \
-       ;;                                      \
-       stf.spill.nta   [r2]=f10,32;            \
-       stf.spill.nta   [r3]=f11,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f12,32;            \
-       stf.spill.nta   [r3]=f13,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f14,32;            \
-       stf.spill.nta   [r3]=f15,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f16,32;            \
-       stf.spill.nta   [r3]=f17,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f18,32;            \
-       stf.spill.nta   [r3]=f19,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f20,32;            \
-       stf.spill.nta   [r3]=f21,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f22,32;            \
-       stf.spill.nta   [r3]=f23,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f24,32;            \
-       stf.spill.nta   [r3]=f25,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f26,32;            \
-       stf.spill.nta   [r3]=f27,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f28,32;            \
-       stf.spill.nta   [r3]=f29,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f30;               \
-       stf.spill.nta   [r3]=f31;               \
-       ;;
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_FPU_HIGH                           \
-       add     r2=CTX(F32),r32;                \
-       add     r3=CTX(F33),r32;                \
-       ;;                                      \
-       stf.spill.nta   [r2]=f32,32;            \
-       stf.spill.nta   [r3]=f33,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f34,32;            \
-       stf.spill.nta   [r3]=f35,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f36,32;            \
-       stf.spill.nta   [r3]=f37,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f38,32;            \
-       stf.spill.nta   [r3]=f39,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f40,32;            \
-       stf.spill.nta   [r3]=f41,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f42,32;            \
-       stf.spill.nta   [r3]=f43,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f44,32;            \
-       stf.spill.nta   [r3]=f45,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f46,32;            \
-       stf.spill.nta   [r3]=f47,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f48,32;            \
-       stf.spill.nta   [r3]=f49,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f50,32;            \
-       stf.spill.nta   [r3]=f51,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f52,32;            \
-       stf.spill.nta   [r3]=f53,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f54,32;            \
-       stf.spill.nta   [r3]=f55,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f56,32;            \
-       stf.spill.nta   [r3]=f57,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f58,32;            \
-       stf.spill.nta   [r3]=f59,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f60,32;            \
-       stf.spill.nta   [r3]=f61,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f62,32;            \
-       stf.spill.nta   [r3]=f63,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f64,32;            \
-       stf.spill.nta   [r3]=f65,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f66,32;            \
-       stf.spill.nta   [r3]=f67,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f68,32;            \
-       stf.spill.nta   [r3]=f69,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f70,32;            \
-       stf.spill.nta   [r3]=f71,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f72,32;            \
-       stf.spill.nta   [r3]=f73,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f74,32;            \
-       stf.spill.nta   [r3]=f75,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f76,32;            \
-       stf.spill.nta   [r3]=f77,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f78,32;            \
-       stf.spill.nta   [r3]=f79,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f80,32;            \
-       stf.spill.nta   [r3]=f81,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f82,32;            \
-       stf.spill.nta   [r3]=f83,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f84,32;            \
-       stf.spill.nta   [r3]=f85,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f86,32;            \
-       stf.spill.nta   [r3]=f87,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f88,32;            \
-       stf.spill.nta   [r3]=f89,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f90,32;            \
-       stf.spill.nta   [r3]=f91,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f92,32;            \
-       stf.spill.nta   [r3]=f93,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f94,32;            \
-       stf.spill.nta   [r3]=f95,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f96,32;            \
-       stf.spill.nta   [r3]=f97,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f98,32;            \
-       stf.spill.nta   [r3]=f99,32;            \
-       ;;                                      \
-       stf.spill.nta   [r2]=f100,32;           \
-       stf.spill.nta   [r3]=f101,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f102,32;           \
-       stf.spill.nta   [r3]=f103,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f104,32;           \
-       stf.spill.nta   [r3]=f105,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f106,32;           \
-       stf.spill.nta   [r3]=f107,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f108,32;           \
-       stf.spill.nta   [r3]=f109,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f110,32;           \
-       stf.spill.nta   [r3]=f111,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f112,32;           \
-       stf.spill.nta   [r3]=f113,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f114,32;           \
-       stf.spill.nta   [r3]=f115,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f116,32;           \
-       stf.spill.nta   [r3]=f117,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f118,32;           \
-       stf.spill.nta   [r3]=f119,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f120,32;           \
-       stf.spill.nta   [r3]=f121,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f122,32;           \
-       stf.spill.nta   [r3]=f123,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f124,32;           \
-       stf.spill.nta   [r3]=f125,32;           \
-       ;;                                      \
-       stf.spill.nta   [r2]=f126;              \
-       stf.spill.nta   [r3]=f127;              \
-       ;;
-
-     /*
-      *      r33:    point to context_t structure
-      */
-#define        RESTORE_FPU_LOW                         \
-    add     r2 = CTX(F2), r33;                 \
-    add     r3 = CTX(F3), r33;                 \
-    ;;                                         \
-    ldf.fill.nta f2 = [r2], 32;                        \
-    ldf.fill.nta f3 = [r3], 32;                        \
-    ;;                                         \
-    ldf.fill.nta f4 = [r2], 32;                        \
-    ldf.fill.nta f5 = [r3], 32;                        \
-    ;;                                         \
-    ldf.fill.nta f6 = [r2], 32;                        \
-    ldf.fill.nta f7 = [r3], 32;                        \
-    ;;                                         \
-    ldf.fill.nta f8 = [r2], 32;                        \
-    ldf.fill.nta f9 = [r3], 32;                        \
-    ;;                                         \
-    ldf.fill.nta f10 = [r2], 32;               \
-    ldf.fill.nta f11 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f12 = [r2], 32;               \
-    ldf.fill.nta f13 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f14 = [r2], 32;               \
-    ldf.fill.nta f15 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f16 = [r2], 32;               \
-    ldf.fill.nta f17 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f18 = [r2], 32;               \
-    ldf.fill.nta f19 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f20 = [r2], 32;               \
-    ldf.fill.nta f21 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f22 = [r2], 32;               \
-    ldf.fill.nta f23 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f24 = [r2], 32;               \
-    ldf.fill.nta f25 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f26 = [r2], 32;               \
-    ldf.fill.nta f27 = [r3], 32;               \
-       ;;                                      \
-    ldf.fill.nta f28 = [r2], 32;               \
-    ldf.fill.nta f29 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f30 = [r2], 32;               \
-    ldf.fill.nta f31 = [r3], 32;               \
-    ;;
-
-
-
-    /*
-     *      r33:    point to context_t structure
-     */
-#define        RESTORE_FPU_HIGH                        \
-    add     r2 = CTX(F32), r33;                        \
-    add     r3 = CTX(F33), r33;                        \
-    ;;                                         \
-    ldf.fill.nta f32 = [r2], 32;               \
-    ldf.fill.nta f33 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f34 = [r2], 32;               \
-    ldf.fill.nta f35 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f36 = [r2], 32;               \
-    ldf.fill.nta f37 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f38 = [r2], 32;               \
-    ldf.fill.nta f39 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f40 = [r2], 32;               \
-    ldf.fill.nta f41 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f42 = [r2], 32;               \
-    ldf.fill.nta f43 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f44 = [r2], 32;               \
-    ldf.fill.nta f45 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f46 = [r2], 32;               \
-    ldf.fill.nta f47 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f48 = [r2], 32;               \
-    ldf.fill.nta f49 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f50 = [r2], 32;               \
-    ldf.fill.nta f51 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f52 = [r2], 32;               \
-    ldf.fill.nta f53 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f54 = [r2], 32;               \
-    ldf.fill.nta f55 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f56 = [r2], 32;               \
-    ldf.fill.nta f57 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f58 = [r2], 32;               \
-    ldf.fill.nta f59 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f60 = [r2], 32;               \
-    ldf.fill.nta f61 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f62 = [r2], 32;               \
-    ldf.fill.nta f63 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f64 = [r2], 32;               \
-    ldf.fill.nta f65 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f66 = [r2], 32;               \
-    ldf.fill.nta f67 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f68 = [r2], 32;               \
-    ldf.fill.nta f69 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f70 = [r2], 32;               \
-    ldf.fill.nta f71 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f72 = [r2], 32;               \
-    ldf.fill.nta f73 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f74 = [r2], 32;               \
-    ldf.fill.nta f75 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f76 = [r2], 32;               \
-    ldf.fill.nta f77 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f78 = [r2], 32;               \
-    ldf.fill.nta f79 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f80 = [r2], 32;               \
-    ldf.fill.nta f81 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f82 = [r2], 32;               \
-    ldf.fill.nta f83 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f84 = [r2], 32;               \
-    ldf.fill.nta f85 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f86 = [r2], 32;               \
-    ldf.fill.nta f87 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f88 = [r2], 32;               \
-    ldf.fill.nta f89 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f90 = [r2], 32;               \
-    ldf.fill.nta f91 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f92 = [r2], 32;               \
-    ldf.fill.nta f93 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f94 = [r2], 32;               \
-    ldf.fill.nta f95 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f96 = [r2], 32;               \
-    ldf.fill.nta f97 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f98 = [r2], 32;               \
-    ldf.fill.nta f99 = [r3], 32;               \
-    ;;                                         \
-    ldf.fill.nta f100 = [r2], 32;              \
-    ldf.fill.nta f101 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f102 = [r2], 32;              \
-    ldf.fill.nta f103 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f104 = [r2], 32;              \
-    ldf.fill.nta f105 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f106 = [r2], 32;              \
-    ldf.fill.nta f107 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f108 = [r2], 32;              \
-    ldf.fill.nta f109 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f110 = [r2], 32;              \
-    ldf.fill.nta f111 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f112 = [r2], 32;              \
-    ldf.fill.nta f113 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f114 = [r2], 32;              \
-    ldf.fill.nta f115 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f116 = [r2], 32;              \
-    ldf.fill.nta f117 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f118 = [r2], 32;              \
-    ldf.fill.nta f119 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f120 = [r2], 32;              \
-    ldf.fill.nta f121 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f122 = [r2], 32;              \
-    ldf.fill.nta f123 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f124 = [r2], 32;              \
-    ldf.fill.nta f125 = [r3], 32;              \
-    ;;                                         \
-    ldf.fill.nta f126 = [r2], 32;              \
-    ldf.fill.nta f127 = [r3], 32;              \
-    ;;
-
-       /*
-        *      r32:            context_t base address
-        */
-#define        SAVE_PTK_REGS                           \
-    add r2=CTX(PKR0), r32;                     \
-    mov r16=7;                                 \
-    ;;                                                 \
-    mov ar.lc=r16;                             \
-    mov r17=r0;                                        \
-    ;;                                         \
-1:                                             \
-    mov r18=pkr[r17];                          \
-    ;;                                         \
-    srlz.i;                                    \
-    ;;                                                 \
-    st8 [r2]=r18, 8;                           \
-    ;;                                         \
-    add r17 =1,r17;                            \
-    ;;                                         \
-    br.cloop.sptk 1b;                          \
-    ;;
-
-/*
- *      r33:    point to context_t structure
- *      ar.lc are corrupted.
- */
-#define RESTORE_PTK_REGS                       \
-    add r2=CTX(PKR0), r33;                     \
-    mov r16=7;                                 \
-    ;;                                                 \
-    mov ar.lc=r16;                             \
-    mov r17=r0;                                        \
-    ;;                                         \
-1:                                             \
-    ld8 r18=[r2], 8;                           \
-    ;;                                         \
-    mov pkr[r17]=r18;                          \
-    ;;                                         \
-    srlz.i;                                    \
-    ;;                                                 \
-    add r17 =1,r17;                            \
-    ;;                                         \
-    br.cloop.sptk 1b;                          \
-    ;;
-
-
-/*
- * void vmm_trampoline( context_t * from,
- *                     context_t * to)
- *
- *     from:   r32
- *     to:     r33
- *  note: interrupt disabled before call this function.
- */
-GLOBAL_ENTRY(vmm_trampoline)
-    mov r16 = psr
-    adds r2 = CTX(PSR), r32
-    ;;
-    st8 [r2] = r16, 8       // psr
-    mov r17 = pr
-    ;;
-    st8 [r2] = r17, 8       // pr
-    mov r18 = ar.unat
-    ;;
-    st8 [r2] = r18
-    mov r17 = ar.rsc
-    ;;
-    adds r2 = CTX(RSC),r32
-    ;;
-    st8 [r2]= r17
-    mov ar.rsc =0
-    flushrs
-    ;;
-    SAVE_GENERAL_REGS
-    ;;
-    SAVE_KERNEL_REGS
-    ;;
-    SAVE_APP_REGS
-    ;;
-    SAVE_BRANCH_REGS
-    ;;
-    SAVE_CTL_REGS
-    ;;
-    SAVE_REGION_REGS
-    ;;
-    //SAVE_DEBUG_REGS
-    ;;
-    rsm  psr.dfl
-    ;;
-    srlz.d
-    ;;
-    SAVE_FPU_LOW
-    ;;
-    rsm  psr.dfh
-    ;;
-    srlz.d
-    ;;
-    SAVE_FPU_HIGH
-    ;;
-    SAVE_PTK_REGS
-    ;;
-    RESTORE_PTK_REGS
-    ;;
-    RESTORE_FPU_HIGH
-    ;;
-    RESTORE_FPU_LOW
-    ;;
-    //RESTORE_DEBUG_REGS
-    ;;
-    RESTORE_REGION_REGS
-    ;;
-    RESTORE_CTL_REGS
-    ;;
-    RESTORE_BRANCH_REGS
-    ;;
-    RESTORE_APP_REGS
-    ;;
-    RESTORE_KERNEL_REGS
-    ;;
-    RESTORE_GENERAL_REGS
-    ;;
-    adds r2=CTX(PSR), r33
-    ;;
-    ld8 r16=[r2], 8       // psr
-    ;;
-    mov psr.l=r16
-    ;;
-    srlz.d
-    ;;
-    ld8 r16=[r2], 8       // pr
-    ;;
-    mov pr =r16,-1
-    ld8 r16=[r2]       // unat
-    ;;
-    mov ar.unat=r16
-    ;;
-    adds r2=CTX(RSC),r33
-    ;;
-    ld8 r16 =[r2]
-    ;;
-    mov ar.rsc = r16
-    ;;
-    br.ret.sptk.few b0
-END(vmm_trampoline)
diff --git a/arch/ia64/kvm/vcpu.c b/arch/ia64/kvm/vcpu.c
deleted file mode 100644 (file)
index 958815c..0000000
+++ /dev/null
@@ -1,2209 +0,0 @@
-/*
- * kvm_vcpu.c: handling all virtual cpu related thing.
- * Copyright (c) 2005, Intel Corporation.
- *
- * 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.
- *
- *  Shaofan Li (Susue Li) <susie.li@intel.com>
- *  Yaozu Dong (Eddie Dong) (Eddie.dong@intel.com)
- *  Xuefei Xu (Anthony Xu) (Anthony.xu@intel.com)
- *  Xiantao Zhang <xiantao.zhang@intel.com>
- */
-
-#include <linux/kvm_host.h>
-#include <linux/types.h>
-
-#include <asm/processor.h>
-#include <asm/ia64regs.h>
-#include <asm/gcc_intrin.h>
-#include <asm/kregs.h>
-#include <asm/pgtable.h>
-#include <asm/tlb.h>
-
-#include "asm-offsets.h"
-#include "vcpu.h"
-
-/*
- * Special notes:
- * - Index by it/dt/rt sequence
- * - Only existing mode transitions are allowed in this table
- * - RSE is placed at lazy mode when emulating guest partial mode
- * - If gva happens to be rr0 and rr4, only allowed case is identity
- *   mapping (gva=gpa), or panic! (How?)
- */
-int mm_switch_table[8][8] = {
-       /*  2004/09/12(Kevin): Allow switch to self */
-       /*
-        *  (it,dt,rt): (0,0,0) -> (1,1,1)
-        *  This kind of transition usually occurs in the very early
-        *  stage of Linux boot up procedure. Another case is in efi
-        *  and pal calls. (see "arch/ia64/kernel/head.S")
-        *
-        *  (it,dt,rt): (0,0,0) -> (0,1,1)
-        *  This kind of transition is found when OSYa exits efi boot
-        *  service. Due to gva = gpa in this case (Same region),
-        *  data access can be satisfied though itlb entry for physical
-        *  emulation is hit.
-        */
-       {SW_SELF, 0,  0,  SW_NOP, 0,  0,  0,  SW_P2V},
-       {0,  0,  0,  0,  0,  0,  0,  0},
-       {0,  0,  0,  0,  0,  0,  0,  0},
-       /*
-        *  (it,dt,rt): (0,1,1) -> (1,1,1)
-        *  This kind of transition is found in OSYa.
-        *
-        *  (it,dt,rt): (0,1,1) -> (0,0,0)
-        *  This kind of transition is found in OSYa
-        */
-       {SW_NOP, 0,  0,  SW_SELF, 0,  0,  0,  SW_P2V},
-       /* (1,0,0)->(1,1,1) */
-       {0,  0,  0,  0,  0,  0,  0,  SW_P2V},
-       /*
-        *  (it,dt,rt): (1,0,1) -> (1,1,1)
-        *  This kind of transition usually occurs when Linux returns
-        *  from the low level TLB miss handlers.
-        *  (see "arch/ia64/kernel/ivt.S")
-        */
-       {0,  0,  0,  0,  0,  SW_SELF, 0,  SW_P2V},
-       {0,  0,  0,  0,  0,  0,  0,  0},
-       /*
-        *  (it,dt,rt): (1,1,1) -> (1,0,1)
-        *  This kind of transition usually occurs in Linux low level
-        *  TLB miss handler. (see "arch/ia64/kernel/ivt.S")
-        *
-        *  (it,dt,rt): (1,1,1) -> (0,0,0)
-        *  This kind of transition usually occurs in pal and efi calls,
-        *  which requires running in physical mode.
-        *  (see "arch/ia64/kernel/head.S")
-        *  (1,1,1)->(1,0,0)
-        */
-
-       {SW_V2P, 0,  0,  0,  SW_V2P, SW_V2P, 0,  SW_SELF},
-};
-
-void physical_mode_init(struct kvm_vcpu  *vcpu)
-{
-       vcpu->arch.mode_flags = GUEST_IN_PHY;
-}
-
-void switch_to_physical_rid(struct kvm_vcpu *vcpu)
-{
-       unsigned long psr;
-
-       /* Save original virtual mode rr[0] and rr[4] */
-       psr = ia64_clear_ic();
-       ia64_set_rr(VRN0<<VRN_SHIFT, vcpu->arch.metaphysical_rr0);
-       ia64_srlz_d();
-       ia64_set_rr(VRN4<<VRN_SHIFT, vcpu->arch.metaphysical_rr4);
-       ia64_srlz_d();
-
-       ia64_set_psr(psr);
-       return;
-}
-
-void switch_to_virtual_rid(struct kvm_vcpu *vcpu)
-{
-       unsigned long psr;
-
-       psr = ia64_clear_ic();
-       ia64_set_rr(VRN0 << VRN_SHIFT, vcpu->arch.metaphysical_saved_rr0);
-       ia64_srlz_d();
-       ia64_set_rr(VRN4 << VRN_SHIFT, vcpu->arch.metaphysical_saved_rr4);
-       ia64_srlz_d();
-       ia64_set_psr(psr);
-       return;
-}
-
-static int mm_switch_action(struct ia64_psr opsr, struct ia64_psr npsr)
-{
-       return mm_switch_table[MODE_IND(opsr)][MODE_IND(npsr)];
-}
-
-void switch_mm_mode(struct kvm_vcpu *vcpu, struct ia64_psr old_psr,
-                                       struct ia64_psr new_psr)
-{
-       int act;
-       act = mm_switch_action(old_psr, new_psr);
-       switch (act) {
-       case SW_V2P:
-               /*printk("V -> P mode transition: (0x%lx -> 0x%lx)\n",
-               old_psr.val, new_psr.val);*/
-               switch_to_physical_rid(vcpu);
-               /*
-                * Set rse to enforced lazy, to prevent active rse
-                *save/restor when guest physical mode.
-                */
-               vcpu->arch.mode_flags |= GUEST_IN_PHY;
-               break;
-       case SW_P2V:
-               switch_to_virtual_rid(vcpu);
-               /*
-                * recover old mode which is saved when entering
-                * guest physical mode
-                */
-               vcpu->arch.mode_flags &= ~GUEST_IN_PHY;
-               break;
-       case SW_SELF:
-               break;
-       case SW_NOP:
-               break;
-       default:
-               /* Sanity check */
-               break;
-       }
-       return;
-}
-
-/*
- * In physical mode, insert tc/tr for region 0 and 4 uses
- * RID[0] and RID[4] which is for physical mode emulation.
- * However what those inserted tc/tr wants is rid for
- * virtual mode. So original virtual rid needs to be restored
- * before insert.
- *
- * Operations which required such switch include:
- *  - insertions (itc.*, itr.*)
- *  - purges (ptc.* and ptr.*)
- *  - tpa
- *  - tak
- *  - thash?, ttag?
- * All above needs actual virtual rid for destination entry.
- */
-
-void check_mm_mode_switch(struct kvm_vcpu *vcpu,  struct ia64_psr old_psr,
-                                       struct ia64_psr new_psr)
-{
-
-       if ((old_psr.dt != new_psr.dt)
-                       || (old_psr.it != new_psr.it)
-                       || (old_psr.rt != new_psr.rt))
-               switch_mm_mode(vcpu, old_psr, new_psr);
-
-       return;
-}
-
-
-/*
- * In physical mode, insert tc/tr for region 0 and 4 uses
- * RID[0] and RID[4] which is for physical mode emulation.
- * However what those inserted tc/tr wants is rid for
- * virtual mode. So original virtual rid needs to be restored
- * before insert.
- *
- * Operations which required such switch include:
- *  - insertions (itc.*, itr.*)
- *  - purges (ptc.* and ptr.*)
- *  - tpa
- *  - tak
- *  - thash?, ttag?
- * All above needs actual virtual rid for destination entry.
- */
-
-void prepare_if_physical_mode(struct kvm_vcpu *vcpu)
-{
-       if (is_physical_mode(vcpu)) {
-               vcpu->arch.mode_flags |= GUEST_PHY_EMUL;
-               switch_to_virtual_rid(vcpu);
-       }
-       return;
-}
-
-/* Recover always follows prepare */
-void recover_if_physical_mode(struct kvm_vcpu *vcpu)
-{
-       if (is_physical_mode(vcpu))
-               switch_to_physical_rid(vcpu);
-       vcpu->arch.mode_flags &= ~GUEST_PHY_EMUL;
-       return;
-}
-
-#define RPT(x) ((u16) &((struct kvm_pt_regs *)0)->x)
-
-static u16 gr_info[32] = {
-       0,      /* r0 is read-only : WE SHOULD NEVER GET THIS */
-       RPT(r1), RPT(r2), RPT(r3),
-       RPT(r4), RPT(r5), RPT(r6), RPT(r7),
-       RPT(r8), RPT(r9), RPT(r10), RPT(r11),
-       RPT(r12), RPT(r13), RPT(r14), RPT(r15),
-       RPT(r16), RPT(r17), RPT(r18), RPT(r19),
-       RPT(r20), RPT(r21), RPT(r22), RPT(r23),
-       RPT(r24), RPT(r25), RPT(r26), RPT(r27),
-       RPT(r28), RPT(r29), RPT(r30), RPT(r31)
-};
-
-#define IA64_FIRST_STACKED_GR   32
-#define IA64_FIRST_ROTATING_FR  32
-
-static inline unsigned long
-rotate_reg(unsigned long sor, unsigned long rrb, unsigned long reg)
-{
-       reg += rrb;
-       if (reg >= sor)
-               reg -= sor;
-       return reg;
-}
-
-/*
- * Return the (rotated) index for floating point register
- * be in the REGNUM (REGNUM must range from 32-127,
- * result is in the range from 0-95.
- */
-static inline unsigned long fph_index(struct kvm_pt_regs *regs,
-                                               long regnum)
-{
-       unsigned long rrb_fr = (regs->cr_ifs >> 25) & 0x7f;
-       return rotate_reg(96, rrb_fr, (regnum - IA64_FIRST_ROTATING_FR));
-}
-
-/*
- * The inverse of the above: given bspstore and the number of
- * registers, calculate ar.bsp.
- */
-static inline unsigned long *kvm_rse_skip_regs(unsigned long *addr,
-                                                       long num_regs)
-{
-       long delta = ia64_rse_slot_num(addr) + num_regs;
-       int i = 0;
-
-       if (num_regs < 0)
-               delta -= 0x3e;
-       if (delta < 0) {
-               while (delta <= -0x3f) {
-                       i--;
-                       delta += 0x3f;
-               }
-       } else {
-               while (delta >= 0x3f) {
-                       i++;
-                       delta -= 0x3f;
-               }
-       }
-
-       return addr + num_regs + i;
-}
-
-static void get_rse_reg(struct kvm_pt_regs *regs, unsigned long r1,
-                                       unsigned long *val, int *nat)
-{
-       unsigned long *bsp, *addr, *rnat_addr, *bspstore;
-       unsigned long *kbs = (void *) current_vcpu + VMM_RBS_OFFSET;
-       unsigned long nat_mask;
-       unsigned long old_rsc, new_rsc;
-       long sof = (regs->cr_ifs) & 0x7f;
-       long sor = (((regs->cr_ifs >> 14) & 0xf) << 3);
-       long rrb_gr = (regs->cr_ifs >> 18) & 0x7f;
-       long ridx = r1 - 32;
-
-       if (ridx < sor)
-               ridx = rotate_reg(sor, rrb_gr, ridx);
-
-       old_rsc = ia64_getreg(_IA64_REG_AR_RSC);
-       new_rsc = old_rsc&(~(0x3));
-       ia64_setreg(_IA64_REG_AR_RSC, new_rsc);
-
-       bspstore = (unsigned long *)ia64_getreg(_IA64_REG_AR_BSPSTORE);
-       bsp = kbs + (regs->loadrs >> 19);
-
-       addr = kvm_rse_skip_regs(bsp, -sof + ridx);
-       nat_mask = 1UL << ia64_rse_slot_num(addr);
-       rnat_addr = ia64_rse_rnat_addr(addr);
-
-       if (addr >= bspstore) {
-               ia64_flushrs();
-               ia64_mf();
-               bspstore = (unsigned long *)ia64_getreg(_IA64_REG_AR_BSPSTORE);
-       }
-       *val = *addr;
-       if (nat) {
-               if (bspstore < rnat_addr)
-                       *nat = (int)!!(ia64_getreg(_IA64_REG_AR_RNAT)
-                                                       & nat_mask);
-               else
-                       *nat = (int)!!((*rnat_addr) & nat_mask);
-               ia64_setreg(_IA64_REG_AR_RSC, old_rsc);
-       }
-}
-
-void set_rse_reg(struct kvm_pt_regs *regs, unsigned long r1,
-                               unsigned long val, unsigned long nat)
-{
-       unsigned long *bsp, *bspstore, *addr, *rnat_addr;
-       unsigned long *kbs = (void *) current_vcpu + VMM_RBS_OFFSET;
-       unsigned long nat_mask;
-       unsigned long old_rsc, new_rsc, psr;
-       unsigned long rnat;
-       long sof = (regs->cr_ifs) & 0x7f;
-       long sor = (((regs->cr_ifs >> 14) & 0xf) << 3);
-       long rrb_gr = (regs->cr_ifs >> 18) & 0x7f;
-       long ridx = r1 - 32;
-
-       if (ridx < sor)
-               ridx = rotate_reg(sor, rrb_gr, ridx);
-
-       old_rsc = ia64_getreg(_IA64_REG_AR_RSC);
-       /* put RSC to lazy mode, and set loadrs 0 */
-       new_rsc = old_rsc & (~0x3fff0003);
-       ia64_setreg(_IA64_REG_AR_RSC, new_rsc);
-       bsp = kbs + (regs->loadrs >> 19); /* 16 + 3 */
-
-       addr = kvm_rse_skip_regs(bsp, -sof + ridx);
-       nat_mask = 1UL << ia64_rse_slot_num(addr);
-       rnat_addr = ia64_rse_rnat_addr(addr);
-
-       local_irq_save(psr);
-       bspstore = (unsigned long *)ia64_getreg(_IA64_REG_AR_BSPSTORE);
-       if (addr >= bspstore) {
-
-               ia64_flushrs();
-               ia64_mf();
-               *addr = val;
-               bspstore = (unsigned long *)ia64_getreg(_IA64_REG_AR_BSPSTORE);
-               rnat = ia64_getreg(_IA64_REG_AR_RNAT);
-               if (bspstore < rnat_addr)
-                       rnat = rnat & (~nat_mask);
-               else
-                       *rnat_addr = (*rnat_addr)&(~nat_mask);
-
-               ia64_mf();
-               ia64_loadrs();
-               ia64_setreg(_IA64_REG_AR_RNAT, rnat);
-       } else {
-               rnat = ia64_getreg(_IA64_REG_AR_RNAT);
-               *addr = val;
-               if (bspstore < rnat_addr)
-                       rnat = rnat&(~nat_mask);
-               else
-                       *rnat_addr = (*rnat_addr) & (~nat_mask);
-
-               ia64_setreg(_IA64_REG_AR_BSPSTORE, (unsigned long)bspstore);
-               ia64_setreg(_IA64_REG_AR_RNAT, rnat);
-       }
-       local_irq_restore(psr);
-       ia64_setreg(_IA64_REG_AR_RSC, old_rsc);
-}
-
-void getreg(unsigned long regnum, unsigned long *val,
-                               int *nat, struct kvm_pt_regs *regs)
-{
-       unsigned long addr, *unat;
-       if (regnum >= IA64_FIRST_STACKED_GR) {
-               get_rse_reg(regs, regnum, val, nat);
-               return;
-       }
-
-       /*
-        * Now look at registers in [0-31] range and init correct UNAT
-        */
-       addr = (unsigned long)regs;
-       unat = &regs->eml_unat;
-
-       addr += gr_info[regnum];
-
-       *val  = *(unsigned long *)addr;
-       /*
-        * do it only when requested
-        */
-       if (nat)
-               *nat  = (*unat >> ((addr >> 3) & 0x3f)) & 0x1UL;
-}
-
-void setreg(unsigned long regnum, unsigned long val,
-                       int nat, struct kvm_pt_regs *regs)
-{
-       unsigned long addr;
-       unsigned long bitmask;
-       unsigned long *unat;
-
-       /*
-        * First takes care of stacked registers
-        */
-       if (regnum >= IA64_FIRST_STACKED_GR) {
-               set_rse_reg(regs, regnum, val, nat);
-               return;
-       }
-
-       /*
-        * Now look at registers in [0-31] range and init correct UNAT
-        */
-       addr = (unsigned long)regs;
-       unat = &regs->eml_unat;
-       /*
-        * add offset from base of struct
-        * and do it !
-        */
-       addr += gr_info[regnum];
-
-       *(unsigned long *)addr = val;
-
-       /*
-        * We need to clear the corresponding UNAT bit to fully emulate the load
-        * UNAT bit_pos = GR[r3]{8:3} form EAS-2.4
-        */
-       bitmask   = 1UL << ((addr >> 3) & 0x3f);
-       if (nat)
-               *unat |= bitmask;
-        else
-               *unat &= ~bitmask;
-
-}
-
-u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       unsigned long val;
-
-       if (!reg)
-               return 0;
-       getreg(reg, &val, 0, regs);
-       return val;
-}
-
-void vcpu_set_gr(struct kvm_vcpu *vcpu, unsigned long reg, u64 value, int nat)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       long sof = (regs->cr_ifs) & 0x7f;
-
-       if (!reg)
-               return;
-       if (reg >= sof + 32)
-               return;
-       setreg(reg, value, nat, regs);  /* FIXME: handle NATs later*/
-}
-
-void getfpreg(unsigned long regnum, struct ia64_fpreg *fpval,
-                               struct kvm_pt_regs *regs)
-{
-       /* Take floating register rotation into consideration*/
-       if (regnum >= IA64_FIRST_ROTATING_FR)
-               regnum = IA64_FIRST_ROTATING_FR + fph_index(regs, regnum);
-#define CASE_FIXED_FP(reg)                     \
-       case  (reg) :                           \
-               ia64_stf_spill(fpval, reg);     \
-       break
-
-       switch (regnum) {
-               CASE_FIXED_FP(0);
-               CASE_FIXED_FP(1);
-               CASE_FIXED_FP(2);
-               CASE_FIXED_FP(3);
-               CASE_FIXED_FP(4);
-               CASE_FIXED_FP(5);
-
-               CASE_FIXED_FP(6);
-               CASE_FIXED_FP(7);
-               CASE_FIXED_FP(8);
-               CASE_FIXED_FP(9);
-               CASE_FIXED_FP(10);
-               CASE_FIXED_FP(11);
-
-               CASE_FIXED_FP(12);
-               CASE_FIXED_FP(13);
-               CASE_FIXED_FP(14);
-               CASE_FIXED_FP(15);
-               CASE_FIXED_FP(16);
-               CASE_FIXED_FP(17);
-               CASE_FIXED_FP(18);
-               CASE_FIXED_FP(19);
-               CASE_FIXED_FP(20);
-               CASE_FIXED_FP(21);
-               CASE_FIXED_FP(22);
-               CASE_FIXED_FP(23);
-               CASE_FIXED_FP(24);
-               CASE_FIXED_FP(25);
-               CASE_FIXED_FP(26);
-               CASE_FIXED_FP(27);
-               CASE_FIXED_FP(28);
-               CASE_FIXED_FP(29);
-               CASE_FIXED_FP(30);
-               CASE_FIXED_FP(31);
-               CASE_FIXED_FP(32);
-               CASE_FIXED_FP(33);
-               CASE_FIXED_FP(34);
-               CASE_FIXED_FP(35);
-               CASE_FIXED_FP(36);
-               CASE_FIXED_FP(37);
-               CASE_FIXED_FP(38);
-               CASE_FIXED_FP(39);
-               CASE_FIXED_FP(40);
-               CASE_FIXED_FP(41);
-               CASE_FIXED_FP(42);
-               CASE_FIXED_FP(43);
-               CASE_FIXED_FP(44);
-               CASE_FIXED_FP(45);
-               CASE_FIXED_FP(46);
-               CASE_FIXED_FP(47);
-               CASE_FIXED_FP(48);
-               CASE_FIXED_FP(49);
-               CASE_FIXED_FP(50);
-               CASE_FIXED_FP(51);
-               CASE_FIXED_FP(52);
-               CASE_FIXED_FP(53);
-               CASE_FIXED_FP(54);
-               CASE_FIXED_FP(55);
-               CASE_FIXED_FP(56);
-               CASE_FIXED_FP(57);
-               CASE_FIXED_FP(58);
-               CASE_FIXED_FP(59);
-               CASE_FIXED_FP(60);
-               CASE_FIXED_FP(61);
-               CASE_FIXED_FP(62);
-               CASE_FIXED_FP(63);
-               CASE_FIXED_FP(64);
-               CASE_FIXED_FP(65);
-               CASE_FIXED_FP(66);
-               CASE_FIXED_FP(67);
-               CASE_FIXED_FP(68);
-               CASE_FIXED_FP(69);
-               CASE_FIXED_FP(70);
-               CASE_FIXED_FP(71);
-               CASE_FIXED_FP(72);
-               CASE_FIXED_FP(73);
-               CASE_FIXED_FP(74);
-               CASE_FIXED_FP(75);
-               CASE_FIXED_FP(76);
-               CASE_FIXED_FP(77);
-               CASE_FIXED_FP(78);
-               CASE_FIXED_FP(79);
-               CASE_FIXED_FP(80);
-               CASE_FIXED_FP(81);
-               CASE_FIXED_FP(82);
-               CASE_FIXED_FP(83);
-               CASE_FIXED_FP(84);
-               CASE_FIXED_FP(85);
-               CASE_FIXED_FP(86);
-               CASE_FIXED_FP(87);
-               CASE_FIXED_FP(88);
-               CASE_FIXED_FP(89);
-               CASE_FIXED_FP(90);
-               CASE_FIXED_FP(91);
-               CASE_FIXED_FP(92);
-               CASE_FIXED_FP(93);
-               CASE_FIXED_FP(94);
-               CASE_FIXED_FP(95);
-               CASE_FIXED_FP(96);
-               CASE_FIXED_FP(97);
-               CASE_FIXED_FP(98);
-               CASE_FIXED_FP(99);
-               CASE_FIXED_FP(100);
-               CASE_FIXED_FP(101);
-               CASE_FIXED_FP(102);
-               CASE_FIXED_FP(103);
-               CASE_FIXED_FP(104);
-               CASE_FIXED_FP(105);
-               CASE_FIXED_FP(106);
-               CASE_FIXED_FP(107);
-               CASE_FIXED_FP(108);
-               CASE_FIXED_FP(109);
-               CASE_FIXED_FP(110);
-               CASE_FIXED_FP(111);
-               CASE_FIXED_FP(112);
-               CASE_FIXED_FP(113);
-               CASE_FIXED_FP(114);
-               CASE_FIXED_FP(115);
-               CASE_FIXED_FP(116);
-               CASE_FIXED_FP(117);
-               CASE_FIXED_FP(118);
-               CASE_FIXED_FP(119);
-               CASE_FIXED_FP(120);
-               CASE_FIXED_FP(121);
-               CASE_FIXED_FP(122);
-               CASE_FIXED_FP(123);
-               CASE_FIXED_FP(124);
-               CASE_FIXED_FP(125);
-               CASE_FIXED_FP(126);
-               CASE_FIXED_FP(127);
-       }
-#undef CASE_FIXED_FP
-}
-
-void setfpreg(unsigned long regnum, struct ia64_fpreg *fpval,
-                                       struct kvm_pt_regs *regs)
-{
-       /* Take floating register rotation into consideration*/
-       if (regnum >= IA64_FIRST_ROTATING_FR)
-               regnum = IA64_FIRST_ROTATING_FR + fph_index(regs, regnum);
-
-#define CASE_FIXED_FP(reg)                     \
-       case (reg) :                            \
-               ia64_ldf_fill(reg, fpval);      \
-       break
-
-       switch (regnum) {
-               CASE_FIXED_FP(2);
-               CASE_FIXED_FP(3);
-               CASE_FIXED_FP(4);
-               CASE_FIXED_FP(5);
-
-               CASE_FIXED_FP(6);
-               CASE_FIXED_FP(7);
-               CASE_FIXED_FP(8);
-               CASE_FIXED_FP(9);
-               CASE_FIXED_FP(10);
-               CASE_FIXED_FP(11);
-
-               CASE_FIXED_FP(12);
-               CASE_FIXED_FP(13);
-               CASE_FIXED_FP(14);
-               CASE_FIXED_FP(15);
-               CASE_FIXED_FP(16);
-               CASE_FIXED_FP(17);
-               CASE_FIXED_FP(18);
-               CASE_FIXED_FP(19);
-               CASE_FIXED_FP(20);
-               CASE_FIXED_FP(21);
-               CASE_FIXED_FP(22);
-               CASE_FIXED_FP(23);
-               CASE_FIXED_FP(24);
-               CASE_FIXED_FP(25);
-               CASE_FIXED_FP(26);
-               CASE_FIXED_FP(27);
-               CASE_FIXED_FP(28);
-               CASE_FIXED_FP(29);
-               CASE_FIXED_FP(30);
-               CASE_FIXED_FP(31);
-               CASE_FIXED_FP(32);
-               CASE_FIXED_FP(33);
-               CASE_FIXED_FP(34);
-               CASE_FIXED_FP(35);
-               CASE_FIXED_FP(36);
-               CASE_FIXED_FP(37);
-               CASE_FIXED_FP(38);
-               CASE_FIXED_FP(39);
-               CASE_FIXED_FP(40);
-               CASE_FIXED_FP(41);
-               CASE_FIXED_FP(42);
-               CASE_FIXED_FP(43);
-               CASE_FIXED_FP(44);
-               CASE_FIXED_FP(45);
-               CASE_FIXED_FP(46);
-               CASE_FIXED_FP(47);
-               CASE_FIXED_FP(48);
-               CASE_FIXED_FP(49);
-               CASE_FIXED_FP(50);
-               CASE_FIXED_FP(51);
-               CASE_FIXED_FP(52);
-               CASE_FIXED_FP(53);
-               CASE_FIXED_FP(54);
-               CASE_FIXED_FP(55);
-               CASE_FIXED_FP(56);
-               CASE_FIXED_FP(57);
-               CASE_FIXED_FP(58);
-               CASE_FIXED_FP(59);
-               CASE_FIXED_FP(60);
-               CASE_FIXED_FP(61);
-               CASE_FIXED_FP(62);
-               CASE_FIXED_FP(63);
-               CASE_FIXED_FP(64);
-               CASE_FIXED_FP(65);
-               CASE_FIXED_FP(66);
-               CASE_FIXED_FP(67);
-               CASE_FIXED_FP(68);
-               CASE_FIXED_FP(69);
-               CASE_FIXED_FP(70);
-               CASE_FIXED_FP(71);
-               CASE_FIXED_FP(72);
-               CASE_FIXED_FP(73);
-               CASE_FIXED_FP(74);
-               CASE_FIXED_FP(75);
-               CASE_FIXED_FP(76);
-               CASE_FIXED_FP(77);
-               CASE_FIXED_FP(78);
-               CASE_FIXED_FP(79);
-               CASE_FIXED_FP(80);
-               CASE_FIXED_FP(81);
-               CASE_FIXED_FP(82);
-               CASE_FIXED_FP(83);
-               CASE_FIXED_FP(84);
-               CASE_FIXED_FP(85);
-               CASE_FIXED_FP(86);
-               CASE_FIXED_FP(87);
-               CASE_FIXED_FP(88);
-               CASE_FIXED_FP(89);
-               CASE_FIXED_FP(90);
-               CASE_FIXED_FP(91);
-               CASE_FIXED_FP(92);
-               CASE_FIXED_FP(93);
-               CASE_FIXED_FP(94);
-               CASE_FIXED_FP(95);
-               CASE_FIXED_FP(96);
-               CASE_FIXED_FP(97);
-               CASE_FIXED_FP(98);
-               CASE_FIXED_FP(99);
-               CASE_FIXED_FP(100);
-               CASE_FIXED_FP(101);
-               CASE_FIXED_FP(102);
-               CASE_FIXED_FP(103);
-               CASE_FIXED_FP(104);
-               CASE_FIXED_FP(105);
-               CASE_FIXED_FP(106);
-               CASE_FIXED_FP(107);
-               CASE_FIXED_FP(108);
-               CASE_FIXED_FP(109);
-               CASE_FIXED_FP(110);
-               CASE_FIXED_FP(111);
-               CASE_FIXED_FP(112);
-               CASE_FIXED_FP(113);
-               CASE_FIXED_FP(114);
-               CASE_FIXED_FP(115);
-               CASE_FIXED_FP(116);
-               CASE_FIXED_FP(117);
-               CASE_FIXED_FP(118);
-               CASE_FIXED_FP(119);
-               CASE_FIXED_FP(120);
-               CASE_FIXED_FP(121);
-               CASE_FIXED_FP(122);
-               CASE_FIXED_FP(123);
-               CASE_FIXED_FP(124);
-               CASE_FIXED_FP(125);
-               CASE_FIXED_FP(126);
-               CASE_FIXED_FP(127);
-       }
-}
-
-void vcpu_get_fpreg(struct kvm_vcpu *vcpu, unsigned long reg,
-                                               struct ia64_fpreg *val)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       getfpreg(reg, val, regs);   /* FIXME: handle NATs later*/
-}
-
-void vcpu_set_fpreg(struct kvm_vcpu *vcpu, unsigned long reg,
-                                               struct ia64_fpreg *val)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       if (reg > 1)
-               setfpreg(reg, val, regs);   /* FIXME: handle NATs later*/
-}
-
-/*
- * The Altix RTC is mapped specially here for the vmm module
- */
-#define SN_RTC_BASE    (u64 *)(KVM_VMM_BASE+(1UL<<KVM_VMM_SHIFT))
-static long kvm_get_itc(struct kvm_vcpu *vcpu)
-{
-#if defined(CONFIG_IA64_SGI_SN2) || defined(CONFIG_IA64_GENERIC)
-       struct kvm *kvm = (struct kvm *)KVM_VM_BASE;
-
-       if (kvm->arch.is_sn2)
-               return (*SN_RTC_BASE);
-       else
-#endif
-               return ia64_getreg(_IA64_REG_AR_ITC);
-}
-
-/************************************************************************
- * lsapic timer
- ***********************************************************************/
-u64 vcpu_get_itc(struct kvm_vcpu *vcpu)
-{
-       unsigned long guest_itc;
-       guest_itc = VMX(vcpu, itc_offset) + kvm_get_itc(vcpu);
-
-       if (guest_itc >= VMX(vcpu, last_itc)) {
-               VMX(vcpu, last_itc) = guest_itc;
-               return  guest_itc;
-       } else
-               return VMX(vcpu, last_itc);
-}
-
-static inline void vcpu_set_itm(struct kvm_vcpu *vcpu, u64 val);
-static void vcpu_set_itc(struct kvm_vcpu *vcpu, u64 val)
-{
-       struct kvm_vcpu *v;
-       struct kvm *kvm;
-       int i;
-       long itc_offset = val - kvm_get_itc(vcpu);
-       unsigned long vitv = VCPU(vcpu, itv);
-
-       kvm = (struct kvm *)KVM_VM_BASE;
-
-       if (kvm_vcpu_is_bsp(vcpu)) {
-               for (i = 0; i < atomic_read(&kvm->online_vcpus); i++) {
-                       v = (struct kvm_vcpu *)((char *)vcpu +
-                                       sizeof(struct kvm_vcpu_data) * i);
-                       VMX(v, itc_offset) = itc_offset;
-                       VMX(v, last_itc) = 0;
-               }
-       }
-       VMX(vcpu, last_itc) = 0;
-       if (VCPU(vcpu, itm) <= val) {
-               VMX(vcpu, itc_check) = 0;
-               vcpu_unpend_interrupt(vcpu, vitv);
-       } else {
-               VMX(vcpu, itc_check) = 1;
-               vcpu_set_itm(vcpu, VCPU(vcpu, itm));
-       }
-
-}
-
-static inline u64 vcpu_get_itm(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, itm));
-}
-
-static inline void vcpu_set_itm(struct kvm_vcpu *vcpu, u64 val)
-{
-       unsigned long vitv = VCPU(vcpu, itv);
-       VCPU(vcpu, itm) = val;
-
-       if (val > vcpu_get_itc(vcpu)) {
-               VMX(vcpu, itc_check) = 1;
-               vcpu_unpend_interrupt(vcpu, vitv);
-               VMX(vcpu, timer_pending) = 0;
-       } else
-               VMX(vcpu, itc_check) = 0;
-}
-
-#define  ITV_VECTOR(itv)    (itv&0xff)
-#define  ITV_IRQ_MASK(itv)  (itv&(1<<16))
-
-static inline void vcpu_set_itv(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, itv) = val;
-       if (!ITV_IRQ_MASK(val) && vcpu->arch.timer_pending) {
-               vcpu_pend_interrupt(vcpu, ITV_VECTOR(val));
-               vcpu->arch.timer_pending = 0;
-       }
-}
-
-static inline void vcpu_set_eoi(struct kvm_vcpu *vcpu, u64 val)
-{
-       int vec;
-
-       vec = highest_inservice_irq(vcpu);
-       if (vec == NULL_VECTOR)
-               return;
-       VMX(vcpu, insvc[vec >> 6]) &= ~(1UL << (vec & 63));
-       VCPU(vcpu, eoi) = 0;
-       vcpu->arch.irq_new_pending = 1;
-
-}
-
-/* See Table 5-8 in SDM vol2 for the definition */
-int irq_masked(struct kvm_vcpu *vcpu, int h_pending, int h_inservice)
-{
-       union ia64_tpr vtpr;
-
-       vtpr.val = VCPU(vcpu, tpr);
-
-       if (h_inservice == NMI_VECTOR)
-               return IRQ_MASKED_BY_INSVC;
-
-       if (h_pending == NMI_VECTOR) {
-               /* Non Maskable Interrupt */
-               return IRQ_NO_MASKED;
-       }
-
-       if (h_inservice == ExtINT_VECTOR)
-               return IRQ_MASKED_BY_INSVC;
-
-       if (h_pending == ExtINT_VECTOR) {
-               if (vtpr.mmi) {
-                       /* mask all external IRQ */
-                       return IRQ_MASKED_BY_VTPR;
-               } else
-                       return IRQ_NO_MASKED;
-       }
-
-       if (is_higher_irq(h_pending, h_inservice)) {
-               if (is_higher_class(h_pending, vtpr.mic + (vtpr.mmi << 4)))
-                       return IRQ_NO_MASKED;
-               else
-                       return IRQ_MASKED_BY_VTPR;
-       } else {
-               return IRQ_MASKED_BY_INSVC;
-       }
-}
-
-void vcpu_pend_interrupt(struct kvm_vcpu *vcpu, u8 vec)
-{
-       long spsr;
-       int ret;
-
-       local_irq_save(spsr);
-       ret = test_and_set_bit(vec, &VCPU(vcpu, irr[0]));
-       local_irq_restore(spsr);
-
-       vcpu->arch.irq_new_pending = 1;
-}
-
-void vcpu_unpend_interrupt(struct kvm_vcpu *vcpu, u8 vec)
-{
-       long spsr;
-       int ret;
-
-       local_irq_save(spsr);
-       ret = test_and_clear_bit(vec, &VCPU(vcpu, irr[0]));
-       local_irq_restore(spsr);
-       if (ret) {
-               vcpu->arch.irq_new_pending = 1;
-               wmb();
-       }
-}
-
-void update_vhpi(struct kvm_vcpu *vcpu, int vec)
-{
-       u64 vhpi;
-
-       if (vec == NULL_VECTOR)
-               vhpi = 0;
-       else if (vec == NMI_VECTOR)
-               vhpi = 32;
-       else if (vec == ExtINT_VECTOR)
-               vhpi = 16;
-       else
-               vhpi = vec >> 4;
-
-       VCPU(vcpu, vhpi) = vhpi;
-       if (VCPU(vcpu, vac).a_int)
-               ia64_call_vsa(PAL_VPS_SET_PENDING_INTERRUPT,
-                               (u64)vcpu->arch.vpd, 0, 0, 0, 0, 0, 0);
-}
-
-u64 vcpu_get_ivr(struct kvm_vcpu *vcpu)
-{
-       int vec, h_inservice, mask;
-
-       vec = highest_pending_irq(vcpu);
-       h_inservice = highest_inservice_irq(vcpu);
-       mask = irq_masked(vcpu, vec, h_inservice);
-       if (vec == NULL_VECTOR || mask == IRQ_MASKED_BY_INSVC) {
-               if (VCPU(vcpu, vhpi))
-                       update_vhpi(vcpu, NULL_VECTOR);
-               return IA64_SPURIOUS_INT_VECTOR;
-       }
-       if (mask == IRQ_MASKED_BY_VTPR) {
-               update_vhpi(vcpu, vec);
-               return IA64_SPURIOUS_INT_VECTOR;
-       }
-       VMX(vcpu, insvc[vec >> 6]) |= (1UL << (vec & 63));
-       vcpu_unpend_interrupt(vcpu, vec);
-       return  (u64)vec;
-}
-
-/**************************************************************************
-  Privileged operation emulation routines
- **************************************************************************/
-u64 vcpu_thash(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       union ia64_pta vpta;
-       union ia64_rr vrr;
-       u64 pval;
-       u64 vhpt_offset;
-
-       vpta.val = vcpu_get_pta(vcpu);
-       vrr.val = vcpu_get_rr(vcpu, vadr);
-       vhpt_offset = ((vadr >> vrr.ps) << 3) & ((1UL << (vpta.size)) - 1);
-       if (vpta.vf) {
-               pval = ia64_call_vsa(PAL_VPS_THASH, vadr, vrr.val,
-                               vpta.val, 0, 0, 0, 0);
-       } else {
-               pval = (vadr & VRN_MASK) | vhpt_offset |
-                       (vpta.val << 3 >> (vpta.size + 3) << (vpta.size));
-       }
-       return  pval;
-}
-
-u64 vcpu_ttag(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       union ia64_rr vrr;
-       union ia64_pta vpta;
-       u64 pval;
-
-       vpta.val = vcpu_get_pta(vcpu);
-       vrr.val = vcpu_get_rr(vcpu, vadr);
-       if (vpta.vf) {
-               pval = ia64_call_vsa(PAL_VPS_TTAG, vadr, vrr.val,
-                                               0, 0, 0, 0, 0);
-       } else
-               pval = 1;
-
-       return  pval;
-}
-
-u64 vcpu_tak(struct kvm_vcpu *vcpu, u64 vadr)
-{
-       struct thash_data *data;
-       union ia64_pta vpta;
-       u64 key;
-
-       vpta.val = vcpu_get_pta(vcpu);
-       if (vpta.vf == 0) {
-               key = 1;
-               return key;
-       }
-       data = vtlb_lookup(vcpu, vadr, D_TLB);
-       if (!data || !data->p)
-               key = 1;
-       else
-               key = data->key;
-
-       return key;
-}
-
-void kvm_thash(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long thash, vadr;
-
-       vadr = vcpu_get_gr(vcpu, inst.M46.r3);
-       thash = vcpu_thash(vcpu, vadr);
-       vcpu_set_gr(vcpu, inst.M46.r1, thash, 0);
-}
-
-void kvm_ttag(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long tag, vadr;
-
-       vadr = vcpu_get_gr(vcpu, inst.M46.r3);
-       tag = vcpu_ttag(vcpu, vadr);
-       vcpu_set_gr(vcpu, inst.M46.r1, tag, 0);
-}
-
-int vcpu_tpa(struct kvm_vcpu *vcpu, u64 vadr, unsigned long *padr)
-{
-       struct thash_data *data;
-       union ia64_isr visr, pt_isr;
-       struct kvm_pt_regs *regs;
-       struct ia64_psr vpsr;
-
-       regs = vcpu_regs(vcpu);
-       pt_isr.val = VMX(vcpu, cr_isr);
-       visr.val = 0;
-       visr.ei = pt_isr.ei;
-       visr.ir = pt_isr.ir;
-       vpsr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-       visr.na = 1;
-
-       data = vhpt_lookup(vadr);
-       if (data) {
-               if (data->p == 0) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       data_page_not_present(vcpu, vadr);
-                       return IA64_FAULT;
-               } else if (data->ma == VA_MATTR_NATPAGE) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       dnat_page_consumption(vcpu, vadr);
-                       return IA64_FAULT;
-               } else {
-                       *padr = (data->gpaddr >> data->ps << data->ps) |
-                               (vadr & (PSIZE(data->ps) - 1));
-                       return IA64_NO_FAULT;
-               }
-       }
-
-       data = vtlb_lookup(vcpu, vadr, D_TLB);
-       if (data) {
-               if (data->p == 0) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       data_page_not_present(vcpu, vadr);
-                       return IA64_FAULT;
-               } else if (data->ma == VA_MATTR_NATPAGE) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       dnat_page_consumption(vcpu, vadr);
-                       return IA64_FAULT;
-               } else{
-                       *padr = ((data->ppn >> (data->ps - 12)) << data->ps)
-                               | (vadr & (PSIZE(data->ps) - 1));
-                       return IA64_NO_FAULT;
-               }
-       }
-       if (!vhpt_enabled(vcpu, vadr, NA_REF)) {
-               if (vpsr.ic) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       alt_dtlb(vcpu, vadr);
-                       return IA64_FAULT;
-               } else {
-                       nested_dtlb(vcpu);
-                       return IA64_FAULT;
-               }
-       } else {
-               if (vpsr.ic) {
-                       vcpu_set_isr(vcpu, visr.val);
-                       dvhpt_fault(vcpu, vadr);
-                       return IA64_FAULT;
-               } else{
-                       nested_dtlb(vcpu);
-                       return IA64_FAULT;
-               }
-       }
-
-       return IA64_NO_FAULT;
-}
-
-int kvm_tpa(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r1, r3;
-
-       r3 = vcpu_get_gr(vcpu, inst.M46.r3);
-
-       if (vcpu_tpa(vcpu, r3, &r1))
-               return IA64_FAULT;
-
-       vcpu_set_gr(vcpu, inst.M46.r1, r1, 0);
-       return(IA64_NO_FAULT);
-}
-
-void kvm_tak(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r1, r3;
-
-       r3 = vcpu_get_gr(vcpu, inst.M46.r3);
-       r1 = vcpu_tak(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M46.r1, r1, 0);
-}
-
-/************************************
- * Insert/Purge translation register/cache
- ************************************/
-void vcpu_itc_i(struct kvm_vcpu *vcpu, u64 pte, u64 itir, u64 ifa)
-{
-       thash_purge_and_insert(vcpu, pte, itir, ifa, I_TLB);
-}
-
-void vcpu_itc_d(struct kvm_vcpu *vcpu, u64 pte, u64 itir, u64 ifa)
-{
-       thash_purge_and_insert(vcpu, pte, itir, ifa, D_TLB);
-}
-
-void vcpu_itr_i(struct kvm_vcpu *vcpu, u64 slot, u64 pte, u64 itir, u64 ifa)
-{
-       u64 ps, va, rid;
-       struct thash_data *p_itr;
-
-       ps = itir_ps(itir);
-       va = PAGEALIGN(ifa, ps);
-       pte &= ~PAGE_FLAGS_RV_MASK;
-       rid = vcpu_get_rr(vcpu, ifa);
-       rid = rid & RR_RID_MASK;
-       p_itr = (struct thash_data *)&vcpu->arch.itrs[slot];
-       vcpu_set_tr(p_itr, pte, itir, va, rid);
-       vcpu_quick_region_set(VMX(vcpu, itr_regions), va);
-}
-
-
-void vcpu_itr_d(struct kvm_vcpu *vcpu, u64 slot, u64 pte, u64 itir, u64 ifa)
-{
-       u64 gpfn;
-       u64 ps, va, rid;
-       struct thash_data *p_dtr;
-
-       ps = itir_ps(itir);
-       va = PAGEALIGN(ifa, ps);
-       pte &= ~PAGE_FLAGS_RV_MASK;
-
-       if (ps != _PAGE_SIZE_16M)
-               thash_purge_entries(vcpu, va, ps);
-       gpfn = (pte & _PAGE_PPN_MASK) >> PAGE_SHIFT;
-       if (__gpfn_is_io(gpfn))
-               pte |= VTLB_PTE_IO;
-       rid = vcpu_get_rr(vcpu, va);
-       rid = rid & RR_RID_MASK;
-       p_dtr = (struct thash_data *)&vcpu->arch.dtrs[slot];
-       vcpu_set_tr((struct thash_data *)&vcpu->arch.dtrs[slot],
-                                                       pte, itir, va, rid);
-       vcpu_quick_region_set(VMX(vcpu, dtr_regions), va);
-}
-
-void vcpu_ptr_d(struct kvm_vcpu *vcpu, u64 ifa, u64 ps)
-{
-       int index;
-       u64 va;
-
-       va = PAGEALIGN(ifa, ps);
-       while ((index = vtr_find_overlap(vcpu, va, ps, D_TLB)) >= 0)
-               vcpu->arch.dtrs[index].page_flags = 0;
-
-       thash_purge_entries(vcpu, va, ps);
-}
-
-void vcpu_ptr_i(struct kvm_vcpu *vcpu, u64 ifa, u64 ps)
-{
-       int index;
-       u64 va;
-
-       va = PAGEALIGN(ifa, ps);
-       while ((index = vtr_find_overlap(vcpu, va, ps, I_TLB)) >= 0)
-               vcpu->arch.itrs[index].page_flags = 0;
-
-       thash_purge_entries(vcpu, va, ps);
-}
-
-void vcpu_ptc_l(struct kvm_vcpu *vcpu, u64 va, u64 ps)
-{
-       va = PAGEALIGN(va, ps);
-       thash_purge_entries(vcpu, va, ps);
-}
-
-void vcpu_ptc_e(struct kvm_vcpu *vcpu, u64 va)
-{
-       thash_purge_all(vcpu);
-}
-
-void vcpu_ptc_ga(struct kvm_vcpu *vcpu, u64 va, u64 ps)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-       long psr;
-       local_irq_save(psr);
-       p->exit_reason = EXIT_REASON_PTC_G;
-
-       p->u.ptc_g_data.rr = vcpu_get_rr(vcpu, va);
-       p->u.ptc_g_data.vaddr = va;
-       p->u.ptc_g_data.ps = ps;
-       vmm_transition(vcpu);
-       /* Do Local Purge Here*/
-       vcpu_ptc_l(vcpu, va, ps);
-       local_irq_restore(psr);
-}
-
-
-void vcpu_ptc_g(struct kvm_vcpu *vcpu, u64 va, u64 ps)
-{
-       vcpu_ptc_ga(vcpu, va, ps);
-}
-
-void kvm_ptc_e(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       vcpu_ptc_e(vcpu, ifa);
-}
-
-void kvm_ptc_g(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa, itir;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       itir = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_ptc_g(vcpu, ifa, itir_ps(itir));
-}
-
-void kvm_ptc_ga(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa, itir;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       itir = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_ptc_ga(vcpu, ifa, itir_ps(itir));
-}
-
-void kvm_ptc_l(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa, itir;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       itir = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_ptc_l(vcpu, ifa, itir_ps(itir));
-}
-
-void kvm_ptr_d(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa, itir;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       itir = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_ptr_d(vcpu, ifa, itir_ps(itir));
-}
-
-void kvm_ptr_i(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long ifa, itir;
-
-       ifa = vcpu_get_gr(vcpu, inst.M45.r3);
-       itir = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_ptr_i(vcpu, ifa, itir_ps(itir));
-}
-
-void kvm_itr_d(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long itir, ifa, pte, slot;
-
-       slot = vcpu_get_gr(vcpu, inst.M45.r3);
-       pte = vcpu_get_gr(vcpu, inst.M45.r2);
-       itir = vcpu_get_itir(vcpu);
-       ifa = vcpu_get_ifa(vcpu);
-       vcpu_itr_d(vcpu, slot, pte, itir, ifa);
-}
-
-
-
-void kvm_itr_i(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long itir, ifa, pte, slot;
-
-       slot = vcpu_get_gr(vcpu, inst.M45.r3);
-       pte = vcpu_get_gr(vcpu, inst.M45.r2);
-       itir = vcpu_get_itir(vcpu);
-       ifa = vcpu_get_ifa(vcpu);
-       vcpu_itr_i(vcpu, slot, pte, itir, ifa);
-}
-
-void kvm_itc_d(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long itir, ifa, pte;
-
-       itir = vcpu_get_itir(vcpu);
-       ifa = vcpu_get_ifa(vcpu);
-       pte = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_itc_d(vcpu, pte, itir, ifa);
-}
-
-void kvm_itc_i(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long itir, ifa, pte;
-
-       itir = vcpu_get_itir(vcpu);
-       ifa = vcpu_get_ifa(vcpu);
-       pte = vcpu_get_gr(vcpu, inst.M45.r2);
-       vcpu_itc_i(vcpu, pte, itir, ifa);
-}
-
-/*************************************
- * Moves to semi-privileged registers
- *************************************/
-
-void kvm_mov_to_ar_imm(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long imm;
-
-       if (inst.M30.s)
-               imm = -inst.M30.imm;
-       else
-               imm = inst.M30.imm;
-
-       vcpu_set_itc(vcpu, imm);
-}
-
-void kvm_mov_to_ar_reg(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r2;
-
-       r2 = vcpu_get_gr(vcpu, inst.M29.r2);
-       vcpu_set_itc(vcpu, r2);
-}
-
-void kvm_mov_from_ar_reg(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r1;
-
-       r1 = vcpu_get_itc(vcpu);
-       vcpu_set_gr(vcpu, inst.M31.r1, r1, 0);
-}
-
-/**************************************************************************
-  struct kvm_vcpu protection key register access routines
- **************************************************************************/
-
-unsigned long vcpu_get_pkr(struct kvm_vcpu *vcpu, unsigned long reg)
-{
-       return ((unsigned long)ia64_get_pkr(reg));
-}
-
-void vcpu_set_pkr(struct kvm_vcpu *vcpu, unsigned long reg, unsigned long val)
-{
-       ia64_set_pkr(reg, val);
-}
-
-/********************************
- * Moves to privileged registers
- ********************************/
-unsigned long vcpu_set_rr(struct kvm_vcpu *vcpu, unsigned long reg,
-                                       unsigned long val)
-{
-       union ia64_rr oldrr, newrr;
-       unsigned long rrval;
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-       unsigned long psr;
-
-       oldrr.val = vcpu_get_rr(vcpu, reg);
-       newrr.val = val;
-       vcpu->arch.vrr[reg >> VRN_SHIFT] = val;
-
-       switch ((unsigned long)(reg >> VRN_SHIFT)) {
-       case VRN6:
-               vcpu->arch.vmm_rr = vrrtomrr(val);
-               local_irq_save(psr);
-               p->exit_reason = EXIT_REASON_SWITCH_RR6;
-               vmm_transition(vcpu);
-               local_irq_restore(psr);
-               break;
-       case VRN4:
-               rrval = vrrtomrr(val);
-               vcpu->arch.metaphysical_saved_rr4 = rrval;
-               if (!is_physical_mode(vcpu))
-                       ia64_set_rr(reg, rrval);
-               break;
-       case VRN0:
-               rrval = vrrtomrr(val);
-               vcpu->arch.metaphysical_saved_rr0 = rrval;
-               if (!is_physical_mode(vcpu))
-                       ia64_set_rr(reg, rrval);
-               break;
-       default:
-               ia64_set_rr(reg, vrrtomrr(val));
-               break;
-       }
-
-       return (IA64_NO_FAULT);
-}
-
-void kvm_mov_to_rr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r2;
-
-       r3 = vcpu_get_gr(vcpu, inst.M42.r3);
-       r2 = vcpu_get_gr(vcpu, inst.M42.r2);
-       vcpu_set_rr(vcpu, r3, r2);
-}
-
-void kvm_mov_to_dbr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-}
-
-void kvm_mov_to_ibr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-}
-
-void kvm_mov_to_pmc(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r2;
-
-       r3 = vcpu_get_gr(vcpu, inst.M42.r3);
-       r2 = vcpu_get_gr(vcpu, inst.M42.r2);
-       vcpu_set_pmc(vcpu, r3, r2);
-}
-
-void kvm_mov_to_pmd(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r2;
-
-       r3 = vcpu_get_gr(vcpu, inst.M42.r3);
-       r2 = vcpu_get_gr(vcpu, inst.M42.r2);
-       vcpu_set_pmd(vcpu, r3, r2);
-}
-
-void kvm_mov_to_pkr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       u64 r3, r2;
-
-       r3 = vcpu_get_gr(vcpu, inst.M42.r3);
-       r2 = vcpu_get_gr(vcpu, inst.M42.r2);
-       vcpu_set_pkr(vcpu, r3, r2);
-}
-
-void kvm_mov_from_rr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_rr(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-void kvm_mov_from_pkr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_pkr(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-void kvm_mov_from_dbr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_dbr(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-void kvm_mov_from_ibr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_ibr(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-void kvm_mov_from_pmc(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_pmc(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-unsigned long vcpu_get_cpuid(struct kvm_vcpu *vcpu, unsigned long reg)
-{
-       /* FIXME: This could get called as a result of a rsvd-reg fault */
-       if (reg > (ia64_get_cpuid(3) & 0xff))
-               return 0;
-       else
-               return ia64_get_cpuid(reg);
-}
-
-void kvm_mov_from_cpuid(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r3, r1;
-
-       r3 = vcpu_get_gr(vcpu, inst.M43.r3);
-       r1 = vcpu_get_cpuid(vcpu, r3);
-       vcpu_set_gr(vcpu, inst.M43.r1, r1, 0);
-}
-
-void vcpu_set_tpr(struct kvm_vcpu *vcpu, unsigned long val)
-{
-       VCPU(vcpu, tpr) = val;
-       vcpu->arch.irq_check = 1;
-}
-
-unsigned long kvm_mov_to_cr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long r2;
-
-       r2 = vcpu_get_gr(vcpu, inst.M32.r2);
-       VCPU(vcpu, vcr[inst.M32.cr3]) = r2;
-
-       switch (inst.M32.cr3) {
-       case 0:
-               vcpu_set_dcr(vcpu, r2);
-               break;
-       case 1:
-               vcpu_set_itm(vcpu, r2);
-               break;
-       case 66:
-               vcpu_set_tpr(vcpu, r2);
-               break;
-       case 67:
-               vcpu_set_eoi(vcpu, r2);
-               break;
-       default:
-               break;
-       }
-
-       return 0;
-}
-
-unsigned long kvm_mov_from_cr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long tgt = inst.M33.r1;
-       unsigned long val;
-
-       switch (inst.M33.cr3) {
-       case 65:
-               val = vcpu_get_ivr(vcpu);
-               vcpu_set_gr(vcpu, tgt, val, 0);
-               break;
-
-       case 67:
-               vcpu_set_gr(vcpu, tgt, 0L, 0);
-               break;
-       default:
-               val = VCPU(vcpu, vcr[inst.M33.cr3]);
-               vcpu_set_gr(vcpu, tgt, val, 0);
-               break;
-       }
-
-       return 0;
-}
-
-void vcpu_set_psr(struct kvm_vcpu *vcpu, unsigned long val)
-{
-
-       unsigned long mask;
-       struct kvm_pt_regs *regs;
-       struct ia64_psr old_psr, new_psr;
-
-       old_psr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-
-       regs = vcpu_regs(vcpu);
-       /* We only support guest as:
-        *  vpsr.pk = 0
-        *  vpsr.is = 0
-        * Otherwise panic
-        */
-       if (val & (IA64_PSR_PK | IA64_PSR_IS | IA64_PSR_VM))
-               panic_vm(vcpu, "Only support guests with vpsr.pk =0 "
-                               "& vpsr.is=0\n");
-
-       /*
-        * For those IA64_PSR bits: id/da/dd/ss/ed/ia
-        * Since these bits will become 0, after success execution of each
-        * instruction, we will change set them to mIA64_PSR
-        */
-       VCPU(vcpu, vpsr) = val
-               & (~(IA64_PSR_ID | IA64_PSR_DA | IA64_PSR_DD |
-                       IA64_PSR_SS | IA64_PSR_ED | IA64_PSR_IA));
-
-       if (!old_psr.i && (val & IA64_PSR_I)) {
-               /* vpsr.i 0->1 */
-               vcpu->arch.irq_check = 1;
-       }
-       new_psr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-
-       /*
-        * All vIA64_PSR bits shall go to mPSR (v->tf->tf_special.psr)
-        * , except for the following bits:
-        *  ic/i/dt/si/rt/mc/it/bn/vm
-        */
-       mask =  IA64_PSR_IC + IA64_PSR_I + IA64_PSR_DT + IA64_PSR_SI +
-               IA64_PSR_RT + IA64_PSR_MC + IA64_PSR_IT + IA64_PSR_BN +
-               IA64_PSR_VM;
-
-       regs->cr_ipsr = (regs->cr_ipsr & mask) | (val & (~mask));
-
-       check_mm_mode_switch(vcpu, old_psr, new_psr);
-
-       return ;
-}
-
-unsigned long vcpu_cover(struct kvm_vcpu *vcpu)
-{
-       struct ia64_psr vpsr;
-
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       vpsr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-
-       if (!vpsr.ic)
-               VCPU(vcpu, ifs) = regs->cr_ifs;
-       regs->cr_ifs = IA64_IFS_V;
-       return (IA64_NO_FAULT);
-}
-
-
-
-/**************************************************************************
-  VCPU banked general register access routines
- **************************************************************************/
-#define vcpu_bsw0_unat(i, b0unat, b1unat, runat, VMM_PT_REGS_R16_SLOT) \
-       do {                                                            \
-               __asm__ __volatile__ (                                  \
-                               ";;extr.u %0 = %3,%6,16;;\n"            \
-                               "dep %1 = %0, %1, 0, 16;;\n"            \
-                               "st8 [%4] = %1\n"                       \
-                               "extr.u %0 = %2, 16, 16;;\n"            \
-                               "dep %3 = %0, %3, %6, 16;;\n"           \
-                               "st8 [%5] = %3\n"                       \
-                               ::"r"(i), "r"(*b1unat), "r"(*b0unat),   \
-                               "r"(*runat), "r"(b1unat), "r"(runat),   \
-                               "i"(VMM_PT_REGS_R16_SLOT) : "memory");  \
-       } while (0)
-
-void vcpu_bsw0(struct kvm_vcpu *vcpu)
-{
-       unsigned long i;
-
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       unsigned long *r = &regs->r16;
-       unsigned long *b0 = &VCPU(vcpu, vbgr[0]);
-       unsigned long *b1 = &VCPU(vcpu, vgr[0]);
-       unsigned long *runat = &regs->eml_unat;
-       unsigned long *b0unat = &VCPU(vcpu, vbnat);
-       unsigned long *b1unat = &VCPU(vcpu, vnat);
-
-
-       if (VCPU(vcpu, vpsr) & IA64_PSR_BN) {
-               for (i = 0; i < 16; i++) {
-                       *b1++ = *r;
-                       *r++ = *b0++;
-               }
-               vcpu_bsw0_unat(i, b0unat, b1unat, runat,
-                               VMM_PT_REGS_R16_SLOT);
-               VCPU(vcpu, vpsr) &= ~IA64_PSR_BN;
-       }
-}
-
-#define vcpu_bsw1_unat(i, b0unat, b1unat, runat, VMM_PT_REGS_R16_SLOT) \
-       do {                                                            \
-               __asm__ __volatile__ (";;extr.u %0 = %3, %6, 16;;\n"    \
-                               "dep %1 = %0, %1, 16, 16;;\n"           \
-                               "st8 [%4] = %1\n"                       \
-                               "extr.u %0 = %2, 0, 16;;\n"             \
-                               "dep %3 = %0, %3, %6, 16;;\n"           \
-                               "st8 [%5] = %3\n"                       \
-                               ::"r"(i), "r"(*b0unat), "r"(*b1unat),   \
-                               "r"(*runat), "r"(b0unat), "r"(runat),   \
-                               "i"(VMM_PT_REGS_R16_SLOT) : "memory");  \
-       } while (0)
-
-void vcpu_bsw1(struct kvm_vcpu *vcpu)
-{
-       unsigned long i;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       unsigned long *r = &regs->r16;
-       unsigned long *b0 = &VCPU(vcpu, vbgr[0]);
-       unsigned long *b1 = &VCPU(vcpu, vgr[0]);
-       unsigned long *runat = &regs->eml_unat;
-       unsigned long *b0unat = &VCPU(vcpu, vbnat);
-       unsigned long *b1unat = &VCPU(vcpu, vnat);
-
-       if (!(VCPU(vcpu, vpsr) & IA64_PSR_BN)) {
-               for (i = 0; i < 16; i++) {
-                       *b0++ = *r;
-                       *r++ = *b1++;
-               }
-               vcpu_bsw1_unat(i, b0unat, b1unat, runat,
-                               VMM_PT_REGS_R16_SLOT);
-               VCPU(vcpu, vpsr) |= IA64_PSR_BN;
-       }
-}
-
-void vcpu_rfi(struct kvm_vcpu *vcpu)
-{
-       unsigned long ifs, psr;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       psr = VCPU(vcpu, ipsr);
-       if (psr & IA64_PSR_BN)
-               vcpu_bsw1(vcpu);
-       else
-               vcpu_bsw0(vcpu);
-       vcpu_set_psr(vcpu, psr);
-       ifs = VCPU(vcpu, ifs);
-       if (ifs >> 63)
-               regs->cr_ifs = ifs;
-       regs->cr_iip = VCPU(vcpu, iip);
-}
-
-/*
-   VPSR can't keep track of below bits of guest PSR
-   This function gets guest PSR
- */
-
-unsigned long vcpu_get_psr(struct kvm_vcpu *vcpu)
-{
-       unsigned long mask;
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-
-       mask = IA64_PSR_BE | IA64_PSR_UP | IA64_PSR_AC | IA64_PSR_MFL |
-               IA64_PSR_MFH | IA64_PSR_CPL | IA64_PSR_RI;
-       return (VCPU(vcpu, vpsr) & ~mask) | (regs->cr_ipsr & mask);
-}
-
-void kvm_rsm(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long vpsr;
-       unsigned long imm24 = (inst.M44.i<<23) | (inst.M44.i2<<21)
-                                       | inst.M44.imm;
-
-       vpsr = vcpu_get_psr(vcpu);
-       vpsr &= (~imm24);
-       vcpu_set_psr(vcpu, vpsr);
-}
-
-void kvm_ssm(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long vpsr;
-       unsigned long imm24 = (inst.M44.i << 23) | (inst.M44.i2 << 21)
-                               | inst.M44.imm;
-
-       vpsr = vcpu_get_psr(vcpu);
-       vpsr |= imm24;
-       vcpu_set_psr(vcpu, vpsr);
-}
-
-/* Generate Mask
- * Parameter:
- *  bit -- starting bit
- *  len -- how many bits
- */
-#define MASK(bit,len)                                  \
-({                                                     \
-               __u64   ret;                            \
-                                                       \
-               __asm __volatile("dep %0=-1, r0, %1, %2"\
-                               : "=r" (ret):           \
-                 "M" (bit),                            \
-                 "M" (len));                           \
-               ret;                                    \
-})
-
-void vcpu_set_psr_l(struct kvm_vcpu *vcpu, unsigned long val)
-{
-       val = (val & MASK(0, 32)) | (vcpu_get_psr(vcpu) & MASK(32, 32));
-       vcpu_set_psr(vcpu, val);
-}
-
-void kvm_mov_to_psr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long val;
-
-       val = vcpu_get_gr(vcpu, inst.M35.r2);
-       vcpu_set_psr_l(vcpu, val);
-}
-
-void kvm_mov_from_psr(struct kvm_vcpu *vcpu, INST64 inst)
-{
-       unsigned long val;
-
-       val = vcpu_get_psr(vcpu);
-       val = (val & MASK(0, 32)) | (val & MASK(35, 2));
-       vcpu_set_gr(vcpu, inst.M33.r1, val, 0);
-}
-
-void vcpu_increment_iip(struct kvm_vcpu *vcpu)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       struct ia64_psr *ipsr = (struct ia64_psr *)&regs->cr_ipsr;
-       if (ipsr->ri == 2) {
-               ipsr->ri = 0;
-               regs->cr_iip += 16;
-       } else
-               ipsr->ri++;
-}
-
-void vcpu_decrement_iip(struct kvm_vcpu *vcpu)
-{
-       struct kvm_pt_regs *regs = vcpu_regs(vcpu);
-       struct ia64_psr *ipsr = (struct ia64_psr *)&regs->cr_ipsr;
-
-       if (ipsr->ri == 0) {
-               ipsr->ri = 2;
-               regs->cr_iip -= 16;
-       } else
-               ipsr->ri--;
-}
-
-/** Emulate a privileged operation.
- *
- *
- * @param vcpu virtual cpu
- * @cause the reason cause virtualization fault
- * @opcode the instruction code which cause virtualization fault
- */
-
-void kvm_emulate(struct kvm_vcpu *vcpu, struct kvm_pt_regs *regs)
-{
-       unsigned long status, cause, opcode ;
-       INST64 inst;
-
-       status = IA64_NO_FAULT;
-       cause = VMX(vcpu, cause);
-       opcode = VMX(vcpu, opcode);
-       inst.inst = opcode;
-       /*
-        * Switch to actual virtual rid in rr0 and rr4,
-        * which is required by some tlb related instructions.
-        */
-       prepare_if_physical_mode(vcpu);
-
-       switch (cause) {
-       case EVENT_RSM:
-               kvm_rsm(vcpu, inst);
-               break;
-       case EVENT_SSM:
-               kvm_ssm(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_PSR:
-               kvm_mov_to_psr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_PSR:
-               kvm_mov_from_psr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_CR:
-               kvm_mov_from_cr(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_CR:
-               kvm_mov_to_cr(vcpu, inst);
-               break;
-       case EVENT_BSW_0:
-               vcpu_bsw0(vcpu);
-               break;
-       case EVENT_BSW_1:
-               vcpu_bsw1(vcpu);
-               break;
-       case EVENT_COVER:
-               vcpu_cover(vcpu);
-               break;
-       case EVENT_RFI:
-               vcpu_rfi(vcpu);
-               break;
-       case EVENT_ITR_D:
-               kvm_itr_d(vcpu, inst);
-               break;
-       case EVENT_ITR_I:
-               kvm_itr_i(vcpu, inst);
-               break;
-       case EVENT_PTR_D:
-               kvm_ptr_d(vcpu, inst);
-               break;
-       case EVENT_PTR_I:
-               kvm_ptr_i(vcpu, inst);
-               break;
-       case EVENT_ITC_D:
-               kvm_itc_d(vcpu, inst);
-               break;
-       case EVENT_ITC_I:
-               kvm_itc_i(vcpu, inst);
-               break;
-       case EVENT_PTC_L:
-               kvm_ptc_l(vcpu, inst);
-               break;
-       case EVENT_PTC_G:
-               kvm_ptc_g(vcpu, inst);
-               break;
-       case EVENT_PTC_GA:
-               kvm_ptc_ga(vcpu, inst);
-               break;
-       case EVENT_PTC_E:
-               kvm_ptc_e(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_RR:
-               kvm_mov_to_rr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_RR:
-               kvm_mov_from_rr(vcpu, inst);
-               break;
-       case EVENT_THASH:
-               kvm_thash(vcpu, inst);
-               break;
-       case EVENT_TTAG:
-               kvm_ttag(vcpu, inst);
-               break;
-       case EVENT_TPA:
-               status = kvm_tpa(vcpu, inst);
-               break;
-       case EVENT_TAK:
-               kvm_tak(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_AR_IMM:
-               kvm_mov_to_ar_imm(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_AR:
-               kvm_mov_to_ar_reg(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_AR:
-               kvm_mov_from_ar_reg(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_DBR:
-               kvm_mov_to_dbr(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_IBR:
-               kvm_mov_to_ibr(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_PMC:
-               kvm_mov_to_pmc(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_PMD:
-               kvm_mov_to_pmd(vcpu, inst);
-               break;
-       case EVENT_MOV_TO_PKR:
-               kvm_mov_to_pkr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_DBR:
-               kvm_mov_from_dbr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_IBR:
-               kvm_mov_from_ibr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_PMC:
-               kvm_mov_from_pmc(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_PKR:
-               kvm_mov_from_pkr(vcpu, inst);
-               break;
-       case EVENT_MOV_FROM_CPUID:
-               kvm_mov_from_cpuid(vcpu, inst);
-               break;
-       case EVENT_VMSW:
-               status = IA64_FAULT;
-               break;
-       default:
-               break;
-       };
-       /*Assume all status is NO_FAULT ?*/
-       if (status == IA64_NO_FAULT && cause != EVENT_RFI)
-               vcpu_increment_iip(vcpu);
-
-       recover_if_physical_mode(vcpu);
-}
-
-void init_vcpu(struct kvm_vcpu *vcpu)
-{
-       int i;
-
-       vcpu->arch.mode_flags = GUEST_IN_PHY;
-       VMX(vcpu, vrr[0]) = 0x38;
-       VMX(vcpu, vrr[1]) = 0x38;
-       VMX(vcpu, vrr[2]) = 0x38;
-       VMX(vcpu, vrr[3]) = 0x38;
-       VMX(vcpu, vrr[4]) = 0x38;
-       VMX(vcpu, vrr[5]) = 0x38;
-       VMX(vcpu, vrr[6]) = 0x38;
-       VMX(vcpu, vrr[7]) = 0x38;
-       VCPU(vcpu, vpsr) = IA64_PSR_BN;
-       VCPU(vcpu, dcr) = 0;
-       /* pta.size must not be 0.  The minimum is 15 (32k) */
-       VCPU(vcpu, pta) = 15 << 2;
-       VCPU(vcpu, itv) = 0x10000;
-       VCPU(vcpu, itm) = 0;
-       VMX(vcpu, last_itc) = 0;
-
-       VCPU(vcpu, lid) = VCPU_LID(vcpu);
-       VCPU(vcpu, ivr) = 0;
-       VCPU(vcpu, tpr) = 0x10000;
-       VCPU(vcpu, eoi) = 0;
-       VCPU(vcpu, irr[0]) = 0;
-       VCPU(vcpu, irr[1]) = 0;
-       VCPU(vcpu, irr[2]) = 0;
-       VCPU(vcpu, irr[3]) = 0;
-       VCPU(vcpu, pmv) = 0x10000;
-       VCPU(vcpu, cmcv) = 0x10000;
-       VCPU(vcpu, lrr0) = 0x10000;   /* default reset value? */
-       VCPU(vcpu, lrr1) = 0x10000;   /* default reset value? */
-       update_vhpi(vcpu, NULL_VECTOR);
-       VLSAPIC_XTP(vcpu) = 0x80;       /* disabled */
-
-       for (i = 0; i < 4; i++)
-               VLSAPIC_INSVC(vcpu, i) = 0;
-}
-
-void kvm_init_all_rr(struct kvm_vcpu *vcpu)
-{
-       unsigned long psr;
-
-       local_irq_save(psr);
-
-       /* WARNING: not allow co-exist of both virtual mode and physical
-        * mode in same region
-        */
-
-       vcpu->arch.metaphysical_saved_rr0 = vrrtomrr(VMX(vcpu, vrr[VRN0]));
-       vcpu->arch.metaphysical_saved_rr4 = vrrtomrr(VMX(vcpu, vrr[VRN4]));
-
-       if (is_physical_mode(vcpu)) {
-               if (vcpu->arch.mode_flags & GUEST_PHY_EMUL)
-                       panic_vm(vcpu, "Machine Status conflicts!\n");
-
-               ia64_set_rr((VRN0 << VRN_SHIFT), vcpu->arch.metaphysical_rr0);
-               ia64_dv_serialize_data();
-               ia64_set_rr((VRN4 << VRN_SHIFT), vcpu->arch.metaphysical_rr4);
-               ia64_dv_serialize_data();
-       } else {
-               ia64_set_rr((VRN0 << VRN_SHIFT),
-                               vcpu->arch.metaphysical_saved_rr0);
-               ia64_dv_serialize_data();
-               ia64_set_rr((VRN4 << VRN_SHIFT),
-                               vcpu->arch.metaphysical_saved_rr4);
-               ia64_dv_serialize_data();
-       }
-       ia64_set_rr((VRN1 << VRN_SHIFT),
-                       vrrtomrr(VMX(vcpu, vrr[VRN1])));
-       ia64_dv_serialize_data();
-       ia64_set_rr((VRN2 << VRN_SHIFT),
-                       vrrtomrr(VMX(vcpu, vrr[VRN2])));
-       ia64_dv_serialize_data();
-       ia64_set_rr((VRN3 << VRN_SHIFT),
-                       vrrtomrr(VMX(vcpu, vrr[VRN3])));
-       ia64_dv_serialize_data();
-       ia64_set_rr((VRN5 << VRN_SHIFT),
-                       vrrtomrr(VMX(vcpu, vrr[VRN5])));
-       ia64_dv_serialize_data();
-       ia64_set_rr((VRN7 << VRN_SHIFT),
-                       vrrtomrr(VMX(vcpu, vrr[VRN7])));
-       ia64_dv_serialize_data();
-       ia64_srlz_d();
-       ia64_set_psr(psr);
-}
-
-int vmm_entry(void)
-{
-       struct kvm_vcpu *v;
-       v = current_vcpu;
-
-       ia64_call_vsa(PAL_VPS_RESTORE, (unsigned long)v->arch.vpd,
-                                               0, 0, 0, 0, 0, 0);
-       kvm_init_vtlb(v);
-       kvm_init_vhpt(v);
-       init_vcpu(v);
-       kvm_init_all_rr(v);
-       vmm_reset_entry();
-
-       return 0;
-}
-
-static void kvm_show_registers(struct kvm_pt_regs *regs)
-{
-       unsigned long ip = regs->cr_iip + ia64_psr(regs)->ri;
-
-       struct kvm_vcpu *vcpu = current_vcpu;
-       if (vcpu != NULL)
-               printk("vcpu 0x%p vcpu %d\n",
-                      vcpu, vcpu->vcpu_id);
-
-       printk("psr : %016lx ifs : %016lx ip  : [<%016lx>]\n",
-              regs->cr_ipsr, regs->cr_ifs, ip);
-
-       printk("unat: %016lx pfs : %016lx rsc : %016lx\n",
-              regs->ar_unat, regs->ar_pfs, regs->ar_rsc);
-       printk("rnat: %016lx bspstore: %016lx pr  : %016lx\n",
-              regs->ar_rnat, regs->ar_bspstore, regs->pr);
-       printk("ldrs: %016lx ccv : %016lx fpsr: %016lx\n",
-              regs->loadrs, regs->ar_ccv, regs->ar_fpsr);
-       printk("csd : %016lx ssd : %016lx\n", regs->ar_csd, regs->ar_ssd);
-       printk("b0  : %016lx b6  : %016lx b7  : %016lx\n", regs->b0,
-                                                       regs->b6, regs->b7);
-       printk("f6  : %05lx%016lx f7  : %05lx%016lx\n",
-              regs->f6.u.bits[1], regs->f6.u.bits[0],
-              regs->f7.u.bits[1], regs->f7.u.bits[0]);
-       printk("f8  : %05lx%016lx f9  : %05lx%016lx\n",
-              regs->f8.u.bits[1], regs->f8.u.bits[0],
-              regs->f9.u.bits[1], regs->f9.u.bits[0]);
-       printk("f10 : %05lx%016lx f11 : %05lx%016lx\n",
-              regs->f10.u.bits[1], regs->f10.u.bits[0],
-              regs->f11.u.bits[1], regs->f11.u.bits[0]);
-
-       printk("r1  : %016lx r2  : %016lx r3  : %016lx\n", regs->r1,
-                                                       regs->r2, regs->r3);
-       printk("r8  : %016lx r9  : %016lx r10 : %016lx\n", regs->r8,
-                                                       regs->r9, regs->r10);
-       printk("r11 : %016lx r12 : %016lx r13 : %016lx\n", regs->r11,
-                                                       regs->r12, regs->r13);
-       printk("r14 : %016lx r15 : %016lx r16 : %016lx\n", regs->r14,
-                                                       regs->r15, regs->r16);
-       printk("r17 : %016lx r18 : %016lx r19 : %016lx\n", regs->r17,
-                                                       regs->r18, regs->r19);
-       printk("r20 : %016lx r21 : %016lx r22 : %016lx\n", regs->r20,
-                                                       regs->r21, regs->r22);
-       printk("r23 : %016lx r24 : %016lx r25 : %016lx\n", regs->r23,
-                                                       regs->r24, regs->r25);
-       printk("r26 : %016lx r27 : %016lx r28 : %016lx\n", regs->r26,
-                                                       regs->r27, regs->r28);
-       printk("r29 : %016lx r30 : %016lx r31 : %016lx\n", regs->r29,
-                                                       regs->r30, regs->r31);
-
-}
-
-void panic_vm(struct kvm_vcpu *v, const char *fmt, ...)
-{
-       va_list args;
-       char buf[256];
-
-       struct kvm_pt_regs *regs = vcpu_regs(v);
-       struct exit_ctl_data *p = &v->arch.exit_data;
-       va_start(args, fmt);
-       vsnprintf(buf, sizeof(buf), fmt, args);
-       va_end(args);
-       printk(buf);
-       kvm_show_registers(regs);
-       p->exit_reason = EXIT_REASON_VM_PANIC;
-       vmm_transition(v);
-       /*Never to return*/
-       while (1);
-}
diff --git a/arch/ia64/kvm/vcpu.h b/arch/ia64/kvm/vcpu.h
deleted file mode 100644 (file)
index 988911b..0000000
+++ /dev/null
@@ -1,752 +0,0 @@
-/*
- *  vcpu.h: vcpu routines
- *     Copyright (c) 2005, Intel Corporation.
- *     Xuefei Xu (Anthony Xu) (Anthony.xu@intel.com)
- *     Yaozu Dong (Eddie Dong) (Eddie.dong@intel.com)
- *
- *     Copyright (c) 2007, Intel Corporation.
- *     Xuefei Xu (Anthony Xu) (Anthony.xu@intel.com)
- *     Xiantao Zhang (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_VCPU_H__
-#define __KVM_VCPU_H__
-
-#include <asm/types.h>
-#include <asm/fpu.h>
-#include <asm/processor.h>
-
-#ifndef __ASSEMBLY__
-#include "vti.h"
-
-#include <linux/kvm_host.h>
-#include <linux/spinlock.h>
-
-typedef unsigned long IA64_INST;
-
-typedef union U_IA64_BUNDLE {
-       unsigned long i64[2];
-       struct { unsigned long template:5, slot0:41, slot1a:18,
-               slot1b:23, slot2:41; };
-       /* NOTE: following doesn't work because bitfields can't cross natural
-          size boundaries
-          struct { unsigned long template:5, slot0:41, slot1:41, slot2:41; }; */
-} IA64_BUNDLE;
-
-typedef union U_INST64_A5 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, imm7b:7, r3:2, imm5c:5,
-               imm9d:9, s:1, major:4; };
-} INST64_A5;
-
-typedef union U_INST64_B4 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, btype:3, un3:3, p:1, b2:3, un11:11, x6:6,
-               wh:2, d:1, un1:1, major:4; };
-} INST64_B4;
-
-typedef union U_INST64_B8 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, un21:21, x6:6, un4:4, major:4; };
-} INST64_B8;
-
-typedef union U_INST64_B9 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm20:20, :1, x6:6, :3, i:1, major:4; };
-} INST64_B9;
-
-typedef union U_INST64_I19 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm20:20, :1, x6:6, x3:3, i:1, major:4; };
-} INST64_I19;
-
-typedef union U_INST64_I26 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, ar3:7, x6:6, x3:3, :1, major:4; };
-} INST64_I26;
-
-typedef union U_INST64_I27 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, imm:7, ar3:7, x6:6, x3:3, s:1, major:4; };
-} INST64_I27;
-
-typedef union U_INST64_I28 { /* not privileged (mov from AR) */
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, :7, ar3:7, x6:6, x3:3, :1, major:4; };
-} INST64_I28;
-
-typedef union U_INST64_M28 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :14, r3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M28;
-
-typedef union U_INST64_M29 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, ar3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M29;
-
-typedef union U_INST64_M30 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, imm:7, ar3:7, x4:4, x2:2,
-               x3:3, s:1, major:4; };
-} INST64_M30;
-
-typedef union U_INST64_M31 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, :7, ar3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M31;
-
-typedef union U_INST64_M32 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, cr3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M32;
-
-typedef union U_INST64_M33 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, :7, cr3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M33;
-
-typedef union U_INST64_M35 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, :7, x6:6, x3:3, :1, major:4; };
-
-} INST64_M35;
-
-typedef union U_INST64_M36 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, :14, x6:6, x3:3, :1, major:4; };
-} INST64_M36;
-
-typedef union U_INST64_M37 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm20a:20, :1, x4:4, x2:2, x3:3,
-               i:1, major:4; };
-} INST64_M37;
-
-typedef union U_INST64_M41 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, :7, x6:6, x3:3, :1, major:4; };
-} INST64_M41;
-
-typedef union U_INST64_M42 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, r3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M42;
-
-typedef union U_INST64_M43 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, :7, r3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M43;
-
-typedef union U_INST64_M44 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm:21, x4:4, i2:2, x3:3, i:1, major:4; };
-} INST64_M44;
-
-typedef union U_INST64_M45 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, r2:7, r3:7, x6:6, x3:3, :1, major:4; };
-} INST64_M45;
-
-typedef union U_INST64_M46 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, un7:7, r3:7, x6:6,
-               x3:3, un1:1, major:4; };
-} INST64_M46;
-
-typedef union U_INST64_M47 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, un14:14, r3:7, x6:6, x3:3, un1:1, major:4; };
-} INST64_M47;
-
-typedef union U_INST64_M1{
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, un7:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M1;
-
-typedef union U_INST64_M2{
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, r2:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M2;
-
-typedef union U_INST64_M3{
-       IA64_INST inst;
-       struct { unsigned long qp:6, r1:7, imm7:7, r3:7, i:1, hint:2,
-               x6:6, s:1, major:4; };
-} INST64_M3;
-
-typedef union U_INST64_M4 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, un7:7, r2:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M4;
-
-typedef union U_INST64_M5 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm7:7, r2:7, r3:7, i:1, hint:2,
-               x6:6, s:1, major:4; };
-} INST64_M5;
-
-typedef union U_INST64_M6 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, f1:7, un7:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M6;
-
-typedef union U_INST64_M9 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, f2:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M9;
-
-typedef union U_INST64_M10 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, imm7:7, f2:7, r3:7, i:1, hint:2,
-               x6:6, s:1, major:4; };
-} INST64_M10;
-
-typedef union U_INST64_M12 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, f1:7, f2:7, r3:7, x:1, hint:2,
-               x6:6, m:1, major:4; };
-} INST64_M12;
-
-typedef union U_INST64_M15 {
-       IA64_INST inst;
-       struct { unsigned long qp:6, :7, imm7:7, r3:7, i:1, hint:2,
-               x6:6, s:1, major:4; };
-} INST64_M15;
-
-typedef union U_INST64 {
-       IA64_INST inst;
-       struct { unsigned long :37, major:4; } generic;
-       INST64_A5 A5;   /* used in build_hypercall_bundle only */
-       INST64_B4 B4;   /* used in build_hypercall_bundle only */
-       INST64_B8 B8;   /* rfi, bsw.[01] */
-       INST64_B9 B9;   /* break.b */
-       INST64_I19 I19; /* used in build_hypercall_bundle only */
-       INST64_I26 I26; /* mov register to ar (I unit) */
-       INST64_I27 I27; /* mov immediate to ar (I unit) */
-       INST64_I28 I28; /* mov from ar (I unit) */
-       INST64_M1  M1;  /* ld integer */
-       INST64_M2  M2;
-       INST64_M3  M3;
-       INST64_M4  M4;  /* st integer */
-       INST64_M5  M5;
-       INST64_M6  M6;  /* ldfd floating pointer                */
-       INST64_M9  M9;  /* stfd floating pointer                */
-       INST64_M10 M10; /* stfd floating pointer                */
-       INST64_M12 M12;     /* ldfd pair floating pointer               */
-       INST64_M15 M15; /* lfetch + imm update                  */
-       INST64_M28 M28; /* purge translation cache entry        */
-       INST64_M29 M29; /* mov register to ar (M unit)          */
-       INST64_M30 M30; /* mov immediate to ar (M unit)         */
-       INST64_M31 M31; /* mov from ar (M unit)                 */
-       INST64_M32 M32; /* mov reg to cr                        */
-       INST64_M33 M33; /* mov from cr                          */
-       INST64_M35 M35; /* mov to psr                           */
-       INST64_M36 M36; /* mov from psr                         */
-       INST64_M37 M37; /* break.m                              */
-       INST64_M41 M41; /* translation cache insert             */
-       INST64_M42 M42; /* mov to indirect reg/translation reg insert*/
-       INST64_M43 M43; /* mov from indirect reg                */
-       INST64_M44 M44; /* set/reset system mask                */
-       INST64_M45 M45; /* translation purge                    */
-       INST64_M46 M46; /* translation access (tpa,tak)         */
-       INST64_M47 M47; /* purge translation entry              */
-} INST64;
-
-#define MASK_41 ((unsigned long)0x1ffffffffff)
-
-/* Virtual address memory attributes encoding */
-#define VA_MATTR_WB         0x0
-#define VA_MATTR_UC         0x4
-#define VA_MATTR_UCE        0x5
-#define VA_MATTR_WC         0x6
-#define VA_MATTR_NATPAGE    0x7
-
-#define PMASK(size)         (~((size) - 1))
-#define PSIZE(size)         (1UL<<(size))
-#define CLEARLSB(ppn, nbits)    (((ppn) >> (nbits)) << (nbits))
-#define PAGEALIGN(va, ps)      CLEARLSB(va, ps)
-#define PAGE_FLAGS_RV_MASK   (0x2|(0x3UL<<50)|(((1UL<<11)-1)<<53))
-#define _PAGE_MA_ST     (0x1 <<  2) /* is reserved for software use */
-
-#define ARCH_PAGE_SHIFT   12
-
-#define INVALID_TI_TAG (1UL << 63)
-
-#define VTLB_PTE_P_BIT      0
-#define VTLB_PTE_IO_BIT     60
-#define VTLB_PTE_IO         (1UL<<VTLB_PTE_IO_BIT)
-#define VTLB_PTE_P          (1UL<<VTLB_PTE_P_BIT)
-
-#define vcpu_quick_region_check(_tr_regions,_ifa)              \
-       (_tr_regions & (1 << ((unsigned long)_ifa >> 61)))
-
-#define vcpu_quick_region_set(_tr_regions,_ifa)             \
-       do {_tr_regions |= (1 << ((unsigned long)_ifa >> 61)); } while (0)
-
-static inline void vcpu_set_tr(struct thash_data *trp, u64 pte, u64 itir,
-               u64 va, u64 rid)
-{
-       trp->page_flags = pte;
-       trp->itir = itir;
-       trp->vadr = va;
-       trp->rid = rid;
-}
-
-extern u64 kvm_get_mpt_entry(u64 gpfn);
-
-/* Return I/ */
-static inline u64 __gpfn_is_io(u64 gpfn)
-{
-       u64  pte;
-       pte = kvm_get_mpt_entry(gpfn);
-       if (!(pte & GPFN_INV_MASK)) {
-               pte = pte & GPFN_IO_MASK;
-               if (pte != GPFN_PHYS_MMIO)
-                       return pte;
-       }
-       return 0;
-}
-#endif
-#define IA64_NO_FAULT  0
-#define IA64_FAULT     1
-
-#define VMM_RBS_OFFSET  ((VMM_TASK_SIZE + 15) & ~15)
-
-#define SW_BAD  0   /* Bad mode transitition */
-#define SW_V2P  1   /* Physical emulatino is activated */
-#define SW_P2V  2   /* Exit physical mode emulation */
-#define SW_SELF 3   /* No mode transition */
-#define SW_NOP  4   /* Mode transition, but without action required */
-
-#define GUEST_IN_PHY    0x1
-#define GUEST_PHY_EMUL  0x2
-
-#define current_vcpu ((struct kvm_vcpu *) ia64_getreg(_IA64_REG_TP))
-
-#define VRN_SHIFT      61
-#define VRN_MASK       0xe000000000000000
-#define VRN0           0x0UL
-#define VRN1           0x1UL
-#define VRN2           0x2UL
-#define VRN3           0x3UL
-#define VRN4           0x4UL
-#define VRN5           0x5UL
-#define VRN6           0x6UL
-#define VRN7           0x7UL
-
-#define IRQ_NO_MASKED         0
-#define IRQ_MASKED_BY_VTPR    1
-#define IRQ_MASKED_BY_INSVC   2   /* masked by inservice IRQ */
-
-#define PTA_BASE_SHIFT      15
-
-#define IA64_PSR_VM_BIT     46
-#define IA64_PSR_VM (__IA64_UL(1) << IA64_PSR_VM_BIT)
-
-/* Interruption Function State */
-#define IA64_IFS_V_BIT      63
-#define IA64_IFS_V  (__IA64_UL(1) << IA64_IFS_V_BIT)
-
-#define PHY_PAGE_UC (_PAGE_A|_PAGE_D|_PAGE_P|_PAGE_MA_UC|_PAGE_AR_RWX)
-#define PHY_PAGE_WB (_PAGE_A|_PAGE_D|_PAGE_P|_PAGE_MA_WB|_PAGE_AR_RWX)
-
-#ifndef __ASSEMBLY__
-
-#include <asm/gcc_intrin.h>
-
-#define is_physical_mode(v)            \
-       ((v->arch.mode_flags) & GUEST_IN_PHY)
-
-#define is_virtual_mode(v)     \
-       (!is_physical_mode(v))
-
-#define MODE_IND(psr)  \
-       (((psr).it << 2) + ((psr).dt << 1) + (psr).rt)
-
-#ifndef CONFIG_SMP
-#define _vmm_raw_spin_lock(x)   do {}while(0)
-#define _vmm_raw_spin_unlock(x) do {}while(0)
-#else
-typedef struct {
-       volatile unsigned int lock;
-} vmm_spinlock_t;
-#define _vmm_raw_spin_lock(x)                                          \
-       do {                                                            \
-               __u32 *ia64_spinlock_ptr = (__u32 *) (x);               \
-               __u64 ia64_spinlock_val;                                \
-               ia64_spinlock_val = ia64_cmpxchg4_acq(ia64_spinlock_ptr, 1, 0);\
-               if (unlikely(ia64_spinlock_val)) {                      \
-                       do {                                            \
-                               while (*ia64_spinlock_ptr)              \
-                               ia64_barrier();                         \
-                               ia64_spinlock_val =                     \
-                               ia64_cmpxchg4_acq(ia64_spinlock_ptr, 1, 0);\
-                       } while (ia64_spinlock_val);                    \
-               }                                                       \
-       } while (0)
-
-#define _vmm_raw_spin_unlock(x)                                \
-       do { barrier();                         \
-               ((vmm_spinlock_t *)x)->lock = 0; } \
-while (0)
-#endif
-
-void vmm_spin_lock(vmm_spinlock_t *lock);
-void vmm_spin_unlock(vmm_spinlock_t *lock);
-enum {
-       I_TLB = 1,
-       D_TLB = 2
-};
-
-union kvm_va {
-       struct {
-               unsigned long off : 60;         /* intra-region offset */
-               unsigned long reg :  4;         /* region number */
-       } f;
-       unsigned long l;
-       void *p;
-};
-
-#define __kvm_pa(x)     ({union kvm_va _v; _v.l = (long) (x);          \
-                                               _v.f.reg = 0; _v.l; })
-#define __kvm_va(x)     ({union kvm_va _v; _v.l = (long) (x);          \
-                               _v.f.reg = -1; _v.p; })
-
-#define _REGION_ID(x)           ({union ia64_rr _v; _v.val = (long)(x); \
-                                               _v.rid; })
-#define _REGION_PAGE_SIZE(x)    ({union ia64_rr _v; _v.val = (long)(x); \
-                                               _v.ps; })
-#define _REGION_HW_WALKER(x)    ({union ia64_rr _v; _v.val = (long)(x);        \
-                                               _v.ve; })
-
-enum vhpt_ref{ DATA_REF, NA_REF, INST_REF, RSE_REF };
-enum tlb_miss_type { INSTRUCTION, DATA, REGISTER };
-
-#define VCPU(_v, _x) ((_v)->arch.vpd->_x)
-#define VMX(_v, _x)  ((_v)->arch._x)
-
-#define VLSAPIC_INSVC(vcpu, i) ((vcpu)->arch.insvc[i])
-#define VLSAPIC_XTP(_v)        VMX(_v, xtp)
-
-static inline unsigned long itir_ps(unsigned long itir)
-{
-       return ((itir >> 2) & 0x3f);
-}
-
-
-/**************************************************************************
-  VCPU control register access routines
- **************************************************************************/
-
-static inline u64 vcpu_get_itir(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, itir));
-}
-
-static inline void vcpu_set_itir(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, itir) = val;
-}
-
-static inline u64 vcpu_get_ifa(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, ifa));
-}
-
-static inline void vcpu_set_ifa(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, ifa) = val;
-}
-
-static inline u64 vcpu_get_iva(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, iva));
-}
-
-static inline u64 vcpu_get_pta(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, pta));
-}
-
-static inline u64 vcpu_get_lid(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, lid));
-}
-
-static inline u64 vcpu_get_tpr(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, tpr));
-}
-
-static inline u64 vcpu_get_eoi(struct kvm_vcpu *vcpu)
-{
-       return (0UL);           /*reads of eoi always return 0 */
-}
-
-static inline u64 vcpu_get_irr0(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, irr[0]));
-}
-
-static inline u64 vcpu_get_irr1(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, irr[1]));
-}
-
-static inline u64 vcpu_get_irr2(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, irr[2]));
-}
-
-static inline u64 vcpu_get_irr3(struct kvm_vcpu *vcpu)
-{
-       return ((u64)VCPU(vcpu, irr[3]));
-}
-
-static inline void vcpu_set_dcr(struct kvm_vcpu *vcpu, u64 val)
-{
-       ia64_setreg(_IA64_REG_CR_DCR, val);
-}
-
-static inline void vcpu_set_isr(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, isr) = val;
-}
-
-static inline void vcpu_set_lid(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, lid) = val;
-}
-
-static inline void vcpu_set_ipsr(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, ipsr) = val;
-}
-
-static inline void vcpu_set_iip(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, iip) = val;
-}
-
-static inline void vcpu_set_ifs(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, ifs) = val;
-}
-
-static inline void vcpu_set_iipa(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, iipa) = val;
-}
-
-static inline void vcpu_set_iha(struct kvm_vcpu *vcpu, u64 val)
-{
-       VCPU(vcpu, iha) = val;
-}
-
-
-static inline u64 vcpu_get_rr(struct kvm_vcpu *vcpu, u64 reg)
-{
-       return vcpu->arch.vrr[reg>>61];
-}
-
-/**************************************************************************
-  VCPU debug breakpoint register access routines
- **************************************************************************/
-
-static inline void vcpu_set_dbr(struct kvm_vcpu *vcpu, u64 reg, u64 val)
-{
-       __ia64_set_dbr(reg, val);
-}
-
-static inline void vcpu_set_ibr(struct kvm_vcpu *vcpu, u64 reg, u64 val)
-{
-       ia64_set_ibr(reg, val);
-}
-
-static inline u64 vcpu_get_dbr(struct kvm_vcpu *vcpu, u64 reg)
-{
-       return ((u64)__ia64_get_dbr(reg));
-}
-
-static inline u64 vcpu_get_ibr(struct kvm_vcpu *vcpu, u64 reg)
-{
-       return ((u64)ia64_get_ibr(reg));
-}
-
-/**************************************************************************
-  VCPU performance monitor register access routines
- **************************************************************************/
-static inline void vcpu_set_pmc(struct kvm_vcpu *vcpu, u64 reg, u64 val)
-{
-       /* NOTE: Writes to unimplemented PMC registers are discarded */
-       ia64_set_pmc(reg, val);
-}
-
-static inline void vcpu_set_pmd(struct kvm_vcpu *vcpu, u64 reg, u64 val)
-{
-       /* NOTE: Writes to unimplemented PMD registers are discarded */
-       ia64_set_pmd(reg, val);
-}
-
-static inline u64 vcpu_get_pmc(struct kvm_vcpu *vcpu, u64 reg)
-{
-       /* NOTE: Reads from unimplemented PMC registers return zero */
-       return ((u64)ia64_get_pmc(reg));
-}
-
-static inline u64 vcpu_get_pmd(struct kvm_vcpu *vcpu, u64 reg)
-{
-       /* NOTE: Reads from unimplemented PMD registers return zero */
-       return ((u64)ia64_get_pmd(reg));
-}
-
-static inline unsigned long vrrtomrr(unsigned long val)
-{
-       union ia64_rr rr;
-       rr.val = val;
-       rr.rid = (rr.rid << 4) | 0xe;
-       if (rr.ps > PAGE_SHIFT)
-               rr.ps = PAGE_SHIFT;
-       rr.ve = 1;
-       return rr.val;
-}
-
-
-static inline int highest_bits(int *dat)
-{
-       u32  bits, bitnum;
-       int i;
-
-       /* loop for all 256 bits */
-       for (i = 7; i >= 0 ; i--) {
-               bits = dat[i];
-               if (bits) {
-                       bitnum = fls(bits);
-                       return i * 32 + bitnum - 1;
-               }
-       }
-       return NULL_VECTOR;
-}
-
-/*
- * The pending irq is higher than the inservice one.
- *
- */
-static inline int is_higher_irq(int pending, int inservice)
-{
-       return ((pending > inservice)
-                       || ((pending != NULL_VECTOR)
-                               && (inservice == NULL_VECTOR)));
-}
-
-static inline int is_higher_class(int pending, int mic)
-{
-       return ((pending >> 4) > mic);
-}
-
-/*
- * Return 0-255 for pending irq.
- *        NULL_VECTOR: when no pending.
- */
-static inline int highest_pending_irq(struct kvm_vcpu *vcpu)
-{
-       if (VCPU(vcpu, irr[0]) & (1UL<<NMI_VECTOR))
-               return NMI_VECTOR;
-       if (VCPU(vcpu, irr[0]) & (1UL<<ExtINT_VECTOR))
-               return ExtINT_VECTOR;
-
-       return highest_bits((int *)&VCPU(vcpu, irr[0]));
-}
-
-static inline int highest_inservice_irq(struct kvm_vcpu *vcpu)
-{
-       if (VMX(vcpu, insvc[0]) & (1UL<<NMI_VECTOR))
-               return NMI_VECTOR;
-       if (VMX(vcpu, insvc[0]) & (1UL<<ExtINT_VECTOR))
-               return ExtINT_VECTOR;
-
-       return highest_bits((int *)&(VMX(vcpu, insvc[0])));
-}
-
-extern void vcpu_get_fpreg(struct kvm_vcpu *vcpu, unsigned long reg,
-                                       struct ia64_fpreg *val);
-extern void vcpu_set_fpreg(struct kvm_vcpu *vcpu, unsigned long reg,
-                                       struct ia64_fpreg *val);
-extern u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg);
-extern void vcpu_set_gr(struct kvm_vcpu *vcpu, unsigned long reg,
-                       u64 val, int nat);
-extern unsigned long vcpu_get_psr(struct kvm_vcpu *vcpu);
-extern void vcpu_set_psr(struct kvm_vcpu *vcpu, unsigned long val);
-extern u64 vcpu_thash(struct kvm_vcpu *vcpu, u64 vadr);
-extern void vcpu_bsw0(struct kvm_vcpu *vcpu);
-extern void thash_vhpt_insert(struct kvm_vcpu *v, u64 pte,
-                                       u64 itir, u64 va, int type);
-extern struct thash_data *vhpt_lookup(u64 va);
-extern u64 guest_vhpt_lookup(u64 iha, u64 *pte);
-extern void thash_purge_entries(struct kvm_vcpu *v, u64 va, u64 ps);
-extern void thash_purge_entries_remote(struct kvm_vcpu *v, u64 va, u64 ps);
-extern u64 translate_phy_pte(u64 *pte, u64 itir, u64 va);
-extern void thash_purge_and_insert(struct kvm_vcpu *v, u64 pte,
-               u64 itir, u64 ifa, int type);
-extern void thash_purge_all(struct kvm_vcpu *v);
-extern struct thash_data *vtlb_lookup(struct kvm_vcpu *v,
-                                               u64 va, int is_data);
-extern int vtr_find_overlap(struct kvm_vcpu *vcpu, u64 va,
-                                               u64 ps, int is_data);
-
-extern void vcpu_increment_iip(struct kvm_vcpu *v);
-extern void vcpu_decrement_iip(struct kvm_vcpu *vcpu);
-extern void vcpu_pend_interrupt(struct kvm_vcpu *vcpu, u8 vec);
-extern void vcpu_unpend_interrupt(struct kvm_vcpu *vcpu, u8 vec);
-extern void data_page_not_present(struct kvm_vcpu *vcpu, u64 vadr);
-extern void dnat_page_consumption(struct kvm_vcpu *vcpu, u64 vadr);
-extern void alt_dtlb(struct kvm_vcpu *vcpu, u64 vadr);
-extern void nested_dtlb(struct kvm_vcpu *vcpu);
-extern void dvhpt_fault(struct kvm_vcpu *vcpu, u64 vadr);
-extern int vhpt_enabled(struct kvm_vcpu *vcpu, u64 vadr, enum vhpt_ref ref);
-
-extern void update_vhpi(struct kvm_vcpu *vcpu, int vec);
-extern int irq_masked(struct kvm_vcpu *vcpu, int h_pending, int h_inservice);
-
-extern int fetch_code(struct kvm_vcpu *vcpu, u64 gip, IA64_BUNDLE *pbundle);
-extern void emulate_io_inst(struct kvm_vcpu *vcpu, u64 padr, u64 ma);
-extern void vmm_transition(struct kvm_vcpu *vcpu);
-extern void vmm_trampoline(union context *from, union context *to);
-extern int vmm_entry(void);
-extern  u64 vcpu_get_itc(struct kvm_vcpu *vcpu);
-
-extern void vmm_reset_entry(void);
-void kvm_init_vtlb(struct kvm_vcpu *v);
-void kvm_init_vhpt(struct kvm_vcpu *v);
-void thash_init(struct thash_cb *hcb, u64 sz);
-
-void panic_vm(struct kvm_vcpu *v, const char *fmt, ...);
-u64 kvm_gpa_to_mpa(u64 gpa);
-extern u64 ia64_call_vsa(u64 proc, u64 arg1, u64 arg2, u64 arg3,
-               u64 arg4, u64 arg5, u64 arg6, u64 arg7);
-
-extern long vmm_sanity;
-
-#endif
-#endif /* __VCPU_H__ */
diff --git a/arch/ia64/kvm/vmm.c b/arch/ia64/kvm/vmm.c
deleted file mode 100644 (file)
index 176a12c..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * vmm.c: vmm module interface with kvm module
- *
- * Copyright (c) 2007, Intel Corporation.
- *
- *  Xiantao Zhang (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.
- */
-
-
-#include <linux/kernel.h>
-#include <linux/module.h>
-#include <asm/fpswa.h>
-
-#include "vcpu.h"
-
-MODULE_AUTHOR("Intel");
-MODULE_LICENSE("GPL");
-
-extern char kvm_ia64_ivt;
-extern char kvm_asm_mov_from_ar;
-extern char kvm_asm_mov_from_ar_sn2;
-extern fpswa_interface_t *vmm_fpswa_interface;
-
-long vmm_sanity = 1;
-
-struct kvm_vmm_info vmm_info = {
-       .module                 = THIS_MODULE,
-       .vmm_entry              = vmm_entry,
-       .tramp_entry            = vmm_trampoline,
-       .vmm_ivt                = (unsigned long)&kvm_ia64_ivt,
-       .patch_mov_ar           = (unsigned long)&kvm_asm_mov_from_ar,
-       .patch_mov_ar_sn2       = (unsigned long)&kvm_asm_mov_from_ar_sn2,
-};
-
-static int __init  kvm_vmm_init(void)
-{
-
-       vmm_fpswa_interface = fpswa_interface;
-
-       /*Register vmm data to kvm side*/
-       return kvm_init(&vmm_info, 1024, 0, THIS_MODULE);
-}
-
-static void __exit kvm_vmm_exit(void)
-{
-       kvm_exit();
-       return ;
-}
-
-void vmm_spin_lock(vmm_spinlock_t *lock)
-{
-       _vmm_raw_spin_lock(lock);
-}
-
-void vmm_spin_unlock(vmm_spinlock_t *lock)
-{
-       _vmm_raw_spin_unlock(lock);
-}
-
-static void vcpu_debug_exit(struct kvm_vcpu *vcpu)
-{
-       struct exit_ctl_data *p = &vcpu->arch.exit_data;
-       long psr;
-
-       local_irq_save(psr);
-       p->exit_reason = EXIT_REASON_DEBUG;
-       vmm_transition(vcpu);
-       local_irq_restore(psr);
-}
-
-asmlinkage int printk(const char *fmt, ...)
-{
-       struct kvm_vcpu *vcpu = current_vcpu;
-       va_list args;
-       int r;
-
-       memset(vcpu->arch.log_buf, 0, VMM_LOG_LEN);
-       va_start(args, fmt);
-       r = vsnprintf(vcpu->arch.log_buf, VMM_LOG_LEN, fmt, args);
-       va_end(args);
-       vcpu_debug_exit(vcpu);
-       return r;
-}
-
-module_init(kvm_vmm_init)
-module_exit(kvm_vmm_exit)
diff --git a/arch/ia64/kvm/vmm_ivt.S b/arch/ia64/kvm/vmm_ivt.S
deleted file mode 100644 (file)
index 397e34a..0000000
+++ /dev/null
@@ -1,1392 +0,0 @@
-/*
- * arch/ia64/kvm/vmm_ivt.S
- *
- * Copyright (C) 1998-2001, 2003 Hewlett-Packard Co
- *      Stephane Eranian <eranian@hpl.hp.com>
- *      David Mosberger <davidm@hpl.hp.com>
- * Copyright (C) 2000, 2002-2003 Intel Co
- *      Asit Mallick <asit.k.mallick@intel.com>
- *      Suresh Siddha <suresh.b.siddha@intel.com>
- *      Kenneth Chen <kenneth.w.chen@intel.com>
- *      Fenghua Yu <fenghua.yu@intel.com>
- *
- *
- * 00/08/23 Asit Mallick <asit.k.mallick@intel.com> TLB handling
- * for SMP
- * 00/12/20 David Mosberger-Tang <davidm@hpl.hp.com> DTLB/ITLB
- * handler now uses virtual PT.
- *
- * 07/6/20 Xuefei Xu  (Anthony Xu) (anthony.xu@intel.com)
- *              Supporting Intel virtualization architecture
- *
- */
-
-/*
- * This file defines the interruption vector table used by the CPU.
- * It does not include one entry per possible cause of interruption.
- *
- * The first 20 entries of the table contain 64 bundles each while the
- * remaining 48 entries contain only 16 bundles each.
- *
- * The 64 bundles are used to allow inlining the whole handler for
- * critical
- * interruptions like TLB misses.
- *
- *  For each entry, the comment is as follows:
- *
- *              // 0x1c00 Entry 7 (size 64 bundles) Data Key Miss
- *              (12,51)
- *  entry offset ----/     /         /                  /
- *  /
- *  entry number ---------/         /                  /
- *  /
- *  size of the entry -------------/                  /
- *  /
- *  vector name -------------------------------------/
- *  /
- *  interruptions triggering this vector
- *  ----------------------/
- *
- * The table is 32KB in size and must be aligned on 32KB
- * boundary.
- * (The CPU ignores the 15 lower bits of the address)
- *
- * Table is based upon EAS2.6 (Oct 1999)
- */
-
-
-#include <asm/asmmacro.h>
-#include <asm/cache.h>
-#include <asm/pgtable.h>
-
-#include "asm-offsets.h"
-#include "vcpu.h"
-#include "kvm_minstate.h"
-#include "vti.h"
-
-#if 0
-# define PSR_DEFAULT_BITS   psr.ac
-#else
-# define PSR_DEFAULT_BITS   0
-#endif
-
-#define KVM_FAULT(n)    \
-       kvm_fault_##n:;          \
-       mov r19=n;;          \
-       br.sptk.many kvm_vmm_panic;         \
-       ;;                  \
-
-#define KVM_REFLECT(n)    \
-       mov r31=pr;           \
-       mov r19=n;       /* prepare to save predicates */ \
-       mov r29=cr.ipsr;      \
-       ;;      \
-       tbit.z p6,p7=r29,IA64_PSR_VM_BIT;       \
-(p7)   br.sptk.many kvm_dispatch_reflection;        \
-       br.sptk.many kvm_vmm_panic;      \
-
-GLOBAL_ENTRY(kvm_vmm_panic)
-       KVM_SAVE_MIN_WITH_COVER_R19
-       alloc r14=ar.pfs,0,0,1,0
-       mov out0=r15
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i    // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       KVM_SAVE_REST
-       mov rp=r14
-       ;;
-       br.call.sptk.many b6=vmm_panic_handler;
-END(kvm_vmm_panic)
-
-    .section .text..ivt,"ax"
-
-    .align 32768    // align on 32KB boundary
-    .global kvm_ia64_ivt
-kvm_ia64_ivt:
-///////////////////////////////////////////////////////////////
-// 0x0000 Entry 0 (size 64 bundles) VHPT Translation (8,20,47)
-ENTRY(kvm_vhpt_miss)
-       KVM_FAULT(0)
-END(kvm_vhpt_miss)
-
-    .org kvm_ia64_ivt+0x400
-////////////////////////////////////////////////////////////////
-// 0x0400 Entry 1 (size 64 bundles) ITLB (21)
-ENTRY(kvm_itlb_miss)
-       mov r31 = pr
-       mov r29=cr.ipsr;
-       ;;
-       tbit.z p6,p7=r29,IA64_PSR_VM_BIT;
-(p6)   br.sptk kvm_alt_itlb_miss
-       mov r19 = 1
-       br.sptk kvm_itlb_miss_dispatch
-       KVM_FAULT(1);
-END(kvm_itlb_miss)
-
-    .org kvm_ia64_ivt+0x0800
-//////////////////////////////////////////////////////////////////
-// 0x0800 Entry 2 (size 64 bundles) DTLB (9,48)
-ENTRY(kvm_dtlb_miss)
-       mov r31 = pr
-       mov r29=cr.ipsr;
-       ;;
-       tbit.z p6,p7=r29,IA64_PSR_VM_BIT;
-(p6)   br.sptk kvm_alt_dtlb_miss
-       br.sptk kvm_dtlb_miss_dispatch
-END(kvm_dtlb_miss)
-
-     .org kvm_ia64_ivt+0x0c00
-////////////////////////////////////////////////////////////////////
-// 0x0c00 Entry 3 (size 64 bundles) Alt ITLB (19)
-ENTRY(kvm_alt_itlb_miss)
-       mov r16=cr.ifa    // get address that caused the TLB miss
-       ;;
-       movl r17=PAGE_KERNEL
-       mov r24=cr.ipsr
-       movl r19=(((1 << IA64_MAX_PHYS_BITS) - 1) & ~0xfff)
-       ;;
-       and r19=r19,r16     // clear ed, reserved bits, and PTE control bits
-       ;;
-       or r19=r17,r19      // insert PTE control bits into r19
-       ;;
-       movl r20=IA64_GRANULE_SHIFT<<2
-       ;;
-       mov cr.itir=r20
-       ;;
-       itc.i r19               // insert the TLB entry
-       mov pr=r31,-1
-       rfi
-END(kvm_alt_itlb_miss)
-
-    .org kvm_ia64_ivt+0x1000
-/////////////////////////////////////////////////////////////////////
-// 0x1000 Entry 4 (size 64 bundles) Alt DTLB (7,46)
-ENTRY(kvm_alt_dtlb_miss)
-       mov r16=cr.ifa          // get address that caused the TLB miss
-       ;;
-       movl r17=PAGE_KERNEL
-       movl r19=(((1 << IA64_MAX_PHYS_BITS) - 1) & ~0xfff)
-       mov r24=cr.ipsr
-       ;;
-       and r19=r19,r16     // clear ed, reserved bits, and PTE control bits
-       ;;
-       or r19=r19,r17  // insert PTE control bits into r19
-       ;;
-       movl r20=IA64_GRANULE_SHIFT<<2
-       ;;
-       mov cr.itir=r20
-       ;;
-       itc.d r19               // insert the TLB entry
-       mov pr=r31,-1
-       rfi
-END(kvm_alt_dtlb_miss)
-
-    .org kvm_ia64_ivt+0x1400
-//////////////////////////////////////////////////////////////////////
-// 0x1400 Entry 5 (size 64 bundles) Data nested TLB (6,45)
-ENTRY(kvm_nested_dtlb_miss)
-       KVM_FAULT(5)
-END(kvm_nested_dtlb_miss)
-
-    .org kvm_ia64_ivt+0x1800
-/////////////////////////////////////////////////////////////////////
-// 0x1800 Entry 6 (size 64 bundles) Instruction Key Miss (24)
-ENTRY(kvm_ikey_miss)
-       KVM_REFLECT(6)
-END(kvm_ikey_miss)
-
-    .org kvm_ia64_ivt+0x1c00
-/////////////////////////////////////////////////////////////////////
-// 0x1c00 Entry 7 (size 64 bundles) Data Key Miss (12,51)
-ENTRY(kvm_dkey_miss)
-       KVM_REFLECT(7)
-END(kvm_dkey_miss)
-
-    .org kvm_ia64_ivt+0x2000
-////////////////////////////////////////////////////////////////////
-// 0x2000 Entry 8 (size 64 bundles) Dirty-bit (54)
-ENTRY(kvm_dirty_bit)
-       KVM_REFLECT(8)
-END(kvm_dirty_bit)
-
-    .org kvm_ia64_ivt+0x2400
-////////////////////////////////////////////////////////////////////
-// 0x2400 Entry 9 (size 64 bundles) Instruction Access-bit (27)
-ENTRY(kvm_iaccess_bit)
-       KVM_REFLECT(9)
-END(kvm_iaccess_bit)
-
-    .org kvm_ia64_ivt+0x2800
-///////////////////////////////////////////////////////////////////
-// 0x2800 Entry 10 (size 64 bundles) Data Access-bit (15,55)
-ENTRY(kvm_daccess_bit)
-       KVM_REFLECT(10)
-END(kvm_daccess_bit)
-
-    .org kvm_ia64_ivt+0x2c00
-/////////////////////////////////////////////////////////////////
-// 0x2c00 Entry 11 (size 64 bundles) Break instruction (33)
-ENTRY(kvm_break_fault)
-       mov r31=pr
-       mov r19=11
-       mov r29=cr.ipsr
-       ;;
-       KVM_SAVE_MIN_WITH_COVER_R19
-       ;;
-       alloc r14=ar.pfs,0,0,4,0 //(must be first in insn group!)
-       mov out0=cr.ifa
-       mov out2=cr.isr     // FIXME: pity to make this slow access twice
-       mov out3=cr.iim     // FIXME: pity to make this slow access twice
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i         // guarantee that interruption collection is on
-       ;;
-       (p15)ssm psr.i               // restore psr.i
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       KVM_SAVE_REST
-       mov rp=r14
-       ;;
-       adds out1=16,sp
-       br.call.sptk.many b6=kvm_ia64_handle_break
-       ;;
-END(kvm_break_fault)
-
-    .org kvm_ia64_ivt+0x3000
-/////////////////////////////////////////////////////////////////
-// 0x3000 Entry 12 (size 64 bundles) External Interrupt (4)
-ENTRY(kvm_interrupt)
-       mov r31=pr              // prepare to save predicates
-       mov r19=12
-       mov r29=cr.ipsr
-       ;;
-       tbit.z p6,p7=r29,IA64_PSR_VM_BIT
-       tbit.z p0,p15=r29,IA64_PSR_I_BIT
-       ;;
-(p7)   br.sptk kvm_dispatch_interrupt
-       ;;
-       mov r27=ar.rsc          /* M */
-       mov r20=r1                      /* A */
-       mov r25=ar.unat         /* M */
-       mov r26=ar.pfs          /* I */
-       mov r28=cr.iip          /* M */
-       cover                   /* B (or nothing) */
-       ;;
-       mov r1=sp
-       ;;
-       invala                  /* M */
-       mov r30=cr.ifs
-       ;;
-       addl r1=-VMM_PT_REGS_SIZE,r1
-       ;;
-       adds r17=2*L1_CACHE_BYTES,r1    /* really: biggest cache-line size */
-       adds r16=PT(CR_IPSR),r1
-       ;;
-       lfetch.fault.excl.nt1 [r17],L1_CACHE_BYTES
-       st8 [r16]=r29                   /* save cr.ipsr */
-       ;;
-       lfetch.fault.excl.nt1 [r17]
-       mov r29=b0
-       ;;
-       adds r16=PT(R8),r1      /* initialize first base pointer */
-       adds r17=PT(R9),r1      /* initialize second base pointer */
-       mov r18=r0                      /* make sure r18 isn't NaT */
-       ;;
-.mem.offset 0,0; st8.spill [r16]=r8,16
-.mem.offset 8,0; st8.spill [r17]=r9,16
-        ;;
-.mem.offset 0,0; st8.spill [r16]=r10,24
-.mem.offset 8,0; st8.spill [r17]=r11,24
-        ;;
-       st8 [r16]=r28,16                /* save cr.iip */
-       st8 [r17]=r30,16                /* save cr.ifs */
-       mov r8=ar.fpsr          /* M */
-       mov r9=ar.csd
-       mov r10=ar.ssd
-       movl r11=FPSR_DEFAULT   /* L-unit */
-       ;;
-       st8 [r16]=r25,16                /* save ar.unat */
-       st8 [r17]=r26,16                /* save ar.pfs */
-       shl r18=r18,16          /* compute ar.rsc to be used for "loadrs" */
-       ;;
-       st8 [r16]=r27,16                /* save ar.rsc */
-       adds r17=16,r17         /* skip over ar_rnat field */
-       ;;
-       st8 [r17]=r31,16                /* save predicates */
-       adds r16=16,r16         /* skip over ar_bspstore field */
-       ;;
-       st8 [r16]=r29,16                /* save b0 */
-       st8 [r17]=r18,16                /* save ar.rsc value for "loadrs" */
-       ;;
-.mem.offset 0,0; st8.spill [r16]=r20,16    /* save original r1 */
-.mem.offset 8,0; st8.spill [r17]=r12,16
-       adds r12=-16,r1
-       /* switch to kernel memory stack (with 16 bytes of scratch) */
-       ;;
-.mem.offset 0,0; st8.spill [r16]=r13,16
-.mem.offset 8,0; st8.spill [r17]=r8,16 /* save ar.fpsr */
-       ;;
-.mem.offset 0,0; st8.spill [r16]=r15,16
-.mem.offset 8,0; st8.spill [r17]=r14,16
-       dep r14=-1,r0,60,4
-       ;;
-.mem.offset 0,0; st8.spill [r16]=r2,16
-.mem.offset 8,0; st8.spill [r17]=r3,16
-       adds r2=VMM_PT_REGS_R16_OFFSET,r1
-       adds r14 = VMM_VCPU_GP_OFFSET,r13
-       ;;
-       mov r8=ar.ccv
-       ld8 r14 = [r14]
-       ;;
-       mov r1=r14       /* establish kernel global pointer */
-       ;;                                          \
-       bsw.1
-       ;;
-       alloc r14=ar.pfs,0,0,1,0        // must be first in an insn group
-       mov out0=r13
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i
-       ;;
-       //(p15) ssm psr.i
-       adds r3=8,r2            // set up second base pointer for SAVE_REST
-       srlz.i                  // ensure everybody knows psr.ic is back on
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r16,16
-.mem.offset 8,0; st8.spill [r3]=r17,16
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r18,16
-.mem.offset 8,0; st8.spill [r3]=r19,16
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r20,16
-.mem.offset 8,0; st8.spill [r3]=r21,16
-       mov r18=b6
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r22,16
-.mem.offset 8,0; st8.spill [r3]=r23,16
-       mov r19=b7
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r24,16
-.mem.offset 8,0; st8.spill [r3]=r25,16
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r26,16
-.mem.offset 8,0; st8.spill [r3]=r27,16
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r28,16
-.mem.offset 8,0; st8.spill [r3]=r29,16
-       ;;
-.mem.offset 0,0; st8.spill [r2]=r30,16
-.mem.offset 8,0; st8.spill [r3]=r31,32
-       ;;
-       mov ar.fpsr=r11       /* M-unit */
-       st8 [r2]=r8,8         /* ar.ccv */
-       adds r24=PT(B6)-PT(F7),r3
-       ;;
-       stf.spill [r2]=f6,32
-       stf.spill [r3]=f7,32
-       ;;
-       stf.spill [r2]=f8,32
-       stf.spill [r3]=f9,32
-       ;;
-       stf.spill [r2]=f10
-       stf.spill [r3]=f11
-       adds r25=PT(B7)-PT(F11),r3
-       ;;
-       st8 [r24]=r18,16       /* b6 */
-       st8 [r25]=r19,16       /* b7 */
-       ;;
-       st8 [r24]=r9           /* ar.csd */
-       st8 [r25]=r10          /* ar.ssd */
-       ;;
-       srlz.d          // make sure we see the effect of cr.ivr
-       addl r14=@gprel(ia64_leave_nested),gp
-       ;;
-       mov rp=r14
-       br.call.sptk.many b6=kvm_ia64_handle_irq
-       ;;
-END(kvm_interrupt)
-
-    .global kvm_dispatch_vexirq
-    .org kvm_ia64_ivt+0x3400
-//////////////////////////////////////////////////////////////////////
-// 0x3400 Entry 13 (size 64 bundles) Reserved
-ENTRY(kvm_virtual_exirq)
-       mov r31=pr
-       mov r19=13
-       mov r30 =r0
-       ;;
-kvm_dispatch_vexirq:
-       cmp.eq p6,p0 = 1,r30
-       ;;
-(p6)   add r29 = VMM_VCPU_SAVED_GP_OFFSET,r21
-       ;;
-(p6)   ld8 r1 = [r29]
-       ;;
-       KVM_SAVE_MIN_WITH_COVER_R19
-       alloc r14=ar.pfs,0,0,1,0
-       mov out0=r13
-
-       ssm psr.ic
-       ;;
-       srlz.i // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.i
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       KVM_SAVE_REST
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       mov rp=r14
-       br.call.sptk.many b6=kvm_vexirq
-END(kvm_virtual_exirq)
-
-    .org kvm_ia64_ivt+0x3800
-/////////////////////////////////////////////////////////////////////
-// 0x3800 Entry 14 (size 64 bundles) Reserved
-       KVM_FAULT(14)
-       // this code segment is from 2.6.16.13
-
-    .org kvm_ia64_ivt+0x3c00
-///////////////////////////////////////////////////////////////////////
-// 0x3c00 Entry 15 (size 64 bundles) Reserved
-       KVM_FAULT(15)
-
-    .org kvm_ia64_ivt+0x4000
-///////////////////////////////////////////////////////////////////////
-// 0x4000 Entry 16 (size 64 bundles) Reserved
-       KVM_FAULT(16)
-
-    .org kvm_ia64_ivt+0x4400
-//////////////////////////////////////////////////////////////////////
-// 0x4400 Entry 17 (size 64 bundles) Reserved
-       KVM_FAULT(17)
-
-    .org kvm_ia64_ivt+0x4800
-//////////////////////////////////////////////////////////////////////
-// 0x4800 Entry 18 (size 64 bundles) Reserved
-       KVM_FAULT(18)
-
-    .org kvm_ia64_ivt+0x4c00
-//////////////////////////////////////////////////////////////////////
-// 0x4c00 Entry 19 (size 64 bundles) Reserved
-       KVM_FAULT(19)
-
-    .org kvm_ia64_ivt+0x5000
-//////////////////////////////////////////////////////////////////////
-// 0x5000 Entry 20 (size 16 bundles) Page Not Present
-ENTRY(kvm_page_not_present)
-       KVM_REFLECT(20)
-END(kvm_page_not_present)
-
-    .org kvm_ia64_ivt+0x5100
-///////////////////////////////////////////////////////////////////////
-// 0x5100 Entry 21 (size 16 bundles) Key Permission vector
-ENTRY(kvm_key_permission)
-       KVM_REFLECT(21)
-END(kvm_key_permission)
-
-    .org kvm_ia64_ivt+0x5200
-//////////////////////////////////////////////////////////////////////
-// 0x5200 Entry 22 (size 16 bundles) Instruction Access Rights (26)
-ENTRY(kvm_iaccess_rights)
-       KVM_REFLECT(22)
-END(kvm_iaccess_rights)
-
-    .org kvm_ia64_ivt+0x5300
-//////////////////////////////////////////////////////////////////////
-// 0x5300 Entry 23 (size 16 bundles) Data Access Rights (14,53)
-ENTRY(kvm_daccess_rights)
-       KVM_REFLECT(23)
-END(kvm_daccess_rights)
-
-    .org kvm_ia64_ivt+0x5400
-/////////////////////////////////////////////////////////////////////
-// 0x5400 Entry 24 (size 16 bundles) General Exception (5,32,34,36,38,39)
-ENTRY(kvm_general_exception)
-       KVM_REFLECT(24)
-       KVM_FAULT(24)
-END(kvm_general_exception)
-
-    .org kvm_ia64_ivt+0x5500
-//////////////////////////////////////////////////////////////////////
-// 0x5500 Entry 25 (size 16 bundles) Disabled FP-Register (35)
-ENTRY(kvm_disabled_fp_reg)
-       KVM_REFLECT(25)
-END(kvm_disabled_fp_reg)
-
-    .org kvm_ia64_ivt+0x5600
-////////////////////////////////////////////////////////////////////
-// 0x5600 Entry 26 (size 16 bundles) Nat Consumption (11,23,37,50)
-ENTRY(kvm_nat_consumption)
-       KVM_REFLECT(26)
-END(kvm_nat_consumption)
-
-    .org kvm_ia64_ivt+0x5700
-/////////////////////////////////////////////////////////////////////
-// 0x5700 Entry 27 (size 16 bundles) Speculation (40)
-ENTRY(kvm_speculation_vector)
-       KVM_REFLECT(27)
-END(kvm_speculation_vector)
-
-    .org kvm_ia64_ivt+0x5800
-/////////////////////////////////////////////////////////////////////
-// 0x5800 Entry 28 (size 16 bundles) Reserved
-       KVM_FAULT(28)
-
-    .org kvm_ia64_ivt+0x5900
-///////////////////////////////////////////////////////////////////
-// 0x5900 Entry 29 (size 16 bundles) Debug (16,28,56)
-ENTRY(kvm_debug_vector)
-       KVM_FAULT(29)
-END(kvm_debug_vector)
-
-    .org kvm_ia64_ivt+0x5a00
-///////////////////////////////////////////////////////////////
-// 0x5a00 Entry 30 (size 16 bundles) Unaligned Reference (57)
-ENTRY(kvm_unaligned_access)
-       KVM_REFLECT(30)
-END(kvm_unaligned_access)
-
-    .org kvm_ia64_ivt+0x5b00
-//////////////////////////////////////////////////////////////////////
-// 0x5b00 Entry 31 (size 16 bundles) Unsupported Data Reference (57)
-ENTRY(kvm_unsupported_data_reference)
-       KVM_REFLECT(31)
-END(kvm_unsupported_data_reference)
-
-    .org kvm_ia64_ivt+0x5c00
-////////////////////////////////////////////////////////////////////
-// 0x5c00 Entry 32 (size 16 bundles) Floating Point FAULT (65)
-ENTRY(kvm_floating_point_fault)
-       KVM_REFLECT(32)
-END(kvm_floating_point_fault)
-
-    .org kvm_ia64_ivt+0x5d00
-/////////////////////////////////////////////////////////////////////
-// 0x5d00 Entry 33 (size 16 bundles) Floating Point Trap (66)
-ENTRY(kvm_floating_point_trap)
-       KVM_REFLECT(33)
-END(kvm_floating_point_trap)
-
-    .org kvm_ia64_ivt+0x5e00
-//////////////////////////////////////////////////////////////////////
-// 0x5e00 Entry 34 (size 16 bundles) Lower Privilege Transfer Trap (66)
-ENTRY(kvm_lower_privilege_trap)
-       KVM_REFLECT(34)
-END(kvm_lower_privilege_trap)
-
-    .org kvm_ia64_ivt+0x5f00
-//////////////////////////////////////////////////////////////////////
-// 0x5f00 Entry 35 (size 16 bundles) Taken Branch Trap (68)
-ENTRY(kvm_taken_branch_trap)
-       KVM_REFLECT(35)
-END(kvm_taken_branch_trap)
-
-    .org kvm_ia64_ivt+0x6000
-////////////////////////////////////////////////////////////////////
-// 0x6000 Entry 36 (size 16 bundles) Single Step Trap (69)
-ENTRY(kvm_single_step_trap)
-       KVM_REFLECT(36)
-END(kvm_single_step_trap)
-    .global kvm_virtualization_fault_back
-    .org kvm_ia64_ivt+0x6100
-/////////////////////////////////////////////////////////////////////
-// 0x6100 Entry 37 (size 16 bundles) Virtualization Fault
-ENTRY(kvm_virtualization_fault)
-       mov r31=pr
-       adds r16 = VMM_VCPU_SAVED_GP_OFFSET,r21
-       ;;
-       st8 [r16] = r1
-       adds r17 = VMM_VCPU_GP_OFFSET, r21
-       ;;
-       ld8 r1 = [r17]
-       cmp.eq p6,p0=EVENT_MOV_FROM_AR,r24
-       cmp.eq p7,p0=EVENT_MOV_FROM_RR,r24
-       cmp.eq p8,p0=EVENT_MOV_TO_RR,r24
-       cmp.eq p9,p0=EVENT_RSM,r24
-       cmp.eq p10,p0=EVENT_SSM,r24
-       cmp.eq p11,p0=EVENT_MOV_TO_PSR,r24
-       cmp.eq p12,p0=EVENT_THASH,r24
-(p6)   br.dptk.many kvm_asm_mov_from_ar
-(p7)   br.dptk.many kvm_asm_mov_from_rr
-(p8)   br.dptk.many kvm_asm_mov_to_rr
-(p9)   br.dptk.many kvm_asm_rsm
-(p10)  br.dptk.many kvm_asm_ssm
-(p11)  br.dptk.many kvm_asm_mov_to_psr
-(p12)  br.dptk.many kvm_asm_thash
-       ;;
-kvm_virtualization_fault_back:
-       adds r16 = VMM_VCPU_SAVED_GP_OFFSET,r21
-       ;;
-       ld8 r1 = [r16]
-       ;;
-       mov r19=37
-       adds r16 = VMM_VCPU_CAUSE_OFFSET,r21
-       adds r17 = VMM_VCPU_OPCODE_OFFSET,r21
-       ;;
-       st8 [r16] = r24
-       st8 [r17] = r25
-       ;;
-       cmp.ne p6,p0=EVENT_RFI, r24
-(p6)   br.sptk kvm_dispatch_virtualization_fault
-       ;;
-       adds r18=VMM_VPD_BASE_OFFSET,r21
-       ;;
-       ld8 r18=[r18]
-       ;;
-       adds r18=VMM_VPD_VIFS_OFFSET,r18
-       ;;
-       ld8 r18=[r18]
-       ;;
-       tbit.z p6,p0=r18,63
-(p6)   br.sptk kvm_dispatch_virtualization_fault
-       ;;
-//if vifs.v=1 desert current register frame
-       alloc r18=ar.pfs,0,0,0,0
-       br.sptk kvm_dispatch_virtualization_fault
-END(kvm_virtualization_fault)
-
-    .org kvm_ia64_ivt+0x6200
-//////////////////////////////////////////////////////////////
-// 0x6200 Entry 38 (size 16 bundles) Reserved
-       KVM_FAULT(38)
-
-    .org kvm_ia64_ivt+0x6300
-/////////////////////////////////////////////////////////////////
-// 0x6300 Entry 39 (size 16 bundles) Reserved
-       KVM_FAULT(39)
-
-    .org kvm_ia64_ivt+0x6400
-/////////////////////////////////////////////////////////////////
-// 0x6400 Entry 40 (size 16 bundles) Reserved
-       KVM_FAULT(40)
-
-    .org kvm_ia64_ivt+0x6500
-//////////////////////////////////////////////////////////////////
-// 0x6500 Entry 41 (size 16 bundles) Reserved
-       KVM_FAULT(41)
-
-    .org kvm_ia64_ivt+0x6600
-//////////////////////////////////////////////////////////////////
-// 0x6600 Entry 42 (size 16 bundles) Reserved
-       KVM_FAULT(42)
-
-    .org kvm_ia64_ivt+0x6700
-//////////////////////////////////////////////////////////////////
-// 0x6700 Entry 43 (size 16 bundles) Reserved
-       KVM_FAULT(43)
-
-    .org kvm_ia64_ivt+0x6800
-//////////////////////////////////////////////////////////////////
-// 0x6800 Entry 44 (size 16 bundles) Reserved
-       KVM_FAULT(44)
-
-    .org kvm_ia64_ivt+0x6900
-///////////////////////////////////////////////////////////////////
-// 0x6900 Entry 45 (size 16 bundles) IA-32 Exeception
-//(17,18,29,41,42,43,44,58,60,61,62,72,73,75,76,77)
-ENTRY(kvm_ia32_exception)
-       KVM_FAULT(45)
-END(kvm_ia32_exception)
-
-    .org kvm_ia64_ivt+0x6a00
-////////////////////////////////////////////////////////////////////
-// 0x6a00 Entry 46 (size 16 bundles) IA-32 Intercept  (30,31,59,70,71)
-ENTRY(kvm_ia32_intercept)
-       KVM_FAULT(47)
-END(kvm_ia32_intercept)
-
-    .org kvm_ia64_ivt+0x6c00
-/////////////////////////////////////////////////////////////////////
-// 0x6c00 Entry 48 (size 16 bundles) Reserved
-       KVM_FAULT(48)
-
-    .org kvm_ia64_ivt+0x6d00
-//////////////////////////////////////////////////////////////////////
-// 0x6d00 Entry 49 (size 16 bundles) Reserved
-       KVM_FAULT(49)
-
-    .org kvm_ia64_ivt+0x6e00
-//////////////////////////////////////////////////////////////////////
-// 0x6e00 Entry 50 (size 16 bundles) Reserved
-       KVM_FAULT(50)
-
-    .org kvm_ia64_ivt+0x6f00
-/////////////////////////////////////////////////////////////////////
-// 0x6f00 Entry 51 (size 16 bundles) Reserved
-       KVM_FAULT(52)
-
-    .org kvm_ia64_ivt+0x7100
-////////////////////////////////////////////////////////////////////
-// 0x7100 Entry 53 (size 16 bundles) Reserved
-       KVM_FAULT(53)
-
-    .org kvm_ia64_ivt+0x7200
-/////////////////////////////////////////////////////////////////////
-// 0x7200 Entry 54 (size 16 bundles) Reserved
-       KVM_FAULT(54)
-
-    .org kvm_ia64_ivt+0x7300
-////////////////////////////////////////////////////////////////////
-// 0x7300 Entry 55 (size 16 bundles) Reserved
-       KVM_FAULT(55)
-
-    .org kvm_ia64_ivt+0x7400
-////////////////////////////////////////////////////////////////////
-// 0x7400 Entry 56 (size 16 bundles) Reserved
-       KVM_FAULT(56)
-
-    .org kvm_ia64_ivt+0x7500
-/////////////////////////////////////////////////////////////////////
-// 0x7500 Entry 57 (size 16 bundles) Reserved
-       KVM_FAULT(57)
-
-    .org kvm_ia64_ivt+0x7600
-/////////////////////////////////////////////////////////////////////
-// 0x7600 Entry 58 (size 16 bundles) Reserved
-       KVM_FAULT(58)
-
-    .org kvm_ia64_ivt+0x7700
-////////////////////////////////////////////////////////////////////
-// 0x7700 Entry 59 (size 16 bundles) Reserved
-       KVM_FAULT(59)
-
-    .org kvm_ia64_ivt+0x7800
-////////////////////////////////////////////////////////////////////
-// 0x7800 Entry 60 (size 16 bundles) Reserved
-       KVM_FAULT(60)
-
-    .org kvm_ia64_ivt+0x7900
-/////////////////////////////////////////////////////////////////////
-// 0x7900 Entry 61 (size 16 bundles) Reserved
-       KVM_FAULT(61)
-
-    .org kvm_ia64_ivt+0x7a00
-/////////////////////////////////////////////////////////////////////
-// 0x7a00 Entry 62 (size 16 bundles) Reserved
-       KVM_FAULT(62)
-
-    .org kvm_ia64_ivt+0x7b00
-/////////////////////////////////////////////////////////////////////
-// 0x7b00 Entry 63 (size 16 bundles) Reserved
-       KVM_FAULT(63)
-
-    .org kvm_ia64_ivt+0x7c00
-////////////////////////////////////////////////////////////////////
-// 0x7c00 Entry 64 (size 16 bundles) Reserved
-       KVM_FAULT(64)
-
-    .org kvm_ia64_ivt+0x7d00
-/////////////////////////////////////////////////////////////////////
-// 0x7d00 Entry 65 (size 16 bundles) Reserved
-       KVM_FAULT(65)
-
-    .org kvm_ia64_ivt+0x7e00
-/////////////////////////////////////////////////////////////////////
-// 0x7e00 Entry 66 (size 16 bundles) Reserved
-       KVM_FAULT(66)
-
-    .org kvm_ia64_ivt+0x7f00
-////////////////////////////////////////////////////////////////////
-// 0x7f00 Entry 67 (size 16 bundles) Reserved
-       KVM_FAULT(67)
-
-    .org kvm_ia64_ivt+0x8000
-// There is no particular reason for this code to be here, other than that
-// there happens to be space here that would go unused otherwise.  If this
-// fault ever gets "unreserved", simply moved the following code to a more
-// suitable spot...
-
-
-ENTRY(kvm_dtlb_miss_dispatch)
-       mov r19 = 2
-       KVM_SAVE_MIN_WITH_COVER_R19
-       alloc r14=ar.pfs,0,0,3,0
-       mov out0=cr.ifa
-       mov out1=r15
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i     // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.i
-       addl r14=@gprel(ia64_leave_hypervisor_prepare),gp
-       ;;
-       KVM_SAVE_REST
-       KVM_SAVE_EXTRA
-       mov rp=r14
-       ;;
-       adds out2=16,r12
-       br.call.sptk.many b6=kvm_page_fault
-END(kvm_dtlb_miss_dispatch)
-
-ENTRY(kvm_itlb_miss_dispatch)
-
-       KVM_SAVE_MIN_WITH_COVER_R19
-       alloc r14=ar.pfs,0,0,3,0
-       mov out0=cr.ifa
-       mov out1=r15
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i   // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.i
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       KVM_SAVE_REST
-       mov rp=r14
-       ;;
-       adds out2=16,r12
-       br.call.sptk.many b6=kvm_page_fault
-END(kvm_itlb_miss_dispatch)
-
-ENTRY(kvm_dispatch_reflection)
-/*
- * Input:
- *  psr.ic: off
- *  r19:    intr type (offset into ivt, see ia64_int.h)
- *  r31:    contains saved predicates (pr)
- */
-       KVM_SAVE_MIN_WITH_COVER_R19
-       alloc r14=ar.pfs,0,0,5,0
-       mov out0=cr.ifa
-       mov out1=cr.isr
-       mov out2=cr.iim
-       mov out3=r15
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i   // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.i
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       KVM_SAVE_REST
-       mov rp=r14
-       ;;
-       adds out4=16,r12
-       br.call.sptk.many b6=reflect_interruption
-END(kvm_dispatch_reflection)
-
-ENTRY(kvm_dispatch_virtualization_fault)
-       adds r16 = VMM_VCPU_CAUSE_OFFSET,r21
-       adds r17 = VMM_VCPU_OPCODE_OFFSET,r21
-       ;;
-       st8 [r16] = r24
-       st8 [r17] = r25
-       ;;
-       KVM_SAVE_MIN_WITH_COVER_R19
-       ;;
-       alloc r14=ar.pfs,0,0,2,0 // (must be first in insn group!)
-       mov out0=r13        //vcpu
-       adds r3=8,r2                // set up second base pointer
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i    // guarantee that interruption collection is on
-       ;;
-       (p15) ssm psr.i               // restore psr.i
-       addl r14=@gprel(ia64_leave_hypervisor_prepare),gp
-       ;;
-       KVM_SAVE_REST
-       KVM_SAVE_EXTRA
-       mov rp=r14
-       ;;
-       adds out1=16,sp         //regs
-       br.call.sptk.many b6=kvm_emulate
-END(kvm_dispatch_virtualization_fault)
-
-
-ENTRY(kvm_dispatch_interrupt)
-       KVM_SAVE_MIN_WITH_COVER_R19     // uses r31; defines r2 and r3
-       ;;
-       alloc r14=ar.pfs,0,0,1,0 // must be first in an insn group
-       adds r3=8,r2            // set up second base pointer for SAVE_REST
-       ;;
-       ssm psr.ic
-       ;;
-       srlz.i
-       ;;
-       (p15) ssm psr.i
-       addl r14=@gprel(ia64_leave_hypervisor),gp
-       ;;
-       KVM_SAVE_REST
-       mov rp=r14
-       ;;
-       mov out0=r13            // pass pointer to pt_regs as second arg
-       br.call.sptk.many b6=kvm_ia64_handle_irq
-END(kvm_dispatch_interrupt)
-
-GLOBAL_ENTRY(ia64_leave_nested)
-       rsm psr.i
-       ;;
-       adds r21=PT(PR)+16,r12
-       ;;
-       lfetch [r21],PT(CR_IPSR)-PT(PR)
-       adds r2=PT(B6)+16,r12
-       adds r3=PT(R16)+16,r12
-       ;;
-       lfetch [r21]
-       ld8 r28=[r2],8          // load b6
-       adds r29=PT(R24)+16,r12
-
-       ld8.fill r16=[r3]
-       adds r3=PT(AR_CSD)-PT(R16),r3
-       adds r30=PT(AR_CCV)+16,r12
-       ;;
-       ld8.fill r24=[r29]
-       ld8 r15=[r30]           // load ar.ccv
-       ;;
-       ld8 r29=[r2],16         // load b7
-       ld8 r30=[r3],16         // load ar.csd
-       ;;
-       ld8 r31=[r2],16         // load ar.ssd
-       ld8.fill r8=[r3],16
-       ;;
-       ld8.fill r9=[r2],16
-       ld8.fill r10=[r3],PT(R17)-PT(R10)
-       ;;
-       ld8.fill r11=[r2],PT(R18)-PT(R11)
-       ld8.fill r17=[r3],16
-       ;;
-       ld8.fill r18=[r2],16
-       ld8.fill r19=[r3],16
-       ;;
-       ld8.fill r20=[r2],16
-       ld8.fill r21=[r3],16
-       mov ar.csd=r30
-       mov ar.ssd=r31
-       ;;
-       rsm psr.i | psr.ic
-       // initiate turning off of interrupt and interruption collection
-       invala                  // invalidate ALAT
-       ;;
-       srlz.i
-       ;;
-       ld8.fill r22=[r2],24
-       ld8.fill r23=[r3],24
-       mov b6=r28
-       ;;
-       ld8.fill r25=[r2],16
-       ld8.fill r26=[r3],16
-       mov b7=r29
-       ;;
-       ld8.fill r27=[r2],16
-       ld8.fill r28=[r3],16
-       ;;
-       ld8.fill r29=[r2],16
-       ld8.fill r30=[r3],24
-       ;;
-       ld8.fill r31=[r2],PT(F9)-PT(R31)
-       adds r3=PT(F10)-PT(F6),r3
-       ;;
-       ldf.fill f9=[r2],PT(F6)-PT(F9)
-       ldf.fill f10=[r3],PT(F8)-PT(F10)
-       ;;
-       ldf.fill f6=[r2],PT(F7)-PT(F6)
-       ;;
-       ldf.fill f7=[r2],PT(F11)-PT(F7)
-       ldf.fill f8=[r3],32
-       ;;
-       srlz.i                  // ensure interruption collection is off
-       mov ar.ccv=r15
-       ;;
-       bsw.0   // switch back to bank 0 (no stop bit required beforehand...)
-       ;;
-       ldf.fill f11=[r2]
-//     mov r18=r13
-//     mov r21=r13
-       adds r16=PT(CR_IPSR)+16,r12
-       adds r17=PT(CR_IIP)+16,r12
-       ;;
-       ld8 r29=[r16],16        // load cr.ipsr
-       ld8 r28=[r17],16        // load cr.iip
-       ;;
-       ld8 r30=[r16],16        // load cr.ifs
-       ld8 r25=[r17],16        // load ar.unat
-       ;;
-       ld8 r26=[r16],16        // load ar.pfs
-       ld8 r27=[r17],16        // load ar.rsc
-       cmp.eq p9,p0=r0,r0
-       // set p9 to indicate that we should restore cr.ifs
-       ;;
-       ld8 r24=[r16],16        // load ar.rnat (may be garbage)
-       ld8 r23=[r17],16// load ar.bspstore (may be garbage)
-       ;;
-       ld8 r31=[r16],16        // load predicates
-       ld8 r22=[r17],16        // load b0
-       ;;
-       ld8 r19=[r16],16        // load ar.rsc value for "loadrs"
-       ld8.fill r1=[r17],16    // load r1
-       ;;
-       ld8.fill r12=[r16],16
-       ld8.fill r13=[r17],16
-       ;;
-       ld8 r20=[r16],16        // ar.fpsr
-       ld8.fill r15=[r17],16
-       ;;
-       ld8.fill r14=[r16],16
-       ld8.fill r2=[r17]
-       ;;
-       ld8.fill r3=[r16]
-       ;;
-       mov r16=ar.bsp          // get existing backing store pointer
-       ;;
-       mov b0=r22
-       mov ar.pfs=r26
-       mov cr.ifs=r30
-       mov cr.ipsr=r29
-       mov ar.fpsr=r20
-       mov cr.iip=r28
-       ;;
-       mov ar.rsc=r27
-       mov ar.unat=r25
-       mov pr=r31,-1
-       rfi
-END(ia64_leave_nested)
-
-GLOBAL_ENTRY(ia64_leave_hypervisor_prepare)
-/*
- * work.need_resched etc. mustn't get changed
- *by this CPU before it returns to
- * user- or fsys-mode, hence we disable interrupts early on:
- */
-       adds r2 = PT(R4)+16,r12
-       adds r3 = PT(R5)+16,r12
-       adds r8 = PT(EML_UNAT)+16,r12
-       ;;
-       ld8 r8 = [r8]
-       ;;
-       mov ar.unat=r8
-       ;;
-       ld8.fill r4=[r2],16    //load r4
-       ld8.fill r5=[r3],16    //load r5
-       ;;
-       ld8.fill r6=[r2]    //load r6
-       ld8.fill r7=[r3]    //load r7
-       ;;
-END(ia64_leave_hypervisor_prepare)
-//fall through
-GLOBAL_ENTRY(ia64_leave_hypervisor)
-       rsm psr.i
-       ;;
-       br.call.sptk.many b0=leave_hypervisor_tail
-       ;;
-       adds r20=PT(PR)+16,r12
-       adds r8=PT(EML_UNAT)+16,r12
-       ;;
-       ld8 r8=[r8]
-       ;;
-       mov ar.unat=r8
-       ;;
-       lfetch [r20],PT(CR_IPSR)-PT(PR)
-       adds r2 = PT(B6)+16,r12
-       adds r3 = PT(B7)+16,r12
-       ;;
-       lfetch [r20]
-       ;;
-       ld8 r24=[r2],16        /* B6 */
-       ld8 r25=[r3],16        /* B7 */
-       ;;
-       ld8 r26=[r2],16        /* ar_csd */
-       ld8 r27=[r3],16        /* ar_ssd */
-       mov b6 = r24
-       ;;
-       ld8.fill r8=[r2],16
-       ld8.fill r9=[r3],16
-       mov b7 = r25
-       ;;
-       mov ar.csd = r26
-       mov ar.ssd = r27
-       ;;
-       ld8.fill r10=[r2],PT(R15)-PT(R10)
-       ld8.fill r11=[r3],PT(R14)-PT(R11)
-       ;;
-       ld8.fill r15=[r2],PT(R16)-PT(R15)
-       ld8.fill r14=[r3],PT(R17)-PT(R14)
-       ;;
-       ld8.fill r16=[r2],16
-       ld8.fill r17=[r3],16
-       ;;
-       ld8.fill r18=[r2],16
-       ld8.fill r19=[r3],16
-       ;;
-       ld8.fill r20=[r2],16
-       ld8.fill r21=[r3],16
-       ;;
-       ld8.fill r22=[r2],16
-       ld8.fill r23=[r3],16
-       ;;
-       ld8.fill r24=[r2],16
-       ld8.fill r25=[r3],16
-       ;;
-       ld8.fill r26=[r2],16
-       ld8.fill r27=[r3],16
-       ;;
-       ld8.fill r28=[r2],16
-       ld8.fill r29=[r3],16
-       ;;
-       ld8.fill r30=[r2],PT(F6)-PT(R30)
-       ld8.fill r31=[r3],PT(F7)-PT(R31)
-       ;;
-       rsm psr.i | psr.ic
-       // initiate turning off of interrupt and interruption collection
-       invala          // invalidate ALAT
-       ;;
-       srlz.i          // ensure interruption collection is off
-       ;;
-       bsw.0
-       ;;
-       adds r16 = PT(CR_IPSR)+16,r12
-       adds r17 = PT(CR_IIP)+16,r12
-       mov r21=r13             // get current
-       ;;
-       ld8 r31=[r16],16    // load cr.ipsr
-       ld8 r30=[r17],16    // load cr.iip
-       ;;
-       ld8 r29=[r16],16    // load cr.ifs
-       ld8 r28=[r17],16    // load ar.unat
-       ;;
-       ld8 r27=[r16],16    // load ar.pfs
-       ld8 r26=[r17],16    // load ar.rsc
-       ;;
-       ld8 r25=[r16],16    // load ar.rnat
-       ld8 r24=[r17],16    // load ar.bspstore
-       ;;
-       ld8 r23=[r16],16    // load predicates
-       ld8 r22=[r17],16    // load b0
-       ;;
-       ld8 r20=[r16],16    // load ar.rsc value for "loadrs"
-       ld8.fill r1=[r17],16    //load r1
-       ;;
-       ld8.fill r12=[r16],16    //load r12
-       ld8.fill r13=[r17],PT(R2)-PT(R13)    //load r13
-       ;;
-       ld8 r19=[r16],PT(R3)-PT(AR_FPSR)    //load ar_fpsr
-       ld8.fill r2=[r17],PT(AR_CCV)-PT(R2)    //load r2
-       ;;
-       ld8.fill r3=[r16]       //load r3
-       ld8 r18=[r17]   //load ar_ccv
-       ;;
-       mov ar.fpsr=r19
-       mov ar.ccv=r18
-       shr.u r18=r20,16
-       ;;
-kvm_rbs_switch:
-       mov r19=96
-
-kvm_dont_preserve_current_frame:
-/*
-    * To prevent leaking bits between the hypervisor and guest domain,
-    * we must clear the stacked registers in the "invalid" partition here.
-    * 5 registers/cycle on McKinley).
-    */
-#   define pRecurse    p6
-#   define pReturn     p7
-#   define Nregs       14
-
-       alloc loc0=ar.pfs,2,Nregs-2,2,0
-       shr.u loc1=r18,9        // RNaTslots <= floor(dirtySize / (64*8))
-       sub r19=r19,r18         // r19 = (physStackedSize + 8) - dirtySize
-       ;;
-       mov ar.rsc=r20          // load ar.rsc to be used for "loadrs"
-       shladd in0=loc1,3,r19
-       mov in1=0
-       ;;
-       TEXT_ALIGN(32)
-kvm_rse_clear_invalid:
-       alloc loc0=ar.pfs,2,Nregs-2,2,0
-       cmp.lt pRecurse,p0=Nregs*8,in0
-       // if more than Nregs regs left to clear, (re)curse
-       add out0=-Nregs*8,in0
-       add out1=1,in1          // increment recursion count
-       mov loc1=0
-       mov loc2=0
-       ;;
-       mov loc3=0
-       mov loc4=0
-       mov loc5=0
-       mov loc6=0
-       mov loc7=0
-(pRecurse) br.call.dptk.few b0=kvm_rse_clear_invalid
-       ;;
-       mov loc8=0
-       mov loc9=0
-       cmp.ne pReturn,p0=r0,in1
-       // if recursion count != 0, we need to do a br.ret
-       mov loc10=0
-       mov loc11=0
-(pReturn) br.ret.dptk.many b0
-
-#      undef pRecurse
-#      undef pReturn
-
-// loadrs has already been shifted
-       alloc r16=ar.pfs,0,0,0,0    // drop current register frame
-       ;;
-       loadrs
-       ;;
-       mov ar.bspstore=r24
-       ;;
-       mov ar.unat=r28
-       mov ar.rnat=r25
-       mov ar.rsc=r26
-       ;;
-       mov cr.ipsr=r31
-       mov cr.iip=r30
-       mov cr.ifs=r29
-       mov ar.pfs=r27
-       adds r18=VMM_VPD_BASE_OFFSET,r21
-       ;;
-       ld8 r18=[r18]   //vpd
-       adds r17=VMM_VCPU_ISR_OFFSET,r21
-       ;;
-       ld8 r17=[r17]
-       adds r19=VMM_VPD_VPSR_OFFSET,r18
-       ;;
-       ld8 r19=[r19]        //vpsr
-       mov r25=r18
-       adds r16= VMM_VCPU_GP_OFFSET,r21
-       ;;
-       ld8 r16= [r16] // Put gp in r24
-       movl r24=@gprel(ia64_vmm_entry)  // calculate return address
-       ;;
-       add  r24=r24,r16
-       ;;
-       br.sptk.many  kvm_vps_sync_write       // call the service
-       ;;
-END(ia64_leave_hypervisor)
-// fall through
-GLOBAL_ENTRY(ia64_vmm_entry)
-/*
- *  must be at bank 0
- *  parameter:
- *  r17:cr.isr
- *  r18:vpd
- *  r19:vpsr
- *  r22:b0
- *  r23:predicate
- */
-       mov r24=r22
-       mov r25=r18
-       tbit.nz p1,p2 = r19,IA64_PSR_IC_BIT        // p1=vpsr.ic
-(p1)   br.cond.sptk.few kvm_vps_resume_normal
-(p2)   br.cond.sptk.many kvm_vps_resume_handler
-       ;;
-END(ia64_vmm_entry)
-
-/*
- * extern u64 ia64_call_vsa(u64 proc, u64 arg1, u64 arg2,
- *                  u64 arg3, u64 arg4, u64 arg5,
- *                  u64 arg6, u64 arg7);
- *
- * XXX: The currently defined services use only 4 args at the max. The
- *  rest are not consumed.
- */
-GLOBAL_ENTRY(ia64_call_vsa)
-    .regstk 4,4,0,0
-
-rpsave  =   loc0
-pfssave =   loc1
-psrsave =   loc2
-entry   =   loc3
-hostret =   r24
-
-       alloc   pfssave=ar.pfs,4,4,0,0
-       mov rpsave=rp
-       adds entry=VMM_VCPU_VSA_BASE_OFFSET, r13
-       ;;
-       ld8 entry=[entry]
-1:     mov hostret=ip
-       mov r25=in1         // copy arguments
-       mov r26=in2
-       mov r27=in3
-       mov psrsave=psr
-       ;;
-       tbit.nz p6,p0=psrsave,14    // IA64_PSR_I
-       tbit.nz p7,p0=psrsave,13    // IA64_PSR_IC
-       ;;
-       add hostret=2f-1b,hostret   // calculate return address
-       add entry=entry,in0
-       ;;
-       rsm psr.i | psr.ic
-       ;;
-       srlz.i
-       mov b6=entry
-       br.cond.sptk b6         // call the service
-2:
-// Architectural sequence for enabling interrupts if necessary
-(p7)    ssm psr.ic
-       ;;
-(p7)    srlz.i
-       ;;
-(p6)    ssm psr.i
-       ;;
-       mov rp=rpsave
-       mov ar.pfs=pfssave
-       mov r8=r31
-       ;;
-       srlz.d
-       br.ret.sptk rp
-
-END(ia64_call_vsa)
-
-#define  INIT_BSPSTORE  ((4<<30)-(12<<20)-0x100)
-
-GLOBAL_ENTRY(vmm_reset_entry)
-       //set up ipsr, iip, vpd.vpsr, dcr
-       // For IPSR: it/dt/rt=1, i/ic=1, si=1, vm/bn=1
-       // For DCR: all bits 0
-       bsw.0
-       ;;
-       mov r21 =r13
-       adds r14=-VMM_PT_REGS_SIZE, r12
-       ;;
-       movl r6=0x501008826000      // IPSR dt/rt/it:1;i/ic:1, si:1, vm/bn:1
-       movl r10=0x8000000000000000
-       adds r16=PT(CR_IIP), r14
-       adds r20=PT(R1), r14
-       ;;
-       rsm psr.ic | psr.i
-       ;;
-       srlz.i
-       ;;
-       mov ar.rsc = 0
-       ;;
-       flushrs
-       ;;
-       mov ar.bspstore = 0
-       // clear BSPSTORE
-       ;;
-       mov cr.ipsr=r6
-       mov cr.ifs=r10
-       ld8 r4 = [r16] // Set init iip for first run.
-       ld8 r1 = [r20]
-       ;;
-       mov cr.iip=r4
-       adds r16=VMM_VPD_BASE_OFFSET,r13
-       ;;
-       ld8 r18=[r16]
-       ;;
-       adds r19=VMM_VPD_VPSR_OFFSET,r18
-       ;;
-       ld8 r19=[r19]
-       mov r17=r0
-       mov r22=r0
-       mov r23=r0
-       br.cond.sptk ia64_vmm_entry
-       br.ret.sptk  b0
-END(vmm_reset_entry)
diff --git a/arch/ia64/kvm/vti.h b/arch/ia64/kvm/vti.h
deleted file mode 100644 (file)
index b214b5b..0000000
+++ /dev/null
@@ -1,290 +0,0 @@
-/*
- * 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 {
-               unsigned int a_int:1;
-               unsigned int a_from_int_cr:1;
-               unsigned int a_to_int_cr:1;
-               unsigned int a_from_psr:1;
-               unsigned int a_from_cpuid:1;
-               unsigned int a_cover:1;
-               unsigned int a_bsw:1;
-               long reserved:57;
-       };
-};
-
-union vdc {
-       unsigned long value;
-       struct {
-               unsigned int d_vmsw:1;
-               unsigned int d_extint:1;
-               unsigned int d_ibr_dbr:1;
-               unsigned int d_pmc:1;
-               unsigned int d_to_pmd:1;
-               unsigned 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*/
diff --git a/arch/ia64/kvm/vtlb.c b/arch/ia64/kvm/vtlb.c
deleted file mode 100644 (file)
index a7869f8..0000000
+++ /dev/null
@@ -1,640 +0,0 @@
-/*
- * vtlb.c: guest virtual tlb handling module.
- * Copyright (c) 2004, Intel Corporation.
- *  Yaozu Dong (Eddie Dong) <Eddie.dong@intel.com>
- *  Xuefei Xu (Anthony Xu) <anthony.xu@intel.com>
- *
- * Copyright (c) 2007, Intel Corporation.
- *  Xuefei Xu (Anthony Xu) <anthony.xu@intel.com>
- *  Xiantao Zhang <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.
- *
- */
-
-#include "vcpu.h"
-
-#include <linux/rwsem.h>
-
-#include <asm/tlb.h>
-
-/*
- * Check to see if the address rid:va is translated by the TLB
- */
-
-static int __is_tr_translated(struct thash_data *trp, u64 rid, u64 va)
-{
-       return ((trp->p) && (trp->rid == rid)
-                               && ((va-trp->vadr) < PSIZE(trp->ps)));
-}
-
-/*
- * Only for GUEST TR format.
- */
-static int __is_tr_overlap(struct thash_data *trp, u64 rid, u64 sva, u64 eva)
-{
-       u64 sa1, ea1;
-
-       if (!trp->p || trp->rid != rid)
-               return 0;
-
-       sa1 = trp->vadr;
-       ea1 = sa1 + PSIZE(trp->ps) - 1;
-       eva -= 1;
-       if ((sva > ea1) || (sa1 > eva))
-               return 0;
-       else
-               return 1;
-
-}
-
-void machine_tlb_purge(u64 va, u64 ps)
-{
-       ia64_ptcl(va, ps << 2);
-}
-
-void local_flush_tlb_all(void)
-{
-       int i, j;
-       unsigned long flags, count0, count1;
-       unsigned long stride0, stride1, addr;
-
-       addr    = current_vcpu->arch.ptce_base;
-       count0  = current_vcpu->arch.ptce_count[0];
-       count1  = current_vcpu->arch.ptce_count[1];
-       stride0 = current_vcpu->arch.ptce_stride[0];
-       stride1 = current_vcpu->arch.ptce_stride[1];
-
-       local_irq_save(flags);
-       for (i = 0; i < count0; ++i) {
-               for (j = 0; j < count1; ++j) {
-                       ia64_ptce(addr);
-                       addr += stride1;
-               }
-               addr += stride0;
-       }
-       local_irq_restore(flags);
-       ia64_srlz_i();          /* srlz.i implies srlz.d */
-}
-
-int vhpt_enabled(struct kvm_vcpu *vcpu, u64 vadr, enum vhpt_ref ref)
-{
-       union ia64_rr    vrr;
-       union ia64_pta   vpta;
-       struct  ia64_psr   vpsr;
-
-       vpsr = *(struct ia64_psr *)&VCPU(vcpu, vpsr);
-       vrr.val = vcpu_get_rr(vcpu, vadr);
-       vpta.val = vcpu_get_pta(vcpu);
-
-       if (vrr.ve & vpta.ve) {
-               switch (ref) {
-               case DATA_REF:
-               case NA_REF:
-                       return vpsr.dt;
-               case INST_REF:
-                       return vpsr.dt && vpsr.it && vpsr.ic;
-               case RSE_REF:
-                       return vpsr.dt && vpsr.rt;
-
-               }
-       }
-       return 0;
-}
-
-struct thash_data *vsa_thash(union ia64_pta vpta, u64 va, u64 vrr, u64 *tag)
-{
-       u64 index, pfn, rid, pfn_bits;
-
-       pfn_bits = vpta.size - 5 - 8;
-       pfn = REGION_OFFSET(va) >> _REGION_PAGE_SIZE(vrr);
-       rid = _REGION_ID(vrr);
-       index = ((rid & 0xff) << pfn_bits)|(pfn & ((1UL << pfn_bits) - 1));
-       *tag = ((rid >> 8) & 0xffff) | ((pfn >> pfn_bits) << 16);
-
-       return (struct thash_data *)((vpta.base << PTA_BASE_SHIFT) +
-                               (index << 5));
-}
-
-struct thash_data *__vtr_lookup(struct kvm_vcpu *vcpu, u64 va, int type)
-{
-
-       struct thash_data *trp;
-       int  i;
-       u64 rid;
-
-       rid = vcpu_get_rr(vcpu, va);
-       rid = rid & RR_RID_MASK;
-       if (type == D_TLB) {
-               if (vcpu_quick_region_check(vcpu->arch.dtr_regions, va)) {
-                       for (trp = (struct thash_data *)&vcpu->arch.dtrs, i = 0;
-                                               i < NDTRS; i++, trp++) {
-                               if (__is_tr_translated(trp, rid, va))
-                                       return trp;
-                       }
-               }
-       } else {
-               if (vcpu_quick_region_check(vcpu->arch.itr_regions, va)) {
-                       for (trp = (struct thash_data *)&vcpu->arch.itrs, i = 0;
-                                       i < NITRS; i++, trp++) {
-                               if (__is_tr_translated(trp, rid, va))
-                                       return trp;
-                       }
-               }
-       }
-
-       return NULL;
-}
-
-static void vhpt_insert(u64 pte, u64 itir, u64 ifa, u64 gpte)
-{
-       union ia64_rr rr;
-       struct thash_data *head;
-       unsigned long ps, gpaddr;
-
-       ps = itir_ps(itir);
-       rr.val = ia64_get_rr(ifa);
-
-        gpaddr = ((gpte & _PAGE_PPN_MASK) >> ps << ps) |
-                                       (ifa & ((1UL << ps) - 1));
-
-       head = (struct thash_data *)ia64_thash(ifa);
-       head->etag = INVALID_TI_TAG;
-       ia64_mf();
-       head->page_flags = pte & ~PAGE_FLAGS_RV_MASK;
-       head->itir = rr.ps << 2;
-       head->etag = ia64_ttag(ifa);
-       head->gpaddr = gpaddr;
-}
-
-void mark_pages_dirty(struct kvm_vcpu *v, u64 pte, u64 ps)
-{
-       u64 i, dirty_pages = 1;
-       u64 base_gfn = (pte&_PAGE_PPN_MASK) >> PAGE_SHIFT;
-       vmm_spinlock_t *lock = __kvm_va(v->arch.dirty_log_lock_pa);
-       void *dirty_bitmap = (void *)KVM_MEM_DIRTY_LOG_BASE;
-
-       dirty_pages <<= ps <= PAGE_SHIFT ? 0 : ps - PAGE_SHIFT;
-
-       vmm_spin_lock(lock);
-       for (i = 0; i < dirty_pages; i++) {
-               /* avoid RMW */
-               if (!test_bit(base_gfn + i, dirty_bitmap))
-                       set_bit(base_gfn + i , dirty_bitmap);
-       }
-       vmm_spin_unlock(lock);
-}
-
-void thash_vhpt_insert(struct kvm_vcpu *v, u64 pte, u64 itir, u64 va, int type)
-{
-       u64 phy_pte, psr;
-       union ia64_rr mrr;
-
-       mrr.val = ia64_get_rr(va);
-       phy_pte = translate_phy_pte(&pte, itir, va);
-
-       if (itir_ps(itir) >= mrr.ps) {
-               vhpt_insert(phy_pte, itir, va, pte);
-       } else {
-               phy_pte  &= ~PAGE_FLAGS_RV_MASK;
-               psr = ia64_clear_ic();
-               ia64_itc(type, va, phy_pte, itir_ps(itir));
-               paravirt_dv_serialize_data();
-               ia64_set_psr(psr);
-       }
-
-       if (!(pte&VTLB_PTE_IO))
-               mark_pages_dirty(v, pte, itir_ps(itir));
-}
-
-/*
- *   vhpt lookup
- */
-struct thash_data *vhpt_lookup(u64 va)
-{
-       struct thash_data *head;
-       u64 tag;
-
-       head = (struct thash_data *)ia64_thash(va);
-       tag = ia64_ttag(va);
-       if (head->etag == tag)
-               return head;
-       return NULL;
-}
-
-u64 guest_vhpt_lookup(u64 iha, u64 *pte)
-{
-       u64 ret;
-       struct thash_data *data;
-
-       data = __vtr_lookup(current_vcpu, iha, D_TLB);
-       if (data != NULL)
-               thash_vhpt_insert(current_vcpu, data->page_flags,
-                       data->itir, iha, D_TLB);
-
-       asm volatile ("rsm psr.ic|psr.i;;"
-                       "srlz.d;;"
-                       "ld8.s r9=[%1];;"
-                       "tnat.nz p6,p7=r9;;"
-                       "(p6) mov %0=1;"
-                       "(p6) mov r9=r0;"
-                       "(p7) extr.u r9=r9,0,53;;"
-                       "(p7) mov %0=r0;"
-                       "(p7) st8 [%2]=r9;;"
-                       "ssm psr.ic;;"
-                       "srlz.d;;"
-                       "ssm psr.i;;"
-                       "srlz.d;;"
-                       : "=&r"(ret) : "r"(iha), "r"(pte) : "memory");
-
-       return ret;
-}
-
-/*
- *  purge software guest tlb
- */
-
-static void vtlb_purge(struct kvm_vcpu *v, u64 va, u64 ps)
-{
-       struct thash_data *cur;
-       u64 start, curadr, size, psbits, tag, rr_ps, num;
-       union ia64_rr vrr;
-       struct thash_cb *hcb = &v->arch.vtlb;
-
-       vrr.val = vcpu_get_rr(v, va);
-       psbits = VMX(v, psbits[(va >> 61)]);
-       start = va & ~((1UL << ps) - 1);
-       while (psbits) {
-               curadr = start;
-               rr_ps = __ffs(psbits);
-               psbits &= ~(1UL << rr_ps);
-               num = 1UL << ((ps < rr_ps) ? 0 : (ps - rr_ps));
-               size = PSIZE(rr_ps);
-               vrr.ps = rr_ps;
-               while (num) {
-                       cur = vsa_thash(hcb->pta, curadr, vrr.val, &tag);
-                       if (cur->etag == tag && cur->ps == rr_ps)
-                               cur->etag = INVALID_TI_TAG;
-                       curadr += size;
-                       num--;
-               }
-       }
-}
-
-
-/*
- *  purge VHPT and machine TLB
- */
-static void vhpt_purge(struct kvm_vcpu *v, u64 va, u64 ps)
-{
-       struct thash_data *cur;
-       u64 start, size, tag, num;
-       union ia64_rr rr;
-
-       start = va & ~((1UL << ps) - 1);
-       rr.val = ia64_get_rr(va);
-       size = PSIZE(rr.ps);
-       num = 1UL << ((ps < rr.ps) ? 0 : (ps - rr.ps));
-       while (num) {
-               cur = (struct thash_data *)ia64_thash(start);
-               tag = ia64_ttag(start);
-               if (cur->etag == tag)
-                       cur->etag = INVALID_TI_TAG;
-               start += size;
-               num--;
-       }
-       machine_tlb_purge(va, ps);
-}
-
-/*
- * Insert an entry into hash TLB or VHPT.
- * NOTES:
- *  1: When inserting VHPT to thash, "va" is a must covered
- *  address by the inserted machine VHPT entry.
- *  2: The format of entry is always in TLB.
- *  3: The caller need to make sure the new entry will not overlap
- *     with any existed entry.
- */
-void vtlb_insert(struct kvm_vcpu *v, u64 pte, u64 itir, u64 va)
-{
-       struct thash_data *head;
-       union ia64_rr vrr;
-       u64 tag;
-       struct thash_cb *hcb = &v->arch.vtlb;
-
-       vrr.val = vcpu_get_rr(v, va);
-       vrr.ps = itir_ps(itir);
-       VMX(v, psbits[va >> 61]) |= (1UL << vrr.ps);
-       head = vsa_thash(hcb->pta, va, vrr.val, &tag);
-       head->page_flags = pte;
-       head->itir = itir;
-       head->etag = tag;
-}
-
-int vtr_find_overlap(struct kvm_vcpu *vcpu, u64 va, u64 ps, int type)
-{
-       struct thash_data  *trp;
-       int  i;
-       u64 end, rid;
-
-       rid = vcpu_get_rr(vcpu, va);
-       rid = rid & RR_RID_MASK;
-       end = va + PSIZE(ps);
-       if (type == D_TLB) {
-               if (vcpu_quick_region_check(vcpu->arch.dtr_regions, va)) {
-                       for (trp = (struct thash_data *)&vcpu->arch.dtrs, i = 0;
-                                       i < NDTRS; i++, trp++) {
-                               if (__is_tr_overlap(trp, rid, va, end))
-                                       return i;
-                       }
-               }
-       } else {
-               if (vcpu_quick_region_check(vcpu->arch.itr_regions, va)) {
-                       for (trp = (struct thash_data *)&vcpu->arch.itrs, i = 0;
-                                       i < NITRS; i++, trp++) {
-                               if (__is_tr_overlap(trp, rid, va, end))
-                                       return i;
-                       }
-               }
-       }
-       return -1;
-}
-
-/*
- * Purge entries in VTLB and VHPT
- */
-void thash_purge_entries(struct kvm_vcpu *v, u64 va, u64 ps)
-{
-       if (vcpu_quick_region_check(v->arch.tc_regions, va))
-               vtlb_purge(v, va, ps);
-       vhpt_purge(v, va, ps);
-}
-
-void thash_purge_entries_remote(struct kvm_vcpu *v, u64 va, u64 ps)
-{
-       u64 old_va = va;
-       va = REGION_OFFSET(va);
-       if (vcpu_quick_region_check(v->arch.tc_regions, old_va))
-               vtlb_purge(v, va, ps);
-       vhpt_purge(v, va, ps);
-}
-
-u64 translate_phy_pte(u64 *pte, u64 itir, u64 va)
-{
-       u64 ps, ps_mask, paddr, maddr, io_mask;
-       union pte_flags phy_pte;
-
-       ps = itir_ps(itir);
-       ps_mask = ~((1UL << ps) - 1);
-       phy_pte.val = *pte;
-       paddr = *pte;
-       paddr = ((paddr & _PAGE_PPN_MASK) & ps_mask) | (va & ~ps_mask);
-       maddr = kvm_get_mpt_entry(paddr >> PAGE_SHIFT);
-       io_mask = maddr & GPFN_IO_MASK;
-       if (io_mask && (io_mask != GPFN_PHYS_MMIO)) {
-               *pte |= VTLB_PTE_IO;
-               return -1;
-       }
-       maddr = ((maddr & _PAGE_PPN_MASK) & PAGE_MASK) |
-                                       (paddr & ~PAGE_MASK);
-       phy_pte.ppn = maddr >> ARCH_PAGE_SHIFT;
-       return phy_pte.val;
-}
-
-/*
- * Purge overlap TCs and then insert the new entry to emulate itc ops.
- * Notes: Only TC entry can purge and insert.
- */
-void  thash_purge_and_insert(struct kvm_vcpu *v, u64 pte, u64 itir,
-                                               u64 ifa, int type)
-{
-       u64 ps;
-       u64 phy_pte, io_mask, index;
-       union ia64_rr vrr, mrr;
-
-       ps = itir_ps(itir);
-       vrr.val = vcpu_get_rr(v, ifa);
-       mrr.val = ia64_get_rr(ifa);
-
-       index = (pte & _PAGE_PPN_MASK) >> PAGE_SHIFT;
-       io_mask = kvm_get_mpt_entry(index) & GPFN_IO_MASK;
-       phy_pte = translate_phy_pte(&pte, itir, ifa);
-
-       /* Ensure WB attribute if pte is related to a normal mem page,
-        * which is required by vga acceleration since qemu maps shared
-        * vram buffer with WB.
-        */
-       if (!(pte & VTLB_PTE_IO) && ((pte & _PAGE_MA_MASK) != _PAGE_MA_NAT) &&
-                       io_mask != GPFN_PHYS_MMIO) {
-               pte &= ~_PAGE_MA_MASK;
-               phy_pte &= ~_PAGE_MA_MASK;
-       }
-
-       vtlb_purge(v, ifa, ps);
-       vhpt_purge(v, ifa, ps);
-
-       if ((ps != mrr.ps) || (pte & VTLB_PTE_IO)) {
-               vtlb_insert(v, pte, itir, ifa);
-               vcpu_quick_region_set(VMX(v, tc_regions), ifa);
-       }
-       if (pte & VTLB_PTE_IO)
-               return;
-
-       if (ps >= mrr.ps)
-               vhpt_insert(phy_pte, itir, ifa, pte);
-       else {
-               u64 psr;
-               phy_pte  &= ~PAGE_FLAGS_RV_MASK;
-               psr = ia64_clear_ic();
-               ia64_itc(type, ifa, phy_pte, ps);
-               paravirt_dv_serialize_data();
-               ia64_set_psr(psr);
-       }
-       if (!(pte&VTLB_PTE_IO))
-               mark_pages_dirty(v, pte, ps);
-
-}
-
-/*
- * Purge all TCs or VHPT entries including those in Hash table.
- *
- */
-
-void thash_purge_all(struct kvm_vcpu *v)
-{
-       int i;
-       struct thash_data *head;
-       struct thash_cb  *vtlb, *vhpt;
-       vtlb = &v->arch.vtlb;
-       vhpt = &v->arch.vhpt;
-
-       for (i = 0; i < 8; i++)
-               VMX(v, psbits[i]) = 0;
-
-       head = vtlb->hash;
-       for (i = 0; i < vtlb->num; i++) {
-               head->page_flags = 0;
-               head->etag = INVALID_TI_TAG;
-               head->itir = 0;
-               head->next = 0;
-               head++;
-       };
-
-       head = vhpt->hash;
-       for (i = 0; i < vhpt->num; i++) {
-               head->page_flags = 0;
-               head->etag = INVALID_TI_TAG;
-               head->itir = 0;
-               head->next = 0;
-               head++;
-       };
-
-       local_flush_tlb_all();
-}
-
-/*
- * Lookup the hash table and its collision chain to find an entry
- * covering this address rid:va or the entry.
- *
- * INPUT:
- *  in: TLB format for both VHPT & TLB.
- */
-struct thash_data *vtlb_lookup(struct kvm_vcpu *v, u64 va, int is_data)
-{
-       struct thash_data  *cch;
-       u64    psbits, ps, tag;
-       union ia64_rr vrr;
-
-       struct thash_cb *hcb = &v->arch.vtlb;
-
-       cch = __vtr_lookup(v, va, is_data);
-       if (cch)
-               return cch;
-
-       if (vcpu_quick_region_check(v->arch.tc_regions, va) == 0)
-               return NULL;
-
-       psbits = VMX(v, psbits[(va >> 61)]);
-       vrr.val = vcpu_get_rr(v, va);
-       while (psbits) {
-               ps = __ffs(psbits);
-               psbits &= ~(1UL << ps);
-               vrr.ps = ps;
-               cch = vsa_thash(hcb->pta, va, vrr.val, &tag);
-               if (cch->etag == tag && cch->ps == ps)
-                       return cch;
-       }
-
-       return NULL;
-}
-
-/*
- * Initialize internal control data before service.
- */
-void thash_init(struct thash_cb *hcb, u64 sz)
-{
-       int i;
-       struct thash_data *head;
-
-       hcb->pta.val = (unsigned long)hcb->hash;
-       hcb->pta.vf = 1;
-       hcb->pta.ve = 1;
-       hcb->pta.size = sz;
-       head = hcb->hash;
-       for (i = 0; i < hcb->num; i++) {
-               head->page_flags = 0;
-               head->itir = 0;
-               head->etag = INVALID_TI_TAG;
-               head->next = 0;
-               head++;
-       }
-}
-
-u64 kvm_get_mpt_entry(u64 gpfn)
-{
-       u64 *base = (u64 *) KVM_P2M_BASE;
-
-       if (gpfn >= (KVM_P2M_SIZE >> 3))
-               panic_vm(current_vcpu, "Invalid gpfn =%lx\n", gpfn);
-
-       return *(base + gpfn);
-}
-
-u64 kvm_lookup_mpa(u64 gpfn)
-{
-       u64 maddr;
-       maddr = kvm_get_mpt_entry(gpfn);
-       return maddr&_PAGE_PPN_MASK;
-}
-
-u64 kvm_gpa_to_mpa(u64 gpa)
-{
-       u64 pte = kvm_lookup_mpa(gpa >> PAGE_SHIFT);
-       return (pte >> PAGE_SHIFT << PAGE_SHIFT) | (gpa & ~PAGE_MASK);
-}
-
-/*
- * Fetch guest bundle code.
- * INPUT:
- *  gip: guest ip
- *  pbundle: used to return fetched bundle.
- */
-int fetch_code(struct kvm_vcpu *vcpu, u64 gip, IA64_BUNDLE *pbundle)
-{
-       u64     gpip = 0;   /* guest physical IP*/
-       u64     *vpa;
-       struct thash_data    *tlb;
-       u64     maddr;
-
-       if (!(VCPU(vcpu, vpsr) & IA64_PSR_IT)) {
-               /* I-side physical mode */
-               gpip = gip;
-       } else {
-               tlb = vtlb_lookup(vcpu, gip, I_TLB);
-               if (tlb)
-                       gpip = (tlb->ppn >> (tlb->ps - 12) << tlb->ps) |
-                               (gip & (PSIZE(tlb->ps) - 1));
-       }
-       if (gpip) {
-               maddr = kvm_gpa_to_mpa(gpip);
-       } else {
-               tlb = vhpt_lookup(gip);
-               if (tlb == NULL) {
-                       ia64_ptcl(gip, ARCH_PAGE_SHIFT << 2);
-                       return IA64_FAULT;
-               }
-               maddr = (tlb->ppn >> (tlb->ps - 12) << tlb->ps)
-                                       | (gip & (PSIZE(tlb->ps) - 1));
-       }
-       vpa = (u64 *)__kvm_va(maddr);
-
-       pbundle->i64[0] = *vpa++;
-       pbundle->i64[1] = *vpa;
-
-       return IA64_NO_FAULT;
-}
-
-void kvm_init_vhpt(struct kvm_vcpu *v)
-{
-       v->arch.vhpt.num = VHPT_NUM_ENTRIES;
-       thash_init(&v->arch.vhpt, VHPT_SHIFT);
-       ia64_set_pta(v->arch.vhpt.pta.val);
-       /*Enable VHPT here?*/
-}
-
-void kvm_init_vtlb(struct kvm_vcpu *v)
-{
-       v->arch.vtlb.num = VTLB_NUM_ENTRIES;
-       thash_init(&v->arch.vtlb, VTLB_SHIFT);
-}
index 0ba4057d271befe7f166f52f66cbd2cdaf9f4ea5..f0f7ef82b7a6e405b39b0dfe664872aa2f468f9e 100644 (file)
@@ -586,11 +586,6 @@ static int ioapic_mmio_write(struct kvm_io_device *this, gpa_t addr, int len,
        case IOAPIC_REG_WINDOW:
                ioapic_write_indirect(ioapic, data);
                break;
-#ifdef CONFIG_IA64
-       case IOAPIC_REG_EOI:
-               __kvm_ioapic_update_eoi(NULL, ioapic, data, IOAPIC_LEVEL_TRIG);
-               break;
-#endif
 
        default:
                break;
index 31725a3a93b8138cca3a97c307fdcc9c1735f9a1..dc3baa3a538f2e9203dc7b32462ba0b861d880ec 100644 (file)
@@ -19,7 +19,6 @@ struct kvm_vcpu;
 /* Direct registers. */
 #define IOAPIC_REG_SELECT  0x00
 #define IOAPIC_REG_WINDOW  0x10
-#define IOAPIC_REG_EOI     0x40        /* IA64 IOSAPIC only */
 
 /* Indirect registers. */
 #define IOAPIC_REG_APIC_ID 0x00        /* x86 IOAPIC only */
index 963b8995a9e8a8035ad4df200afb20ca55d6fa1f..1345bde064f536a07d9a4fb4608cf70a77cf7b7c 100644 (file)
@@ -26,9 +26,6 @@
 #include <trace/events/kvm.h>
 
 #include <asm/msidef.h>
-#ifdef CONFIG_IA64
-#include <asm/iosapic.h>
-#endif
 
 #include "irq.h"
 
@@ -57,12 +54,7 @@ static int kvm_set_ioapic_irq(struct kvm_kernel_irq_routing_entry *e,
 
 inline static bool kvm_is_dm_lowest_prio(struct kvm_lapic_irq *irq)
 {
-#ifdef CONFIG_IA64
-       return irq->delivery_mode ==
-               (IOSAPIC_LOWEST_PRIORITY << IOSAPIC_DELIVERY_SHIFT);
-#else
        return irq->delivery_mode == APIC_DM_LOWEST;
-#endif
 }
 
 int kvm_irq_delivery_to_apic(struct kvm *kvm, struct kvm_lapic *src,
@@ -346,20 +338,6 @@ static const struct kvm_irq_routing_entry default_routing[] = {
        ROUTING_ENTRY1(18), ROUTING_ENTRY1(19),
        ROUTING_ENTRY1(20), ROUTING_ENTRY1(21),
        ROUTING_ENTRY1(22), ROUTING_ENTRY1(23),
-#ifdef CONFIG_IA64
-       ROUTING_ENTRY1(24), ROUTING_ENTRY1(25),
-       ROUTING_ENTRY1(26), ROUTING_ENTRY1(27),
-       ROUTING_ENTRY1(28), ROUTING_ENTRY1(29),
-       ROUTING_ENTRY1(30), ROUTING_ENTRY1(31),
-       ROUTING_ENTRY1(32), ROUTING_ENTRY1(33),
-       ROUTING_ENTRY1(34), ROUTING_ENTRY1(35),
-       ROUTING_ENTRY1(36), ROUTING_ENTRY1(37),
-       ROUTING_ENTRY1(38), ROUTING_ENTRY1(39),
-       ROUTING_ENTRY1(40), ROUTING_ENTRY1(41),
-       ROUTING_ENTRY1(42), ROUTING_ENTRY1(43),
-       ROUTING_ENTRY1(44), ROUTING_ENTRY1(45),
-       ROUTING_ENTRY1(46), ROUTING_ENTRY1(47),
-#endif
 };
 
 int kvm_setup_default_irq_routing(struct kvm *kvm)