X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=os-win32.c;h=725ad652e8bb89d63bf1fa3e1715b9b39575d920;hb=faba8e123f41902edf762bb12054f096713a5338;hp=ad76370c7c780b5e9112c6b09a0e0ec80f7e7392;hpb=4e1ea514f9b9f07358b84554dc3d35f533ec3971;p=mirror_qemu.git diff --git a/os-win32.c b/os-win32.c index ad76370c7c..725ad652e8 100644 --- a/os-win32.c +++ b/os-win32.c @@ -22,89 +22,37 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ -#include -#include -#include -#include -#include -#include -#include -#include "config-host.h" -#include "sysemu.h" -#include "qemu-options.h" -/***********************************************************/ -/* Functions missing in mingw */ +#include "qemu/osdep.h" +#include +#include +#include "sysemu/runstate.h" -int setenv(const char *name, const char *value, int overwrite) +static BOOL WINAPI qemu_ctrl_handler(DWORD type) { - int result = 0; - if (overwrite || !getenv(name)) { - size_t length = strlen(name) + strlen(value) + 2; - char *string = g_malloc(length); - snprintf(string, length, "%s=%s", name, value); - result = putenv(string); + qemu_system_shutdown_request(SHUTDOWN_CAUSE_HOST_SIGNAL); + /* Windows 7 kills application when the function returns. + Sleep here to give QEMU a try for closing. + Sleep period is 10000ms because Windows kills the program + after 10 seconds anyway. */ + Sleep(10000); - /* Windows takes a copy and does not continue to use our string. - * Therefore it can be safely freed on this platform. POSIX code - * typically has to leak the string because according to the spec it - * becomes part of the environment. - */ - g_free(string); - } - return result; + return TRUE; } -static BOOL WINAPI qemu_ctrl_handler(DWORD type) +static TIMECAPS mm_tc; + +static void os_undo_timer_resolution(void) { - exit(STATUS_CONTROL_C_EXIT); - return TRUE; + timeEndPeriod(mm_tc.wPeriodMin); } void os_setup_early_signal_handling(void) { - /* Note: cpu_interrupt() is currently not SMP safe, so we force - QEMU to run on a single CPU */ - HANDLE h; - DWORD_PTR mask, smask; - int i; - SetConsoleCtrlHandler(qemu_ctrl_handler, TRUE); - - h = GetCurrentProcess(); - if (GetProcessAffinityMask(h, &mask, &smask)) { - for(i = 0; i < 32; i++) { - if (mask & (1 << i)) - break; - } - if (i != 32) { - mask = 1 << i; - SetProcessAffinityMask(h, mask); - } - } -} - -/* Look for support files in the same directory as the executable. */ -char *os_find_datadir(const char *argv0) -{ - char *p; - char buf[MAX_PATH]; - DWORD len; - - len = GetModuleFileName(NULL, buf, sizeof(buf) - 1); - if (len == 0) { - return NULL; - } - - buf[len] = 0; - p = buf + len - 1; - while (p != buf && *p != '\\') - p--; - *p = 0; - if (access(buf, R_OK) == 0) { - return g_strdup(buf); - } - return NULL; + timeGetDevCaps(&mm_tc, sizeof(mm_tc)); + timeBeginPeriod(mm_tc.wPeriodMin); + atexit(os_undo_timer_resolution); } void os_set_line_buffering(void) @@ -112,42 +60,3 @@ void os_set_line_buffering(void) setbuf(stdout, NULL); setbuf(stderr, NULL); } - -/* - * Parse OS specific command line options. - * return 0 if option handled, -1 otherwise - */ -void os_parse_cmd_args(int index, const char *optarg) -{ - return; -} - -void os_pidfile_error(void) -{ - fprintf(stderr, "Could not acquire pid file: %s\n", strerror(errno)); -} - -int qemu_create_pidfile(const char *filename) -{ - char buffer[128]; - int len; - HANDLE file; - OVERLAPPED overlap; - BOOL ret; - memset(&overlap, 0, sizeof(overlap)); - - file = CreateFile(filename, GENERIC_WRITE, FILE_SHARE_READ, NULL, - OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); - - if (file == INVALID_HANDLE_VALUE) { - return -1; - } - len = snprintf(buffer, sizeof(buffer), "%d\n", getpid()); - ret = WriteFile(file, (LPCVOID)buffer, (DWORD)len, - NULL, &overlap); - CloseHandle(file); - if (ret == 0) { - return -1; - } - return 0; -}