OLD | NEW |
(Empty) | |
| 1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |
| 2 /* ***** BEGIN LICENSE BLOCK ***** |
| 3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1 |
| 4 * |
| 5 * The contents of this file are subject to the Mozilla Public License Version |
| 6 * 1.1 (the "License"); you may not use this file except in compliance with |
| 7 * the License. You may obtain a copy of the License at |
| 8 * http://www.mozilla.org/MPL/ |
| 9 * |
| 10 * Software distributed under the License is distributed on an "AS IS" basis, |
| 11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License |
| 12 * for the specific language governing rights and limitations under the |
| 13 * License. |
| 14 * |
| 15 * The Original Code is the Netscape Portable Runtime (NSPR). |
| 16 * |
| 17 * The Initial Developer of the Original Code is |
| 18 * Netscape Communications Corporation. |
| 19 * Portions created by the Initial Developer are Copyright (C) 1998-2000 |
| 20 * the Initial Developer. All Rights Reserved. |
| 21 * |
| 22 * Contributor(s): |
| 23 * |
| 24 * Alternatively, the contents of this file may be used under the terms of |
| 25 * either the GNU General Public License Version 2 or later (the "GPL"), or |
| 26 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), |
| 27 * in which case the provisions of the GPL or the LGPL are applicable instead |
| 28 * of those above. If you wish to allow use of your version of this file only |
| 29 * under the terms of either the GPL or the LGPL, and not to allow others to |
| 30 * use your version of this file under the terms of the MPL, indicate your |
| 31 * decision by deleting the provisions above and replace them with the notice |
| 32 * and other provisions required by the GPL or the LGPL. If you do not delete |
| 33 * the provisions above, a recipient may use your version of this file under |
| 34 * the terms of any one of the MPL, the GPL or the LGPL. |
| 35 * |
| 36 * ***** END LICENSE BLOCK ***** */ |
| 37 |
| 38 #ifndef nspr_beos_defs_h___ |
| 39 #define nspr_beos_defs_h___ |
| 40 |
| 41 #include "prtypes.h" |
| 42 #include "prio.h" |
| 43 #include "prthread.h" |
| 44 #include "prproces.h" |
| 45 #include "prmem.h" |
| 46 #include "obsolete/prsem.h" |
| 47 #include <errno.h> |
| 48 |
| 49 #include <support/SupportDefs.h> |
| 50 #include <kernel/OS.h> |
| 51 #include <dirent.h> |
| 52 |
| 53 /* |
| 54 * Internal configuration macros |
| 55 */ |
| 56 |
| 57 #ifdef BONE_VERSION |
| 58 #define _PR_HAVE_SOCKADDR_LEN |
| 59 #endif |
| 60 |
| 61 #define PR_LINKER_ARCH "beos" |
| 62 #define _PR_SI_SYSNAME "BEOS" |
| 63 #ifdef __powerpc__ |
| 64 #define _PR_SI_ARCHITECTURE "ppc" |
| 65 #else |
| 66 #define _PR_SI_ARCHITECTURE "x86" |
| 67 #endif |
| 68 #define PR_DLL_SUFFIX ".so" |
| 69 |
| 70 #define _PR_VMBASE 0x30000000 |
| 71 #define _PR_STACK_VMBASE 0x50000000 |
| 72 #define _MD_DEFAULT_STACK_SIZE 65536L |
| 73 #define _MD_MMAP_FLAGS MAP_PRIVATE |
| 74 |
| 75 #undef HAVE_STACK_GROWING_UP |
| 76 #define HAVE_DLL |
| 77 #define _PR_NO_CLOCK_TIMER |
| 78 |
| 79 /* |
| 80 * The Atomic operations |
| 81 */ |
| 82 |
| 83 #define _PR_HAVE_ATOMIC_OPS |
| 84 #define _MD_INIT_ATOMIC _MD_AtomicInit |
| 85 #define _MD_ATOMIC_INCREMENT _MD_AtomicIncrement |
| 86 #define _MD_ATOMIC_ADD _MD_AtomicAdd |
| 87 #define _MD_ATOMIC_DECREMENT _MD_AtomicDecrement |
| 88 #define _MD_ATOMIC_SET _MD_AtomicSet |
| 89 |
| 90 #define HAVE_CVAR_BUILT_ON_SEM |
| 91 #define _PR_GLOBAL_THREADS_ONLY |
| 92 #define _PR_BTHREADS |
| 93 #define _PR_NEED_FAKE_POLL |
| 94 #define _PR_HAVE_PEEK_BUFFER |
| 95 #define _PR_PEEK_BUFFER_MAX (16 * 1024) |
| 96 #define _PR_FD_NEED_EMULATE_MSG_PEEK(fd) 1 |
| 97 #define _PR_CONNECT_DOES_NOT_BIND |
| 98 #define _PR_HAVE_O_APPEND |
| 99 |
| 100 /* Define threading functions and objects as native BeOS */ |
| 101 struct _MDThread { |
| 102 thread_id tid; /* BeOS thread handle */ |
| 103 sem_id joinSem; /* sems used to synchronzie joining */ |
| 104 PRBool is_joining; /* TRUE if someone is currently waiting to |
| 105 join this thread */ |
| 106 }; |
| 107 |
| 108 struct _MDThreadStack { |
| 109 PRInt8 notused; |
| 110 }; |
| 111 |
| 112 /* |
| 113 * Lock and Semaphore related definitions |
| 114 */ |
| 115 |
| 116 struct _MDLock { |
| 117 sem_id semaphoreID; |
| 118 int32 benaphoreCount; |
| 119 }; |
| 120 |
| 121 struct _MDCVar { |
| 122 sem_id sem1; |
| 123 sem_id sem2; |
| 124 int16 count; |
| 125 }; |
| 126 |
| 127 struct _MDSemaphore { |
| 128 sem_id sid; |
| 129 }; |
| 130 |
| 131 /* |
| 132 ** CPU-related definitions |
| 133 */ |
| 134 struct _MDCPU { |
| 135 int8 unused; |
| 136 }; |
| 137 |
| 138 /* |
| 139 ** Process-related definitions |
| 140 */ |
| 141 struct _MDProcess { |
| 142 pid_t pid; |
| 143 }; |
| 144 |
| 145 struct _MDSegment { |
| 146 PRInt8 notused; |
| 147 }; |
| 148 |
| 149 /* |
| 150 ** File- and directory-related definitions |
| 151 */ |
| 152 |
| 153 #ifndef BONE_VERSION |
| 154 #define BE_SOCK_SHUTDOWN_READ 0x01 |
| 155 #define BE_SOCK_SHUTDOWN_WRITE 0x02 |
| 156 #endif |
| 157 |
| 158 struct _MDFileDesc { |
| 159 PRInt32 osfd; |
| 160 PRInt32 sock_state; |
| 161 PRBool accepted_socket; |
| 162 PRNetAddr peer_addr; |
| 163 #ifndef BONE_VERSION |
| 164 PRBool connectValueValid; |
| 165 int connectReturnValue; |
| 166 int connectReturnError; |
| 167 #endif |
| 168 }; |
| 169 |
| 170 struct _MDDir { |
| 171 DIR *d; |
| 172 }; |
| 173 |
| 174 #define PR_DIRECTORY_SEPARATOR '/' |
| 175 #define PR_DIRECTORY_SEPARATOR_STR "/" |
| 176 #define PR_PATH_SEPARATOR ':' |
| 177 #define PR_PATH_SEPARATOR_STR ":" |
| 178 |
| 179 #define GETTIMEOFDAY(tp) gettimeofday((tp), NULL) |
| 180 |
| 181 /* --- Memory-mapped files stuff --- not implemented on BeOS */ |
| 182 |
| 183 struct _MDFileMap { |
| 184 PRInt8 unused; |
| 185 }; |
| 186 |
| 187 /* |
| 188 * Network related definitions. |
| 189 */ |
| 190 |
| 191 #ifndef BONE_VERSION |
| 192 #define IPPROTO_IP 0 |
| 193 #define AF_UNIX 2 |
| 194 #define TCP_NODELAY SO_NONBLOCK |
| 195 #define SO_LINGER -1 |
| 196 #define SO_ERROR 4 |
| 197 #endif |
| 198 |
| 199 #define _PR_INTERRUPT_CHECK_INTERVAL_SECS 5 |
| 200 |
| 201 #ifndef BONE_VERSION |
| 202 /* these aren't actually used. if they are, we're screwed */ |
| 203 struct protoent { |
| 204 char *p_name; /* official protocol name */ |
| 205 char **p_aliases; /* alias list */ |
| 206 int p_proto; /* protocol # */ |
| 207 }; |
| 208 |
| 209 struct protoent* getprotobyname(const char* name); |
| 210 struct protoent* getprotobynumber(int number); |
| 211 #endif |
| 212 |
| 213 /* |
| 214 * malloc() related definitions. |
| 215 */ |
| 216 |
| 217 #undef _PR_OVERRIDE_MALLOC |
| 218 |
| 219 /* Miscellaneous */ |
| 220 |
| 221 #define _MD_ERRNO() (errno) |
| 222 |
| 223 #define _MD_CLEANUP_BEFORE_EXIT _MD_cleanup_before_exit |
| 224 #define _MD_EXIT _MD_exit |
| 225 |
| 226 #define _MD_GET_ENV getenv |
| 227 #define _MD_PUT_ENV putenv |
| 228 |
| 229 #define _MD_EARLY_INIT _MD_early_init |
| 230 #define _MD_FINAL_INIT _MD_final_init |
| 231 |
| 232 /* CPU Stuff */ |
| 233 |
| 234 #define _MD_INIT_CPUS _MD_init_cpus |
| 235 #define _MD_WAKEUP_CPUS _MD_wakeup_cpus |
| 236 #define _MD_START_INTERRUPTS _MD_start_interrupts |
| 237 #define _MD_STOP_INTERRUPTS _MD_stop_interrupts |
| 238 #define _MD_DISABLE_CLOCK_INTERRUPTS _MD_disable_clock_interrupts |
| 239 #define _MD_BLOCK_CLOCK_INTERRUPTS _MD_block_clock_interrupts |
| 240 #define _MD_UNBLOCK_CLOCK_INTERRUPTS _MD_unblock_clock_interrupts |
| 241 #define _MD_CLOCK_INTERRUPT _MD_clock_interrupt |
| 242 #define _MD_INIT_STACK _MD_init_stack |
| 243 #define _MD_CLEAR_STACK _MD_clear_stack |
| 244 // #define _MD_GET_INTSOFF _MD_get_intsoff |
| 245 // #define _MD_SET_INTSOFF _MD_set_intsoff |
| 246 #define _MD_CURRENT_CPU _MD_current_cpu |
| 247 #define _MD_SET_CURRENT_CPU _MD_set_current_cpu |
| 248 #define _MD_INIT_RUNNING_CPU _MD_init_running_cpu |
| 249 #define _MD_PAUSE_CPU _MD_pause_cpu |
| 250 |
| 251 /* Thread stuff */ |
| 252 |
| 253 #define _MD_CURRENT_THREAD() PR_GetCurrentThread() |
| 254 // #define _MD_GET_ATTACHED_THREAD _MD_get_attached_thread |
| 255 #define _MD_LAST_THREAD _MD_last_thread |
| 256 #define _MD_SET_CURRENT_THREAD _MD_set_current_THREAD |
| 257 #define _MD_SET_LAST_THREAD _MD_set_last_thread |
| 258 #define _MD_INIT_THREAD _MD_init_thread |
| 259 #define _MD_EXIT_THREAD _MD_exit_thread |
| 260 #define _MD_INIT_ATTACHED_THREAD _MD_init_attached_thread |
| 261 |
| 262 #define _MD_SUSPEND_THREAD _MD_suspend_thread |
| 263 #define _MD_RESUME_THREAD _MD_resume_thread |
| 264 #define _MD_SUSPEND_CPU _MD_suspend_cpu |
| 265 #define _MD_RESUME_CPU _MD_resume_cpu |
| 266 #define _MD_BEGIN_SUSPEND_ALL _MD_begin_suspend_all |
| 267 #define _MD_END_SUSPEND_ALL _MD_end_suspend_all |
| 268 #define _MD_BEGIN_RESUME_ALL _MD_begin_resume_all |
| 269 #define _MD_END_RESUME_ALL _MD_end_resume_all |
| 270 |
| 271 #define _MD_GET_SP _MD_get_sp |
| 272 |
| 273 #define _MD_CLEAN_THREAD _MD_clean_thread |
| 274 #define _MD_CREATE_PRIMORDIAL_USER_THREAD _MD_create_primordial_user_thread |
| 275 #define _MD_CREATE_USER_THREAD _MD_create_user_thread |
| 276 #define _MD_INIT_PRIMORDIAL_THREAD _MD_init_primordial_thread |
| 277 #define _MD_CREATE_THREAD _MD_create_thread |
| 278 #define _MD_YIELD _MD_yield |
| 279 #define _MD_SET_PRIORITY _MD_set_priority |
| 280 |
| 281 #define _MD_SUSPENDALL _MD_suspendall |
| 282 #define _MD_RESUMEALL _MD_resumeall |
| 283 |
| 284 #define _MD_SWITCH_CONTEXT _MD_switch_context |
| 285 #define _MD_RESTORE_CONTEXT _MD_restore_context |
| 286 |
| 287 #define _MD_WAIT _MD_wait |
| 288 #define _MD_WAKEUP_WAITER _MD_wakeup_waiter |
| 289 |
| 290 #define _MD_SETTHREADAFFINITYMASK _MD_setthreadaffinitymask |
| 291 #define _MD_GETTHREADAFFINITYMASK _MD_getthreadaffinitymask |
| 292 |
| 293 /* Thread Synchronization */ |
| 294 |
| 295 #define _MD_INIT_LOCKS _MD_init_locks |
| 296 #define _MD_NEW_LOCK _MD_new_lock |
| 297 #define _MD_FREE_LOCK _MD_free_lock |
| 298 #define _MD_LOCK _MD_lock |
| 299 #define _MD_TEST_AND_LOCK _MD_test_and_lock |
| 300 #define _MD_UNLOCK _MD_unlock |
| 301 #define _MD_IOQ_LOCK _MD_ioq_lock |
| 302 #define _MD_IOQ_UNLOCK _MD_ioq_unlock |
| 303 #define _MD_NEW_SEM _MD_new_sem |
| 304 #define _MD_DESTROY_SEM _MD_destroy_sem |
| 305 #define _MD_TIMED_WAIT_SEM _MD_timed_wait_sem |
| 306 #define _MD_WAIT_SEM _MD_wait_sem |
| 307 #define _MD_POST_SEM _MD_post_sem |
| 308 // #define _MD_NEW_CV _MD_new_cv |
| 309 // #define _MD_FREE_CV _MD_free_cv |
| 310 // #define _MD_WAIT_CV _MD_wait_cv |
| 311 // #define _MD_NOTIFY_CV _MD_notify_cv |
| 312 // #define _MD_NOTIFYALL_CV _MD_notifyall_cv |
| 313 |
| 314 /* File I/O */ |
| 315 |
| 316 /* don't need any I/O initializations */ |
| 317 #define _MD_INIT_IO() |
| 318 #define _MD_INIT_FILEDESC(fd) |
| 319 |
| 320 #define _MD_OPEN_DIR _MD_open_dir |
| 321 #define _MD_READ_DIR _MD_read_dir |
| 322 #define _MD_CLOSE_DIR _MD_close_dir |
| 323 #define _MD_MAKE_NONBLOCK _MD_make_nonblock |
| 324 #define _MD_SET_FD_INHERITABLE _MD_set_fd_inheritable |
| 325 #define _MD_INIT_FD_INHERITABLE _MD_init_fd_inheritable |
| 326 #define _MD_QUERY_FD_INHERITABLE _MD_query_fd_inheritable |
| 327 #define _MD_OPEN _MD_open |
| 328 #define _MD_OPEN_FILE _MD_open |
| 329 #define _MD_CLOSE_FILE _MD_close_file |
| 330 #define _MD_READ _MD_read |
| 331 #define _MD_WRITE _MD_write |
| 332 #define _MD_WRITEV _MD_writev |
| 333 #define _MD_LSEEK _MD_lseek |
| 334 #define _MD_LSEEK64 _MD_lseek64 |
| 335 #define _MD_FSYNC _MD_fsync |
| 336 #define _MD_DELETE _MD_delete |
| 337 #define _MD_GETFILEINFO _MD_getfileinfo |
| 338 #define _MD_GETFILEINFO64 _MD_getfileinfo64 |
| 339 #define _MD_GETOPENFILEINFO _MD_getopenfileinfo |
| 340 #define _MD_GETOPENFILEINFO64 _MD_getopenfileinfo64 |
| 341 #define _MD_RENAME _MD_rename |
| 342 #define _MD_ACCESS _MD_access |
| 343 #define _MD_STAT stat |
| 344 #define _MD_MKDIR _MD_mkdir |
| 345 #define _MD_MAKE_DIR _MD_mkdir |
| 346 #define _MD_RMDIR _MD_rmdir |
| 347 #define _MD_PR_POLL _MD_pr_poll |
| 348 |
| 349 /* Network I/O */ |
| 350 |
| 351 #define _MD_CLOSE_SOCKET _MD_close_socket |
| 352 #define _MD_CONNECT _MD_connect |
| 353 #define _MD_ACCEPT _MD_accept |
| 354 #define _MD_BIND _MD_bind |
| 355 #define _MD_LISTEN _MD_listen |
| 356 #define _MD_SHUTDOWN _MD_shutdown |
| 357 #define _MD_RECV _MD_recv |
| 358 #define _MD_SEND _MD_send |
| 359 #define _MD_ACCEPT_READ _MD_accept_read |
| 360 #define _MD_GETSOCKNAME _MD_getsockname |
| 361 #define _MD_GETPEERNAME _MD_getpeername |
| 362 #define _MD_GETSOCKOPT _MD_getsockopt |
| 363 #define _MD_SETSOCKOPT _MD_setsockopt |
| 364 #define _MD_RECVFROM _MD_recvfrom |
| 365 #define _MD_SENDTO _MD_sendto |
| 366 #define _MD_SOCKETPAIR _MD_socketpair |
| 367 #define _MD_SOCKET _MD_socket |
| 368 #define _MD_SOCKETAVAILABLE _MD_socketavailable |
| 369 #define _MD_PIPEAVAILABLE _MD_socketavailable |
| 370 |
| 371 #define _MD_GET_SOCKET_ERROR() (errno) |
| 372 #define _MD_GETHOSTNAME _MD_gethostname |
| 373 |
| 374 #define _MD_SELECT select |
| 375 |
| 376 /* Process management */ |
| 377 |
| 378 #define _MD_CREATE_PROCESS _MD_create_process |
| 379 #define _MD_DETACH_PROCESS _MD_detach_process |
| 380 #define _MD_WAIT_PROCESS _MD_wait_process |
| 381 #define _MD_KILL_PROCESS _MD_kill_process |
| 382 |
| 383 /* Atomic data operations */ |
| 384 |
| 385 // #define _MD_INIT_ATOMIC _MD_init_atomic |
| 386 // #define _MD_ATOMIC_INCREMENT _MD_atomic_increment |
| 387 // #define _MD_ATOMIC_DECREMENT _MD_atomic_decrement |
| 388 // #define _MD_ATOMIC_SET _MD_atomic_set |
| 389 |
| 390 /* memory management */ |
| 391 |
| 392 #define _MD_INIT_SEGS _MD_init_segs |
| 393 #define _MD_ALLOC_SEGMENT _MD_alloc_segment |
| 394 #define _MD_FREE_SEGMENT _MD_free_segment |
| 395 |
| 396 /* Memory mapped file I/O */ |
| 397 |
| 398 #define _MD_CREATE_FILE_MAP _MD_create_file_map |
| 399 #define _MD_GET_MEM_MAP_ALIGNMENT _MD_get_mem_map_alignment |
| 400 #define _MD_MEM_MAP _MD_mem_map |
| 401 #define _MD_MEM_UNMAP _MD_mem_unmap |
| 402 #define _MD_CLOSE_FILE_MAP _MD_close_file_map |
| 403 |
| 404 /* Time related */ |
| 405 |
| 406 #define _MD_NOW _MD_now |
| 407 #define _MD_INTERVAL_INIT _MD_interval_init |
| 408 #define _MD_GET_INTERVAL _MD_get_interval |
| 409 #define _MD_INTERVAL_PER_SEC _MD_interval_per_sec |
| 410 |
| 411 /* File locking */ |
| 412 |
| 413 #define _MD_LOCKFILE _MD_lockfile |
| 414 #define _MD_TLOCKFILE _MD_tlockfile |
| 415 #define _MD_UNLOCKFILE _MD_unlockfile |
| 416 |
| 417 /** |
| 418 * Prototypes for machine dependent function implementations. (Too bad |
| 419 * NSPR's MD system blows so much that we have to reiterate every stinking |
| 420 * thing we implement here in our MD header file.) |
| 421 */ |
| 422 |
| 423 /* Miscellaneous */ |
| 424 |
| 425 NSPR_API(void) _MD_cleanup_before_exit(void); |
| 426 NSPR_API(void) _MD_exit(PRIntn status); |
| 427 |
| 428 NSPR_API(char*) _MD_get_env(const char *name); |
| 429 NSPR_API(PRIntn) _MD_put_env(const char *name); |
| 430 |
| 431 NSPR_API(void) _MD_early_init(void); |
| 432 NSPR_API(void) _MD_final_init(void); |
| 433 |
| 434 /* CPU Stuff */ |
| 435 |
| 436 NSPR_API(void) _MD_init_cpus(); |
| 437 NSPR_API(void) _MD_wakeup_cpus(); |
| 438 NSPR_API(void) _MD_start_interrupts(void); |
| 439 NSPR_API(void) _MD_stop_interrupts(void); |
| 440 NSPR_API(void) _MD_disable_clock_interrupts(void); |
| 441 NSPR_API(void) _MD_block_clock_interrupts(void); |
| 442 NSPR_API(void) _MD_unblock_clock_interrupts(void); |
| 443 NSPR_API(void) _MD_clock_interrupt(void); |
| 444 // NSPR_API(void) _MD_init_stack(PRThreadStack *ts, PRIntn redzone); |
| 445 // NSPR_API(void) _MD_clear_stack(PRThreadStack* ts); |
| 446 // NSPR_API(PRInt32) _MD_get_intsoff(void); |
| 447 // NSPR_API(void) _MD_set_intsoff(PRInt32 _val); |
| 448 // NSPR_API(_PRCPU*) _MD_current_cpu(void); |
| 449 // NSPR_API(void) _MD_set_current_cpu(_PRCPU *cpu); |
| 450 // NSPR_API(void) _MD_init_running_cpu(_PRCPU *cpu); |
| 451 NSPR_API(PRInt32) _MD_pause_cpu(PRIntervalTime timeout); |
| 452 |
| 453 /* Thread stuff */ |
| 454 |
| 455 // NSPR_API(PRThread*) _MD_current_thread(void); |
| 456 NSPR_API(PRThread*) _MD_get_attached_thread(void); |
| 457 NSPR_API(PRThread*) _MD_last_thread(void); |
| 458 NSPR_API(void) _MD_set_current_thread(PRThread *thread); |
| 459 NSPR_API(void) _MD_set_last_thread(PRThread *thread); |
| 460 NSPR_API(PRStatus) _MD_init_thread(PRThread *thread); |
| 461 NSPR_API(void) _MD_exit_thread(PRThread *thread); |
| 462 NSPR_API(PRStatus) _MD_init_attached_thread(PRThread *thread); |
| 463 |
| 464 NSPR_API(void) _MD_suspend_thread(PRThread *thread); |
| 465 NSPR_API(void) _MD_resume_thread(PRThread *thread); |
| 466 // NSPR_API(void) _MD_suspend_cpu(_PRCPU *cpu); |
| 467 // NSPR_API(void) _MD_resume_cpu(_PRCPU *cpu); |
| 468 NSPR_API(void) _MD_begin_suspend_all(void); |
| 469 NSPR_API(void) _MD_end_suspend_all(void); |
| 470 NSPR_API(void) _MD_begin_resume_all(void); |
| 471 NSPR_API(void) _MD_end_resume_all(void); |
| 472 |
| 473 NSPR_API(void *) _MD_get_sp(PRThread *thread); |
| 474 |
| 475 NSPR_API(void) _MD_clean_thread(PRThread *thread); |
| 476 NSPR_API(void) _MD_create_primordial_user_thread(PRThread *); |
| 477 NSPR_API(PRThread*) _MD_create_user_thread(PRUint32 stacksize, void (*start)(voi
d *), void *arg); |
| 478 NSPR_API(void) _MD_init_primordial_thread(PRThread *thread); |
| 479 NSPR_API(PRStatus) _MD_create_thread(PRThread *thread, void (*start)(void *), PR
ThreadPriority priority, PRThreadScope scope, PRThreadState state, PRUint32 stac
kSize); |
| 480 NSPR_API(void) _MD_yield(void); |
| 481 NSPR_API(void) _MD_set_priority(struct _MDThread *md, PRThreadPriority newPri); |
| 482 |
| 483 NSPR_API(void) _MD_suspendall(void); |
| 484 NSPR_API(void) _MD_resumeall(void); |
| 485 |
| 486 NSPR_API(void) _MD_init_context(PRThread *thread, char *top, void (*start) (void
), PRBool *status); |
| 487 NSPR_API(void) _MD_switch_context(PRThread *thread); |
| 488 NSPR_API(void) _MD_restore_context(PRThread *thread); |
| 489 |
| 490 NSPR_API(PRStatus) _MD_wait(PRThread *, PRIntervalTime timeout); |
| 491 NSPR_API(PRStatus) _MD_wakeup_waiter(PRThread *); |
| 492 |
| 493 NSPR_API(PRInt32) _MD_setthreadaffinitymask(PRThread *thread, PRUint32 mask ); |
| 494 NSPR_API(PRInt32) _MD_getthreadaffinitymask(PRThread *thread, PRUint32 *mask); |
| 495 |
| 496 /* Thread Synchronization */ |
| 497 |
| 498 NSPR_API(void) _MD_init_locks(void); |
| 499 NSPR_API(PRStatus) _MD_new_lock(struct _MDLock *md); |
| 500 NSPR_API(void) _MD_free_lock(struct _MDLock *md); |
| 501 NSPR_API(void) _MD_lock(struct _MDLock *md); |
| 502 NSPR_API(PRIntn) _MD_test_and_lock(struct _MDLock *md); |
| 503 NSPR_API(void) _MD_unlock(struct _MDLock *md); |
| 504 NSPR_API(void) _MD_ioq_lock(void); |
| 505 NSPR_API(void) _MD_ioq_unlock(void); |
| 506 NSPR_API(void) _MD_new_sem(struct _MDSemaphore *md, PRUintn value); |
| 507 NSPR_API(void) _MD_destroy_sem(struct _MDSemaphore *md); |
| 508 NSPR_API(PRStatus) _MD_timed_wait_sem(struct _MDSemaphore *md, PRIntervalTime ti
meout); |
| 509 NSPR_API(PRStatus) _MD_wait_sem(struct _MDSemaphore *md); |
| 510 NSPR_API(void) _MD_post_sem(struct _MDSemaphore *md); |
| 511 // NSPR_API(PRInt32) _MD_new_cv(struct _MDCVar *md); |
| 512 // NSPR_API(void) _MD_free_cv(struct _MDCVar *md); |
| 513 // NSPR_API(void) _MD_wait_cv(struct _MDCVar *mdCVar, struct _MDLock *mdLock, PR
IntervalTime timeout); |
| 514 // NSPR_API(void) _MD_notify_cv(struct _MDCVar *md, struct _MDLock *lock); |
| 515 // NSPR_API(void) _MD_notifyall_cv(struct _MDCVar *md, struct _MDLock *lock); |
| 516 |
| 517 /* File I/O */ |
| 518 |
| 519 // NSPR_API(void) _MD_init_io(void); |
| 520 NSPR_API(PRStatus) _MD_open_dir(struct _MDDir *md,const char *name); |
| 521 NSPR_API(char *) _MD_read_dir(struct _MDDir *md, PRIntn flags); |
| 522 NSPR_API(PRInt32) _MD_close_dir(struct _MDDir *md); |
| 523 NSPR_API(void) _MD_make_nonblock(PRFileDesc *fd); |
| 524 NSPR_API(void) _MD_init_fd_inheritable(PRFileDesc *fd, PRBool imported); |
| 525 NSPR_API(void) _MD_query_fd_inheritable(PRFileDesc *fd); |
| 526 NSPR_API(PRInt32) _MD_open(const char *name, PRIntn osflags, PRIntn mode); |
| 527 NSPR_API(PRInt32) _MD_close_file(PRInt32 osfd); |
| 528 NSPR_API(PRInt32) _MD_read(PRFileDesc *fd, void *buf, PRInt32 amount); |
| 529 NSPR_API(PRInt32) _MD_write(PRFileDesc *fd, const void *buf, PRInt32 amount); |
| 530 NSPR_API(PRInt32) _MD_writev(PRFileDesc *fd, const PRIOVec *iov, PRInt32 iov_siz
e, PRIntervalTime timeout); |
| 531 NSPR_API(PRInt32) _MD_lseek(PRFileDesc *fd, PRInt32 offset, int whence); |
| 532 NSPR_API(PRInt64) _MD_lseek64(PRFileDesc *fd, PRInt64 offset, int whence); |
| 533 NSPR_API(PRInt32) _MD_fsync(PRFileDesc *fd); |
| 534 NSPR_API(PRInt32) _MD_delete(const char *name); |
| 535 NSPR_API(PRInt32) _MD_getfileinfo(const char *fn, PRFileInfo *info); |
| 536 NSPR_API(PRInt32) _MD_getfileinfo64(const char *fn, PRFileInfo64 *info); |
| 537 NSPR_API(PRInt32) _MD_getopenfileinfo(const PRFileDesc *fd, PRFileInfo *info); |
| 538 NSPR_API(PRInt32) _MD_getopenfileinfo64(const PRFileDesc *fd, PRFileInfo64 *info
); |
| 539 NSPR_API(PRInt32) _MD_rename(const char *from, const char *to); |
| 540 NSPR_API(PRInt32) _MD_access(const char *name, PRIntn how); |
| 541 NSPR_API(PRInt32) _MD_stat(const char *name, struct stat *buf); |
| 542 NSPR_API(PRInt32) _MD_mkdir(const char *name, PRIntn mode); |
| 543 NSPR_API(PRInt32) _MD_rmdir(const char *name); |
| 544 NSPR_API(PRInt32) _MD_pr_poll(PRPollDesc *pds, PRIntn npds, PRIntervalTime timeo
ut); |
| 545 |
| 546 /* Network I/O */ |
| 547 NSPR_API(PRInt32) _MD_close_socket(PRInt32 osfd); |
| 548 NSPR_API(PRInt32) _MD_connect(PRFileDesc *fd, const PRNetAddr *addr, PRUint32 ad
drlen, PRIntervalTime timeout); |
| 549 NSPR_API(PRInt32) _MD_accept(PRFileDesc *fd, PRNetAddr *addr, PRUint32 *addrlen,
PRIntervalTime timeout); |
| 550 NSPR_API(PRInt32) _MD_bind(PRFileDesc *fd, const PRNetAddr *addr, PRUint32 addrl
en); |
| 551 NSPR_API(PRInt32) _MD_listen(PRFileDesc *fd, PRIntn backlog); |
| 552 NSPR_API(PRInt32) _MD_shutdown(PRFileDesc *fd, PRIntn how); |
| 553 NSPR_API(PRInt32) _MD_recv(PRFileDesc *fd, void *buf, PRInt32 amount, PRIntn fla
gs, PRIntervalTime timeout); |
| 554 NSPR_API(PRInt32) _MD_send(PRFileDesc *fd, const void *buf, PRInt32 amount, PRIn
tn flags, PRIntervalTime timeout); |
| 555 NSPR_API(PRInt32) _MD_accept_read(PRFileDesc *sd, PRInt32 *newSock, PRNetAddr **
raddr, void *buf, PRInt32 amount, PRIntervalTime timeout); |
| 556 // NSPR_API(PRInt32) _MD_fast_accept(PRFileDesc *fd, PRNetAddr *addr, PRUint32 *
addrlen, PRIntervalTime timeout, PRBool fast, _PR_AcceptTimeoutCallback callback
, void *callbackArg); |
| 557 // NSPR_API(PRInt32) _MD_fast_accept_read(PRFileDesc *sd, PRInt32 *newSock, PRNe
tAddr **raddr, void *buf, PRInt32 amount, PRIntervalTime timeout, PRBool fast, _
PR_AcceptTimeoutCallback callback, void *callbackArg); |
| 558 // NSPR_API(void) _MD_update_accept_context(PRInt32 s, PRInt32 ls); |
| 559 NSPR_API(PRStatus) _MD_getsockname(PRFileDesc *fd, PRNetAddr *addr, PRUint32 *ad
drlen); |
| 560 NSPR_API(PRStatus) _MD_getpeername(PRFileDesc *fd, PRNetAddr *addr, PRUint32 *ad
drlen); |
| 561 NSPR_API(PRStatus) _MD_getsockopt(PRFileDesc *fd, PRInt32 level, PRInt32 optname
, char* optval, PRInt32* optlen); |
| 562 NSPR_API(PRStatus) _MD_setsockopt(PRFileDesc *fd, PRInt32 level, PRInt32 optname
, const char* optval, PRInt32 optlen); |
| 563 NSPR_API(PRInt32) _MD_recvfrom(PRFileDesc *fd, void *buf, PRInt32 amount, PRIntn
flags, PRNetAddr *addr, PRUint32 *addrlen, PRIntervalTime timeout); |
| 564 NSPR_API(PRInt32) _MD_sendto(PRFileDesc *fd, const void *buf, PRInt32 amount, PR
Intn flags, const PRNetAddr *addr, PRUint32 addrlen, PRIntervalTime timeout); |
| 565 NSPR_API(PRInt32) _MD_socketpair(int af, int type, int flags, PRInt32 *osfd); |
| 566 NSPR_API(PRInt32) _MD_socket(int af, int type, int flags); |
| 567 NSPR_API(PRInt32) _MD_socketavailable(PRFileDesc *fd); |
| 568 |
| 569 // NSPR_API(PRInt32) _MD_get_socket_error(void); |
| 570 NSPR_API(PRStatus) _MD_gethostname(char *name, PRUint32 namelen); |
| 571 |
| 572 /* Process management */ |
| 573 |
| 574 NSPR_API(PRProcess *) _MD_create_process(const char *path, char *const *argv, ch
ar *const *envp, const PRProcessAttr *attr); |
| 575 NSPR_API(PRStatus) _MD_detach_process(PRProcess *process); |
| 576 NSPR_API(PRStatus) _MD_wait_process(PRProcess *process, PRInt32 *exitCode); |
| 577 NSPR_API(PRStatus) _MD_kill_process(PRProcess *process); |
| 578 |
| 579 /* Atomic data operations */ |
| 580 |
| 581 // NSPR_API(void) _MD_init_atomic(void); |
| 582 // NSPR_API(PRInt32) _MD_atomic_increment(PRInt32 *); |
| 583 // NSPR_API(PRInt32) _MD_atomic_decrement(PRInt32 *); |
| 584 // NSPR_API(PRInt32) _MD_atomic_set(PRInt32 *, PRInt32); |
| 585 |
| 586 /* Memory management */ |
| 587 |
| 588 NSPR_API(void) _MD_init_segs(void); |
| 589 NSPR_API(PRStatus) _MD_alloc_segment(PRSegment *seg, PRUint32 size, void *vaddr)
; |
| 590 NSPR_API(void) _MD_free_segment(PRSegment *seg); |
| 591 |
| 592 /* Memory mapped file I/O */ |
| 593 |
| 594 NSPR_API(PRStatus) _MD_create_file_map(PRFileMap *fmap, PRInt64 size); |
| 595 NSPR_API(PRInt32) _MD_get_mem_map_alignment(void); |
| 596 NSPR_API(void *) _MD_mem_map(PRFileMap *fmap, PRInt64 offset, PRUint32 len); |
| 597 NSPR_API(PRStatus) _MD_mem_unmap(void *addr, PRUint32 size); |
| 598 NSPR_API(PRStatus) _MD_close_file_map(PRFileMap *fmap); |
| 599 |
| 600 /* Time related */ |
| 601 |
| 602 NSPR_API(PRTime) _MD_now(void); |
| 603 NSPR_API(void) _MD_interval_init(void); |
| 604 NSPR_API(PRIntervalTime) _MD_get_interval(void); |
| 605 NSPR_API(PRIntervalTime) _MD_interval_per_sec(void); |
| 606 |
| 607 /* File locking */ |
| 608 |
| 609 NSPR_API(PRStatus) _MD_lockfile(PRInt32 osfd); |
| 610 NSPR_API(PRStatus) _MD_tlockfile(PRInt32 osfd); |
| 611 NSPR_API(PRStatus) _MD_unlockfile(PRInt32 osfd); |
| 612 |
| 613 #endif /* _nspr_beos_defs_h___*/ |
OLD | NEW |