2
0

oslib-win32.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * os-win32.c
  3. *
  4. * Copyright (c) 2003-2008 Fabrice Bellard
  5. * Copyright (c) 2010 Red Hat, Inc.
  6. *
  7. * QEMU library functions for win32 which are shared between QEMU and
  8. * the QEMU tools.
  9. *
  10. * Permission is hereby granted, free of charge, to any person obtaining a copy
  11. * of this software and associated documentation files (the "Software"), to deal
  12. * in the Software without restriction, including without limitation the rights
  13. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  14. * copies of the Software, and to permit persons to whom the Software is
  15. * furnished to do so, subject to the following conditions:
  16. *
  17. * The above copyright notice and this permission notice shall be included in
  18. * all copies or substantial portions of the Software.
  19. *
  20. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  21. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  22. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  23. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  24. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  25. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  26. * THE SOFTWARE.
  27. */
  28. #include <windows.h>
  29. #include "config-host.h"
  30. #include "sysemu.h"
  31. #include "main-loop.h"
  32. #include "trace.h"
  33. #include "qemu_socket.h"
  34. void *qemu_oom_check(void *ptr)
  35. {
  36. if (ptr == NULL) {
  37. fprintf(stderr, "Failed to allocate memory: %lu\n", GetLastError());
  38. abort();
  39. }
  40. return ptr;
  41. }
  42. void *qemu_memalign(size_t alignment, size_t size)
  43. {
  44. void *ptr;
  45. if (!size) {
  46. abort();
  47. }
  48. ptr = qemu_oom_check(VirtualAlloc(NULL, size, MEM_COMMIT, PAGE_READWRITE));
  49. trace_qemu_memalign(alignment, size, ptr);
  50. return ptr;
  51. }
  52. void *qemu_vmalloc(size_t size)
  53. {
  54. void *ptr;
  55. /* FIXME: this is not exactly optimal solution since VirtualAlloc
  56. has 64Kb granularity, but at least it guarantees us that the
  57. memory is page aligned. */
  58. if (!size) {
  59. abort();
  60. }
  61. ptr = qemu_oom_check(VirtualAlloc(NULL, size, MEM_COMMIT, PAGE_READWRITE));
  62. trace_qemu_vmalloc(size, ptr);
  63. return ptr;
  64. }
  65. void qemu_vfree(void *ptr)
  66. {
  67. trace_qemu_vfree(ptr);
  68. VirtualFree(ptr, 0, MEM_RELEASE);
  69. }
  70. void socket_set_block(int fd)
  71. {
  72. unsigned long opt = 0;
  73. WSAEventSelect(fd, NULL, 0);
  74. ioctlsocket(fd, FIONBIO, &opt);
  75. }
  76. void socket_set_nonblock(int fd)
  77. {
  78. unsigned long opt = 1;
  79. ioctlsocket(fd, FIONBIO, &opt);
  80. qemu_fd_register(fd);
  81. }
  82. int inet_aton(const char *cp, struct in_addr *ia)
  83. {
  84. uint32_t addr = inet_addr(cp);
  85. if (addr == 0xffffffff) {
  86. return 0;
  87. }
  88. ia->s_addr = addr;
  89. return 1;
  90. }
  91. void qemu_set_cloexec(int fd)
  92. {
  93. }
  94. /* Offset between 1/1/1601 and 1/1/1970 in 100 nanosec units */
  95. #define _W32_FT_OFFSET (116444736000000000ULL)
  96. int qemu_gettimeofday(qemu_timeval *tp)
  97. {
  98. union {
  99. unsigned long long ns100; /*time since 1 Jan 1601 in 100ns units */
  100. FILETIME ft;
  101. } _now;
  102. if(tp) {
  103. GetSystemTimeAsFileTime (&_now.ft);
  104. tp->tv_usec=(long)((_now.ns100 / 10ULL) % 1000000ULL );
  105. tp->tv_sec= (long)((_now.ns100 - _W32_FT_OFFSET) / 10000000ULL);
  106. }
  107. /* Always return 0 as per Open Group Base Specifications Issue 6.
  108. Do not set errno on error. */
  109. return 0;
  110. }
  111. int qemu_get_thread_id(void)
  112. {
  113. return GetCurrentThreadId();
  114. }