47c1c8c12f
That's a forward port of the core HAX interface code from the emu-2.2-release branch in the external/qemu-android repository as used by the Android emulator. The original commit was "target/i386: Add Intel HAX to android emulator" saying: """ Backport of 2b3098ff27bab079caab9b46b58546b5036f5c0c from studio-1.4-dev into emu-master-dev Intel HAX (harware acceleration) will enhance android emulator performance in Windows and Mac OS X in the systems powered by Intel processors with "Intel Hardware Accelerated Execution Manager" package installed when user runs android emulator with Intel target. Signed-off-by: David Chou <david.j.chou@intel.com> """ It has been modified to build and run along with the current code base. The formatting has been fixed to go through scripts/checkpatch.pl, and the DPRINTF macros have been updated to get the instanciations checked by the compiler. The FPU registers saving/restoring has been updated to match the current QEMU registers layout. The implementation has been simplified by doing the following modifications: - removing the code for supporting the hardware without Unrestricted Guest (UG) mode (including all the code to fallback on TCG emulation). - not including the Darwin support (which is not yet debugged/tested). - simplifying the initialization by removing the leftovers from the Android specific code, then trimming down the remaining logic. - removing the unused MemoryListener callbacks. Signed-off-by: Vincent Palatin <vpalatin@chromium.org> Message-Id: <e1023837f8d0e4c470f6c4a3bf643971b2bca5be.1484045952.git.vpalatin@chromium.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
90 lines
3.5 KiB
C
90 lines
3.5 KiB
C
/*
|
|
* QEMU HAXM support
|
|
*
|
|
* Copyright IBM, Corp. 2008
|
|
*
|
|
* Authors:
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
*
|
|
* Copyright (c) 2011 Intel Corporation
|
|
* Written by:
|
|
* Jiang Yunhong<yunhong.jiang@intel.com>
|
|
* Xin Xiaohui<xiaohui.xin@intel.com>
|
|
* Zhang Xiantao<xiantao.zhang@intel.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef TARGET_I386_HAX_WINDOWS_H
|
|
#define TARGET_I386_HAX_WINDOWS_H
|
|
|
|
#include <windows.h>
|
|
#include <memory.h>
|
|
#include <malloc.h>
|
|
#include <winioctl.h>
|
|
#include <string.h>
|
|
#include <stdio.h>
|
|
#include <windef.h>
|
|
|
|
#define HAX_INVALID_FD INVALID_HANDLE_VALUE
|
|
|
|
static inline void hax_mod_close(struct hax_state *hax)
|
|
{
|
|
CloseHandle(hax->fd);
|
|
}
|
|
|
|
static inline void hax_close_fd(hax_fd fd)
|
|
{
|
|
CloseHandle(fd);
|
|
}
|
|
|
|
static inline int hax_invalid_fd(hax_fd fd)
|
|
{
|
|
return (fd == INVALID_HANDLE_VALUE);
|
|
}
|
|
|
|
#define HAX_DEVICE_TYPE 0x4000
|
|
|
|
#define HAX_IOCTL_VERSION CTL_CODE(HAX_DEVICE_TYPE, 0x900, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_IOCTL_CREATE_VM CTL_CODE(HAX_DEVICE_TYPE, 0x901, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_IOCTL_CAPABILITY CTL_CODE(HAX_DEVICE_TYPE, 0x910, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
|
|
#define HAX_VM_IOCTL_VCPU_CREATE CTL_CODE(HAX_DEVICE_TYPE, 0x902, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VM_IOCTL_ALLOC_RAM CTL_CODE(HAX_DEVICE_TYPE, 0x903, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VM_IOCTL_SET_RAM CTL_CODE(HAX_DEVICE_TYPE, 0x904, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VM_IOCTL_VCPU_DESTROY CTL_CODE(HAX_DEVICE_TYPE, 0x905, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
|
|
#define HAX_VCPU_IOCTL_RUN CTL_CODE(HAX_DEVICE_TYPE, 0x906, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_IOCTL_SET_MSRS CTL_CODE(HAX_DEVICE_TYPE, 0x907, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_IOCTL_GET_MSRS CTL_CODE(HAX_DEVICE_TYPE, 0x908, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_IOCTL_SET_FPU CTL_CODE(HAX_DEVICE_TYPE, 0x909, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_IOCTL_GET_FPU CTL_CODE(HAX_DEVICE_TYPE, 0x90a, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
|
|
#define HAX_VCPU_IOCTL_SETUP_TUNNEL CTL_CODE(HAX_DEVICE_TYPE, 0x90b, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_IOCTL_INTERRUPT CTL_CODE(HAX_DEVICE_TYPE, 0x90c, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_SET_REGS CTL_CODE(HAX_DEVICE_TYPE, 0x90d, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define HAX_VCPU_GET_REGS CTL_CODE(HAX_DEVICE_TYPE, 0x90e, \
|
|
METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
|
|
#define HAX_VM_IOCTL_NOTIFY_QEMU_VERSION CTL_CODE(HAX_DEVICE_TYPE, 0x910, \
|
|
METHOD_BUFFERED, \
|
|
FILE_ANY_ACCESS)
|
|
#endif /* TARGET_I386_HAX_WINDOWS_H */
|