hw/misc/imx6_src: Don't crash trying to reset missing CPUs
[qemu/ar7.git] / target / i386 / hax-darwin.h
blob0c0968b77d50d64d1afce45b2575f1fa38de4b53
1 /*
2 * QEMU HAXM support
4 * Copyright (c) 2011 Intel Corporation
5 * Written by:
6 * Jiang Yunhong<yunhong.jiang@intel.com>
7 * Xin Xiaohui<xiaohui.xin@intel.com>
8 * Zhang Xiantao<xiantao.zhang@intel.com>
10 * This work is licensed under the terms of the GNU GPL, version 2 or later.
11 * See the COPYING file in the top-level directory.
15 #ifndef TARGET_I386_HAX_DARWIN_H
16 #define TARGET_I386_HAX_DARWIN_H
18 #include <sys/types.h>
19 #include <sys/ioctl.h>
20 #include <sys/mman.h>
21 #include <stdarg.h>
23 #define HAX_INVALID_FD (-1)
24 static inline int hax_invalid_fd(hax_fd fd)
26 return fd <= 0;
29 static inline void hax_mod_close(struct hax_state *hax)
31 close(hax->fd);
34 static inline void hax_close_fd(hax_fd fd)
36 close(fd);
39 /* HAX model level ioctl */
40 #define HAX_IOCTL_VERSION _IOWR(0, 0x20, struct hax_module_version)
41 #define HAX_IOCTL_CREATE_VM _IOWR(0, 0x21, uint32_t)
42 #define HAX_IOCTL_DESTROY_VM _IOW(0, 0x22, uint32_t)
43 #define HAX_IOCTL_CAPABILITY _IOR(0, 0x23, struct hax_capabilityinfo)
45 #define HAX_VM_IOCTL_VCPU_CREATE _IOWR(0, 0x80, uint32_t)
46 #define HAX_VM_IOCTL_ALLOC_RAM _IOWR(0, 0x81, struct hax_alloc_ram_info)
47 #define HAX_VM_IOCTL_SET_RAM _IOWR(0, 0x82, struct hax_set_ram_info)
48 #define HAX_VM_IOCTL_VCPU_DESTROY _IOW(0, 0x83, uint32_t)
49 #define HAX_VM_IOCTL_NOTIFY_QEMU_VERSION _IOW(0, 0x84, struct hax_qemu_version)
51 #define HAX_VCPU_IOCTL_RUN _IO(0, 0xc0)
52 #define HAX_VCPU_IOCTL_SET_MSRS _IOWR(0, 0xc1, struct hax_msr_data)
53 #define HAX_VCPU_IOCTL_GET_MSRS _IOWR(0, 0xc2, struct hax_msr_data)
55 #define HAX_VCPU_IOCTL_SET_FPU _IOW(0, 0xc3, struct fx_layout)
56 #define HAX_VCPU_IOCTL_GET_FPU _IOR(0, 0xc4, struct fx_layout)
58 #define HAX_VCPU_IOCTL_SETUP_TUNNEL _IOWR(0, 0xc5, struct hax_tunnel_info)
59 #define HAX_VCPU_IOCTL_INTERRUPT _IOWR(0, 0xc6, uint32_t)
60 #define HAX_VCPU_SET_REGS _IOWR(0, 0xc7, struct vcpu_state_t)
61 #define HAX_VCPU_GET_REGS _IOWR(0, 0xc8, struct vcpu_state_t)
63 #endif /* TARGET_I386_HAX_DARWIN_H */