1
/* $Id: os_palmos.h 3553 2011-05-05 06:14:19Z nanang $ */
3
* Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
4
* Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20
#ifndef __PJ_COMPAT_OS_PALMOS_H__
21
#define __PJ_COMPAT_OS_PALMOS_H__
25
* @brief Describes PalmOS operating system specifics.
28
#define PJ_OS_NAME "palmos"
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
34
#define PJ_HAS_MALLOC_H 1
35
#define PJ_HAS_NETDB_H 0
36
#define PJ_HAS_NETINET_IN_H 0
37
#define PJ_HAS_SETJMP_H 1
38
#define PJ_HAS_STDARG_H 1
39
#define PJ_HAS_STDDEF_H 1
40
#define PJ_HAS_STDIO_H 1
41
#define PJ_HAS_STDLIB_H 1
42
#define PJ_HAS_STRING_H 1
43
#define PJ_HAS_SYS_IOCTL_H 0
44
#define PJ_HAS_SYS_SELECT_H 0
45
#define PJ_HAS_SYS_SOCKET_H 0
46
#define PJ_HAS_SYS_TIMEB_H 0
47
#define PJ_HAS_SYS_TYPES_H 1
48
#define PJ_HAS_TIME_H 1
49
#define PJ_HAS_UNISTD_H 0
51
#define PJ_HAS_MSWSOCK_H 0
52
#define PJ_HAS_WINSOCK_H 0
53
#define PJ_HAS_WINSOCK2_H 0
55
#define PJ_SOCK_HAS_INET_ATON 0
57
/* Set 1 if native sockaddr_in has sin_len member.
60
#define PJ_SOCKADDR_HAS_LEN 0
63
* If this macro is set, it tells select I/O Queue that select() needs to
64
* be given correct value of nfds (i.e. largest fd + 1). This requires
65
* select ioqueue to re-scan the descriptors on each registration and
67
* If this macro is not set, then ioqueue will always give FD_SETSIZE for
68
* nfds argument when calling select().
72
#define PJ_SELECT_NEEDS_NFDS 0
74
/* Is errno a good way to retrieve OS errors?
76
#define PJ_HAS_ERRNO_VAR 0
78
/* When this macro is set, getsockopt(SOL_SOCKET, SO_ERROR) will return
79
* the status of non-blocking connect() operation.
81
#define PJ_HAS_SO_ERROR 0
83
/* This value specifies the value set in errno by the OS when a non-blocking
84
* socket recv() can not return immediate daata.
86
#define PJ_BLOCKING_ERROR_VAL xxx
88
/* This value specifies the value set in errno by the OS when a non-blocking
89
* socket connect() can not get connected immediately.
91
#define PJ_BLOCKING_CONNECT_ERROR_VAL xxx
93
/* Default threading is enabled, unless it's overridden. */
94
#ifndef PJ_HAS_THREADS
95
# define PJ_HAS_THREADS (1)
98
#define PJ_HAS_HIGH_RES_TIMER 1
99
#ifndef PJ_OS_HAS_CHECK_STACK
100
# define PJ_OS_HAS_CHECK_STACK 0
101
#define PJ_NATIVE_STRING_IS_UNICODE 0
103
/* If 1, use Read/Write mutex emulation for platforms that don't support it */
104
#define PJ_EMULATE_RWMUTEX 1
106
/* If 1, pj_thread_create() should enforce the stack size when creating
108
* Default: 0 (let OS decide the thread's stack size).
110
#define PJ_THREAD_SET_STACK_SIZE 0
112
/* If 1, pj_thread_create() should allocate stack from the pool supplied.
113
* Default: 0 (let OS allocate memory for thread's stack).
115
#define PJ_THREAD_ALLOCATE_STACK 0
118
#endif /* __PJ_COMPAT_OS_PALMOS_H__ */