X-Git-Url: https://git.proxmox.com/?p=qemu.git;a=blobdiff_plain;f=os-win32.c;h=50b7f6f8859a70ef159c62a483f3dc59eec43c37;hp=9673a81c7dbce14085b6bbe6d2f71d5cf66a1efd;hb=60aad298cb6de52f2716b2e82e1353ea9de95fd6;hpb=501a7ce7270955be151c442c27620fa7af2f3ce5 diff --git a/os-win32.c b/os-win32.c index 9673a81c7..50b7f6f88 100644 --- a/os-win32.c +++ b/os-win32.c @@ -23,6 +23,7 @@ * THE SOFTWARE. */ #include +#include #include #include #include @@ -67,27 +68,19 @@ static BOOL WINAPI qemu_ctrl_handler(DWORD type) return TRUE; } -void os_setup_early_signal_handling(void) +static TIMECAPS mm_tc; + +static void os_undo_timer_resolution(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; + timeEndPeriod(mm_tc.wPeriodMin); +} +void os_setup_early_signal_handling(void) +{ 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); - } - } + timeGetDevCaps(&mm_tc, sizeof(mm_tc)); + timeBeginPeriod(mm_tc.wPeriodMin); + atexit(os_undo_timer_resolution); } /* Look for support files in the same directory as the executable. */