Ticket #354: build PJLIB as dynamic libraries (.DSO) in Symbian

git-svn-id: https://svn.pjsip.org/repos/pjproject/trunk@1405 74dad513-b988-da41-8d7b-12977e46ad98
diff --git a/build.symbian/00.bat b/build.symbian/00.bat
index 908c635..6a9a635 100644
--- a/build.symbian/00.bat
+++ b/build.symbian/00.bat
@@ -1,5 +1,6 @@
-rem set MWSym2Libraries=1
-rem set EPOCROOT=\Symbian\9.1\S60_3rd\
-rem set EPOCROOT=\Symbian\9.1\S60_3rd_MR_2\
-rem set EPOCROOT=\Symbian\UIQ3SDK\
+@rem set MWSym2Libraries=1
+@rem set EPOCROOT=\Symbian\9.1\S60_3rd\
+@rem set EPOCROOT=\Symbian\9.1\S60_3rd_MR_2\
+@rem set EPOCROOT=\Symbian\UIQ3SDK\
+@rem set EPOCROOT=\symbian\UIQ3.1\
 bldmake bldfiles
diff --git a/build.symbian/01.bat b/build.symbian/01.bat
index 6a3f0a3..e670ae6 100644
--- a/build.symbian/01.bat
+++ b/build.symbian/01.bat
@@ -1,6 +1,7 @@
-rem set MWSym2Libraries=1
-rem set MWSym2Libraries=\Symbian\9.1\S60_3rd\Epoc32\release\winscw\udeb
+@rem call abld build -v vs6 udeb
+@rem call abld build -v gcce urel
+@rem call abld build winscw udeb
+call abld build %1 %2 %3 %4
 
-rem set EPOCROOT=\Symbian\9.1\S60_3rd\
-rem set EPOCROOT=\Symbian\9.1\S60_3rd_MR_2\
-call abld build -v vs6 udeb
+
+
diff --git a/build.symbian/bld.inf b/build.symbian/bld.inf
index 9e51ee9..42edf83 100644
--- a/build.symbian/bld.inf
+++ b/build.symbian/bld.inf
@@ -1,10 +1,11 @@
 prj_platforms
 winscw
-armv5
+//armv5
 gcce
 
 prj_mmpfiles
 pjlib.mmp
+pjlib_test.mmp
 pjlib_util.mmp
 pjnath.mmp
 pjsdp.mmp
@@ -12,8 +13,8 @@
 pjsip.mmp
 pjsip_simple.mmp
 pjsip_ua.mmp
-//pjlib_test.mmp
-//sipstateless.mmp
+pjlib_test.mmp
+sipstateless.mmp
 pjsua_lib.mmp
 null_audio.mmp
 symbian_ua.mmp
diff --git a/build.symbian/makedef.sh b/build.symbian/makedef.sh
new file mode 100644
index 0000000..46d85b6
--- /dev/null
+++ b/build.symbian/makedef.sh
@@ -0,0 +1,56 @@
+#!/bin/sh

+

+MMP=$1

+if test "$MMP" == ""; then

+	echo Usage: makedef.sh FILE.MMP

+	exit 1

+fi

+

+if test -f $MMP; then

+	true

+else

+	echo "Unable to open $MMP"

+	exit 1

+fi

+

+TARGET=`grep -w TARGET $MMP | awk '{print $2}' | awk -F '.' '{print $1}' | head -1`

+DEFFILE="${TARGET}U.def"

+SOURCES=`grep -w SOURCE $MMP | awk '{print $2}' | tr '\\\\' '/'`

+SOURCEPATH=`grep -w SOURCEPATH $MMP | tr '\\\\' '/' | awk '{print $2}'`

+INCPATH=`grep INCLUDE $MMP | awk '{print $2}' | grep pj | tr '\\\\' '/'`

+INCLUDE=""

+for INC in $INCPATH; do

+	INCLUDE=`echo $INCLUDE -I$INC`

+done

+

+echo > tmpnames.def

+

+

+for file in $SOURCES; do

+	#SYMBOLS=`grep PJ_DEF ${SOURCEPATH}/$file | awk -F ')' '{print $2}' | awk -F '(' '{print $1}' | awk -F '=' '{print $1}' | tr -d '[:blank:]' | sort | uniq`

+	SYMBOLS=`

+		cpp -DPJ_SYMBIAN=1 -DPJ_DLL -DPJ_EXPORTING=1 $INCLUDE ${SOURCEPATH}/$file 2>&1 |

+       		grep EXPORT_C | 

+		sed 's/(/;/' | 

+		sed 's/=/;/' | 

+		awk -F ';' '{print $1}' | 

+		awk '{print $NF}'`

+	echo Processing ${SOURCEPATH}/$file..

+	for SYM in $SYMBOLS; do

+		echo $SYM >> tmpnames.def

+	done

+done

+

+echo "Writing $DEFFILE"

+echo EXPORTS > $DEFFILE

+i=0

+for SYM in `cat tmpnames.def | sort | uniq`; do

+	echo "             $SYM"

+	i=`expr $i + 1`

+	printf "\\t%-40s @ $i NONAME\\n" $SYM >> $DEFFILE

+done

+

+

+echo

+echo "Done. Total $i symbols exported."

+

diff --git a/build.symbian/pjlib.mmp b/build.symbian/pjlib.mmp
index e574b47..e2d5cc9 100644
--- a/build.symbian/pjlib.mmp
+++ b/build.symbian/pjlib.mmp
@@ -1,7 +1,22 @@
+#if defined(EKA2)
+// ARM ABIv2 doesn't support static libraries anymore
+TARGET		pjlib.dll
+TARGETTYPE	dll
+UID		0x1000008d 0xA0004299
+CAPABILITY	NONE
+LIBRARY		esock.lib insock.lib charconv.lib euser.lib estlib.lib
+MACRO		PJ_DLL
+MACRO		PJ_EXPORTING
+
+DEFFILE		.\pjlib.def
+
+#else
+
 TARGET 		pjlib.lib
 TARGETTYPE 	lib
 UID		0x100039CE 0x10004299
-VENDORID	0x70000001
+//VENDORID	0x70000001
+#endif
 
 SOURCEPATH	..\pjlib\src\pj
 
@@ -32,6 +47,7 @@
 SOURCE		pool_caching.c
 SOURCE		rand.c
 SOURCE		rbtree.c
+SOURCE		sock_common.c
 SOURCE		types.c
 
 
@@ -91,7 +107,7 @@
 //DOCUMENT	pj\unicode.h
 
 SYSTEMINCLUDE	..\pjlib\include
-
 SYSTEMINCLUDE	\epoc32\include
 SYSTEMINCLUDE	\epoc32\include\libc
 
+
diff --git a/build.symbian/pjlibU.def b/build.symbian/pjlibU.def
new file mode 100644
index 0000000..6af41e2
--- /dev/null
+++ b/build.symbian/pjlibU.def
@@ -0,0 +1,290 @@
+EXPORTS
+	PJ_FD_CLR                                @ 1 NONAME
+	PJ_FD_COUNT                              @ 2 NONAME
+	PJ_FD_ISSET                              @ 3 NONAME
+	PJ_FD_SET                                @ 4 NONAME
+	PJ_FD_ZERO                               @ 5 NONAME
+	pj_AF_INET                               @ 6 NONAME
+	pj_AF_INET6                              @ 7 NONAME
+	pj_AF_IRDA                               @ 8 NONAME
+	pj_AF_PACKET                             @ 9 NONAME
+	pj_AF_UNIX                               @ 10 NONAME
+	pj_IPTOS_LOWDELAY                        @ 11 NONAME
+	pj_IPTOS_MINCOST                         @ 12 NONAME
+	pj_IPTOS_RELIABILITY                     @ 13 NONAME
+	pj_IPTOS_THROUGHPUT                      @ 14 NONAME
+	pj_IP_TOS                                @ 15 NONAME
+	pj_MSG_DONTROUTE                         @ 16 NONAME
+	pj_MSG_OOB                               @ 17 NONAME
+	pj_MSG_PEEK                              @ 18 NONAME
+	pj_SOCK_DGRAM                            @ 19 NONAME
+	pj_SOCK_RAW                              @ 20 NONAME
+	pj_SOCK_RDM                              @ 21 NONAME
+	pj_SOCK_STREAM                           @ 22 NONAME
+	pj_SOL_IP                                @ 23 NONAME
+	pj_SOL_IPV6                              @ 24 NONAME
+	pj_SOL_SOCKET                            @ 25 NONAME
+	pj_SOL_TCP                               @ 26 NONAME
+	pj_SOL_UDP                               @ 27 NONAME
+	pj_SO_RCVBUF                             @ 28 NONAME
+	pj_SO_SNDBUF                             @ 29 NONAME
+	pj_SO_TYPE                               @ 30 NONAME
+	pj_ansi_to_unicode                       @ 31 NONAME
+	pj_array_erase                           @ 32 NONAME
+	pj_array_find                            @ 33 NONAME
+	pj_array_insert                          @ 34 NONAME
+	pj_atexit                                @ 35 NONAME
+	pj_atomic_add                            @ 36 NONAME
+	pj_atomic_add_and_get                    @ 37 NONAME
+	pj_atomic_create                         @ 38 NONAME
+	pj_atomic_dec                            @ 39 NONAME
+	pj_atomic_dec_and_get                    @ 40 NONAME
+	pj_atomic_destroy                        @ 41 NONAME
+	pj_atomic_get                            @ 42 NONAME
+	pj_atomic_inc                            @ 43 NONAME
+	pj_atomic_inc_and_get                    @ 44 NONAME
+	pj_atomic_set                            @ 45 NONAME
+	pj_caching_pool_destroy                  @ 46 NONAME
+	pj_caching_pool_init                     @ 47 NONAME
+	pj_create_random_string                  @ 48 NONAME
+	pj_create_unique_string                  @ 49 NONAME
+	pj_dump_config                           @ 50 NONAME
+	pj_elapsed_cycle                         @ 51 NONAME
+	pj_elapsed_msec                          @ 52 NONAME
+	pj_elapsed_nanosec                       @ 53 NONAME
+	pj_elapsed_time                          @ 54 NONAME
+	pj_elapsed_usec                          @ 55 NONAME
+	pj_enter_critical_section                @ 56 NONAME
+	pj_enum_ip_interface                     @ 57 NONAME
+	pj_enum_ip_route                         @ 58 NONAME
+	pj_exception_id_alloc                    @ 59 NONAME
+	pj_exception_id_free                     @ 60 NONAME
+	pj_exception_id_name                     @ 61 NONAME
+	pj_fifobuf_alloc                         @ 62 NONAME
+	pj_fifobuf_free                          @ 63 NONAME
+	pj_fifobuf_init                          @ 64 NONAME
+	pj_fifobuf_max_size                      @ 65 NONAME
+	pj_fifobuf_unalloc                       @ 66 NONAME
+	pj_file_close                            @ 67 NONAME
+	pj_file_delete                           @ 68 NONAME
+	pj_file_exists                           @ 69 NONAME
+	pj_file_flush                            @ 70 NONAME
+	pj_file_getpos                           @ 71 NONAME
+	pj_file_getstat                          @ 72 NONAME
+	pj_file_move                             @ 73 NONAME
+	pj_file_open                             @ 74 NONAME
+	pj_file_read                             @ 75 NONAME
+	pj_file_setpos                           @ 76 NONAME
+	pj_file_size                             @ 77 NONAME
+	pj_file_write                            @ 78 NONAME
+	pj_generate_unique_string                @ 79 NONAME
+	pj_get_netos_error                       @ 80 NONAME
+	pj_get_os_error                          @ 81 NONAME
+	pj_get_timestamp                         @ 82 NONAME
+	pj_get_timestamp_freq                    @ 83 NONAME
+	pj_gethostaddr                           @ 84 NONAME
+	pj_gethostbyname                         @ 85 NONAME
+	pj_gethostip                             @ 86 NONAME
+	pj_gethostname                           @ 87 NONAME
+	pj_getpid                                @ 88 NONAME
+	pj_gettimeofday                          @ 89 NONAME
+	pj_hash_calc                             @ 90 NONAME
+	pj_hash_calc_tolower                     @ 91 NONAME
+	pj_hash_count                            @ 92 NONAME
+	pj_hash_create                           @ 93 NONAME
+	pj_hash_first                            @ 94 NONAME
+	pj_hash_get                              @ 95 NONAME
+	pj_hash_next                             @ 96 NONAME
+	pj_hash_set                              @ 97 NONAME
+	pj_hash_set_np                           @ 98 NONAME
+	pj_hash_this                             @ 99 NONAME
+	pj_htonl                                 @ 100 NONAME
+	pj_htons                                 @ 101 NONAME
+	pj_inet_addr                             @ 102 NONAME
+	pj_inet_addr2                            @ 103 NONAME
+	pj_inet_aton                             @ 104 NONAME
+	pj_inet_ntoa                             @ 105 NONAME
+	pj_init                                  @ 106 NONAME
+	pj_ioqueue_accept                        @ 107 NONAME
+	pj_ioqueue_connect                       @ 108 NONAME
+	pj_ioqueue_create                        @ 109 NONAME
+	pj_ioqueue_destroy                       @ 110 NONAME
+	pj_ioqueue_get_user_data                 @ 111 NONAME
+	pj_ioqueue_is_pending                    @ 112 NONAME
+	pj_ioqueue_name                          @ 113 NONAME
+	pj_ioqueue_op_key_init                   @ 114 NONAME
+	pj_ioqueue_poll                          @ 115 NONAME
+	pj_ioqueue_post_completion               @ 116 NONAME
+	pj_ioqueue_recv                          @ 117 NONAME
+	pj_ioqueue_recvfrom                      @ 118 NONAME
+	pj_ioqueue_register_sock                 @ 119 NONAME
+	pj_ioqueue_send                          @ 120 NONAME
+	pj_ioqueue_sendto                        @ 121 NONAME
+	pj_ioqueue_set_lock                      @ 122 NONAME
+	pj_ioqueue_set_user_data                 @ 123 NONAME
+	pj_ioqueue_unregister                    @ 124 NONAME
+	pj_leave_critical_section                @ 125 NONAME
+	pj_list_erase                            @ 126 NONAME
+	pj_list_find_node                        @ 127 NONAME
+	pj_list_insert_after                     @ 128 NONAME
+	pj_list_insert_before                    @ 129 NONAME
+	pj_list_insert_nodes_after               @ 130 NONAME
+	pj_list_insert_nodes_before              @ 131 NONAME
+	pj_list_merge_first                      @ 132 NONAME
+	pj_list_merge_last                       @ 133 NONAME
+	pj_list_search                           @ 134 NONAME
+	pj_list_size                             @ 135 NONAME
+	pj_lock_acquire                          @ 136 NONAME
+	pj_lock_create_null_mutex                @ 137 NONAME
+	pj_lock_create_recursive_mutex           @ 138 NONAME
+	pj_lock_create_semaphore                 @ 139 NONAME
+	pj_lock_create_simple_mutex              @ 140 NONAME
+	pj_lock_destroy                          @ 141 NONAME
+	pj_lock_release                          @ 142 NONAME
+	pj_lock_tryacquire                       @ 143 NONAME
+	pj_log                                   @ 144 NONAME
+	pj_log_1                                 @ 145 NONAME
+	pj_log_2                                 @ 146 NONAME
+	pj_log_3                                 @ 147 NONAME
+	pj_log_4                                 @ 148 NONAME
+	pj_log_5                                 @ 149 NONAME
+	pj_log_get_decor                         @ 150 NONAME
+	pj_log_get_level                         @ 151 NONAME
+	pj_log_get_log_func                      @ 152 NONAME
+	pj_log_set_decor                         @ 153 NONAME
+	pj_log_set_level                         @ 154 NONAME
+	pj_log_set_log_func                      @ 155 NONAME
+	pj_log_write                             @ 156 NONAME
+	pj_mutex_create                          @ 157 NONAME
+	pj_mutex_create_recursive                @ 158 NONAME
+	pj_mutex_create_simple                   @ 159 NONAME
+	pj_mutex_destroy                         @ 160 NONAME
+	pj_mutex_lock                            @ 161 NONAME
+	pj_mutex_trylock                         @ 162 NONAME
+	pj_mutex_unlock                          @ 163 NONAME
+	pj_ntohl                                 @ 164 NONAME
+	pj_ntohs                                 @ 165 NONAME
+	pj_pool_alloc                            @ 166 NONAME
+	pj_pool_alloc_from_block                 @ 167 NONAME
+	pj_pool_allocate_find                    @ 168 NONAME
+	pj_pool_calloc                           @ 169 NONAME
+	pj_pool_create                           @ 170 NONAME
+	pj_pool_create_int                       @ 171 NONAME
+	pj_pool_create_on_buf                    @ 172 NONAME
+	pj_pool_destroy_int                      @ 173 NONAME
+	pj_pool_factory_default_policy           @ 174 NONAME
+	pj_pool_factory_get_default_policy       @ 175 NONAME
+	pj_pool_get_capacity                     @ 176 NONAME
+	pj_pool_get_used_size                    @ 177 NONAME
+	pj_pool_getobjname                       @ 178 NONAME
+	pj_pool_init_int                         @ 179 NONAME
+	pj_pool_release                          @ 180 NONAME
+	pj_pool_reset                            @ 181 NONAME
+	pj_rand                                  @ 182 NONAME
+	pj_rbtree_erase                          @ 183 NONAME
+	pj_rbtree_find                           @ 184 NONAME
+	pj_rbtree_first                          @ 185 NONAME
+	pj_rbtree_init                           @ 186 NONAME
+	pj_rbtree_insert                         @ 187 NONAME
+	pj_rbtree_last                           @ 188 NONAME
+	pj_rbtree_max_height                     @ 189 NONAME
+	pj_rbtree_min_height                     @ 190 NONAME
+	pj_rbtree_next                           @ 191 NONAME
+	pj_rbtree_prev                           @ 192 NONAME
+	pj_register_strerror                     @ 193 NONAME
+	pj_rwmutex_create                        @ 194 NONAME
+	pj_rwmutex_destroy                       @ 195 NONAME
+	pj_rwmutex_lock_read                     @ 196 NONAME
+	pj_rwmutex_lock_write                    @ 197 NONAME
+	pj_rwmutex_unlock_read                   @ 198 NONAME
+	pj_rwmutex_unlock_write                  @ 199 NONAME
+	pj_sem_create                            @ 200 NONAME
+	pj_sem_destroy                           @ 201 NONAME
+	pj_sem_post                              @ 202 NONAME
+	pj_sem_trywait                           @ 203 NONAME
+	pj_sem_wait                              @ 204 NONAME
+	pj_set_netos_error                       @ 205 NONAME
+	pj_set_os_error                          @ 206 NONAME
+	pj_shutdown                              @ 207 NONAME
+	pj_sock_accept                           @ 208 NONAME
+	pj_sock_bind                             @ 209 NONAME
+	pj_sock_bind_in                          @ 210 NONAME
+	pj_sock_close                            @ 211 NONAME
+	pj_sock_connect                          @ 212 NONAME
+	pj_sock_getpeername                      @ 213 NONAME
+	pj_sock_getsockname                      @ 214 NONAME
+	pj_sock_getsockopt                       @ 215 NONAME
+	pj_sock_listen                           @ 216 NONAME
+	pj_sock_recv                             @ 217 NONAME
+	pj_sock_recvfrom                         @ 218 NONAME
+	pj_sock_select                           @ 219 NONAME
+	pj_sock_send                             @ 220 NONAME
+	pj_sock_sendto                           @ 221 NONAME
+	pj_sock_setsockopt                       @ 222 NONAME
+	pj_sock_shutdown                         @ 223 NONAME
+	pj_sock_socket                           @ 224 NONAME
+	pj_sockaddr_in_init                      @ 225 NONAME
+	pj_sockaddr_in_set_str_addr              @ 226 NONAME
+	pj_srand                                 @ 227 NONAME
+	pj_str                                   @ 228 NONAME
+	pj_strassign                             @ 229 NONAME
+	pj_strcat                                @ 230 NONAME
+	pj_strcat2                               @ 231 NONAME
+	pj_strcmp                                @ 232 NONAME
+	pj_strcmp2                               @ 233 NONAME
+	pj_strcpy                                @ 234 NONAME
+	pj_strcpy2                               @ 235 NONAME
+	pj_strdup                                @ 236 NONAME
+	pj_strdup2                               @ 237 NONAME
+	pj_strdup2_with_null                     @ 238 NONAME
+	pj_strdup3                               @ 239 NONAME
+	pj_strdup_with_null                      @ 240 NONAME
+	pj_strerror                              @ 241 NONAME
+	pj_stricmp                               @ 242 NONAME
+	pj_stricmp2                              @ 243 NONAME
+	pj_strltrim                              @ 244 NONAME
+	pj_strncmp                               @ 245 NONAME
+	pj_strncmp2                              @ 246 NONAME
+	pj_strncpy                               @ 247 NONAME
+	pj_strncpy_with_null                     @ 248 NONAME
+	pj_strnicmp                              @ 249 NONAME
+	pj_strnicmp2                             @ 250 NONAME
+	pj_strrtrim                              @ 251 NONAME
+	pj_strtoul                               @ 252 NONAME
+	pj_strtoul2                              @ 253 NONAME
+	pj_strtrim                               @ 254 NONAME
+	pj_symbianos_poll                        @ 255 NONAME
+	pj_thread_create                         @ 256 NONAME
+	pj_thread_destroy                        @ 257 NONAME
+	pj_thread_get_name                       @ 258 NONAME
+	pj_thread_join                           @ 259 NONAME
+	pj_thread_local_alloc                    @ 260 NONAME
+	pj_thread_local_free                     @ 261 NONAME
+	pj_thread_local_get                      @ 262 NONAME
+	pj_thread_local_set                      @ 263 NONAME
+	pj_thread_register                       @ 264 NONAME
+	pj_thread_resume                         @ 265 NONAME
+	pj_thread_sleep                          @ 266 NONAME
+	pj_thread_this                           @ 267 NONAME
+	pj_time_decode                           @ 268 NONAME
+	pj_time_encode                           @ 269 NONAME
+	pj_time_gmt_to_local                     @ 270 NONAME
+	pj_time_local_to_gmt                     @ 271 NONAME
+	pj_time_val_normalize                    @ 272 NONAME
+	pj_timer_entry_init                      @ 273 NONAME
+	pj_timer_heap_cancel                     @ 274 NONAME
+	pj_timer_heap_count                      @ 275 NONAME
+	pj_timer_heap_create                     @ 276 NONAME
+	pj_timer_heap_destroy                    @ 277 NONAME
+	pj_timer_heap_earliest_time              @ 278 NONAME
+	pj_timer_heap_mem_size                   @ 279 NONAME
+	pj_timer_heap_poll                       @ 280 NONAME
+	pj_timer_heap_schedule                   @ 281 NONAME
+	pj_timer_heap_set_lock                   @ 282 NONAME
+	pj_timer_heap_set_max_timed_out_per_poll @ 283 NONAME
+	pj_unicode_to_ansi                       @ 284 NONAME
+	pj_utoa                                  @ 285 NONAME
+	pj_utoa_pad                              @ 286 NONAME
+	platform_strerror                        @ 287 NONAME
+	snprintf                                 @ 288 NONAME
+	vsnprintf                                @ 289 NONAME
diff --git a/build.symbian/pjlib_test.mmp b/build.symbian/pjlib_test.mmp
index ed88906..7c9bd53 100644
--- a/build.symbian/pjlib_test.mmp
+++ b/build.symbian/pjlib_test.mmp
@@ -8,6 +8,10 @@
 MACRO		PJ_M_I386=1
 MACRO		PJ_SYMBIAN=1
 
