1 /******************************************************************************
4 * Linux-specific hypervisor handling.
6 * Copyright (c) 2002-2004, K A Fraser
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License version 2
10 * as published by the Free Software Foundation; or, when distributed
11 * separately from the Linux kernel or incorporated into other
12 * software packages, subject to the following license:
14 * Permission is hereby granted, free of charge, to any person obtaining a copy
15 * of this source file (the "Software"), to deal in the Software without
16 * restriction, including without limitation the rights to use, copy, modify,
17 * merge, publish, distribute, sublicense, and/or sell copies of the Software,
18 * and to permit persons to whom the Software is furnished to do so, subject to
19 * the following conditions:
21 * The above copyright notice and this permission notice shall be included in
22 * all copies or substantial portions of the Software.
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
29 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
33 #ifndef _ASM_IA64_XEN_HYPERCALL_H
34 #define _ASM_IA64_XEN_HYPERCALL_H
36 #include <xen/interface/xen.h>
37 #include <xen/interface/physdev.h>
38 #include <xen/interface/sched.h>
39 #include <asm/xen/xcom_hcall.h>
40 struct xencomm_handle
;
41 extern unsigned long __hypercall(unsigned long a1
, unsigned long a2
,
42 unsigned long a3
, unsigned long a4
,
43 unsigned long a5
, unsigned long cmd
);
46 * Assembler stubs for hyper-calls.
49 #define _hypercall0(type, name) \
52 __res = __hypercall(0, 0, 0, 0, 0, __HYPERVISOR_##name);\
56 #define _hypercall1(type, name, a1) \
59 __res = __hypercall((unsigned long)a1, \
60 0, 0, 0, 0, __HYPERVISOR_##name); \
64 #define _hypercall2(type, name, a1, a2) \
67 __res = __hypercall((unsigned long)a1, \
69 0, 0, 0, __HYPERVISOR_##name); \
73 #define _hypercall3(type, name, a1, a2, a3) \
76 __res = __hypercall((unsigned long)a1, \
79 0, 0, __HYPERVISOR_##name); \
83 #define _hypercall4(type, name, a1, a2, a3, a4) \
86 __res = __hypercall((unsigned long)a1, \
90 0, __HYPERVISOR_##name); \
94 #define _hypercall5(type, name, a1, a2, a3, a4, a5) \
97 __res = __hypercall((unsigned long)a1, \
102 __HYPERVISOR_##name); \
108 xencomm_arch_hypercall_sched_op(int cmd
, struct xencomm_handle
*arg
)
110 return _hypercall2(int, sched_op_new
, cmd
, arg
);
114 HYPERVISOR_set_timer_op(u64 timeout
)
116 unsigned long timeout_hi
= (unsigned long)(timeout
>> 32);
117 unsigned long timeout_lo
= (unsigned long)timeout
;
118 return _hypercall2(long, set_timer_op
, timeout_lo
, timeout_hi
);
122 xencomm_arch_hypercall_multicall(struct xencomm_handle
*call_list
,
125 return _hypercall2(int, multicall
, call_list
, nr_calls
);
129 xencomm_arch_hypercall_memory_op(unsigned int cmd
, struct xencomm_handle
*arg
)
131 return _hypercall2(int, memory_op
, cmd
, arg
);
135 xencomm_arch_hypercall_event_channel_op(int cmd
, struct xencomm_handle
*arg
)
137 return _hypercall2(int, event_channel_op
, cmd
, arg
);
141 xencomm_arch_hypercall_xen_version(int cmd
, struct xencomm_handle
*arg
)
143 return _hypercall2(int, xen_version
, cmd
, arg
);
147 xencomm_arch_hypercall_console_io(int cmd
, int count
,
148 struct xencomm_handle
*str
)
150 return _hypercall3(int, console_io
, cmd
, count
, str
);
154 xencomm_arch_hypercall_physdev_op(int cmd
, struct xencomm_handle
*arg
)
156 return _hypercall2(int, physdev_op
, cmd
, arg
);
160 xencomm_arch_hypercall_grant_table_op(unsigned int cmd
,
161 struct xencomm_handle
*uop
,
164 return _hypercall3(int, grant_table_op
, cmd
, uop
, count
);
167 int HYPERVISOR_grant_table_op(unsigned int cmd
, void *uop
, unsigned int count
);
169 extern int xencomm_arch_hypercall_suspend(struct xencomm_handle
*arg
);
172 xencomm_arch_hypercall_callback_op(int cmd
, struct xencomm_handle
*arg
)
174 return _hypercall2(int, callback_op
, cmd
, arg
);
178 xencomm_arch_hypercall_vcpu_op(int cmd
, int cpu
, void *arg
)
180 return _hypercall3(long, vcpu_op
, cmd
, cpu
, arg
);
184 HYPERVISOR_physdev_op(int cmd
, void *arg
)
188 return _hypercall1(int, ia64_fast_eoi
,
189 ((struct physdev_eoi
*)arg
)->irq
);
191 return xencomm_hypercall_physdev_op(cmd
, arg
);
196 xencomm_arch_hypercall_opt_feature(struct xencomm_handle
*arg
)
198 return _hypercall1(long, opt_feature
, arg
);
201 /* for balloon driver */
202 #define HYPERVISOR_update_va_mapping(va, new_val, flags) (0)
204 /* Use xencomm to do hypercalls. */
205 #define HYPERVISOR_sched_op xencomm_hypercall_sched_op
206 #define HYPERVISOR_event_channel_op xencomm_hypercall_event_channel_op
207 #define HYPERVISOR_callback_op xencomm_hypercall_callback_op
208 #define HYPERVISOR_multicall xencomm_hypercall_multicall
209 #define HYPERVISOR_xen_version xencomm_hypercall_xen_version
210 #define HYPERVISOR_console_io xencomm_hypercall_console_io
211 #define HYPERVISOR_memory_op xencomm_hypercall_memory_op
212 #define HYPERVISOR_suspend xencomm_hypercall_suspend
213 #define HYPERVISOR_vcpu_op xencomm_hypercall_vcpu_op
214 #define HYPERVISOR_opt_feature xencomm_hypercall_opt_feature
216 /* to compile gnttab_copy_grant_page() in drivers/xen/core/gnttab.c */
217 #define HYPERVISOR_mmu_update(req, count, success_count, domid) ({ BUG(); 0; })
223 struct sched_shutdown sched_shutdown
= {
227 int rc
= HYPERVISOR_sched_op(SCHEDOP_shutdown
, &sched_shutdown
);
232 /* for netfront.c, netback.c */
233 #define MULTI_UVMFLAGS_INDEX 0 /* XXX any value */
236 MULTI_update_va_mapping(
237 struct multicall_entry
*mcl
, unsigned long va
,
238 pte_t new_val
, unsigned long flags
)
240 mcl
->op
= __HYPERVISOR_update_va_mapping
;
245 MULTI_grant_table_op(struct multicall_entry
*mcl
, unsigned int cmd
,
246 void *uop
, unsigned int count
)
248 mcl
->op
= __HYPERVISOR_grant_table_op
;
250 mcl
->args
[1] = (unsigned long)uop
;
251 mcl
->args
[2] = count
;
255 MULTI_mmu_update(struct multicall_entry
*mcl
, struct mmu_update
*req
,
256 int count
, int *success_count
, domid_t domid
)
258 mcl
->op
= __HYPERVISOR_mmu_update
;
259 mcl
->args
[0] = (unsigned long)req
;
260 mcl
->args
[1] = count
;
261 mcl
->args
[2] = (unsigned long)success_count
;
262 mcl
->args
[3] = domid
;
265 #endif /* _ASM_IA64_XEN_HYPERCALL_H */