os_palmos.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  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_PALMOS_H__
  20. #define __PJ_COMPAT_OS_PALMOS_H__
  21. /**
  22. * @file os_palmos.h
  23. * @brief Describes PalmOS operating system specifics.
  24. */
  25. #define PJ_OS_NAME "palmos"
  26. #define PJ_HAS_ARPA_INET_H 0
  27. #define PJ_HAS_ASSERT_H 1
  28. #define PJ_HAS_CTYPE_H 1
  29. #define PJ_HAS_ERRNO_H 0
  30. #define PJ_HAS_MALLOC_H 1
  31. #define PJ_HAS_NETDB_H 0
  32. #define PJ_HAS_NETINET_IN_H 0
  33. #define PJ_HAS_SETJMP_H 1
  34. #define PJ_HAS_STDARG_H 1
  35. #define PJ_HAS_STDDEF_H 1
  36. #define PJ_HAS_STDIO_H 1
  37. #define PJ_HAS_STDLIB_H 1
  38. #define PJ_HAS_STRING_H 1
  39. #define PJ_HAS_SYS_IOCTL_H 0
  40. #define PJ_HAS_SYS_SELECT_H 0
  41. #define PJ_HAS_SYS_SOCKET_H 0
  42. #define PJ_HAS_SYS_TIMEB_H 0
  43. #define PJ_HAS_SYS_TYPES_H 1
  44. #define PJ_HAS_TIME_H 1
  45. #define PJ_HAS_UNISTD_H 0
  46. #define PJ_HAS_MSWSOCK_H 0
  47. #define PJ_HAS_WINSOCK_H 0
  48. #define PJ_HAS_WINSOCK2_H 0
  49. #define PJ_SOCK_HAS_INET_ATON 0
  50. /* Set 1 if native sockaddr_in has sin_len member.
  51. * Default: 0
  52. */
  53. #define PJ_SOCKADDR_HAS_LEN 0
  54. /**
  55. * If this macro is set, it tells select I/O Queue that select() needs to
  56. * be given correct value of nfds (i.e. largest fd + 1). This requires
  57. * select ioqueue to re-scan the descriptors on each registration and
  58. * unregistration.
  59. * If this macro is not set, then ioqueue will always give FD_SETSIZE for
  60. * nfds argument when calling select().
  61. *
  62. * Default: 0
  63. */
  64. #define PJ_SELECT_NEEDS_NFDS 0
  65. /* Is errno a good way to retrieve OS errors?
  66. */
  67. #define PJ_HAS_ERRNO_VAR 0
  68. /* When this macro is set, getsockopt(SOL_SOCKET, SO_ERROR) will return
  69. * the status of non-blocking connect() operation.
  70. */
  71. #define PJ_HAS_SO_ERROR 0
  72. /* This value specifies the value set in errno by the OS when a non-blocking
  73. * socket recv() can not return immediate daata.
  74. */
  75. #define PJ_BLOCKING_ERROR_VAL xxx
  76. /* This value specifies the value set in errno by the OS when a non-blocking
  77. * socket connect() can not get connected immediately.
  78. */
  79. #define PJ_BLOCKING_CONNECT_ERROR_VAL xxx
  80. /* Default threading is enabled, unless it's overridden. */
  81. #ifndef PJ_HAS_THREADS
  82. # define PJ_HAS_THREADS (1)
  83. #endif
  84. #define PJ_HAS_HIGH_RES_TIMER 1
  85. #ifndef PJ_OS_HAS_CHECK_STACK
  86. # define PJ_OS_HAS_CHECK_STACK 0
  87. #define PJ_NATIVE_STRING_IS_UNICODE 0
  88. /* If 1, use Read/Write mutex emulation for platforms that don't support it */
  89. #define PJ_EMULATE_RWMUTEX 1
  90. /* If 1, pj_thread_create() should enforce the stack size when creating
  91. * threads.
  92. * Default: 0 (let OS decide the thread's stack size).
  93. */
  94. #define PJ_THREAD_SET_STACK_SIZE 0
  95. /* If 1, pj_thread_create() should allocate stack from the pool supplied.
  96. * Default: 0 (let OS allocate memory for thread's stack).
  97. */
  98. #define PJ_THREAD_ALLOCATE_STACK 0
  99. #endif /* __PJ_COMPAT_OS_PALMOS_H__ */