+#if defined(EKA2)
+MACRO		PJ_DLL
+#endif
+
 OPTION		CW -lang c++
 OPTION		ARMCC --cpp
 OPTION		GCC	-x c++
diff --git a/pjlib-util/src/pjlib-util-test/resolver_test.c b/pjlib-util/src/pjlib-util-test/resolver_test.c
index 193a7d2..81e4c99 100644
--- a/pjlib-util/src/pjlib-util-test/resolver_test.c
+++ b/pjlib-util/src/pjlib-util-test/resolver_test.c
@@ -427,7 +427,7 @@
     for (i=0; i<2; ++i) {
 	pj_sockaddr_in addr;
 
-	status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &g_server[i].sock);
+	status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &g_server[i].sock);
 	if (status != PJ_SUCCESS)
 	    return -10;
 
diff --git a/pjlib-util/src/pjlib-util/resolver.c b/pjlib-util/src/pjlib-util/resolver.c
index 0a0905a..3c86958 100644
--- a/pjlib-util/src/pjlib-util/resolver.c
+++ b/pjlib-util/src/pjlib-util/resolver.c
@@ -305,7 +305,7 @@
     pj_list_init(&resv->query_free_nodes);
 
     /* Create the UDP socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &resv->udp_sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &resv->udp_sock);
     if (status != PJ_SUCCESS)
 	goto on_error;
 
diff --git a/pjlib-util/src/pjlib-util/stun_simple_client.c b/pjlib-util/src/pjlib-util/stun_simple_client.c
index 7ec5b14..8a58f71 100644
--- a/pjlib-util/src/pjlib-util/stun_simple_client.c
+++ b/pjlib-util/src/pjlib-util/stun_simple_client.c
@@ -217,7 +217,7 @@
 	if (rec[i].srv[0].mapped_addr == rec[i].srv[1].mapped_addr &&
 	    rec[i].srv[0].mapped_port == rec[i].srv[1].mapped_port)
 	{
-	    mapped_addr[i].sin_family = PJ_AF_INET;
+	    mapped_addr[i].sin_family = pj_AF_INET();
 	    mapped_addr[i].sin_addr.s_addr = rec[i].srv[0].mapped_addr;
 	    mapped_addr[i].sin_port = (pj_uint16_t)rec[i].srv[0].mapped_port;
 
diff --git a/pjlib/build/Makefile b/pjlib/build/Makefile
index d5f78ce..95262ca 100644
--- a/pjlib/build/Makefile
+++ b/pjlib/build/Makefile
@@ -25,8 +25,7 @@
 	array.o config.o ctype.o errno.o except.o fifobuf.o guid.o \
 	hash.o ip_helper_generic.o list.o lock.o log.o os_time_common.o \
 	pool.o pool_buf.o pool_caching.o pool_dbg.o rand.o \
-	rbtree.o string.o timer.o \
-	types.o symbols.o
+	rbtree.o sock_common.o string.o timer.o types.o
 export PJLIB_CFLAGS += $(_CFLAGS)
 
 ###############################################################################
diff --git a/pjlib/build/pjlib.dsp b/pjlib/build/pjlib.dsp
index bd841f7..321d9c7 100644
--- a/pjlib/build/pjlib.dsp
+++ b/pjlib/build/pjlib.dsp
@@ -40,6 +40,7 @@
 # PROP Output_Dir ".\output\pjlib-i386-win32-vc6-release"

 # PROP Intermediate_Dir ".\output\pjlib-i386-win32-vc6-release"

 # PROP Target_Dir ""

+F90=df.exe

 # ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c

 # ADD CPP /nologo /MD /W4 /Zi /O2 /Ob2 /I "../include" /D "NDEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "PJ_WIN32" /D "PJ_M_I386" /FR /FD /c

 # SUBTRACT CPP /YX

@@ -64,6 +65,7 @@
 # PROP Output_Dir ".\output\pjlib-i386-win32-vc6-debug"

 # PROP Intermediate_Dir ".\output\pjlib-i386-win32-vc6-debug"

 # PROP Target_Dir ""

+F90=df.exe

 # ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c

 # ADD CPP /nologo /MTd /W4 /Gm /GX /ZI /Od /I "../include" /D "_DEBUG" /D "WIN32" /D "_MBCS" /D "_LIB" /D "PJ_WIN32" /D "PJ_M_I386" /FR /FD /GZ /c

 # SUBTRACT CPP /YX

@@ -331,6 +333,10 @@
 # End Source File

 # Begin Source File

 

+SOURCE=..\src\pj\sock_common.c

+# End Source File

+# Begin Source File

+

 SOURCE=..\src\pj\sock_select.c

 # End Source File

 # Begin Source File

diff --git a/pjlib/build/pjlib.vcproj b/pjlib/build/pjlib.vcproj
index 9218378..c795771 100644
--- a/pjlib/build/pjlib.vcproj
+++ b/pjlib/build/pjlib.vcproj
@@ -916,6 +916,10 @@
 				</FileConfiguration>

 			</File>

 			<File

+				RelativePath="..\src\pj\sock_common.c"

+				>

+			</File>

+			<File

 				RelativePath="..\src\pj\sock_select.c"

 				>

 				<FileConfiguration

diff --git a/pjlib/build/wince-evc4/pjlib_wince.vcp b/pjlib/build/wince-evc4/pjlib_wince.vcp
index 38b0f5f..8c0fdc2 100644
--- a/pjlib/build/wince-evc4/pjlib_wince.vcp
+++ b/pjlib/build/wince-evc4/pjlib_wince.vcp
@@ -375,25 +375,34 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\compat\socket.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -801,24 +810,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -1200,19 +1218,27 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_CONFI=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ioqueue.h"\

 	"..\..\include\pj\log.h"\

 	"..\..\include\pj\types.h"\

@@ -1437,20 +1463,28 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_CTYPE=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\types.h"\

 	

@@ -1689,24 +1723,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -2079,24 +2122,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -2429,19 +2481,27 @@
 DEP_CPP_FIFOB=\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\fifobuf.h"\

 	"..\..\include\pj\log.h"\

 	"..\..\include\pj\os.h"\

@@ -2698,24 +2758,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -3051,20 +3120,28 @@
 DEP_CPP_FILE_I=\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\errno.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\file_io.h"\

 	"..\..\include\pj\types.h"\

@@ -3331,24 +3408,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -3718,24 +3804,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -4121,24 +4216,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -4557,25 +4661,34 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\compat\socket.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -5063,24 +5176,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -5617,9 +5739,11 @@
 	"..\..\include\pj\types.h"\

 	"..\..\include\pj\unicode.h"\

 	"..\..\include\pjlib.h"\

-	{$(INCLUDE)}"ipexport.h"\

-	{$(INCLUDE)}"Iphlpapi.h"\

-	{$(INCLUDE)}"iptypes.h"\

+	

+NODEP_CPP_IP_HE=\

+	".\pexport.h"\

+	".\phlpapi.h"\

+	".\ptypes.h"\

 	

 

 !ENDIF 

@@ -5655,19 +5779,27 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_LIST_=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\list.h"\

 	"..\..\include\pj\list_i.h"\

 	"..\..\include\pj\types.h"\

@@ -5911,24 +6043,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -6333,17 +6474,24 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

@@ -6352,6 +6500,7 @@
 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -6721,20 +6870,28 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_LOG_W=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\compat\stdfileio.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\log.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\types.h"\

@@ -6990,24 +7147,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -7444,17 +7610,24 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

@@ -7463,6 +7636,7 @@
 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -7849,24 +8023,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -8165,20 +8348,28 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_OS_TIM=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\types.h"\

 	

@@ -8405,20 +8596,28 @@
 DEP_CPP_OS_TIME=\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\errno.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\log.h"\

 	"..\..\include\pj\os.h"\

@@ -8674,24 +8873,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -9117,24 +9325,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -9664,24 +9881,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -10073,25 +10299,34 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

 	"..\..\include\pj\compat\malloc.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -10121,6 +10356,7 @@
 	"..\..\include\pj\types.h"\

 	"..\..\include\pj\unicode.h"\

 	"..\..\include\pjlib.h"\

+	"..\..\src\pj\pool_signature.h"\

 	

 

 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4I) Release"

@@ -10468,20 +10704,28 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_RAND_=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\rand.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\rand.h"\

 	"..\..\include\pj\types.h"\

@@ -10714,19 +10958,27 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_RBTRE=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\rbtree.h"\

 	"..\..\include\pj\types.h"\

@@ -10972,25 +11224,34 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\compat\socket.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -11366,6 +11627,293 @@
 # End Source File

 # Begin Source File

 

+SOURCE=..\..\src\pj\sock_common.c

+

+!IF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Release"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4I) Release"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4I) Debug"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4) Release"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4) Debug"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4T) Release"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE ARMV4T) Debug"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE x86) Release"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE x86) Debug"

+

+DEP_CPP_SOCK_C=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

+	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

+	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

+	"..\..\include\pj\compat\os_darwinos.h"\

+	"..\..\include\pj\compat\os_linux.h"\

+	"..\..\include\pj\compat\os_linux_kernel.h"\

+	"..\..\include\pj\compat\os_palmos.h"\

+	"..\..\include\pj\compat\os_rtems.h"\

+	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

+	"..\..\include\pj\compat\os_win32.h"\

+	"..\..\include\pj\compat\os_win32_wince.h"\

+	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\config.h"\

+	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

+	"..\..\include\pj\sock.h"\

+	"..\..\include\pj\types.h"\

+	

+

+!ENDIF 

+

+# End Source File

+# Begin Source File

+

 SOURCE=..\..\src\pj\sock_select.c

 

 !IF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Release"

@@ -11401,21 +11949,29 @@
 DEP_CPP_SOCK_S=\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\errno.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\compat\socket.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\sock_select.h"\

@@ -11698,24 +12254,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -12110,24 +12675,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

@@ -12522,19 +13096,27 @@
 !ELSEIF  "$(CFG)" == "pjlib_wince - Win32 (WCE emulator) Debug"

 

 DEP_CPP_TYPES=\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\size_t.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\os.h"\

 	"..\..\include\pj\types.h"\

 	

@@ -12766,24 +13348,33 @@
 	"..\..\include\pj\array.h"\

 	"..\..\include\pj\assert.h"\

 	"..\..\include\pj\compat\assert.h"\

+	"..\..\include\pj\compat\cc_armcc.h"\

+	"..\..\include\pj\compat\cc_codew.h"\

 	"..\..\include\pj\compat\cc_gcc.h"\

+	"..\..\include\pj\compat\cc_gcce.h"\

 	"..\..\include\pj\compat\cc_msvc.h"\

+	"..\..\include\pj\compat\cc_mwcc.h"\

 	"..\..\include\pj\compat\ctype.h"\

 	"..\..\include\pj\compat\errno.h"\

 	"..\..\include\pj\compat\high_precision.h"\

+	"..\..\include\pj\compat\m_auto.h"\

+	"..\..\include\pj\compat\os_auto.h"\

 	"..\..\include\pj\compat\os_darwinos.h"\

 	"..\..\include\pj\compat\os_linux.h"\

 	"..\..\include\pj\compat\os_linux_kernel.h"\

 	"..\..\include\pj\compat\os_palmos.h"\

 	"..\..\include\pj\compat\os_rtems.h"\

 	"..\..\include\pj\compat\os_sunos.h"\

+	"..\..\include\pj\compat\os_symbian.h"\

 	"..\..\include\pj\compat\os_win32.h"\

 	"..\..\include\pj\compat\os_win32_wince.h"\

 	"..\..\include\pj\compat\setjmp.h"\

 	"..\..\include\pj\compat\size_t.h"\

+	"..\..\include\pj\compat\stdarg.h"\

 	"..\..\include\pj\compat\string.h"\

 	"..\..\include\pj\config.h"\

 	"..\..\include\pj\config_site.h"\

+	"..\..\include\pj\config_site_sample.h"\

 	"..\..\include\pj\ctype.h"\

 	"..\..\include\pj\errno.h"\

 	"..\..\include\pj\except.h"\

diff --git a/pjlib/include/pj/compat/cc_msvc.h b/pjlib/include/pj/compat/cc_msvc.h
index 3d6aa80..d028578 100644
--- a/pjlib/include/pj/compat/cc_msvc.h
+++ b/pjlib/include/pj/compat/cc_msvc.h
@@ -53,6 +53,10 @@
 #  define PJ_INLINE_SPECIFIER	static __inline
 #endif
 
+#define PJ_EXPORT_DECL_SPECIFIER    __declspec(dllexport)
+#define PJ_EXPORT_DEF_SPECIFIER	    __declspec(dllexport)
+#define PJ_IMPORT_DECL_SPECIFIER    __declspec(dllimport)
+
 #define PJ_THREAD_FUNC	
 #define PJ_NORETURN		__declspec(noreturn)
 #define PJ_ATTR_NORETURN	
diff --git a/pjlib/include/pj/compat/os_symbian.h b/pjlib/include/pj/compat/os_symbian.h
index f6787b0..fd224ff 100644
--- a/pjlib/include/pj/compat/os_symbian.h
+++ b/pjlib/include/pj/compat/os_symbian.h
@@ -148,15 +148,11 @@
 #include <e32def.h>
 #endif
 
-/*
-#if defined(PJ_EXPORTING)
-#   define PJ_EXPORT_IMPORT EXPORT_C
-#elif defined(PJ_IMPORTING)
-#   define PJ_EXPORT_IMPORT IMPORT_C
-#else
-#   error "Must define either PJ_EXPORTING or PJ_IMPORTING"
-#endif
-*/
+#define PJ_EXPORT_DECL_SPECIFIER	IMPORT_C
+//#define PJ_EXPORT_DECL_SPECIFIER
+#define PJ_EXPORT_DEF_SPECIFIER		EXPORT_C
+#define PJ_IMPORT_DECL_SPECIFIER	IMPORT_C
+
 
 #endif	/* __PJ_COMPAT_OS_SYMBIAN_H__ */
 
diff --git a/pjlib/include/pj/config.h b/pjlib/include/pj/config.h
index cbdc0aa..db557c9 100644
--- a/pjlib/include/pj/config.h
+++ b/pjlib/include/pj/config.h
@@ -657,6 +657,37 @@
  */
 
 /**
+ * Guide for building dynamic link libraries (DLL).
+ *
+ * The libraries support generation of dynamic link libraries for
+ * Symbian ABIv2 target (.dso files, in S60 3rd Edition). Similar
+ * procedures may be applied for Win32 DLL too, with some modification.
+ *
+ * Macros related for building DLL/DSO files:
+ *  - For platforms that supports dynamic link libraries generation,
+ *    it must declare PJ_EXPORT_SPECIFIER macro which value contains
+ *    the prefix to be added to symbol definition, to export this 
+ *    symbol in the DLL/DSO. For example, on Win32/Visual Studio, the
+ *    value of this macro is "__declspec(dllexport)", and for ARM 
+ *    ABIv2/Symbian, the value is \a EXPORT_C. 
+ *  - For platforms that supports linking with dynamic link libraries,
+ *    it must declare PJ_IMPORT_SPECIFIER macro which value contains
+ *    the prefix to be added to symbol declaration, to import this 
+ *    symbol from a DLL/DSO. For example, on Win32/Visual Studio, the
+ *    value of this macro is "__declspec(dllimport)", and for ARM 
+ *    ABIv2/Symbian, the value is \a IMPORT_C. 
+ *  - When PJLIB is built as DLL/DSO, both \a PJ_DLL and \a PJ_EXPORTING
+ *    macros must be declared, so that PJ_EXPORT_SPECIFIER prefix will be
+ *    added into function definition.
+ *  - When application wants to link dynamically with PJLIB, then it
+ *    must declare \a PJ_DLL macro when using/including PJLIB header,
+ *    so that PJ_IMPORT_SPECIFIER is properly added into symbol
+ *    declarations.
+ *
+ * When \a PJ_DLL macro is not declared, static linking is assumed.
+ */
+
+/**
  * @def PJ_INLINE(type)
  * @param type The return type of the function.
  * Expand the function as inline.
@@ -664,11 +695,6 @@
 #define PJ_INLINE(type)	  PJ_INLINE_SPECIFIER type
 
 /**
- * @def PJ_DECL(type)
- * @param type The return type of the function.
- * Declare a function.
- */
-/**
  * @def PJ_DECL_NO_RETURN(type)
  * @param type The return type of the function.
  * Declare a function that will not return.
@@ -682,38 +708,124 @@
  * Mark end of declaration section in a header file.
  */
 #ifdef __cplusplus
