os_win32_wince.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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_WINCE_H__
  20. #define __PJ_COMPAT_OS_WIN32_WINCE_H__
  21. /**
  22. * @file os_win32.h
  23. * @brief Describes Win32 operating system family specifics.
  24. */
  25. #define PJ_OS_NAME "win32-wince"
  26. #define WIN32_LEAN_AND_MEAN
  27. #define RPC_NO_WINDOWS_H
  28. //#define PJ_WIN32_WINNT 0x0400
  29. //#define _WIN32_WINNT PJ_WIN32_WINNT
  30. #define PJ_HAS_ARPA_INET_H 0
  31. #define PJ_HAS_ASSERT_H 1
  32. #define PJ_HAS_CTYPE_H 1
  33. #define PJ_HAS_ERRNO_H 0 /* Must be zero, otherwise errno_test() fails. */
  34. #define PJ_HAS_LINUX_SOCKET_H 0
  35. #define PJ_HAS_MALLOC_H 1
  36. #define PJ_HAS_NETDB_H 0
  37. #define PJ_HAS_NETINET_IN_H 0
  38. #define PJ_HAS_NETINET_TCP_H 0
  39. #define PJ_HAS_SETJMP_H 1
  40. #define PJ_HAS_STDARG_H 1
  41. #define PJ_HAS_STDDEF_H 1
  42. #define PJ_HAS_STDIO_H 1
  43. #define PJ_HAS_STDLIB_H 1
  44. #define PJ_HAS_STRING_H 1
  45. #define PJ_HAS_SYS_IOCTL_H 0
  46. #define PJ_HAS_SYS_SELECT_H 0
  47. #define PJ_HAS_SYS_SOCKET_H 0
  48. #define PJ_HAS_SYS_TIME_H 0
  49. #define PJ_HAS_SYS_TIMEB_H 0 /* Doesn't have sys/timeb.h */
  50. #define PJ_HAS_SYS_TYPES_H 0 /* Doesn't have sys/types.h */
  51. #define PJ_HAS_TIME_H 1
  52. #define PJ_HAS_UNISTD_H 0
  53. #define PJ_HAS_MSWSOCK_H 1
  54. #define PJ_HAS_WINSOCK_H 0
  55. #define PJ_HAS_WINSOCK2_H 1
  56. #define PJ_SOCK_HAS_INET_ATON 0
  57. /* Set 1 if native sockaddr_in has sin_len member.
  58. * Default: 0
  59. */
  60. #define PJ_SOCKADDR_HAS_LEN 0
  61. /* Is errno a good way to retrieve OS errors? (no)
  62. */
  63. #define PJ_HAS_ERRNO_VAR 0
  64. /* When this macro is set, getsockopt(SOL_SOCKET, SO_ERROR) will return
  65. * the status of non-blocking connect() operation.
  66. */
  67. #define PJ_HAS_SO_ERROR 0
  68. /* This value specifies the value set in errno by the OS when a non-blocking
  69. * socket recv() or send() can not return immediately.
  70. */
  71. #define PJ_BLOCKING_ERROR_VAL WSAEWOULDBLOCK
  72. /* This value specifies the value set in errno by the OS when a non-blocking
  73. * socket connect() can not get connected immediately.
  74. */
  75. #define PJ_BLOCKING_CONNECT_ERROR_VAL WSAEWOULDBLOCK
  76. /**
  77. * If this macro is set, it tells select I/O Queue that select() needs to
  78. * be given correct value of nfds (i.e. largest fd + 1). This requires
  79. * select ioqueue to re-scan the descriptors on each registration and
  80. * unregistration.
  81. * If this macro is not set, then ioqueue will always give FD_SETSIZE for
  82. * nfds argument when calling select().
  83. *
  84. * Default: 0
  85. */
  86. #define PJ_SELECT_NEEDS_NFDS 0
  87. /* Endianness */
  88. #ifndef PJ_IS_LITTLE_ENDIAN
  89. # define PJ_IS_LITTLE_ENDIAN 1
  90. # define PJ_IS_BIG_ENDIAN 0
  91. #endif
  92. /* Default threading is enabled, unless it's overridden. */
  93. #ifndef PJ_HAS_THREADS
  94. # define PJ_HAS_THREADS (1)
  95. #endif
  96. #define PJ_HAS_HIGH_RES_TIMER 1
  97. #define PJ_HAS_MALLOC 1
  98. #define PJ_OS_HAS_CHECK_STACK 1
  99. #define PJ_ATOMIC_VALUE_TYPE long
  100. /* TlsAlloc() error value. */
  101. #define TLS_OUT_OF_INDEXES 0xFFFFFFFF
  102. /* No console. */
  103. #define PJ_TERM_HAS_COLOR 0
  104. /* No rdtsc */
  105. #define PJ_TIMESTAMP_USE_RDTSC 0
  106. /* Native string is Unicode. */
  107. #define PJ_NATIVE_STRING_IS_UNICODE 1
  108. /* If 1, use Read/Write mutex emulation for platforms that don't support it */
  109. #define PJ_EMULATE_RWMUTEX 1
  110. /* If 1, pj_thread_create() should enforce the stack size when creating
  111. * threads.
  112. * Default: 0 (let OS decide the thread's stack size).
  113. */
  114. #define PJ_THREAD_SET_STACK_SIZE 0
  115. /* If 1, pj_thread_create() should allocate stack from the pool supplied.
  116. * Default: 0 (let OS allocate memory for thread's stack).
  117. */
  118. #define PJ_THREAD_ALLOCATE_STACK 0
  119. #endif /* __PJ_COMPAT_OS_WIN32_WINCE_H__ */