os_win32.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /*
  2. * Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
  3. * Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. */
  19. #ifndef __PJ_COMPAT_OS_WIN32_H__
  20. #define __PJ_COMPAT_OS_WIN32_H__
  21. /**
  22. * @file os_win32.h
  23. * @brief Describes Win32 operating system family specifics.
  24. */
  25. #define PJ_OS_NAME "win32"
  26. #define WIN32_LEAN_AND_MEAN
  27. #define PJ_WIN32_WINNT 0x0501
  28. #ifndef _WIN32_WINNT
  29. # define _WIN32_WINNT PJ_WIN32_WINNT
  30. #endif
  31. #define PJ_HAS_ARPA_INET_H 0
  32. #define PJ_HAS_ASSERT_H 1
  33. #define PJ_HAS_CTYPE_H 1
  34. #define PJ_HAS_ERRNO_H 0 /* Must be zero, otherwise errno_test() fails. */
  35. #define PJ_HAS_INTTYPES_H 1
  36. #define PJ_HAS_LINUX_SOCKET_H 0
  37. #define PJ_HAS_MALLOC_H 1
  38. #define PJ_HAS_NETDB_H 0
  39. #define PJ_HAS_NETINET_IN_H 0
  40. #define PJ_HAS_NETINET_TCP_H 0
  41. #define PJ_HAS_SETJMP_H 1
  42. #define PJ_HAS_STDARG_H 1
  43. #define PJ_HAS_STDDEF_H 1
  44. /* vs2010/msvc10 or later has stdint.h */
  45. #if PJ_CC_VER_1 >= 16
  46. # define PJ_HAS_STDINT_H 1
  47. #else
  48. # undef PJ_HAS_STDINT_H
  49. #endif
  50. #define PJ_HAS_STDIO_H 1
  51. #define PJ_HAS_STDLIB_H 1
  52. #define PJ_HAS_STRING_H 1
  53. #define PJ_HAS_SYS_IOCTL_H 0
  54. #define PJ_HAS_SYS_SELECT_H 0
  55. #define PJ_HAS_SYS_SOCKET_H 0
  56. #define PJ_HAS_SYS_TIME_H 0
  57. #define PJ_HAS_SYS_TIMEB_H 1
  58. #define PJ_HAS_SYS_TYPES_H 1
  59. #define PJ_HAS_TIME_H 1
  60. #define PJ_HAS_UNISTD_H 0
  61. #define PJ_HAS_LIMITS_H 1
  62. #define PJ_HAS_MSWSOCK_H 1
  63. #define PJ_HAS_WINSOCK_H 0
  64. #define PJ_HAS_WINSOCK2_H 1
  65. #define PJ_HAS_WS2TCPIP_H 1
  66. #define PJ_SOCK_HAS_INET_ATON 0
  67. /* Set 1 if native sockaddr_in has sin_len member.
  68. * Default: 0
  69. */
  70. #define PJ_SOCKADDR_HAS_LEN 0
  71. /* Is errno a good way to retrieve OS errors? (No)
  72. */
  73. #define PJ_HAS_ERRNO_VAR 0
  74. /* When this macro is set, getsockopt(SOL_SOCKET, SO_ERROR) will return
  75. * the status of non-blocking connect() operation.
  76. */
  77. #define PJ_HAS_SO_ERROR 1
  78. /* This value specifies the value set in errno by the OS when a non-blocking
  79. * socket recv() or send() can not return immediately.
  80. */
  81. #define PJ_BLOCKING_ERROR_VAL WSAEWOULDBLOCK
  82. /* This value specifies the value set in errno by the OS when a non-blocking
  83. * socket connect() can not get connected immediately.
  84. */
  85. #define PJ_BLOCKING_CONNECT_ERROR_VAL WSAEWOULDBLOCK
  86. /**
  87. * If this macro is set, it tells select I/O Queue that select() needs to
  88. * be given correct value of nfds (i.e. largest fd + 1). This requires
  89. * select ioqueue to re-scan the descriptors on each registration and
  90. * unregistration.
  91. * If this macro is not set, then ioqueue will always give FD_SETSIZE for
  92. * nfds argument when calling select().
  93. *
  94. * Default: 0
  95. */
  96. #define PJ_SELECT_NEEDS_NFDS 0
  97. /* Default threading is enabled, unless it's overridden. */
  98. #ifndef PJ_HAS_THREADS
  99. # define PJ_HAS_THREADS (1)
  100. #endif
  101. #define PJ_HAS_HIGH_RES_TIMER 1
  102. #define PJ_HAS_MALLOC 1
  103. #ifndef PJ_OS_HAS_CHECK_STACK
  104. # define PJ_OS_HAS_CHECK_STACK 1
  105. #endif
  106. #ifdef UNICODE
  107. # define PJ_NATIVE_STRING_IS_UNICODE 1
  108. #else
  109. # define PJ_NATIVE_STRING_IS_UNICODE 0
  110. #endif
  111. #define PJ_ATOMIC_VALUE_TYPE long
  112. /* If 1, use Read/Write mutex emulation for platforms that don't support it */
  113. #define PJ_EMULATE_RWMUTEX 1
  114. /* If 1, pj_thread_create() should enforce the stack size when creating
  115. * threads.
  116. * Default: 0 (let OS decide the thread's stack size).
  117. */
  118. #define PJ_THREAD_SET_STACK_SIZE 0
  119. /* If 1, pj_thread_create() should allocate stack from the pool supplied.
  120. * Default: 0 (let OS allocate memory for thread's stack).
  121. */
  122. #define PJ_THREAD_ALLOCATE_STACK 0
  123. /* Endianness */
  124. #if defined(_M_ARM64)
  125. # ifndef PJ_IS_LITTLE_ENDIAN
  126. # define PJ_IS_LITTLE_ENDIAN 1
  127. # define PJ_IS_BIG_ENDIAN 0
  128. # endif
  129. #endif
  130. #endif /* __PJ_COMPAT_OS_WIN32_H__ */