-#  define PJ_DECL(type)		    type
 #  define PJ_DECL_NO_RETURN(type)   type PJ_NORETURN
 #  define PJ_IDECL_NO_RETURN(type)  PJ_INLINE(type) PJ_NORETURN
 #  define PJ_BEGIN_DECL		    extern "C" {
 #  define PJ_END_DECL		    }
 #else
-#  define PJ_DECL(type)		    extern type
 #  define PJ_DECL_NO_RETURN(type)   PJ_NORETURN type
 #  define PJ_IDECL_NO_RETURN(type)  PJ_NORETURN PJ_INLINE(type)
 #  define PJ_BEGIN_DECL
 #  define PJ_END_DECL
 #endif
 
+
+/**
+ * This macro declares platform/compiler specific specifier prefix
+ * to be added to symbol declaration to export the symbol when PJLIB
+ * is built as dynamic library.
+ *
+ * This macro should have been added by platform specific headers,
+ * if the platform supports building dynamic library target. 
+ */
+#ifndef PJ_EXPORT_DECL_SPECIFIER
+#   define PJ_EXPORT_DECL_SPECIFIER
+#endif
+
+
+/**
+ * This macro declares platform/compiler specific specifier prefix
+ * to be added to symbol definition to export the symbol when PJLIB
+ * is built as dynamic library.
+ *
+ * This macro should have been added by platform specific headers,
+ * if the platform supports building dynamic library target. 
+ */
+#ifndef PJ_EXPORT_DEF_SPECIFIER
+#   define PJ_EXPORT_DEF_SPECIFIER
+#endif
+
+
+/**
+ * This macro declares platform/compiler specific specifier prefix
+ * to be added to symbol declaration to import the symbol.
+ *
+ * This macro should have been added by platform specific headers,
+ * if the platform supports building dynamic library target.
+ */
+#ifndef PJ_IMPORT_DECL_SPECIFIER
+#   define PJ_IMPORT_DECL_SPECIFIER
+#endif
+
+
+/**
+ * This macro has been deprecated. It will evaluate to nothing.
+ */
+#ifndef PJ_EXPORT_SYMBOL
+#   define PJ_EXPORT_SYMBOL(x)
+#endif
+
+
+/**
+ * @def PJ_DECL(type)
+ * @param type The return type of the function.
+ * Declare a function.
+ */
+#if defined(PJ_DLL)
+#   if defined(PJ_EXPORTING)
+#	define PJ_DECL(type)	    PJ_EXPORT_DECL_SPECIFIER type
+#   else
+#	define PJ_DECL(type)	    PJ_IMPORT_DECL_SPECIFIER type
+#   endif
+#elif !defined(PJ_DECL)
+#   if defined(__cplusplus)
+#	define PJ_DECL(type)	    type
+#   else
+#	define PJ_DECL(type)	    extern type
+#   endif
+#endif
+
+
 /**
  * @def PJ_DEF(type)
  * @param type The return type of the function.
  * Define a function.
  */
-#define PJ_DEF(type)	  type
+#if defined(PJ_DLL) && defined(PJ_EXPORTING)
+#   define PJ_DEF(type)		    PJ_EXPORT_DEF_SPECIFIER type
+#elif !defined(PJ_DEF)
+#   define PJ_DEF(type)		    type
+#endif
+
 
 /**
- * @def PJ_EXPORT_SYMBOL(sym)
- * @param sym The symbol to export.
- * Export the specified symbol in compilation type that requires export
- * (e.g. Linux kernel).
- */
-#ifdef __PJ_EXPORT_SYMBOL
-#  define PJ_EXPORT_SYMBOL(sym)	    __PJ_EXPORT_SYMBOL(sym)
-#else
-#  define PJ_EXPORT_SYMBOL(sym)
+ * @def PJ_DECL_DATA(type)
+ * @param type The data type.
+ * Declare a global data.
+ */ 
+#if defined(PJ_DLL)
+#   if defined(PJ_EXPORTING)
+#	define PJ_DECL_DATA(type)   PJ_EXPORT_DECL_SPECIFIER extern type
+#   else
+#	define PJ_DECL_DATA(type)   PJ_IMPORT_DECL_SPECIFIER extern type
+#   endif
+#elif !defined(PJ_DECL_DATA)
+#   define PJ_DECL_DATA(type)	    extern type
 #endif
 
+
+/**
+ * @def PJ_DEF_DATA(type)
+ * @param type The data type.
+ * Define a global data.
+ */ 
+#if defined(PJ_DLL) && defined(PJ_EXPORTING)
+#   define PJ_DEF_DATA(type)	    PJ_EXPORT_DEF_SPECIFIER type
+#elif !defined(PJ_DEF_DATA)
+#   define PJ_DEF_DATA(type)	    type
+#endif
+
+
 /**
  * @def PJ_IDECL(type)
  * @param type  The function's return type.
@@ -733,6 +845,7 @@
 #  define PJ_IDEF(type)   PJ_DEF(type)
 #endif
 
+
 /**
  * @def PJ_UNUSED_ARG(arg)
  * @param arg   The argument name.
diff --git a/pjlib/include/pj/errno.h b/pjlib/include/pj/errno.h
index df6c1b0..9d2c504 100644
--- a/pjlib/include/pj/errno.h
+++ b/pjlib/include/pj/errno.h
@@ -352,11 +352,10 @@
  *  - PJNATH_ERRNO_START	(PJ_ERRNO_START_USER + PJ_ERRNO_SPACE_SIZE*4)
  */
 
-
-PJ_END_DECL
-
 /* Internal */
 void pj_errno_clear_handlers(void);
 
+PJ_END_DECL
+
 #endif	/* __PJ_ERRNO_H__ */
 
diff --git a/pjlib/include/pj/ioqueue.h b/pjlib/include/pj/ioqueue.h
index bc93e2d..616ccc1 100644
--- a/pjlib/include/pj/ioqueue.h
+++ b/pjlib/include/pj/ioqueue.h
@@ -478,6 +478,9 @@
 /**
  * Poll the I/O Queue for completed events.
  *
+ * Note: polling the ioqueue is not necessary in Symbian. Please see
+ * @ref PJ_SYMBIAN_OS for more info.
+ *
  * @param ioque		the I/O Queue.
  * @param timeout	polling timeout, or NULL if the thread wishes to wait
  *			indefinetely for the event.
diff --git a/pjlib/include/pj/list_i.h b/pjlib/include/pj/list_i.h
index f0a628e..b604d79 100644
--- a/pjlib/include/pj/list_i.h
+++ b/pjlib/include/pj/list_i.h
@@ -19,27 +19,13 @@
 
 
 /* Internal */
-PJ_IDEF(void) pj_link_node(pj_list_type *prev, pj_list_type *next)
+PJ_INLINE(void) pj_link_node(pj_list_type *prev, pj_list_type *next)
 {
     ((pj_list*)prev)->next = next;
     ((pj_list*)next)->prev = prev;
 }
 
-/*
-PJ_IDEF(void) 
-pj_list_init(pj_list_type * node)
-{
-    ((pj_list*)node)->next = ((pj_list*)node)->prev = node;
-}
-
-PJ_IDEF(int) pj_list_empty(const pj_list_type * node)
-{
-    return ((pj_list*)node)->next == node;
-}
-*/
-
-PJ_IDEF(void) 
-pj_list_insert_after(pj_list_type *pos, pj_list_type *node)
+PJ_IDEF(void) pj_list_insert_after(pj_list_type *pos, pj_list_type *node)
 {
     ((pj_list*)node)->prev = pos;
     ((pj_list*)node)->next = ((pj_list*)pos)->next;
@@ -48,15 +34,13 @@
 }
 
 
-PJ_IDEF(void) 
-pj_list_insert_before(pj_list_type *pos, pj_list_type *node)
+PJ_IDEF(void) pj_list_insert_before(pj_list_type *pos, pj_list_type *node)
 {
     pj_list_insert_after(((pj_list*)pos)->prev, node);
 }
 
 
-PJ_IDEF(void)	    
-pj_list_insert_nodes_after(pj_list_type *pos, pj_list_type *lst)
+PJ_IDEF(void) pj_list_insert_nodes_after(pj_list_type *pos, pj_list_type *lst)
 {
     pj_list *lst_last = (pj_list *) ((pj_list*)lst)->prev;
     pj_list *pos_next = (pj_list *) ((pj_list*)pos)->next;
@@ -65,14 +49,12 @@
     pj_link_node(lst_last, pos_next);
 }
 
-PJ_IDEF(void) 
-pj_list_insert_nodes_before(pj_list_type *pos, pj_list_type *lst)
+PJ_IDEF(void) pj_list_insert_nodes_before(pj_list_type *pos, pj_list_type *lst)
 {
     pj_list_insert_nodes_after(((pj_list*)pos)->prev, lst);
 }
 
-PJ_IDEF(void)
-pj_list_merge_last(pj_list_type *lst1, pj_list_type *lst2)
+PJ_IDEF(void) pj_list_merge_last(pj_list_type *lst1, pj_list_type *lst2)
 {
     if (!pj_list_empty(lst2)) {
 	pj_link_node(((pj_list*)lst1)->prev, ((pj_list*)lst2)->next);
@@ -81,8 +63,7 @@
     }
 }
 
-PJ_IDEF(void)
-pj_list_merge_first(pj_list_type *lst1, pj_list_type *lst2)
+PJ_IDEF(void) pj_list_merge_first(pj_list_type *lst1, pj_list_type *lst2)
 {
     if (!pj_list_empty(lst2)) {
 	pj_link_node(((pj_list*)lst2)->prev, ((pj_list*)lst1)->next);
@@ -91,15 +72,13 @@
     }
 }
 
-PJ_IDEF(void) 
-pj_list_erase(pj_list_type *node)
+PJ_IDEF(void) pj_list_erase(pj_list_type *node)
 {
     pj_link_node( ((pj_list*)node)->prev, ((pj_list*)node)->next);
 }
 
 
-PJ_IDEF(pj_list_type*) 
-pj_list_find_node(pj_list_type *list, pj_list_type *node)
+PJ_IDEF(pj_list_type*) pj_list_find_node(pj_list_type *list, pj_list_type *node)
 {
     pj_list *p = (pj_list *) ((pj_list*)list)->next;
     while (p != list && p != node)
@@ -109,9 +88,8 @@
 }
 
 
-PJ_IDEF(pj_list_type*) 
-pj_list_search(pj_list_type *list, void *value,
-	       int (*comp)(void *value, const pj_list_type *node))
+PJ_IDEF(pj_list_type*) pj_list_search(pj_list_type *list, void *value,
+	       		int (*comp)(void *value, const pj_list_type *node))
 {
     pj_list *p = (pj_list *) ((pj_list*)list)->next;
     while (p != list && (*comp)(value, p) != 0)
diff --git a/pjlib/include/pj/log.h b/pjlib/include/pj/log.h
index 3b9e3af..c04a3ad 100644
--- a/pjlib/include/pj/log.h
+++ b/pjlib/include/pj/log.h
@@ -174,10 +174,10 @@
  *
  * @return	    Current log maximum level.
  */
-#if 0
+#if 1
 PJ_DECL(int) pj_log_get_level(void);
 #else
-extern int pj_log_max_level;
+PJ_DECL_DATA(int) pj_log_max_level;
 #define pj_log_get_level()  pj_log_max_level
 #endif
 
diff --git a/pjlib/include/pj/os.h b/pjlib/include/pj/os.h
index c1a570f..10cc552 100644
--- a/pjlib/include/pj/os.h
+++ b/pjlib/include/pj/os.h
@@ -236,6 +236,69 @@
 
 /* **************************************************************************/
 /**
+ * @defgroup PJ_SYMBIAN_OS Symbian OS Specific
+ * @ingroup PJ_OS
+ * @{
+ * Functionalities specific to Symbian OS.
+ *
+ * Symbian OS strongly discourages the use of polling since this wastes
+ * CPU power, and instead provides Active Object and Active Scheduler
+ * pattern to allow application (in this case, PJLIB) to register asynchronous
+ * tasks. PJLIB port for Symbian complies to this recommended behavior.
+ * As the result, few things have been changed in PJLIB for Symbian:
+ *	- the timer heap (see @ref PJ_TIMER) is implemented with active
+ *	  object framework, and each timer entry registered to the timer 
+ *	  heap will register an Active Object to the Active Scheduler.
+ *	  Because of this, polling the timer heap with pj_timer_heap_poll()
+ *	  is no longer necessary, and this function will just evaluate
+ *	  to nothing.
+ *	- the ioqueue (see @ref PJ_IOQUEUE) is also implemented with
+ *	  active object framework, with each asynchronous operation will
+ *	  register an Active Object to the Active Scheduler. Because of
+ *	  this, polling the ioqueue with pj_ioqueue_poll() is no longer
+ *	  necessary, and this function will just evaluate to nothing.
+ *
+ * Since timer heap and ioqueue polling are no longer necessary, Symbian
+ * application can now poll for all events by calling 
+ * \a User::WaitForAnyRequest() and \a CActiveScheduler::RunIfReady().
+ * PJLIB provides a thin wrapper which calls these two functions,
+ * called pj_symbianos_poll().
+ */
+ 
+/**
+ * Wait the completion of any Symbian active objects. When the timeout
+ * value is not specified (the \a ms_timeout argument is -1), this 
+ * function is a thin wrapper which calls \a User::WaitForAnyRequest() 
+ * and \a CActiveScheduler::RunIfReady(). If the timeout value is
+ * specified, this function will schedule a timer entry to the timer
+ * heap (which is an Active Object), to limit the wait time for event
+ * occurences. Scheduling a timer entry is an expensive operation,
+ * therefore application should only specify a timeout value when it's
+ * really necessary (for example, when it's not sure there are other
+ * Active Objects currently running in the application).
+ *
+ * @param priority	The minimum priority of the Active Objects to
+ *			poll, which values are from CActive::TPriority
+ *			constants. If -1 is given, CActive::EPriorityStandard.
+ *			priority will be used.
+ * @param ms_timeout	Optional timeout to wait. Application should
+ *			specify -1 to let the function wait indefinitely
+ *			for any events.
+ *
+ * @return		PJ_TRUE if there have been any events executed
+ *			during the polling. This function will only return
+ *			PJ_FALSE if \a ms_timeout argument is specified
+ *			(i.e. the value is not -1) and there was no event
+ *			executed when the timeout timer elapsed.
+ */
+PJ_DECL(pj_bool_t) pj_symbianos_poll(int priority, int ms_timeout);
+
+/**
+ * @}
+ */
+ 
+/* **************************************************************************/
+/**
  * @defgroup PJ_TLS Thread Local Storage.
  * @ingroup PJ_OS
  * @{
@@ -405,7 +468,7 @@
  * Mutex types:
  *  - PJ_MUTEX_DEFAULT: default mutex type, which is system dependent.
  *  - PJ_MUTEX_SIMPLE: non-recursive mutex.
- *  - PJ_MUTEX_RECURSIVE: recursive mutex.
+ *  - PJ_MUTEX_RECURSE: recursive mutex.
  */
 typedef enum pj_mutex_type_e
 {
diff --git a/pjlib/include/pj/pool.h b/pjlib/include/pj/pool.h
index 06cdd03..5cb6aaf 100644
--- a/pjlib/include/pj/pool.h
+++ b/pjlib/include/pj/pool.h
@@ -227,9 +227,9 @@
 	    return 1;
 	}
 
-	// Create the pool factory, in this case, a caching pool.
-	pj_caching_pool_init(&cp, &pj_pool_factory_default_policy, 
-			     1024*1024 );
+	// Create the pool factory, in this case, a caching pool,
+	// using default pool policy.
+	pj_caching_pool_init(&cp, NULL, 1024*1024 );
 
 	// Do a demo
 	pool_demo_1(&cp.factory);
@@ -505,8 +505,14 @@
 #define PJ_POOL_ZALLOC_T(pool,type) \
 	    ((type*)pj_pool_zalloc(pool, sizeof(type)))
 
+/*
+ * Internal functions
+ */
+PJ_IDECL(void*) pj_pool_alloc_from_block(pj_pool_block *block, pj_size_t size);
+PJ_DECL(void*) pj_pool_allocate_find(pj_pool_t *pool, unsigned size);
 
 
+	
 /**
  * @}	// PJ_POOL
  */
@@ -617,8 +623,19 @@
  *  - block allocation and deallocation use malloc() and free().
  *  - callback will raise PJ_NO_MEMORY_EXCEPTION exception.
  *  - access to pool factory is not serialized (i.e. not thread safe).
+ *
+ * @see pj_pool_factory_get_default_policy
  */
-extern pj_pool_factory_policy pj_pool_factory_default_policy;
+PJ_DECL_DATA(pj_pool_factory_policy) pj_pool_factory_default_policy;
+
+
+/**
+ * Get the default pool factory policy.
+ *
+ * @return the pool policy.
+ */
+PJ_DECL(const pj_pool_factory_policy*) pj_pool_factory_get_default_policy(void);
+
 
 /**
  * This structure contains the declaration for pool factory interface.
diff --git a/pjlib/include/pj/pool_i.h b/pjlib/include/pj/pool_i.h
index 1a9b626..a3a96ad 100644
--- a/pjlib/include/pj/pool_i.h
+++ b/pjlib/include/pj/pool_i.h
@@ -20,7 +20,6 @@
 
 #include <pj/string.h>
 
-PJ_DECL(void*) pj_pool_allocate_find(pj_pool_t *pool, unsigned size);
 
 PJ_IDEF(pj_size_t) pj_pool_get_capacity( pj_pool_t *pool )
 {
diff --git a/pjlib/include/pj/sock.h b/pjlib/include/pj/sock.h
index 0be0258..fe97c10 100644
--- a/pjlib/include/pj/sock.h
+++ b/pjlib/include/pj/sock.h
@@ -59,12 +59,18 @@
  * APPLICATION MUST USE THESE VALUES INSTEAD OF NORMAL AF_*, BECAUSE
  * THE LIBRARY WILL DO TRANSLATION TO THE NATIVE VALUE.
  */
-extern const pj_uint16_t PJ_AF_UNIX;    /**< Unix domain socket.	*/
-#define PJ_AF_LOCAL	 PJ_AF_UNIX;    /**< POSIX name for AF_UNIX	*/
-extern const pj_uint16_t PJ_AF_INET;    /**< Internet IP protocol.	*/
-extern const pj_uint16_t PJ_AF_INET6;   /**< IP version 6.		*/
-extern const pj_uint16_t PJ_AF_PACKET;  /**< Packet family.		*/
-extern const pj_uint16_t PJ_AF_IRDA;    /**< IRDA sockets.		*/
+extern const pj_uint16_t PJ_AF_UNIX; /**< Unix domain socket.	*/
+#define PJ_AF_LOCAL	 PJ_AF_UNIX; /**< POSIX name for AF_UNIX	*/
+extern const pj_uint16_t PJ_AF_INET; /**< Internet IP protocol.	*/
+extern const pj_uint16_t PJ_AF_INET6;/**< IP version 6.		*/
+extern const pj_uint16_t PJ_AF_PACKET;/**< Packet family.	*/
+extern const pj_uint16_t PJ_AF_IRDA; /**< IRDA sockets.		*/
+
+PJ_DECL(pj_uint16_t) pj_AF_UNIX(void);
+PJ_DECL(pj_uint16_t) pj_AF_INET(void);
+PJ_DECL(pj_uint16_t) pj_AF_INET6(void);
+PJ_DECL(pj_uint16_t) pj_AF_PACKET(void);
+PJ_DECL(pj_uint16_t) pj_AF_IRDA(void);
 
 
 /**
@@ -74,14 +80,20 @@
  */
 
 extern const pj_uint16_t PJ_SOCK_STREAM; /**< Sequenced, reliable, connection-
-					      based byte streams.           */
+					     based byte streams.           */
 extern const pj_uint16_t PJ_SOCK_DGRAM;  /**< Connectionless, unreliable 
-					      datagrams of fixed maximum 
-					      lengths.                      */
+					     datagrams of fixed maximum 
+					     lengths.                      */
 extern const pj_uint16_t PJ_SOCK_RAW;    /**< Raw protocol interface.       */
 extern const pj_uint16_t PJ_SOCK_RDM;    /**< Reliably-delivered messages.  */
 
 
+PJ_DECL(int) pj_SOCK_STREAM(void);
+PJ_DECL(int) pj_SOCK_DGRAM(void);
+PJ_DECL(int) pj_SOCK_RAW(void);
+PJ_DECL(int) pj_SOCK_RDM(void);
+
+
 /**
  * Socket level specified in #pj_sock_setsockopt() or #pj_sock_getsockopt().
  * APPLICATION MUST USE THESE VALUES INSTEAD OF NORMAL SOL_*, BECAUSE
@@ -93,6 +105,12 @@
 extern const pj_uint16_t PJ_SOL_UDP;	/**< UDP level.	    */
 extern const pj_uint16_t PJ_SOL_IPV6;	/**< IP version 6   */
 
+PJ_DECL(pj_uint16_t) pj_SOL_SOCKET(void);
+PJ_DECL(pj_uint16_t) pj_SOL_IP(void);
+PJ_DECL(pj_uint16_t) pj_SOL_TCP(void);
+PJ_DECL(pj_uint16_t) pj_SOL_UDP(void);
+PJ_DECL(pj_uint16_t) pj_SOL_IPV6(void);
+
 
 /* IP_TOS 
  *
@@ -102,6 +120,7 @@
  */
 extern const pj_uint16_t PJ_IP_TOS;	/**< IP_TOS optname in setsockopt() */
 
+PJ_DECL(int) pj_IP_TOS(void);
 
 /*
  * IP TOS related constats.
@@ -114,24 +133,37 @@
 extern const pj_uint16_t PJ_IPTOS_THROUGHPUT;	/**< Optimize throughput    */
 extern const pj_uint16_t PJ_IPTOS_RELIABILITY;	/**< Optimize for reliability*/
 extern const pj_uint16_t PJ_IPTOS_MINCOST;	/**< "filler data" where slow 
-						 transmission does't matter */
+						  transmission does't matter */
+
+PJ_DECL(int) pj_IPTOS_LOWDELAY(void);
+PJ_DECL(int) pj_IPTOS_THROUGHPUT(void);
+PJ_DECL(int) pj_IPTOS_RELIABILITY(void);
+PJ_DECL(int) pj_IPTOS_MINCOST(void);
 
 
 /**
  * Values to be specified as \c optname when calling #pj_sock_setsockopt() 
  * or #pj_sock_getsockopt().
  */
-extern const pj_uint16_t PJ_SO_TYPE;    /**< Socket type.               */
-extern const pj_uint16_t PJ_SO_RCVBUF;  /**< Buffer size for receive.   */
-extern const pj_uint16_t PJ_SO_SNDBUF;  /**< Buffer size for send.      */
+extern const pj_uint16_t PJ_SO_TYPE;  /**< Socket type.             */
+extern const pj_uint16_t PJ_SO_RCVBUF;/**< Buffer size for receive. */
+extern const pj_uint16_t PJ_SO_SNDBUF;/**< Buffer size for send.    */
+
+PJ_DECL(pj_uint16_t) pj_SO_TYPE(void);
+PJ_DECL(pj_uint16_t) pj_SO_RCVBUF(void);
+PJ_DECL(pj_uint16_t) pj_SO_SNDBUF(void);
 
 
 /*
  * Flags to be specified in #pj_sock_recv, #pj_sock_send, etc.
  */
-extern const int PJ_MSG_OOB;	    /**< Out-of-band messages.		 */
-extern const int PJ_MSG_PEEK;	    /**< Peek, don't remove from buffer. */
-extern const int PJ_MSG_DONTROUTE;  /**< Don't route.			 */
+extern const int PJ_MSG_OOB;	  /**< Out-of-band messages.         */
+extern const int PJ_MSG_PEEK;	  /**< Peek, don't remove from buffer*/
+extern const int PJ_MSG_DONTROUTE;/**< Don't route.                  */
+
+PJ_DECL(int) pj_MSG_OOB(void);
+PJ_DECL(int) pj_MSG_PEEK(void);
+PJ_DECL(int) pj_MSG_DONTROUTE(void);
 
 
 /**
diff --git a/pjlib/include/pj/sock_select.h b/pjlib/include/pj/sock_select.h
index d0ef5d9..8ce7a65 100644
--- a/pjlib/include/pj/sock_select.h
+++ b/pjlib/include/pj/sock_select.h
@@ -67,6 +67,21 @@
 
 
 /**
+ * This is an internal function, application shouldn't use this.
+ * 
+ * Get the number of descriptors in the set. This is defined in sock_select.c
+ * This function will only return the number of sockets set from PJ_FD_SET
+ * operation. When the set is modified by other means (such as by select()),
+ * the count will not be reflected here.
+ *
+ * @param fdsetp    The descriptor set.
+ *
+ * @return          Number of descriptors in the set.
+ */
+PJ_DECL(pj_size_t) PJ_FD_COUNT(const pj_fd_set_t *fdsetp);
+
+
+/**
  * Add the file descriptor fd to the set pointed to by fdsetp. 
  * If the file descriptor fd is already in this set, there shall be no effect
  * on the set, nor will an error be returned.
diff --git a/pjlib/include/pj/timer.h b/pjlib/include/pj/timer.h
index 6e4839c..a8b3eb6 100644
--- a/pjlib/include/pj/timer.h
+++ b/pjlib/include/pj/timer.h
@@ -253,6 +253,9 @@
  * Poll the timer heap, check for expired timers and call the callback for
  * each of the expired timers.
  *
+ * Note: polling the timer heap is not necessary in Symbian. Please see
+ * @ref PJ_SYMBIAN_OS for more info.
+ *
  * @param ht         The timer heap.
  * @param next_delay If this parameter is not NULL, it will be filled up with
  *		     the time delay until the next timer elapsed, or -1 in
diff --git a/pjlib/include/pj/types.h b/pjlib/include/pj/types.h
index e909552..4ea5b79 100644
--- a/pjlib/include/pj/types.h
+++ b/pjlib/include/pj/types.h
@@ -302,7 +302,11 @@
  */
 PJ_DECL(void) pj_shutdown(void);
 
+/**
+ * Type of callback to register to pj_atexit().
+ */
 typedef void (*pj_exit_callback)(void);
+
 /**
  * Register cleanup function to be called by PJLIB when pj_shutdown() is 
  * called.
diff --git a/pjlib/src/pj/addr_resolv_sock.c b/pjlib/src/pj/addr_resolv_sock.c
index 9e64378..408eae1 100644
--- a/pjlib/src/pj/addr_resolv_sock.c
+++ b/pjlib/src/pj/addr_resolv_sock.c
@@ -83,7 +83,7 @@
 	pj_sockaddr_in a;
 	int len;
 
-	status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &fd);
+	status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &fd);
 	if (status != PJ_SUCCESS) {
 	    return status;
 	}
diff --git a/pjlib/src/pj/addr_resolv_symbian.cpp b/pjlib/src/pj/addr_resolv_symbian.cpp
index 95da5cd..ea3c766 100644
--- a/pjlib/src/pj/addr_resolv_symbian.cpp
+++ b/pjlib/src/pj/addr_resolv_symbian.cpp
@@ -76,7 +76,7 @@
     // Return hostent
     he->h_name = resolved_name;
     he->h_aliases = no_aliases;
-    he->h_addrtype = PJ_AF_INET;
+    he->h_addrtype = pj_AF_INET();
     he->h_length = 4;
     he->h_addr_list = (char**) addr_list;
 
@@ -85,7 +85,7 @@
 
 
 /* Resolve the IP address of local machine */
-pj_status_t pj_gethostip(pj_in_addr *addr)
+PJ_DEF(pj_status_t) pj_gethostip(pj_in_addr *addr)
 {
     const pj_str_t *hostname = pj_gethostname();
     struct pj_hostent he;
@@ -111,7 +111,7 @@
 	pj_sockaddr_in a;
 	int len;
 
-	status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &fd);
+	status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &fd);
 	if (status != PJ_SUCCESS) {
 	    return status;
 	}
