KVM: New guest debug interface
[linux-2.6/mini2440.git] / arch / ia64 / include / asm / kvm.h
blobbe3fdb891214e8c27262b13da5c6ac02c7d24ddc
1 #ifndef __ASM_IA64_KVM_H
2 #define __ASM_IA64_KVM_H
4 /*
5 * kvm structure definitions for ia64
7 * Copyright (C) 2007 Xiantao Zhang <xiantao.zhang@intel.com>
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms and conditions of the GNU General Public License,
11 * version 2, as published by the Free Software Foundation.
13 * This program is distributed in the hope it will be useful, but WITHOUT
14 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
16 * more details.
18 * You should have received a copy of the GNU General Public License along with
19 * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
20 * Place - Suite 330, Boston, MA 02111-1307 USA.
24 #include <asm/types.h>
26 #include <linux/ioctl.h>
28 /* Select x86 specific features in <linux/kvm.h> */
29 #define __KVM_HAVE_IOAPIC
30 #define __KVM_HAVE_DEVICE_ASSIGNMENT
32 /* Architectural interrupt line count. */
33 #define KVM_NR_INTERRUPTS 256
35 #define KVM_IOAPIC_NUM_PINS 48
37 struct kvm_ioapic_state {
38 __u64 base_address;
39 __u32 ioregsel;
40 __u32 id;
41 __u32 irr;
42 __u32 pad;
43 union {
44 __u64 bits;
45 struct {
46 __u8 vector;
47 __u8 delivery_mode:3;
48 __u8 dest_mode:1;
49 __u8 delivery_status:1;
50 __u8 polarity:1;
51 __u8 remote_irr:1;
52 __u8 trig_mode:1;
53 __u8 mask:1;
54 __u8 reserve:7;
55 __u8 reserved[4];
56 __u8 dest_id;
57 } fields;
58 } redirtbl[KVM_IOAPIC_NUM_PINS];
61 #define KVM_IRQCHIP_PIC_MASTER 0
62 #define KVM_IRQCHIP_PIC_SLAVE 1
63 #define KVM_IRQCHIP_IOAPIC 2
65 #define KVM_CONTEXT_SIZE 8*1024
67 struct kvm_fpreg {
68 union {
69 unsigned long bits[2];
70 long double __dummy; /* force 16-byte alignment */
71 } u;
74 union context {
75 /* 8K size */
76 char dummy[KVM_CONTEXT_SIZE];
77 struct {
78 unsigned long psr;
79 unsigned long pr;
80 unsigned long caller_unat;
81 unsigned long pad;
82 unsigned long gr[32];
83 unsigned long ar[128];
84 unsigned long br[8];
85 unsigned long cr[128];
86 unsigned long rr[8];
87 unsigned long ibr[8];
88 unsigned long dbr[8];
89 unsigned long pkr[8];
90 struct kvm_fpreg fr[128];
94 struct thash_data {
95 union {
96 struct {
97 unsigned long p : 1; /* 0 */
98 unsigned long rv1 : 1; /* 1 */
99 unsigned long ma : 3; /* 2-4 */
100 unsigned long a : 1; /* 5 */
101 unsigned long d : 1; /* 6 */
102 unsigned long pl : 2; /* 7-8 */
103 unsigned long ar : 3; /* 9-11 */
104 unsigned long ppn : 38; /* 12-49 */
105 unsigned long rv2 : 2; /* 50-51 */
106 unsigned long ed : 1; /* 52 */
107 unsigned long ig1 : 11; /* 53-63 */
109 struct {
110 unsigned long __rv1 : 53; /* 0-52 */
111 unsigned long contiguous : 1; /*53 */
112 unsigned long tc : 1; /* 54 TR or TC */
113 unsigned long cl : 1;
114 /* 55 I side or D side cache line */
115 unsigned long len : 4; /* 56-59 */
116 unsigned long io : 1; /* 60 entry is for io or not */
117 unsigned long nomap : 1;
118 /* 61 entry cann't be inserted into machine TLB.*/
119 unsigned long checked : 1;
120 /* 62 for VTLB/VHPT sanity check */
121 unsigned long invalid : 1;
122 /* 63 invalid entry */
124 unsigned long page_flags;
125 }; /* same for VHPT and TLB */
127 union {
128 struct {
129 unsigned long rv3 : 2;
130 unsigned long ps : 6;
131 unsigned long key : 24;
132 unsigned long rv4 : 32;
134 unsigned long itir;
136 union {
137 struct {
138 unsigned long ig2 : 12;
139 unsigned long vpn : 49;
140 unsigned long vrn : 3;
142 unsigned long ifa;
143 unsigned long vadr;
144 struct {
145 unsigned long tag : 63;
146 unsigned long ti : 1;
148 unsigned long etag;
150 union {
151 struct thash_data *next;
152 unsigned long rid;
153 unsigned long gpaddr;
157 #define NITRS 8
158 #define NDTRS 8
160 struct saved_vpd {
161 unsigned long vhpi;
162 unsigned long vgr[16];
163 unsigned long vbgr[16];
164 unsigned long vnat;
165 unsigned long vbnat;
166 unsigned long vcpuid[5];
167 unsigned long vpsr;
168 unsigned long vpr;
169 unsigned long vcr[128];
172 struct kvm_regs {
173 struct saved_vpd vpd;
174 /*Arch-regs*/
175 int mp_state;
176 unsigned long vmm_rr;
177 /* TR and TC. */
178 struct thash_data itrs[NITRS];
179 struct thash_data dtrs[NDTRS];
180 /* Bit is set if there is a tr/tc for the region. */
181 unsigned char itr_regions;
182 unsigned char dtr_regions;
183 unsigned char tc_regions;
185 char irq_check;
186 unsigned long saved_itc;
187 unsigned long itc_check;
188 unsigned long timer_check;
189 unsigned long timer_pending;
190 unsigned long last_itc;
192 unsigned long vrr[8];
193 unsigned long ibr[8];
194 unsigned long dbr[8];
195 unsigned long insvc[4]; /* Interrupt in service. */
196 unsigned long xtp;
198 unsigned long metaphysical_rr0; /* from kvm_arch (so is pinned) */
199 unsigned long metaphysical_rr4; /* from kvm_arch (so is pinned) */
200 unsigned long metaphysical_saved_rr0; /* from kvm_arch */
201 unsigned long metaphysical_saved_rr4; /* from kvm_arch */
202 unsigned long fp_psr; /*used for lazy float register */
203 unsigned long saved_gp;
204 /*for phycial emulation */
206 union context saved_guest;
208 unsigned long reserved[64]; /* for future use */
211 struct kvm_sregs {
214 struct kvm_fpu {
217 struct kvm_debug_exit_arch {
220 /* for KVM_SET_GUEST_DEBUG */
221 struct kvm_guest_debug_arch {
224 #endif