diff --git a/pjlib/src/pj/errno.c b/pjlib/src/pj/errno.c
index f7273a4..a11f3b4 100644
--- a/pjlib/src/pj/errno.c
+++ b/pjlib/src/pj/errno.c
@@ -101,7 +101,7 @@
 #define IN_RANGE(val,start,end)	    ((val)>=(start) && (val)<(end))
 
 /* Register strerror handle. */
-PJ_DECL(pj_status_t) pj_register_strerror(pj_status_t start,
+PJ_DEF(pj_status_t) pj_register_strerror( pj_status_t start,
 					  pj_status_t space,
 					  pjsip_error_callback f)
 {
diff --git a/pjlib/src/pj/fifobuf.c b/pjlib/src/pj/fifobuf.c
index 08bf907..54a2375 100644
--- a/pjlib/src/pj/fifobuf.c
+++ b/pjlib/src/pj/fifobuf.c
@@ -25,8 +25,7 @@
 
 #define SZ  sizeof(unsigned)
 
-PJ_DEF(void)
-pj_fifobuf_init (pj_fifobuf_t *fifobuf, void *buffer, unsigned size)
+PJ_DEF(void) pj_fifobuf_init (pj_fifobuf_t *fifobuf, void *buffer, unsigned size)
 {
     PJ_CHECK_STACK();
 
@@ -40,8 +39,7 @@
     fifobuf->full = 0;
 }
 
-PJ_DEF(unsigned)
-pj_fifobuf_max_size (pj_fifobuf_t *fifobuf)
+PJ_DEF(unsigned) pj_fifobuf_max_size (pj_fifobuf_t *fifobuf)
 {
     unsigned s1, s2;
 
@@ -57,8 +55,7 @@
     return s1<s2 ? s2 : s1;
 }
 
-PJ_DEF(void*)
-pj_fifobuf_alloc (pj_fifobuf_t *fifobuf, unsigned size)
+PJ_DEF(void*) pj_fifobuf_alloc (pj_fifobuf_t *fifobuf, unsigned size)
 {
     unsigned available;
     char *start;
@@ -115,8 +112,7 @@
     return NULL;
 }
 
-PJ_DEF(pj_status_t)
-pj_fifobuf_unalloc (pj_fifobuf_t *fifobuf, void *buf)
+PJ_DEF(pj_status_t) pj_fifobuf_unalloc (pj_fifobuf_t *fifobuf, void *buf)
 {
     char *ptr = (char*)buf;
     char *endptr;
@@ -146,8 +142,7 @@
     return 0;
 }
 
-PJ_DEF(pj_status_t)
-pj_fifobuf_free (pj_fifobuf_t *fifobuf, void *buf)
+PJ_DEF(pj_status_t) pj_fifobuf_free (pj_fifobuf_t *fifobuf, void *buf)
 {
     char *ptr = (char*)buf;
     char *end;
diff --git a/pjlib/src/pj/file_io_ansi.c b/pjlib/src/pj/file_io_ansi.c
index 6d340ce..1bdfef8 100644
--- a/pjlib/src/pj/file_io_ansi.c
+++ b/pjlib/src/pj/file_io_ansi.c
@@ -109,11 +109,13 @@
     return PJ_SUCCESS;
 }
 
+/*
 PJ_DEF(pj_bool_t) pj_file_eof(pj_oshandle_t fd, enum pj_file_access access)
 {
     PJ_UNUSED_ARG(access);
     return feof((FILE*)fd) ? PJ_TRUE : 0;
 }
+*/
 
 PJ_DEF(pj_status_t) pj_file_setpos( pj_oshandle_t fd,
                                     pj_off_t offset,
diff --git a/pjlib/src/pj/ioqueue_common_abs.c b/pjlib/src/pj/ioqueue_common_abs.c
index 8fd1be7..fdd1afe 100644
--- a/pjlib/src/pj/ioqueue_common_abs.c
+++ b/pjlib/src/pj/ioqueue_common_abs.c
@@ -100,10 +100,10 @@
      * will be performed during send to allow parallel send operations.
      */
     optlen = sizeof(key->fd_type);
-    rc = pj_sock_getsockopt(sock, PJ_SOL_SOCKET, PJ_SO_TYPE,
+    rc = pj_sock_getsockopt(sock, pj_SOL_SOCKET(), pj_SO_TYPE(),
                             &key->fd_type, &optlen);
     if (rc != PJ_SUCCESS)
-        key->fd_type = PJ_SOCK_STREAM;
+        key->fd_type = pj_SOCK_STREAM();
 
     /* Create mutex for the key. */
 #if !PJ_IOQUEUE_HAS_SAFE_UNREG
@@ -269,7 +269,7 @@
         /* For datagrams, we can remove the write_op from the list
          * so that send() can work in parallel.
          */
-        if (h->fd_type == PJ_SOCK_DGRAM) {
+        if (h->fd_type == pj_SOCK_DGRAM()) {
             pj_list_erase(write_op);
 
             if (pj_list_empty(&h->write_list))
@@ -315,12 +315,12 @@
         /* Are we finished with this buffer? */
         if (send_rc!=PJ_SUCCESS || 
             write_op->written == (pj_ssize_t)write_op->size ||
-            h->fd_type == PJ_SOCK_DGRAM) 
+            h->fd_type == pj_SOCK_DGRAM()) 
         {
 
 	    write_op->op = PJ_IOQUEUE_OP_NONE;
 
-            if (h->fd_type != PJ_SOCK_DGRAM) {
+            if (h->fd_type != pj_SOCK_DGRAM()) {
                 /* Write completion of the whole stream. */
                 pj_list_erase(write_op);
 
diff --git a/pjlib/src/pj/ioqueue_select.c b/pjlib/src/pj/ioqueue_select.c
index e200d64..48612d2 100644
--- a/pjlib/src/pj/ioqueue_select.c
+++ b/pjlib/src/pj/ioqueue_select.c
@@ -64,22 +64,6 @@
 #   error "Error reporting must be enabled for this function to work!"
 #endif
 
-/**
- * Get the number of descriptors in the set. This is defined in sock_select.c
- * This function will only return the number of sockets set from PJ_FD_SET
- * operation. When the set is modified by other means (such as by select()),
- * the count will not be reflected here.
- *
- * That's why don't export this function in the header file, to avoid
- * misunderstanding.
- *
- * @param fdsetp    The descriptor set.
- *
- * @return          Number of descriptors in the set.
- */
-PJ_DECL(pj_size_t) PJ_FD_COUNT(const pj_fd_set_t *fdsetp);
-
-
 /*
  * During debugging build, VALIDATE_FD_SET is set.
  * This will check the validity of the fd_sets.
diff --git a/pjlib/src/pj/ioqueue_winnt.c b/pjlib/src/pj/ioqueue_winnt.c
index 8d17878..3e8253e 100644
--- a/pjlib/src/pj/ioqueue_winnt.c
+++ b/pjlib/src/pj/ioqueue_winnt.c
@@ -1106,7 +1106,7 @@
      */
     op_key_rec = (union operation_key*)op_key->internal__;
     
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, 
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, 
                             &op_key_rec->accept.newsock);
     if (status != PJ_SUCCESS)
 	return status;
diff --git a/pjlib/src/pj/log.c b/pjlib/src/pj/log.c
index 518854c..59e8956 100644
--- a/pjlib/src/pj/log.c
+++ b/pjlib/src/pj/log.c
@@ -24,7 +24,11 @@
 
 #if PJ_LOG_MAX_LEVEL >= 1
 
-PJ_DEF(int) pj_log_max_level = PJ_LOG_MAX_LEVEL;
+#if 0
+PJ_DEF_DATA(int) pj_log_max_level = PJ_LOG_MAX_LEVEL;
+#else
+static int pj_log_max_level = PJ_LOG_MAX_LEVEL;
+#endif
 static pj_log_func *log_writer = &pj_log_write;
 static unsigned log_decor = PJ_LOG_HAS_TIME | PJ_LOG_HAS_MICRO_SEC |
 			    PJ_LOG_HAS_SENDER | PJ_LOG_HAS_NEWLINE;
@@ -48,7 +52,7 @@
     pj_log_max_level = level;
 }
 
-#if 0
+#if 1
 PJ_DEF(int) pj_log_get_level(void)
 {
     return pj_log_max_level;
@@ -169,6 +173,7 @@
 	(*log_writer)(level, log_buffer, len);
 }
 
+/*
 PJ_DEF(void) pj_log_0(const char *obj, const char *format, ...)
 {
     va_list arg;
@@ -176,6 +181,7 @@
     pj_log(obj, 0, format, arg);
     va_end(arg);
 }
+*/
 
 PJ_DEF(void) pj_log_1(const char *obj, const char *format, ...)
 {
diff --git a/pjlib/src/pj/os_core_symbian.cpp b/pjlib/src/pj/os_core_symbian.cpp
index a3ec3c0..f13365a 100644
--- a/pjlib/src/pj/os_core_symbian.cpp
+++ b/pjlib/src/pj/os_core_symbian.cpp
@@ -260,8 +260,6 @@
 }
 
 
-PJ_DECL(void) pj_shutdown(void);
-
 /*
  * pj_init(void).
  * Init PJLIB!
@@ -333,6 +331,94 @@
     os->Shutdown();
 }
 
+/////////////////////////////////////////////////////////////////////////////
+
+class CPollTimeoutTimer : public CActive 
+{
+public:
+    static CPollTimeoutTimer* NewL(int msec, TInt prio);
+    ~CPollTimeoutTimer();
+    
+    virtual void RunL();
+    virtual void DoCancel();
+
+private:	
+    RTimer	     rtimer_;
+    
+    explicit CPollTimeoutTimer(TInt prio);
+    void ConstructL(int msec);
+};
+
+CPollTimeoutTimer::CPollTimeoutTimer(TInt prio)
+: CActive(prio)
+{
+}
+
+
+CPollTimeoutTimer::~CPollTimeoutTimer() 
+{
+    rtimer_.Close();
+}
+
+void CPollTimeoutTimer::ConstructL(int msec) 
+{
+    rtimer_.CreateLocal();
+    CActiveScheduler::Add(this);
+    rtimer_.After(iStatus, msec*1000);
+    SetActive();
+}
+
+CPollTimeoutTimer* CPollTimeoutTimer::NewL(int msec, TInt prio) 
+{
+    CPollTimeoutTimer *self = new CPollTimeoutTimer(prio);
+    CleanupStack::PushL(self);
+    self->ConstructL(msec);    
+    CleanupStack::Pop(self);
+
+    return self;
+}
+
+void CPollTimeoutTimer::RunL() 
+{
+}
+
+void CPollTimeoutTimer::DoCancel() 
+{
+     rtimer_.Cancel();
+}
+
+
+/*
+ * Wait the completion of any Symbian active objects. 
+ */
+PJ_DEF(pj_bool_t) pj_symbianos_poll(int priority, int ms_timeout)
+{
+    CPollTimeoutTimer *timer = NULL;
+    
+    if (priority==-1)
+    	priority = CActive::EPriorityStandard;
+    
+    if (ms_timeout >= 0) {
+    	timer = CPollTimeoutTimer::NewL(ms_timeout, priority);
+    }
+    
+    PjSymbianOS::Instance()->WaitForActiveObjects(priority);
+    
+    if (timer) {
+        bool timer_is_active = timer->IsActive();
+    
+        if (timer_is_active)
+            timer->Cancel();
+        
+        delete timer;
+        
+    	return timer_is_active ? PJ_TRUE : PJ_FALSE;
+    	
+    } else {
+    	return PJ_TRUE;
+    }
+}
+
 
 /*
  * pj_thread_register(..)
diff --git a/pjlib/src/pj/os_symbian.h b/pjlib/src/pj/os_symbian.h
index a197787..abfa7f0 100644
--- a/pjlib/src/pj/os_symbian.h
+++ b/pjlib/src/pj/os_symbian.h
@@ -220,7 +220,7 @@
 			       pj_sockaddr_in &pj_addr)
     {
 	pj_bzero(&pj_addr, sizeof(pj_sockaddr_in));
-	pj_addr.sin_family = PJ_AF_INET;
+	pj_addr.sin_family = pj_AF_INET();
 	pj_addr.sin_addr.s_addr = pj_htonl(sym_addr.Address());
 	pj_addr.sin_port = pj_htons((pj_uint16_t) sym_addr.Port());
     }
diff --git a/pjlib/src/pj/os_time_common.c b/pjlib/src/pj/os_time_common.c
index 5fffe94..331116b 100644
--- a/pjlib/src/pj/os_time_common.c
+++ b/pjlib/src/pj/os_time_common.c
@@ -18,6 +18,8 @@
  */
 #include <pj/os.h>
 #include <pj/compat/time.h>
+#include <pj/errno.h>
+
 
 ///////////////////////////////////////////////////////////////////////////////
 
@@ -65,11 +67,19 @@
 /**
  * Convert local time to GMT.
  */
-PJ_DEF(pj_status_t) pj_time_local_to_gmt(pj_time_val *tv);
+PJ_DEF(pj_status_t) pj_time_local_to_gmt(pj_time_val *tv)
+{
+    PJ_UNUSED_ARG(tv);
+    return PJ_EBUG;
+}
 
 /**
  * Convert GMT to local time.
  */
-PJ_DEF(pj_status_t) pj_time_gmt_to_local(pj_time_val *tv);
+PJ_DEF(pj_status_t) pj_time_gmt_to_local(pj_time_val *tv)
+{
+    PJ_UNUSED_ARG(tv);
+    return PJ_EBUG;
+}
 
 
diff --git a/pjlib/src/pj/pool_caching.c b/pjlib/src/pj/pool_caching.c
index 01c303d..295d6b9 100644
--- a/pjlib/src/pj/pool_caching.c
+++ b/pjlib/src/pj/pool_caching.c
@@ -65,6 +65,10 @@
     for (i=0; i<PJ_CACHING_POOL_ARRAY_SIZE; ++i)
 	pj_list_init(&cp->free_list[i]);
 
+    if (policy == NULL) {
+    	policy = &pj_pool_factory_default_policy;
+    }
+    
     pj_memcpy(&cp->factory.policy, policy, sizeof(pj_pool_factory_policy));
     cp->factory.create_pool = &cpool_create_pool;
     cp->factory.release_pool = &cpool_release_pool;
diff --git a/pjlib/src/pj/pool_policy_kmalloc.c b/pjlib/src/pj/pool_policy_kmalloc.c
index 439fa4c..7dc4044 100644
--- a/pjlib/src/pj/pool_policy_kmalloc.c
+++ b/pjlib/src/pj/pool_policy_kmalloc.c
@@ -56,3 +56,8 @@
     0
 };
 
+PJ_DEF(const pj_pool_factory_policy*) pj_pool_factory_get_default_policy(void)
+{
+    return &pj_pool_factory_default_policy;
+}
+
diff --git a/pjlib/src/pj/pool_policy_malloc.c b/pjlib/src/pj/pool_policy_malloc.c
index d7e8ad1..38db7fd 100644
--- a/pjlib/src/pj/pool_policy_malloc.c
+++ b/pjlib/src/pj/pool_policy_malloc.c
@@ -86,7 +86,7 @@
     PJ_THROW(PJ_NO_MEMORY_EXCEPTION);
 }
 
-pj_pool_factory_policy pj_pool_factory_default_policy = 
+PJ_DECL_DATA(pj_pool_factory_policy) pj_pool_factory_default_policy =
 {
     &default_block_alloc,
     &default_block_free,
@@ -94,4 +94,10 @@
     0
 };
 
+PJ_DEF(const pj_pool_factory_policy*) pj_pool_factory_get_default_policy(void)
+{
+    return &pj_pool_factory_default_policy;
+}
+
+
 #endif	/* PJ_HAS_POOL_ALT_API */
diff --git a/pjlib/src/pj/pool_policy_new.cpp b/pjlib/src/pj/pool_policy_new.cpp
index 82374ad..4277166 100644
--- a/pjlib/src/pj/pool_policy_new.cpp
+++ b/pjlib/src/pj/pool_policy_new.cpp
@@ -77,19 +77,19 @@
     PJ_THROW(PJ_NO_MEMORY_EXCEPTION);
 }
 
-pj_pool_factory_policy pj_pool_factory_default_policy = 
+PJ_DEF_DATA(pj_pool_factory_policy) pj_pool_factory_default_policy = 
 {
     &operator_new,
     &operator_delete,
     &default_pool_callback,
     0
 };
- 
-PJ_DEF(pj_pool_factory_policy*) pj_pool_factory_get_default_policy(void)
+
+PJ_DEF(const pj_pool_factory_policy*) pj_pool_factory_get_default_policy(void)
 {
     return &pj_pool_factory_default_policy;
 }
 
-
+ 
 #endif	/* PJ_HAS_POOL_ALT_API */
 
diff --git a/pjlib/src/pj/sock_common.c b/pjlib/src/pj/sock_common.c
new file mode 100644
index 0000000..4431f59
--- /dev/null
+++ b/pjlib/src/pj/sock_common.c
@@ -0,0 +1,145 @@
+/* $Id$ */
+/* 
+ * Copyright (C)2003-2007 Benny Prijono <benny@prijono.org>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA 
+ */
+#include <pj/sock.h>
+
+PJ_DEF(pj_uint16_t) pj_AF_UNIX(void)
+{
+    return PJ_AF_UNIX;
+}
+
+PJ_DEF(pj_uint16_t) pj_AF_INET(void)
+{
+    return PJ_AF_INET;
+}
+
+PJ_DEF(pj_uint16_t) pj_AF_INET6(void)
+{
+    return PJ_AF_INET6;
+}
+
+PJ_DEF(pj_uint16_t) pj_AF_PACKET(void)
+{
+    return PJ_AF_PACKET;
+}
+
+PJ_DEF(pj_uint16_t) pj_AF_IRDA(void)
+{
+    return PJ_AF_IRDA;
+}
+
+PJ_DEF(int) pj_SOCK_STREAM(void)
+{
+    return PJ_SOCK_STREAM;
+}
+
+PJ_DEF(int) pj_SOCK_DGRAM(void)
+{
+    return PJ_SOCK_DGRAM;
+}
+
+PJ_DEF(int) pj_SOCK_RAW(void)
+{
+    return PJ_SOCK_RAW;
+}
+
+PJ_DEF(int) pj_SOCK_RDM(void)
+{
+    return PJ_SOCK_RDM;
+}
+
+PJ_DEF(pj_uint16_t) pj_SOL_SOCKET(void)
+{
+    return PJ_SOL_SOCKET;
+}
+
+PJ_DEF(pj_uint16_t) pj_SOL_IP(void)
+{
+    return PJ_SOL_IP;
+}
+
+PJ_DEF(pj_uint16_t) pj_SOL_TCP(void)
+{
+    return PJ_SOL_TCP;
+}
+
+PJ_DEF(pj_uint16_t) pj_SOL_UDP(void)
+{
+    return PJ_SOL_UDP;
+}
+
+PJ_DEF(pj_uint16_t) pj_SOL_IPV6(void)
+{
+    return PJ_SOL_IPV6;
+}
+
+PJ_DEF(int) pj_IP_TOS(void)
+{
+    return PJ_IP_TOS;
+}
+
+PJ_DEF(int) pj_IPTOS_LOWDELAY(void)
+{
+    return PJ_IPTOS_LOWDELAY;
+}
+
+PJ_DEF(int) pj_IPTOS_THROUGHPUT(void)
+{
+    return PJ_IPTOS_THROUGHPUT;
+}
+
+PJ_DEF(int) pj_IPTOS_RELIABILITY(void)
+{
+    return PJ_IPTOS_RELIABILITY;
+}
+
+PJ_DEF(int) pj_IPTOS_MINCOST(void)
+{
+    return PJ_IPTOS_MINCOST;
+}
+
+PJ_DEF(pj_uint16_t) pj_SO_TYPE(void)
+{
+    return PJ_SO_TYPE;
+}
+
+PJ_DEF(pj_uint16_t) pj_SO_RCVBUF(void)
+{
+    return PJ_SO_RCVBUF;
+}
+
+PJ_DEF(pj_uint16_t) pj_SO_SNDBUF(void)
+{
+    return PJ_SO_SNDBUF;
+}
+
+PJ_DEF(int) pj_MSG_OOB(void)
+{
+    return PJ_MSG_OOB;
+}
+
+PJ_DEF(int) pj_MSG_PEEK(void)
+{
+    return PJ_MSG_PEEK;
+}
+
+PJ_DEF(int) pj_MSG_DONTROUTE(void)
+{
+    return PJ_MSG_DONTROUTE;
+}
+
diff --git a/pjlib/src/pj/sock_symbian.cpp b/pjlib/src/pj/sock_symbian.cpp
index 3896091..7c7680a 100644
--- a/pjlib/src/pj/sock_symbian.cpp
+++ b/pjlib/src/pj/sock_symbian.cpp
@@ -52,11 +52,22 @@
 const pj_uint16_t PJ_SOL_UDP	= 0xFFFF;
 const pj_uint16_t PJ_SOL_IPV6	= 0xFFFF;
 
+/* TOS */
+const pj_uint16_t PJ_IP_TOS		= 0;
+const pj_uint16_t PJ_IPTOS_LOWDELAY	= 0;
+const pj_uint16_t PJ_IPTOS_THROUGHPUT	= 0;
+const pj_uint16_t PJ_IPTOS_RELIABILITY	= 0;
+const pj_uint16_t PJ_IPTOS_MINCOST	= 0;
+
 /* ioctl() is also not supported. */
 const pj_uint16_t PJ_SO_TYPE    = 0xFFFF;
 const pj_uint16_t PJ_SO_RCVBUF  = 0xFFFF;
 const pj_uint16_t PJ_SO_SNDBUF  = 0xFFFF;
 
+/* Flags */
+const int PJ_MSG_OOB	     = 0;
+const int PJ_MSG_PEEK	     = KSockReadPeek;
+const int PJ_MSG_DONTROUTE   = 0;
 
 /////////////////////////////////////////////////////////////////////////////
 //
@@ -455,9 +466,9 @@
 
     /* Set proto if none is specified. */
     if (proto == 0) {
-	if (type == PJ_SOCK_STREAM)
+	if (type == pj_SOCK_STREAM())
 	    proto = KProtocolInetTcp;
-	else if (type == PJ_SOCK_DGRAM)
+	else if (type == pj_SOCK_DGRAM())
 	    proto = KProtocolInetUdp;
     }
 
diff --git a/pjlib/src/pj/types.c b/pjlib/src/pj/types.c
index 030d6fc..1581b4c 100644
--- a/pjlib/src/pj/types.c
+++ b/pjlib/src/pj/types.c
@@ -19,7 +19,7 @@
 #include <pj/types.h>
 #include <pj/os.h>
 
-void pj_time_val_normalize(pj_time_val *t)
+PJ_DEF(void) pj_time_val_normalize(pj_time_val *t)
 {
     PJ_CHECK_STACK();
 
diff --git a/pjlib/src/pjlib-test/echo_clt.c b/pjlib/src/pjlib-test/echo_clt.c
index d13391e..4f7448b 100644
--- a/pjlib/src/pjlib-test/echo_clt.c
+++ b/pjlib/src/pjlib-test/echo_clt.c
@@ -65,7 +65,7 @@
     pj_status_t last_recv_err = PJ_SUCCESS, last_send_err = PJ_SUCCESS;
     unsigned counter = 0;
 
-    rc = app_socket(PJ_AF_INET, client->sock_type, 0, -1, &sock);
+    rc = app_socket(pj_AF_INET(), client->sock_type, 0, -1, &sock);
     if (rc != PJ_SUCCESS) {
         app_perror("...unable to create socket", rc);
         return -10;
diff --git a/pjlib/src/pjlib-test/ioq_perf.c b/pjlib/src/pjlib-test/ioq_perf.c
index e15fe1b..92d4540 100644
--- a/pjlib/src/pjlib-test/ioq_perf.c
+++ b/pjlib/src/pjlib-test/ioq_perf.c
@@ -275,7 +275,7 @@
 
         /* Create socket pair. */
 	TRACE_((THIS_FILE, "      calling socketpair.."));
-        rc = app_socketpair(PJ_AF_INET, sock_type, 0, 
+        rc = app_socketpair(pj_AF_INET(), sock_type, 0, 
                             &items[i].server_fd, &items[i].client_fd);
         if (rc != PJ_SUCCESS) {
             app_perror("...error: unable to create socket pair", rc);
@@ -451,49 +451,49 @@
         int         sockpair_cnt;
     } test_param[] = 
     {
-        { PJ_SOCK_DGRAM, "udp", 1, 1},
-        { PJ_SOCK_DGRAM, "udp", 1, 2},
-        { PJ_SOCK_DGRAM, "udp", 1, 4},
-        { PJ_SOCK_DGRAM, "udp", 1, 8},
-        { PJ_SOCK_DGRAM, "udp", 2, 1},
-        { PJ_SOCK_DGRAM, "udp", 2, 2},
-        { PJ_SOCK_DGRAM, "udp", 2, 4},
-        { PJ_SOCK_DGRAM, "udp", 2, 8},
-        { PJ_SOCK_DGRAM, "udp", 4, 1},
-        { PJ_SOCK_DGRAM, "udp", 4, 2},
-        { PJ_SOCK_DGRAM, "udp", 4, 4},
-        { PJ_SOCK_DGRAM, "udp", 4, 8},
-        { PJ_SOCK_DGRAM, "udp", 4, 16},
-        { PJ_SOCK_STREAM, "tcp", 1, 1},
-        { PJ_SOCK_STREAM, "tcp", 1, 2},
-        { PJ_SOCK_STREAM, "tcp", 1, 4},
-        { PJ_SOCK_STREAM, "tcp", 1, 8},
-        { PJ_SOCK_STREAM, "tcp", 2, 1},
-        { PJ_SOCK_STREAM, "tcp", 2, 2},
-        { PJ_SOCK_STREAM, "tcp", 2, 4},
-        { PJ_SOCK_STREAM, "tcp", 2, 8},
-        { PJ_SOCK_STREAM, "tcp", 4, 1},
-        { PJ_SOCK_STREAM, "tcp", 4, 2},
-        { PJ_SOCK_STREAM, "tcp", 4, 4},
-        { PJ_SOCK_STREAM, "tcp", 4, 8},
-        { PJ_SOCK_STREAM, "tcp", 4, 16},
+        { pj_SOCK_DGRAM(), "udp", 1, 1},
+        { pj_SOCK_DGRAM(), "udp", 1, 2},
+        { pj_SOCK_DGRAM(), "udp", 1, 4},
+        { pj_SOCK_DGRAM(), "udp", 1, 8},
+        { pj_SOCK_DGRAM(), "udp", 2, 1},
+        { pj_SOCK_DGRAM(), "udp", 2, 2},
+        { pj_SOCK_DGRAM(), "udp", 2, 4},
+        { pj_SOCK_DGRAM(), "udp", 2, 8},
+        { pj_SOCK_DGRAM(), "udp", 4, 1},
+        { pj_SOCK_DGRAM(), "udp", 4, 2},
+        { pj_SOCK_DGRAM(), "udp", 4, 4},
+        { pj_SOCK_DGRAM(), "udp", 4, 8},
+        { pj_SOCK_DGRAM(), "udp", 4, 16},
+        { pj_SOCK_STREAM(), "tcp", 1, 1},
+        { pj_SOCK_STREAM(), "tcp", 1, 2},
+        { pj_SOCK_STREAM(), "tcp", 1, 4},
+        { pj_SOCK_STREAM(), "tcp", 1, 8},
+        { pj_SOCK_STREAM(), "tcp", 2, 1},
+        { pj_SOCK_STREAM(), "tcp", 2, 2},
+        { pj_SOCK_STREAM(), "tcp", 2, 4},
+        { pj_SOCK_STREAM(), "tcp", 2, 8},
+        { pj_SOCK_STREAM(), "tcp", 4, 1},
+        { pj_SOCK_STREAM(), "tcp", 4, 2},
+        { pj_SOCK_STREAM(), "tcp", 4, 4},
+        { pj_SOCK_STREAM(), "tcp", 4, 8},
+        { pj_SOCK_STREAM(), "tcp", 4, 16},
 /*
-	{ PJ_SOCK_DGRAM, "udp", 32, 1},
-	{ PJ_SOCK_DGRAM, "udp", 32, 1},
-	{ PJ_SOCK_DGRAM, "udp", 32, 1},
-	{ PJ_SOCK_DGRAM, "udp", 32, 1},
-	{ PJ_SOCK_DGRAM, "udp", 1, 32},
-	{ PJ_SOCK_DGRAM, "udp", 1, 32},
-	{ PJ_SOCK_DGRAM, "udp", 1, 32},
-	{ PJ_SOCK_DGRAM, "udp", 1, 32},
-	{ PJ_SOCK_STREAM, "tcp", 32, 1},
-	{ PJ_SOCK_STREAM, "tcp", 32, 1},
-	{ PJ_SOCK_STREAM, "tcp", 32, 1},
-	{ PJ_SOCK_STREAM, "tcp", 32, 1},
-	{ PJ_SOCK_STREAM, "tcp", 1, 32},
-	{ PJ_SOCK_STREAM, "tcp", 1, 32},
-	{ PJ_SOCK_STREAM, "tcp", 1, 32},
-	{ PJ_SOCK_STREAM, "tcp", 1, 32},
+	{ pj_SOCK_DGRAM(), "udp", 32, 1},
+	{ pj_SOCK_DGRAM(), "udp", 32, 1},
+	{ pj_SOCK_DGRAM(), "udp", 32, 1},
+	{ pj_SOCK_DGRAM(), "udp", 32, 1},
+	{ pj_SOCK_DGRAM(), "udp", 1, 32},
+	{ pj_SOCK_DGRAM(), "udp", 1, 32},
+	{ pj_SOCK_DGRAM(), "udp", 1, 32},
+	{ pj_SOCK_DGRAM(), "udp", 1, 32},
+	{ pj_SOCK_STREAM(), "tcp", 32, 1},
+	{ pj_SOCK_STREAM(), "tcp", 32, 1},
+	{ pj_SOCK_STREAM(), "tcp", 32, 1},
+	{ pj_SOCK_STREAM(), "tcp", 32, 1},
+	{ pj_SOCK_STREAM(), "tcp", 1, 32},
+	{ pj_SOCK_STREAM(), "tcp", 1, 32},
+	{ pj_SOCK_STREAM(), "tcp", 1, 32},
+	{ pj_SOCK_STREAM(), "tcp", 1, 32},
 */
     };
     pj_size_t best_bandwidth;
diff --git a/pjlib/src/pjlib-test/ioq_tcp.c b/pjlib/src/pjlib-test/ioq_tcp.c
index fc280de..c6e117d 100644
--- a/pjlib/src/pjlib-test/ioq_tcp.c
+++ b/pjlib/src/pjlib-test/ioq_tcp.c
@@ -50,6 +50,7 @@
                              callback_write_size,
                              callback_accept_status,
                              callback_connect_status;
+static unsigned		     callback_call_count;
 static pj_ioqueue_key_t     *callback_read_key,
                             *callback_write_key,
                             *callback_accept_key,
@@ -65,6 +66,7 @@
     callback_read_key = key;
     callback_read_op = op_key;
     callback_read_size = bytes_read;
+    callback_call_count++;
 }
 
 static void on_ioqueue_write(pj_ioqueue_key_t *key, 
@@ -74,6 +76,7 @@
     callback_write_key = key;
     callback_write_op = op_key;
     callback_write_size = bytes_written;
+    callback_call_count++;
 }
 
 static void on_ioqueue_accept(pj_ioqueue_key_t *key, 
@@ -96,6 +99,7 @@
 	callback_accept_key = key;
 	callback_accept_op = op_key;
 	callback_accept_status = status;
+	callback_call_count++;
     }
 }
 
@@ -103,6 +107,7 @@
 {
     callback_connect_key = key;
     callback_connect_status = status;
+    callback_call_count++;
 }
 
 static pj_ioqueue_callback test_cb = 
@@ -168,7 +173,12 @@
     status = 0;
     while (pending_op > 0) {
         timeout.sec = 1; timeout.msec = 0;
+#ifdef PJ_SYMBIAN
+	PJ_UNUSED_ARG(ioque);
+	status = pj_symbianos_poll(-1, 1000);
+#else
 	status = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	if (status > 0) {
             if (callback_read_size) {
                 if (callback_read_size != bufsize)
@@ -197,7 +207,11 @@
     // Pending op is zero.
     // Subsequent poll should yield zero too.
     timeout.sec = timeout.msec = 0;
+#ifdef PJ_SYMBIAN
+    status = pj_symbianos_poll(-1, 1);
+#else
     status = pj_ioqueue_poll(ioque, &timeout);
+#endif
     if (status != 0)
         return -173;
 
@@ -226,7 +240,7 @@
     pj_pool_t *pool = NULL;
     char *send_buf, *recv_buf;
     pj_ioqueue_t *ioque = NULL;
-    pj_ioqueue_key_t *skey, *ckey0, *ckey1;
+    pj_ioqueue_key_t *skey=NULL, *ckey0=NULL, *ckey1=NULL;
     pj_ioqueue_op_key_t accept_op;
     int bufsize = BUF_MIN_SIZE;
     pj_ssize_t status = -1;
@@ -243,13 +257,13 @@
     recv_buf = (char*)pj_pool_alloc(pool, bufsize);
 
     // Create server socket and client socket for connecting
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &ssock);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &ssock);
     if (rc != PJ_SUCCESS) {
         app_perror("...error creating socket", rc);
         status=-1; goto on_error;
     }
 
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &csock1);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &csock1);
     if (rc != PJ_SUCCESS) {
         app_perror("...error creating socket", rc);
 	status=-1; goto on_error;
@@ -321,6 +335,7 @@
     // Poll until connected
     callback_read_size = callback_write_size = 0;
     callback_accept_status = callback_connect_status = -2;
+    callback_call_count = 0;
 
     callback_read_key = callback_write_key = 
         callback_accept_key = callback_connect_key = NULL;
@@ -329,7 +344,13 @@
     while (pending_op) {
 	pj_time_val timeout = {1, 0};
 
-	status=pj_ioqueue_poll(ioque, &timeout);
+#ifdef PJ_SYMBIAN
+	callback_call_count = 0;
+	pj_symbianos_poll(-1, 1000);
+	status = callback_call_count;
+#else
+	status = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	if (status > 0) {
             if (callback_accept_status != -2) {
                 if (callback_accept_status != 0) {
@@ -373,7 +394,11 @@
     // When we poll the ioqueue, there must not be events.
     if (pending_op == 0) {
         pj_time_val timeout = {1, 0};
+#ifdef PJ_SYMBIAN
+	status = pj_symbianos_poll(-1, 1000);
+#else
         status = pj_ioqueue_poll(ioque, &timeout);
+#endif
         if (status != 0) {
             status=-60; goto on_error;
         }
@@ -407,12 +432,21 @@
     status = 0;
 
 on_error:
-    if (ssock != PJ_INVALID_SOCKET)
+    if (skey != NULL)
+    	pj_ioqueue_unregister(skey);
+    else if (ssock != PJ_INVALID_SOCKET)
 	pj_sock_close(ssock);
-    if (csock1 != PJ_INVALID_SOCKET)
+    
+    if (ckey1 != NULL)
+    	pj_ioqueue_unregister(ckey1);
+    else if (csock1 != PJ_INVALID_SOCKET)
 	pj_sock_close(csock1);
-    if (csock0 != PJ_INVALID_SOCKET)
+    
+    if (ckey0 != NULL)
+    	pj_ioqueue_unregister(ckey0);
+    else if (csock0 != PJ_INVALID_SOCKET)
 	pj_sock_close(csock0);
+    
     if (ioque != NULL)
 	pj_ioqueue_destroy(ioque);
     pj_pool_release(pool);
@@ -426,11 +460,11 @@
  */
 static int compliance_test_1(void)
 {
-    pj_sock_t csock1=-1;
+    pj_sock_t csock1=PJ_INVALID_SOCKET;
     pj_sockaddr_in addr;
     pj_pool_t *pool = NULL;
     pj_ioqueue_t *ioque = NULL;
-    pj_ioqueue_key_t *ckey1;
+    pj_ioqueue_key_t *ckey1 = NULL;
     pj_ssize_t status = -1;
     int pending_op = 0;
     pj_str_t s;
@@ -446,7 +480,7 @@
     }
 
     // Create client socket
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &csock1);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &csock1);
     if (rc != PJ_SUCCESS) {
         app_perror("...ERROR in pj_sock_socket()", rc);
 	status=-1; goto on_error;
@@ -483,7 +517,13 @@
     while (pending_op) {
 	pj_time_val timeout = {1, 0};
 
-	status=pj_ioqueue_poll(ioque, &timeout);
+#ifdef PJ_SYMBIAN
+	callback_call_count = 0;
+	pj_symbianos_poll(-1, 1000);
+	status = callback_call_count;
+#else
+	status = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	if (status > 0) {
             if (callback_connect_key==ckey1) {
 		if (callback_connect_status == 0) {
@@ -512,7 +552,11 @@
     // When we poll the ioqueue, there must not be events.
     if (pending_op == 0) {
         pj_time_val timeout = {1, 0};
+#ifdef PJ_SYMBIAN
+	status = pj_symbianos_poll(-1, 1000);
+#else
         status = pj_ioqueue_poll(ioque, &timeout);
+#endif
         if (status != 0) {
             status=-60; goto on_error;
         }
@@ -522,8 +566,11 @@
     status = 0;
 
 on_error:
-    if (csock1 != PJ_INVALID_SOCKET)
+    if (ckey1 != NULL)
+    	pj_ioqueue_unregister(ckey1);
+    else if (csock1 != PJ_INVALID_SOCKET)
 	pj_sock_close(csock1);
+    
     if (ioque != NULL)
 	pj_ioqueue_destroy(ioque);
     pj_pool_release(pool);
@@ -576,6 +623,19 @@
     pj_str_t s;
     pj_status_t rc;
 
+    listener.sock = PJ_INVALID_SOCKET;
+    listener.key = NULL;
+    
+    for (i=0; i<MAX_PAIR; ++i) {
+    	server[i].sock = PJ_INVALID_SOCKET;
+    	server[i].key = NULL;
+    }
+    
+    for (i=0; i<MAX_PAIR; ++i) {
+    	client[i].sock = PJ_INVALID_SOCKET;
+    	client[i].key = NULL;	
+    }
+    
     // Create pool.
     pool = pj_pool_create(mem, NULL, POOL_SIZE, 4000, NULL);
 
@@ -593,7 +653,7 @@
     recv_buf = (char*)pj_pool_alloc(pool, bufsize);
 
     // Create listener socket
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &listener.sock);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &listener.sock);
     if (rc != PJ_SUCCESS) {
         app_perror("...error creating socket", rc);
         status=-20; goto on_error;
@@ -635,7 +695,7 @@
     for (test_loop=0; test_loop < TEST_LOOP; ++test_loop) {
 	// Client connect and server accept.
 	for (i=0; i<MAX_PAIR; ++i) {
-	    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &client[i].sock);
+	    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &client[i].sock);
 	    if (rc != PJ_SUCCESS) {
 		app_perror("...error creating socket", rc);
 		status=-70; goto on_error;
@@ -683,7 +743,11 @@
 	while (pending_op) {
 	    pj_time_val timeout = {1, 0};
 
-	    status=pj_ioqueue_poll(ioque, &timeout);
+#ifdef PJ_SYMBIAN
+	    status = pj_symbianos_poll(-1, 1000);
+#else
+	    status = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	    if (status > 0) {
 		if (status > pending_op) {
 		    PJ_LOG(3,(THIS_FILE,
@@ -704,7 +768,11 @@
 	// When we poll the ioqueue, there must not be events.
 	if (pending_op == 0) {
 	    pj_time_val timeout = {1, 0};
+#ifdef PJ_SYMBIAN
+	    status = pj_symbianos_poll(-1, 1000);
+#else
 	    status = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	    if (status != 0) {
 		status=-120; goto on_error;
 	    }
@@ -719,7 +787,7 @@
 	    }
 
 	    // Check addresses
-	    if (server[i].local_addr.sin_family != PJ_AF_INET ||
+	    if (server[i].local_addr.sin_family != pj_AF_INET() ||
 		server[i].local_addr.sin_addr.s_addr == 0 ||
 		server[i].local_addr.sin_port == 0)
 	    {
@@ -728,7 +796,7 @@
 		goto on_error;
 	    }
 
-	    if (server[i].rem_addr.sin_family != PJ_AF_INET ||
+	    if (server[i].rem_addr.sin_family != pj_AF_INET() ||
 		server[i].rem_addr.sin_addr.s_addr == 0 ||
 		server[i].rem_addr.sin_port == 0)
 	    {
diff --git a/pjlib/src/pjlib-test/ioq_udp.c b/pjlib/src/pjlib-test/ioq_udp.c
index e6f4c0f..1bbe494 100644
--- a/pjlib/src/pjlib-test/ioq_udp.c
+++ b/pjlib/src/pjlib-test/ioq_udp.c
@@ -133,7 +133,7 @@
     pj_pool_t *pool = NULL;
     char *send_buf, *recv_buf;
     pj_ioqueue_t *ioque = NULL;
-    pj_ioqueue_key_t *skey, *ckey;
+    pj_ioqueue_key_t *skey = NULL, *ckey = NULL;
     pj_ioqueue_op_key_t read_op, write_op;
     int bufsize = BUF_MIN_SIZE;
     pj_ssize_t bytes, status = -1;
@@ -152,9 +152,9 @@
 
     // Allocate sockets for sending and receiving.
     TRACE_("creating sockets...");
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &ssock);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &ssock);
     if (rc==PJ_SUCCESS)
-        rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &csock);
+        rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &csock);
     else
         csock = PJ_INVALID_SOCKET;
     if (rc != PJ_SUCCESS) {
@@ -165,7 +165,7 @@
     // Bind server socket.
     TRACE_("bind socket...");
     pj_bzero(&addr, sizeof(addr));
-    addr.sin_family = PJ_AF_INET;
+    addr.sin_family = pj_AF_INET();
     addr.sin_port = pj_htons(PORT);
     if (pj_sock_bind(ssock, &addr, sizeof(addr))) {
 	status=-10; goto on_error;
@@ -258,7 +258,11 @@
 	pj_time_val timeout = { 5, 0 };
 
 	TRACE_("poll...");
+#ifdef PJ_SYMBIAN
+	rc = pj_symbianos_poll(-1, 5000);
+#else
 	rc = pj_ioqueue_poll(ioque, &timeout);
+#endif
 
 	if (rc == 0) {
 	    PJ_LOG(1,(THIS_FILE, "...ERROR: timed out..."));
@@ -285,7 +289,7 @@
 	    if (addrlen != sizeof(pj_sockaddr_in)) {
 		status=-68; goto on_error;
 	    }
-	    if (addr.sin_family != PJ_AF_INET) {
+	    if (addr.sin_family != pj_AF_INET()) {
 		status=-69; goto on_error;
 	    }
 
@@ -312,10 +316,16 @@
     status = 0;
 
 on_error:
-    if (ssock)
+    if (skey)
+    	pj_ioqueue_unregister(skey);
+    else if (ssock != -1)
 	pj_sock_close(ssock);
-    if (csock)
+    
+    if (ckey)
+    	pj_ioqueue_unregister(ckey);
+    else if (csock != -1)
 	pj_sock_close(csock);
+    
     if (ioque != NULL)
 	pj_ioqueue_destroy(ioque);
     pj_pool_release(pool);
@@ -372,14 +382,14 @@
     }
 
     /* Create sender socket */
-    status = app_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, SPORT, &ssock);
+    status = app_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, SPORT, &ssock);
     if (status != PJ_SUCCESS) {
 	app_perror("Error initializing socket", status);
 	return -120;
     }
 
     /* Create receiver socket. */
-    status = app_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, RPORT, &rsock);
+    status = app_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, RPORT, &rsock);
     if (status != PJ_SUCCESS) {
 	app_perror("Error initializing socket", status);
 	return -130;
@@ -435,7 +445,11 @@
 
     /* Check if packet is received. */
     timeout.sec = 1; timeout.msec = 0;
+#ifdef PJ_SYMBIAN
+    pj_symbianos_poll(-1, 1000);
+#else
     pj_ioqueue_poll(ioqueue, &timeout);
+#endif
 
     if (packet_cnt != 1) {
 	return -180;
@@ -469,8 +483,12 @@
     pj_ioqueue_unregister(key);
 
     /* Poll ioqueue. */
+#ifdef PJ_SYMBIAN
+    pj_symbianos_poll(-1, 1000);
+#else
     timeout.sec = 1; timeout.msec = 0;
     pj_ioqueue_poll(ioqueue, &timeout);
+#endif
 
     /* Must NOT receive any packets after socket is closed! */
     if (packet_cnt > 0) {
@@ -524,7 +542,7 @@
     /* Register as many sockets. */
     for (count=0; count<MAX; ++count) {
 	sock[count] = PJ_INVALID_SOCKET;
-	rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock[count]);
+	rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &sock[count]);
 	if (rc != PJ_SUCCESS || sock[count] == PJ_INVALID_SOCKET) {
 	    PJ_LOG(3,(THIS_FILE, "....unable to create %d-th socket, rc=%d", 
 				 count, rc));
@@ -591,7 +609,7 @@
     pj_ioqueue_op_key_t *inactive_read_op;
     char *send_buf, *recv_buf;
     pj_ioqueue_t *ioque = NULL;
-    pj_ioqueue_key_t *skey, *ckey, *key;
+    pj_ioqueue_key_t *skey, *ckey, *keys[SOCK_INACTIVE_MAX+2];
     pj_timestamp t1, t2, t_elapsed;
     int rc=0, i;    /* i must be signed */
     pj_str_t temp;
@@ -607,9 +625,9 @@
     recv_buf = (char*)pj_pool_alloc(pool, bufsize);
 
     // Allocate sockets for sending and receiving.
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &ssock);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &ssock);
     if (rc == PJ_SUCCESS) {
-        rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &csock);
+        rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &csock);
     } else
         csock = PJ_INVALID_SOCKET;
     if (rc != PJ_SUCCESS) {
@@ -619,7 +637,7 @@
 
     // Bind server socket.
     pj_bzero(&addr, sizeof(addr));
-    addr.sin_family = PJ_AF_INET;
+    addr.sin_family = pj_AF_INET();
     addr.sin_port = pj_htons(PORT);
     if (pj_sock_bind(ssock, &addr, sizeof(addr)))
 	goto on_error;
@@ -640,11 +658,11 @@
     inactive_read_op = (pj_ioqueue_op_key_t*)pj_pool_alloc(pool,
                               inactive_sock_count*sizeof(pj_ioqueue_op_key_t));
     pj_bzero(&addr, sizeof(addr));
-    addr.sin_family = PJ_AF_INET;
+    addr.sin_family = pj_AF_INET();
     for (i=0; i<inactive_sock_count; ++i) {
         pj_ssize_t bytes;
 
-	rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &inactive_sock[i]);
+	rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &inactive_sock[i]);
 	if (rc != PJ_SUCCESS || inactive_sock[i] < 0) {
 	    app_perror("...error: pj_sock_socket()", rc);
 	    goto on_error;
@@ -656,7 +674,7 @@
 	    goto on_error;
 	}
 	rc = pj_ioqueue_register_sock(pool, ioque, inactive_sock[i], 
-			              NULL, &test_cb, &key);
+			              NULL, &test_cb, &keys[i]);
 	if (rc != PJ_SUCCESS) {
 	    pj_sock_close(inactive_sock[i]);
 	    inactive_sock[i] = PJ_INVALID_SOCKET;
@@ -665,7 +683,7 @@
 	    goto on_error;
 	}
         bytes = bufsize;
-	rc = pj_ioqueue_recv(key, &inactive_read_op[i], recv_buf, &bytes, 0);
+	rc = pj_ioqueue_recv(keys[i], &inactive_read_op[i], recv_buf, &bytes, 0);
 	if (rc != PJ_EPENDING) {
 	    pj_sock_close(inactive_sock[i]);
 	    inactive_sock[i] = PJ_INVALID_SOCKET;
@@ -735,7 +753,11 @@
 	TRACE__((THIS_FILE, "     waiting for key = %p", skey));
 	do {
 	    pj_time_val timeout = { 1, 0 };
+#ifdef PJ_SYMBIAN
+	    rc = pj_symbianos_poll(-1, 1000);
+#else
 	    rc = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	    TRACE__((THIS_FILE, "     poll rc=%d", rc));
 	} while (rc >= 0 && callback_read_key != skey);
 
@@ -760,7 +782,11 @@
 	// Poll until all events are exhausted, before we start the next loop.
 	do {
 	    pj_time_val timeout = { 0, 10 };
+#ifdef PJ_SYMBIAN
+	    rc = pj_symbianos_poll(-1, 100);
+#else	    
 	    rc = pj_ioqueue_poll(ioque, &timeout);
+#endif
 	} while (rc>0);
 
 	rc = 0;
@@ -784,11 +810,11 @@
 
     // Cleaning up.
     for (i=inactive_sock_count-1; i>=0; --i) {
-	pj_sock_close(inactive_sock[i]);
+	pj_ioqueue_unregister(keys[i]);
     }
 
-    pj_sock_close(ssock);
-    pj_sock_close(csock);
+    pj_ioqueue_unregister(skey);
+    pj_ioqueue_unregister(ckey);
 
 
     pj_ioqueue_destroy(ioque);
diff --git a/pjlib/src/pjlib-test/ioq_unreg.c b/pjlib/src/pjlib-test/ioq_unreg.c
index 791befc..33e8627 100644
--- a/pjlib/src/pjlib-test/ioq_unreg.c
+++ b/pjlib/src/pjlib-test/ioq_unreg.c
@@ -159,7 +159,7 @@
      * will return from the poll early.
      */
     if (other_socket) {
-	status = app_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, 56127, &osd.sock);
+	status = app_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, 56127, &osd.sock);
 	if (status != PJ_SUCCESS) {
 	    app_perror("Error creating other socket", status);
 	    return -12;
@@ -200,7 +200,7 @@
     }
 
     /* Create pair of client/server sockets */
-    status = app_socketpair(PJ_AF_INET, PJ_SOCK_DGRAM, 0, 
+    status = app_socketpair(pj_AF_INET(), pj_SOCK_DGRAM(), 0, 
 			    &sock_data.sock, &sock_data.csock);
     if (status != PJ_SUCCESS) {
 	app_perror("app_socketpair error", status);
diff --git a/pjlib/src/pjlib-test/main.c b/pjlib/src/pjlib-test/main.c
index 2670ba7..60dc319 100644
--- a/pjlib/src/pjlib-test/main.c
+++ b/pjlib/src/pjlib-test/main.c
@@ -81,9 +81,9 @@
             pj_str_t type = pj_str(argv[--argc]);
             
             if (pj_stricmp2(&type, "tcp")==0)
-                param_echo_sock_type = PJ_SOCK_STREAM;
+                param_echo_sock_type = pj_SOCK_STREAM();
             else if (pj_stricmp2(&type, "udp")==0)
-                param_echo_sock_type = PJ_SOCK_DGRAM;
+                param_echo_sock_type = pj_SOCK_DGRAM();
             else {
                 PJ_LOG(3,("", "error: unknown socket type %s", type.ptr));
                 return 1;
diff --git a/pjlib/src/pjlib-test/select.c b/pjlib/src/pjlib-test/select.c
index 949d146..c3c3f8f 100644
--- a/pjlib/src/pjlib-test/select.c
+++ b/pjlib/src/pjlib-test/select.c
@@ -112,12 +112,12 @@
     PJ_LOG(3, (THIS_FILE, "...Testing simple UDP select()"));
     
     // Create two UDP sockets.
-    rc = pj_sock_socket( PJ_AF_INET, PJ_SOCK_DGRAM, 0, &udp1);
+    rc = pj_sock_socket( pj_AF_INET(), pj_SOCK_DGRAM(), 0, &udp1);
     if (rc != PJ_SUCCESS) {
         app_perror("...error: unable to create socket", rc);
 	status=-10; goto on_return;
     }
-    rc = pj_sock_socket( PJ_AF_INET, PJ_SOCK_DGRAM, 0, &udp2);
+    rc = pj_sock_socket( pj_AF_INET(), pj_SOCK_DGRAM(), 0, &udp2);
     if (udp2 == PJ_INVALID_SOCKET) {
         app_perror("...error: unable to create socket", rc);
 	status=-20; goto on_return;
@@ -125,7 +125,7 @@
 
     // Bind one of the UDP socket.
     pj_bzero(&udp_addr, sizeof(udp_addr));
-    udp_addr.sin_family = PJ_AF_INET;
+    udp_addr.sin_family = pj_AF_INET();
     udp_addr.sin_port = UDP_PORT;
     udp_addr.sin_addr = pj_inet_addr(pj_cstr(&s, "127.0.0.1"));
 
diff --git a/pjlib/src/pjlib-test/sock.c b/pjlib/src/pjlib-test/sock.c
index 9011a70..5e583e4 100644
--- a/pjlib/src/pjlib-test/sock.c
+++ b/pjlib/src/pjlib-test/sock.c
@@ -77,12 +77,7 @@
     char zero[64];
     pj_sockaddr_in addr2;
     const pj_str_t *hostname;
-#if defined(PJ_SYMBIAN) && PJ_SYMBIAN!=0
-    /* Symbian IP address is saved in host order */
-    unsigned char A[] = {1, 0, 0, 127};
-#else
-    unsigned char A[] = {127, 0, 0, 1};
-#endif
+    const unsigned char A[] = {127, 0, 0, 1};
 
     PJ_LOG(3,("test", "...format_test()"));
     
@@ -136,16 +131,16 @@
     int i;
     pj_status_t rc = PJ_SUCCESS;
 
-    types[0] = PJ_SOCK_STREAM;
-    types[1] = PJ_SOCK_DGRAM;
+    types[0] = pj_SOCK_STREAM();
+    types[1] = pj_SOCK_DGRAM();
 
     PJ_LOG(3,("test", "...simple_sock_test()"));
 
     for (i=0; i<(int)(sizeof(types)/sizeof(types[0])); ++i) {
 	
-	rc = pj_sock_socket(PJ_AF_INET, types[i], 0, &sock);
+	rc = pj_sock_socket(pj_AF_INET(), types[i], 0, &sock);
 	if (rc != PJ_SUCCESS) {
-	    app_perror("...error: unable to create socket type %d", rc);
+	    app_perror("...error: unable to create socket", rc);
 	    break;
 	} else {
 	    rc = pj_sock_close(sock);
@@ -237,7 +232,7 @@
                 rc = -156; goto on_error;
             }
 	    if (received != DATA_LEN-total_received) {
-                if (sock_type != PJ_SOCK_STREAM) {
+                if (sock_type != pj_SOCK_STREAM()) {
 	            PJ_LOG(3,("", "...error: expecting %u bytes, got %u bytes",
                               DATA_LEN-total_received, received));
 	            rc = -157; goto on_error;
@@ -295,7 +290,7 @@
             rc = -173; goto on_error;
         }
 	if (received != BIG_DATA_LEN-total_received) {
-            if (sock_type != PJ_SOCK_STREAM) {
+            if (sock_type != pj_SOCK_STREAM()) {
 	        PJ_LOG(3,("", "...error: expecting %u bytes, got %u bytes",
                           BIG_DATA_LEN-total_received, received));
 	        rc = -176; goto on_error;
@@ -325,19 +320,19 @@
 
     PJ_LOG(3,("test", "...udp_test()"));
 
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &ss);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &ss);
     if (rc != 0) {
 	app_perror("...error: unable to create socket", rc);
 	return -100;
     }
 
-    rc = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &cs);
+    rc = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &cs);
     if (rc != 0)
 	return -110;
 
     /* Bind server socket. */
     pj_bzero(&dstaddr, sizeof(dstaddr));
-    dstaddr.sin_family = PJ_AF_INET;
+    dstaddr.sin_family = pj_AF_INET();
     dstaddr.sin_port = pj_htons(UDP_PORT);
     dstaddr.sin_addr = pj_inet_addr(pj_cstr(&s, ADDRESS));
     
@@ -348,7 +343,7 @@
 
     /* Bind client socket. */
     pj_bzero(&srcaddr, sizeof(srcaddr));
-    srcaddr.sin_family = PJ_AF_INET;
+    srcaddr.sin_family = pj_AF_INET();
     srcaddr.sin_port = pj_htons(UDP_PORT-1);
     srcaddr.sin_addr = pj_inet_addr(pj_cstr(&s, ADDRESS));
 
@@ -358,13 +353,13 @@
     }
 	    
     /* Test send/recv, with sendto */
-    rc = send_recv_test(PJ_SOCK_DGRAM, ss, cs, &dstaddr, NULL, 
+    rc = send_recv_test(pj_SOCK_DGRAM(), ss, cs, &dstaddr, NULL, 
                         sizeof(dstaddr));
     if (rc != 0)
 	goto on_error;
 
     /* Test send/recv, with sendto and recvfrom */
-    rc = send_recv_test(PJ_SOCK_DGRAM, ss, cs, &dstaddr, 
+    rc = send_recv_test(pj_SOCK_DGRAM(), ss, cs, &dstaddr, 
                         &srcaddr, sizeof(dstaddr));
     if (rc != 0)
 	goto on_error;
@@ -382,12 +377,12 @@
     }
 
     /* Test send/recv with send() */
-    rc = send_recv_test(PJ_SOCK_DGRAM, ss, cs, NULL, NULL, 0);
+    rc = send_recv_test(pj_SOCK_DGRAM(), ss, cs, NULL, NULL, 0);
     if (rc != 0)
 	goto on_error;
 
     /* Test send/recv with send() and recvfrom */
-    rc = send_recv_test(PJ_SOCK_DGRAM, ss, cs, NULL, &srcaddr, 
+    rc = send_recv_test(pj_SOCK_DGRAM(), ss, cs, NULL, &srcaddr, 
                         sizeof(srcaddr));
     if (rc != 0)
 	goto on_error;
@@ -420,14 +415,14 @@
 
     PJ_LOG(3,("test", "...tcp_test()"));
 
-    rc = app_socketpair(PJ_AF_INET, PJ_SOCK_STREAM, 0, &ss, &cs);
+    rc = app_socketpair(pj_AF_INET(), pj_SOCK_STREAM(), 0, &ss, &cs);
     if (rc != PJ_SUCCESS) {
         app_perror("...error: app_socketpair():", rc);
         return -2000;
     }
 
     /* Test send/recv with send() and recv() */
-    retval = send_recv_test(PJ_SOCK_STREAM, ss, cs, NULL, NULL, 0);
+    retval = send_recv_test(pj_SOCK_STREAM(), ss, cs, NULL, NULL, 0);
 
     rc = pj_sock_close(cs);
     if (rc != PJ_SUCCESS) {
diff --git a/pjlib/src/pjlib-test/sock_perf.c b/pjlib/src/pjlib-test/sock_perf.c
index a5420af..41548ea 100644
--- a/pjlib/src/pjlib-test/sock_perf.c
+++ b/pjlib/src/pjlib-test/sock_perf.c
@@ -62,7 +62,7 @@
         return -10;
 
     /* Create producer-consumer pair. */
-    rc = app_socketpair(PJ_AF_INET, sock_type, 0, &consumer, &producer);
+    rc = app_socketpair(pj_AF_INET(), sock_type, 0, &consumer, &producer);
     if (rc != PJ_SUCCESS) {
         app_perror("...error: create socket pair", rc);
         return -20;
@@ -105,7 +105,7 @@
                 return -73;
             }
 	    if ((pj_size_t)part_received != buf_size-received) {
-                if (sock_type != PJ_SOCK_STREAM) {
+                if (sock_type != pj_SOCK_STREAM()) {
 	            PJ_LOG(3,("", "...error: expecting %u bytes, got %u bytes",
                               buf_size-received, part_received));
 	            return -76;
@@ -165,13 +165,13 @@
      */    
 #if !defined(PJ_SYMBIAN) || PJ_SYMBIAN==0
     /* Benchmarking UDP */
-    rc = sock_producer_consumer(PJ_SOCK_DGRAM, 512, LOOP, &bandwidth);
+    rc = sock_producer_consumer(pj_SOCK_DGRAM(), 512, LOOP, &bandwidth);
     if (rc != 0) return rc;
     PJ_LOG(3,("", "....bandwidth UDP = %d KB/s", bandwidth));
 #endif
 
     /* Benchmarking TCP */
-    rc = sock_producer_consumer(PJ_SOCK_STREAM, 512, LOOP, &bandwidth);
+    rc = sock_producer_consumer(pj_SOCK_STREAM(), 512, LOOP, &bandwidth);
     if (rc != 0) return rc;
     PJ_LOG(3,("", "....bandwidth TCP = %d KB/s", bandwidth));
 
diff --git a/pjlib/src/pjlib-test/test.c b/pjlib/src/pjlib-test/test.c
index 5c78397..0202a3d 100644
--- a/pjlib/src/pjlib-test/test.c
+++ b/pjlib/src/pjlib-test/test.c
@@ -64,7 +64,7 @@
     }
     
     //pj_dump_config();
-    pj_caching_pool_init( &caching_pool, &pj_pool_factory_default_policy, 0 );
+    pj_caching_pool_init( &caching_pool, NULL, 0 );
 
 #if INCLUDE_ERRNO_TEST
     DO_TEST( errno_test() );
@@ -165,7 +165,7 @@
 
 #elif INCLUDE_ECHO_CLIENT
     if (param_echo_sock_type == 0)
-        param_echo_sock_type = PJ_SOCK_DGRAM;
+        param_echo_sock_type = pj_SOCK_DGRAM();
 
     echo_client( param_echo_sock_type, 
                  param_echo_server, 
@@ -191,10 +191,15 @@
     return 0;
 }
 
+#include <pj/sock.h>
+
 int test_main(void)
 {
+    int i;
     PJ_USE_EXCEPTION;
 
+    i = pj_AF_INET();
+
     PJ_TRY {
         return test_inner();
     }
diff --git a/pjlib/src/pjlib-test/udp_echo_srv_ioqueue.c b/pjlib/src/pjlib-test/udp_echo_srv_ioqueue.c
index d2d2246..231facc 100644
--- a/pjlib/src/pjlib-test/udp_echo_srv_ioqueue.c
+++ b/pjlib/src/pjlib-test/udp_echo_srv_ioqueue.c
@@ -176,7 +176,7 @@
         return -20;
     }
 
-    rc = app_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, 
+    rc = app_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, 
                     ECHO_SERVER_START_PORT, &sock);
     if (rc != PJ_SUCCESS) {
         app_perror("...app_socket error", rc);
diff --git a/pjlib/src/pjlib-test/udp_echo_srv_sync.c b/pjlib/src/pjlib-test/udp_echo_srv_sync.c
index 8c0ef2b..37a9e04 100644
--- a/pjlib/src/pjlib-test/udp_echo_srv_sync.c
+++ b/pjlib/src/pjlib-test/udp_echo_srv_sync.c
@@ -77,7 +77,7 @@
         return -6;
     }
 
-    rc = app_socket(PJ_AF_INET, PJ_SOCK_DGRAM,0, ECHO_SERVER_START_PORT, &sock);
+    rc = app_socket(pj_AF_INET(), pj_SOCK_DGRAM(),0, ECHO_SERVER_START_PORT, &sock);
     if (rc != PJ_SUCCESS) {
         app_perror("...socket error", rc);
         return -10;
diff --git a/pjlib/src/pjlib-test/util.c b/pjlib/src/pjlib-test/util.c
index a38c076..4f68b25 100644
--- a/pjlib/src/pjlib-test/util.c
+++ b/pjlib/src/pjlib-test/util.c
@@ -53,7 +53,7 @@
         return rc;
     
 #if PJ_HAS_TCP
-    if (type == PJ_SOCK_STREAM) {
+    if (type == pj_SOCK_STREAM()) {
         rc = pj_sock_listen(sock, 5);
         if (rc != PJ_SUCCESS)
             return rc;
@@ -86,7 +86,7 @@
 
     /* Retry bind */
     pj_bzero(&addr, sizeof(addr));
-    addr.sin_family = PJ_AF_INET;
+    addr.sin_family = pj_AF_INET();
     for (i=0; i<5; ++i) {
         addr.sin_port = pj_htons(port++);
         rc = pj_sock_bind(sock[SERVER], &addr, sizeof(addr));
@@ -99,7 +99,7 @@
 
     /* For TCP, listen the socket. */
 #if PJ_HAS_TCP
-    if (type == PJ_SOCK_STREAM) {
+    if (type == pj_SOCK_STREAM()) {
         rc = pj_sock_listen(sock[SERVER], PJ_SOMAXCONN);
         if (rc != PJ_SUCCESS)
             goto on_error;
@@ -114,7 +114,7 @@
 
     /* For TCP, must accept(), and get the new socket. */
 #if PJ_HAS_TCP
-    if (type == PJ_SOCK_STREAM) {
+    if (type == pj_SOCK_STREAM()) {
         pj_sock_t newserver;
 
         rc = pj_sock_accept(sock[SERVER], &newserver, NULL, NULL);
diff --git a/pjmedia/src/pjmedia/transport_udp.c b/pjmedia/src/pjmedia/transport_udp.c
index f1ef7f6..e519259 100644
--- a/pjmedia/src/pjmedia/transport_udp.c
+++ b/pjmedia/src/pjmedia/transport_udp.c
@@ -162,7 +162,7 @@
     si.rtp_sock = si.rtcp_sock = PJ_INVALID_SOCKET;
 
     /* Create RTP socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &si.rtp_sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &si.rtp_sock);
     if (status != PJ_SUCCESS)
 	goto on_error;
 
@@ -175,7 +175,7 @@
 
 
     /* Create RTCP socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &si.rtcp_sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &si.rtcp_sock);
     if (status != PJ_SUCCESS)
 	goto on_error;
 
diff --git a/pjmedia/src/test/audio_tool.c b/pjmedia/src/test/audio_tool.c
index b302dac..4eeb5e4 100644
--- a/pjmedia/src/test/audio_tool.c
+++ b/pjmedia/src/test/audio_tool.c
@@ -264,7 +264,7 @@
     }
 
     pj_bzero(&skinfo, sizeof(skinfo));
-    skinfo.rtp_sock = skinfo.rtcp_sock = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, 0);
+    skinfo.rtp_sock = skinfo.rtcp_sock = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, 0);
     if (skinfo.rtp_sock == PJ_INVALID_SOCKET) {
 	PJ_LOG(1,(THIS_FILE, "Unable to create socket"));
 	goto on_error;
diff --git a/pjnath/src/pjnath/ice_session.c b/pjnath/src/pjnath/ice_session.c
index 8bce5a8..0c33207 100644
--- a/pjnath/src/pjnath/ice_session.c
+++ b/pjnath/src/pjnath/ice_session.c
@@ -726,7 +726,7 @@
 
     pj_ansi_strcpy(laddr, pj_inet_ntoa(lcand->addr.ipv4.sin_addr));
 
-    if (lcand->addr.addr.sa_family == PJ_AF_INET) {
+    if (lcand->addr.addr.sa_family == pj_AF_INET()) {
 	len = pj_ansi_snprintf(buffer, bufsize,
 			       "%d: [%d] %s:%d-->%s:%d",
 			       GET_CHECK_ID(clist, check),
@@ -834,10 +834,10 @@
     if (a1->addr.sa_family != a2->addr.sa_family)
 	return SOCKADDR_NOT_EQUAL;
 
-    if (a1->addr.sa_family == PJ_AF_INET) {
+    if (a1->addr.sa_family == pj_AF_INET()) {
 	return !(a1->ipv4.sin_addr.s_addr == a2->ipv4.sin_addr.s_addr &&
 		 a1->ipv4.sin_port == a2->ipv4.sin_port);
-    } else if (a1->addr.sa_family == PJ_AF_INET6) {
+    } else if (a1->addr.sa_family == pj_AF_INET6()) {
 	return pj_memcmp(&a1->ipv6, &a2->ipv6, sizeof(a1->ipv6));
     } else {
 	pj_assert(!"Invalid address family!");
diff --git a/pjnath/src/pjnath/ice_strans.c b/pjnath/src/pjnath/ice_strans.c
index e834462..052e1a8 100644
--- a/pjnath/src/pjnath/ice_strans.c
+++ b/pjnath/src/pjnath/ice_strans.c
@@ -285,7 +285,7 @@
     pj_memcpy(comp->ka_tsx_id, &tsx_id, sizeof(comp->ka_tsx_id));
 
     /* Create socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &comp->sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &comp->sock);
     if (status != PJ_SUCCESS)
 	return status;
 
diff --git a/pjnath/src/pjnath/stun_msg.c b/pjnath/src/pjnath/stun_msg.c
index eb79f2d..d16e1cb 100644
--- a/pjnath/src/pjnath/stun_msg.c
+++ b/pjnath/src/pjnath/stun_msg.c
@@ -769,7 +769,7 @@
     *buf++ = '\0';
 
     /* Family (IPv4 only for now) */
-    PJ_ASSERT_RETURN(ca->sockaddr.addr.sa_family == PJ_AF_INET, PJ_EINVAL);
+    PJ_ASSERT_RETURN(ca->sockaddr.addr.sa_family == pj_AF_INET(), PJ_EINVAL);
     *buf++ = 1;
 
     if (ca->xor_ed) {
diff --git a/pjnath/src/pjnath/stun_msg_dump.c b/pjnath/src/pjnath/stun_msg_dump.c
index 14baf1a..c208879 100644
--- a/pjnath/src/pjnath/stun_msg_dump.c
+++ b/pjnath/src/pjnath/stun_msg_dump.c
@@ -83,13 +83,13 @@
 
 	    attr = (const pj_stun_sockaddr_attr*)ahdr;
 
-	    if (attr->sockaddr.addr.sa_family == PJ_AF_INET) {
+	    if (attr->sockaddr.addr.sa_family == pj_AF_INET()) {
 		len = pj_ansi_snprintf(p, end-p,
 				       ", IPv4 addr=%s:%d\n",
 				       pj_inet_ntoa(attr->sockaddr.ipv4.sin_addr),
 				       pj_ntohs(attr->sockaddr.ipv4.sin_port));
 
-	    } else if (attr->sockaddr.addr.sa_family == PJ_AF_INET6) {
+	    } else if (attr->sockaddr.addr.sa_family == pj_AF_INET6()) {
 		len = pj_ansi_snprintf(p, end-p,
 				       ", IPv6 addr present\n");
 	    } else {
diff --git a/pjnath/src/pjnath/stun_session.c b/pjnath/src/pjnath/stun_session.c
index 334ba1a..2e11a81 100644
--- a/pjnath/src/pjnath/stun_session.c
+++ b/pjnath/src/pjnath/stun_session.c
@@ -562,10 +562,10 @@
     const pj_sockaddr *dst = (const pj_sockaddr*)addr;
     char buf[512];
     
-    if (dst->addr.sa_family == PJ_AF_INET) {
+    if (dst->addr.sa_family == pj_AF_INET()) {
 	dst_name = pj_inet_ntoa(dst->ipv4.sin_addr);
 	dst_port = pj_ntohs(dst->ipv4.sin_port);
-    } else if (dst->addr.sa_family == PJ_AF_INET6) {
+    } else if (dst->addr.sa_family == pj_AF_INET6()) {
 	dst_name = "IPv6";
 	dst_port = pj_ntohs(dst->ipv6.sin6_port);
     } else {
diff --git a/pjnath/src/pjstun-client/client_main.c b/pjnath/src/pjstun-client/client_main.c
index 0631f01..578a582 100644
--- a/pjnath/src/pjstun-client/client_main.c
+++ b/pjnath/src/pjstun-client/client_main.c
@@ -270,13 +270,13 @@
     pj_stun_config_init(&g.stun_config, &g.cp.factory, 0, NULL, g.th);
     pj_assert(status == PJ_SUCCESS);
 
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &g.peer_sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &g.peer_sock);
     pj_assert(status == PJ_SUCCESS);
 
     status = pj_sock_bind_in(g.peer_sock, 0, 0);
     pj_assert(status == PJ_SUCCESS);
 
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &g.sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &g.sock);
     pj_assert(status == PJ_SUCCESS);
 
     status = pj_sockaddr_in_init(&addr, NULL, 0);
diff --git a/pjnath/src/pjstun-srv-test/bind_usage.c b/pjnath/src/pjstun-srv-test/bind_usage.c
index a6c9a7e..84928af 100644
--- a/pjnath/src/pjstun-srv-test/bind_usage.c
+++ b/pjnath/src/pjstun-srv-test/bind_usage.c
@@ -74,7 +74,7 @@
     usage_cb.on_destroy = &usage_on_destroy;
 
     status = pj_stun_usage_create(srv, "bind%p", &usage_cb,
-				  PJ_AF_INET, PJ_SOCK_DGRAM, 0,
+				  pj_AF_INET(), pj_SOCK_DGRAM(), 0,
 				  &local_addr, sizeof(local_addr),
 				  &bu->usage);
     if (status != PJ_SUCCESS) {
diff --git a/pjnath/src/pjstun-srv-test/main.c b/pjnath/src/pjstun-srv-test/main.c
index 68adf45..1b5fef3 100644
--- a/pjnath/src/pjstun-srv-test/main.c
+++ b/pjnath/src/pjstun-srv-test/main.c
@@ -131,7 +131,7 @@
     }
     */
 
-    status = pj_stun_turn_usage_create(srv, PJ_SOCK_DGRAM, NULL,
+    status = pj_stun_turn_usage_create(srv, pj_SOCK_DGRAM(), NULL,
 				       3478, o.use_fingerprint, &turn);
     if (status != PJ_SUCCESS) {
 	pj_stun_perror(THIS_FILE, "Unable to create bind usage", status);
diff --git a/pjnath/src/pjstun-srv-test/turn_usage.c b/pjnath/src/pjstun-srv-test/turn_usage.c
index 8549227..409db4a 100644
--- a/pjnath/src/pjstun-srv-test/turn_usage.c
+++ b/pjnath/src/pjstun-srv-test/turn_usage.c
@@ -159,7 +159,7 @@
     pj_sockaddr_in local_addr;
     pj_status_t status;
 
-    PJ_ASSERT_RETURN(srv && (type==PJ_SOCK_DGRAM||type==PJ_SOCK_STREAM),
+    PJ_ASSERT_RETURN(srv && (type==pj_SOCK_DGRAM()||type==pj_SOCK_STREAM()),
 		     PJ_EINVAL);
     si = pj_stun_server_get_info(srv);
 
@@ -185,7 +185,7 @@
     usage_cb.on_rx_data = &tu_on_rx_data;
     usage_cb.on_destroy = &tu_on_destroy;
     status = pj_stun_usage_create(srv, "turn%p", &usage_cb,
-				  PJ_AF_INET, tu->type, 0,
+				  pj_AF_INET(), tu->type, 0,
 				  &local_addr, sizeof(local_addr),
 				  &tu->usage);
     if (status != PJ_SUCCESS) {
@@ -297,7 +297,7 @@
 
     /* STUN message decoding flag */
     flags = 0;
-    if (tu->type == PJ_SOCK_DGRAM)
+    if (tu->type == pj_SOCK_DGRAM())
 	flags |= PJ_STUN_IS_DATAGRAM;
     
 
@@ -361,7 +361,7 @@
 	*err_code = PJ_STUN_SC_INVALID_PORT;
 
 	/* Allocate specific port */
-	status = pj_sock_socket(PJ_AF_INET, type, 0, &sock);
+	status = pj_sock_socket(pj_AF_INET(), type, 0, &sock);
 	if (status != PJ_SUCCESS)
 	    return status;
 
@@ -400,7 +400,7 @@
 		break;
 	    }
 
-	    status = pj_sock_socket(PJ_AF_INET, type, 0, &sock);
+	    status = pj_sock_socket(pj_AF_INET(), type, 0, &sock);
 	    if (status != PJ_SUCCESS)
 		return status;
 
@@ -510,7 +510,7 @@
 
     sd = (struct session_data*) pj_stun_session_get_user_data(sess);
 
-    if (sd->tu->type == PJ_SOCK_DGRAM) {
+    if (sd->tu->type == pj_SOCK_DGRAM()) {
 	return pj_stun_usage_sendto(sd->tu->usage, pkt, pkt_size, 0,
 				    dst_addr, addr_len);
     } else {
@@ -546,9 +546,9 @@
 
 static const char *get_tp_type(int type)
 {
-    if (type==PJ_SOCK_DGRAM)
+    if (type==pj_SOCK_DGRAM())
 	return "udp";
-    else if (type==PJ_SOCK_STREAM)
+    else if (type==pj_SOCK_STREAM())
 	return "tcp";
     else
 	return "???";
@@ -594,7 +594,7 @@
 
     sd = (struct session_data*) pj_stun_session_get_user_data(sess);
 
-    if (sd->tu->type == PJ_SOCK_DGRAM) {
+    if (sd->tu->type == pj_SOCK_DGRAM()) {
 	return pj_stun_usage_sendto(sd->tu->usage, pkt, pkt_size, 0,
 				    dst_addr, addr_len);
     } else {
@@ -951,13 +951,13 @@
 		       src_addr, src_addr_len);
 	return PJ_SUCCESS;
     } else if (a_rt) {
-	client->sock_type = a_rt->value ? PJ_SOCK_STREAM : PJ_SOCK_DGRAM;
+	client->sock_type = a_rt->value ? pj_SOCK_STREAM() : pj_SOCK_DGRAM();
     } else {
 	client->sock_type = client->tu->type;;
     }
 
     /* Process REQUESTED-IP attribute */
-    if (a_rip && a_rip->sockaddr.addr.sa_family != PJ_AF_INET) {
+    if (a_rip && a_rip->sockaddr.addr.sa_family != pj_AF_INET()) {
 	client_respond(client, msg, PJ_STUN_SC_INVALID_IP_ADDR, NULL,
 		       src_addr, src_addr_len);
 	return PJ_SUCCESS;
@@ -1130,7 +1130,7 @@
 	/* Remote active destination needs to be cleared */
 	client->active_peer = NULL;
 
-    } else if (a_raddr->sockaddr.addr.sa_family != PJ_AF_INET) {
+    } else if (a_raddr->sockaddr.addr.sa_family != pj_AF_INET()) {
 	/* Bad request (not IPv4) */
 	client_respond(client, msg, PJ_STUN_SC_BAD_REQUEST, NULL,
 		       src_addr, src_addr_len);
@@ -1196,7 +1196,7 @@
 	/* REMOTE-ADDRESS not present, discard packet */
 	return PJ_SUCCESS;
 
-    } else if (a_raddr->sockaddr.addr.sa_family != PJ_AF_INET) {
+    } else if (a_raddr->sockaddr.addr.sa_family != pj_AF_INET()) {
 	/* REMOTE-ADDRESS present but not IPv4, discard packet */
 	return PJ_SUCCESS;
 
@@ -1209,7 +1209,7 @@
 	data = (const pj_uint8_t *)a_data->data;
 	datalen = a_data->length;
 
-    } else if (client->sock_type == PJ_SOCK_STREAM) {
+    } else if (client->sock_type == pj_SOCK_STREAM()) {
 	/* Discard if no Data and Allocation type is TCP */
 	return PJ_SUCCESS;
 
diff --git a/pjsip-apps/src/samples/invtester.c b/pjsip-apps/src/samples/invtester.c
index 734e8e9..c75063b 100644
--- a/pjsip-apps/src/samples/invtester.c
+++ b/pjsip-apps/src/samples/invtester.c
@@ -225,7 +225,7 @@
     {
 	pj_sockaddr_in addr;
 
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons(PORT);
 
diff --git a/pjsip-apps/src/samples/pjsip-perf.c b/pjsip-apps/src/samples/pjsip-perf.c
index e3d7fc4..7d46bb9 100644
--- a/pjsip-apps/src/samples/pjsip-perf.c
+++ b/pjsip-apps/src/samples/pjsip-perf.c
@@ -760,7 +760,7 @@
 	const char *transport_type = NULL;
 
 	pj_bzero(&addr, sizeof(addr));
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons((pj_uint16_t)app.local_port);
 
diff --git a/pjsip-apps/src/samples/proxy.h b/pjsip-apps/src/samples/proxy.h
index a2f9799..8eef92b 100644
--- a/pjsip-apps/src/samples/proxy.h
+++ b/pjsip-apps/src/samples/proxy.h
@@ -212,7 +212,7 @@
     {
 	pj_sockaddr_in addr;
 
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons((pj_uint16_t)global.port);
 
diff --git a/pjsip-apps/src/samples/simpleua.c b/pjsip-apps/src/samples/simpleua.c
index 7ab6e21..48cea12 100644
--- a/pjsip-apps/src/samples/simpleua.c
+++ b/pjsip-apps/src/samples/simpleua.c
@@ -181,7 +181,7 @@
     {
 	pj_sockaddr_in addr;
 
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons(5060);
 
diff --git a/pjsip-apps/src/samples/siprtp.c b/pjsip-apps/src/samples/siprtp.c
index 40ae172..1e9ee06 100644
--- a/pjsip-apps/src/samples/siprtp.c
+++ b/pjsip-apps/src/samples/siprtp.c
@@ -305,7 +305,7 @@
 	pjsip_transport *tp;
 
 	pj_bzero(&addr, sizeof(addr));
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons((pj_uint16_t)app.sip_port);
 
diff --git a/pjsip-apps/src/samples/sipstateless.c b/pjsip-apps/src/samples/sipstateless.c
index 53b1fc7..6aa4037 100644
--- a/pjsip-apps/src/samples/sipstateless.c
+++ b/pjsip-apps/src/samples/sipstateless.c
@@ -128,7 +128,7 @@
     {
 	pj_sockaddr_in addr;
 
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons(5060);
 
@@ -148,7 +148,7 @@
     {
 	pj_sockaddr_in addr;
 
-	addr.sin_family = PJ_AF_INET;
+	addr.sin_family = pj_AF_INET();
 	addr.sin_addr.s_addr = 0;
 	addr.sin_port = pj_htons(5060);
 
diff --git a/pjsip/src/pjsip/sip_transport.c b/pjsip/src/pjsip/sip_transport.c
index 2305b53..8f5dabb 100644
--- a/pjsip/src/pjsip/sip_transport.c
+++ b/pjsip/src/pjsip/sip_transport.c
@@ -560,7 +560,7 @@
     tdata->tp_info.transport = tr;
     pj_memcpy(&tdata->tp_info.dst_addr, addr, addr_len);
     tdata->tp_info.dst_addr_len = addr_len;
-    if (((pj_sockaddr*)addr)->addr.sa_family == PJ_AF_INET) {
+    if (((pj_sockaddr*)addr)->addr.sa_family == pj_AF_INET()) {
 	const char *str_addr;
 	str_addr = pj_inet_ntoa(((pj_sockaddr_in*)addr)->sin_addr);
 	pj_ansi_strcpy(tdata->tp_info.dst_name, str_addr);
@@ -1471,12 +1471,12 @@
 	    /* For datagram INET transports, try lookup with zero address.
 	     */
 	    else if ((flag & PJSIP_TRANSPORT_DATAGRAM) && 
-		     (remote_addr->addr.sa_family == PJ_AF_INET)) 
+		     (remote_addr->addr.sa_family == pj_AF_INET())) 
 	    {
 		pj_sockaddr_in *addr = (pj_sockaddr_in*)&key.rem_addr;
 
 		pj_bzero(addr, sizeof(pj_sockaddr_in));
-		addr->sin_family = PJ_AF_INET;
+		addr->sin_family = pj_AF_INET();
 
 		key_len = sizeof(key.type) + sizeof(pj_sockaddr_in);
 		transport = (pjsip_transport*)
diff --git a/pjsip/src/pjsip/sip_transport_loop.c b/pjsip/src/pjsip/sip_transport_loop.c
index 45895d9..6e0e3c6 100644
--- a/pjsip/src/pjsip/sip_transport_loop.c
+++ b/pjsip/src/pjsip/sip_transport_loop.c
@@ -367,7 +367,7 @@
     if (status != PJ_SUCCESS)
 	goto on_error;
     loop->base.key.type = PJSIP_TRANSPORT_LOOP_DGRAM;
-    //loop->base.key.rem_addr.sa_family = PJ_AF_INET;
+    //loop->base.key.rem_addr.sa_family = pj_AF_INET();
     loop->base.type_name = "LOOP-DGRAM";
     loop->base.info = "LOOP-DGRAM";
     loop->base.flag = PJSIP_TRANSPORT_DATAGRAM;
diff --git a/pjsip/src/pjsip/sip_transport_tcp.c b/pjsip/src/pjsip/sip_transport_tcp.c
index 40ec04b..585dad1 100644
--- a/pjsip/src/pjsip/sip_transport_tcp.c
+++ b/pjsip/src/pjsip/sip_transport_tcp.c
@@ -239,7 +239,8 @@
 
 
     /* Create and bind socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &listener->sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, 
+			    &listener->sock);
     if (status != PJ_SUCCESS)
 	goto on_error;
 
@@ -787,7 +788,7 @@
 		     addr_len && p_transport, PJ_EINVAL);
 
     /* Check that address is a sockaddr_in */
-    PJ_ASSERT_RETURN(rem_addr->addr.sa_family == PJ_AF_INET &&
+    PJ_ASSERT_RETURN(rem_addr->addr.sa_family == pj_AF_INET() &&
 		     addr_len == sizeof(pj_sockaddr_in), PJ_EINVAL);
 
 
@@ -795,7 +796,7 @@
 
     
     /* Create socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &sock);
     if (status != PJ_SUCCESS)
 	return status;
 
diff --git a/pjsip/src/pjsip/sip_transport_tls_ossl.c b/pjsip/src/pjsip/sip_transport_tls_ossl.c
index 454574d..235a32e 100644
--- a/pjsip/src/pjsip/sip_transport_tls_ossl.c
+++ b/pjsip/src/pjsip/sip_transport_tls_ossl.c
@@ -937,7 +937,7 @@
 
 
     /* Create and bind socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &listener->sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &listener->sock);
     if (status != PJ_SUCCESS)
 	goto on_error;
 
@@ -1526,7 +1526,7 @@
 		     addr_len && p_transport, PJ_EINVAL);
 
     /* Check that address is a sockaddr_in */
-    PJ_ASSERT_RETURN(rem_addr->addr.sa_family == PJ_AF_INET &&
+    PJ_ASSERT_RETURN(rem_addr->addr.sa_family == pj_AF_INET() &&
 		     addr_len == sizeof(pj_sockaddr_in), PJ_EINVAL);
 
 
@@ -1534,7 +1534,7 @@
 
     
     /* Create socket */
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_STREAM, 0, &sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_STREAM(), 0, &sock);
     if (status != PJ_SUCCESS)
 	return status;
 
diff --git a/pjsip/src/pjsip/sip_transport_udp.c b/pjsip/src/pjsip/sip_transport_udp.c
index 43d671d..307dc03 100644
--- a/pjsip/src/pjsip/sip_transport_udp.c
+++ b/pjsip/src/pjsip/sip_transport_udp.c
@@ -419,7 +419,7 @@
     pj_sockaddr_in tmp_addr;
     pj_status_t status;
 
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &sock);
     if (status != PJ_SUCCESS)
 	return status;
 
@@ -508,7 +508,7 @@
 
     /* Adjust socket rcvbuf size */
     sobuf_size = PJSIP_UDP_SO_RCVBUF_SIZE;
-    status = pj_sock_setsockopt(sock, PJ_SOL_SOCKET, PJ_SO_RCVBUF,
+    status = pj_sock_setsockopt(sock, pj_SOL_SOCKET(), pj_SO_RCVBUF(),
 				&sobuf_size, sizeof(sobuf_size));
     if (status != PJ_SUCCESS) {
 	char errmsg[PJ_ERR_MSG_SIZE];
@@ -519,7 +519,7 @@
 
     /* Adjust socket sndbuf size */
     sobuf_size = PJSIP_UDP_SO_SNDBUF_SIZE;
-    status = pj_sock_setsockopt(sock, PJ_SOL_SOCKET, PJ_SO_SNDBUF,
+    status = pj_sock_setsockopt(sock, pj_SOL_SOCKET(), pj_SO_SNDBUF(),
 				&sobuf_size, sizeof(sobuf_size));
     if (status != PJ_SUCCESS) {
 	char errmsg[PJ_ERR_MSG_SIZE];
@@ -639,7 +639,7 @@
     tp->base.key.type = PJSIP_TRANSPORT_UDP;
 
     /* Remote address is left zero (except the family) */
-    tp->base.key.rem_addr.addr.sa_family = PJ_AF_INET;
+    tp->base.key.rem_addr.addr.sa_family = pj_AF_INET();
 
     /* Type name. */
     tp->base.type_name = "UDP";
diff --git a/pjsip/src/pjsua-lib/pjsua_core.c b/pjsip/src/pjsua-lib/pjsua_core.c
index c0e6098..f2d18dc 100644
--- a/pjsip/src/pjsua-lib/pjsua_core.c
+++ b/pjsip/src/pjsua-lib/pjsua_core.c
@@ -1080,7 +1080,7 @@
 	return status;
     }
 
-    status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock);
+    status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &sock);
     if (status != PJ_SUCCESS) {
 	pjsua_perror(THIS_FILE, "socket() error", status);
 	return status;
@@ -1151,7 +1151,7 @@
 	    return status;
 	}
 
-	p_pub_addr->sin_family = PJ_AF_INET;
+	p_pub_addr->sin_family = pj_AF_INET();
 	p_pub_addr->sin_port = pj_htons((pj_uint16_t)port);
     }
 
diff --git a/pjsip/src/pjsua-lib/pjsua_media.c b/pjsip/src/pjsua-lib/pjsua_media.c
index 2105a06..6f646fb 100644
--- a/pjsip/src/pjsua-lib/pjsua_media.c
+++ b/pjsip/src/pjsua-lib/pjsua_media.c
@@ -243,7 +243,7 @@
     for (i=0; i<RTP_RETRY; ++i, next_rtp_port += 2) {
 
 	/* Create and bind RTP socket. */
-	status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock[0]);
+	status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &sock[0]);
 	if (status != PJ_SUCCESS) {
 	    pjsua_perror(THIS_FILE, "socket() error", status);
 	    return status;
@@ -258,7 +258,7 @@
 	}
 
 	/* Create and bind RTCP socket. */
-	status = pj_sock_socket(PJ_AF_INET, PJ_SOCK_DGRAM, 0, &sock[1]);
+	status = pj_sock_socket(pj_AF_INET(), pj_SOCK_DGRAM(), 0, &sock[1]);
 	if (status != PJ_SUCCESS) {
 	    pjsua_perror(THIS_FILE, "socket() error", status);
 	    pj_sock_close(sock[0]);
diff --git a/pjsip/src/test-pjsip/dns_test.c b/pjsip/src/test-pjsip/dns_test.c
index 5c90470..b1c6815 100644
--- a/pjsip/src/test-pjsip/dns_test.c
+++ b/pjsip/src/test-pjsip/dns_test.c
@@ -483,7 +483,7 @@
     r->entry[r->count].addr_len = sizeof(pj_sockaddr_in);
 
     a = (pj_sockaddr_in *)&r->entry[r->count].addr;
-    a->sin_family = PJ_AF_INET;
+    a->sin_family = pj_AF_INET();
     tmp = pj_str(addr);
     a->sin_addr = pj_inet_addr(&tmp);
     a->sin_port = pj_htons((pj_uint16_t)port);