| OLD | NEW |
| (Empty) |
| 1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ | |
| 2 /* | |
| 3 * The contents of this file are subject to the Mozilla Public | |
| 4 * License Version 1.1 (the "License"); you may not use this file | |
| 5 * except in compliance with the License. You may obtain a copy of | |
| 6 * the License at http://www.mozilla.org/MPL/ | |
| 7 * | |
| 8 * Software distributed under the License is distributed on an "AS | |
| 9 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or | |
| 10 * implied. See the License for the specific language governing | |
| 11 * rights and limitations under the License. | |
| 12 * | |
| 13 * The Original Code is the Netscape Portable Runtime (NSPR). | |
| 14 * | |
| 15 * The Initial Developer of the Original Code is Netscape | |
| 16 * Communications Corporation. Portions created by Netscape are | |
| 17 * Copyright (C) 1998-2000 Netscape Communications Corporation. All | |
| 18 * Rights Reserved. | |
| 19 * | |
| 20 * Contributor(s): | |
| 21 * | |
| 22 * Alternatively, the contents of this file may be used under the | |
| 23 * terms of the GNU General Public License Version 2 or later (the | |
| 24 * "GPL"), in which case the provisions of the GPL are applicable | |
| 25 * instead of those above. If you wish to allow use of your | |
| 26 * version of this file only under the terms of the GPL and not to | |
| 27 * allow others to use your version of this file under the MPL, | |
| 28 * indicate your decision by deleting the provisions above and | |
| 29 * replace them with the notice and other provisions required by | |
| 30 * the GPL. If you do not delete the provisions above, a recipient | |
| 31 * may use your version of this file under either the MPL or the | |
| 32 * GPL. | |
| 33 */ | |
| 34 | |
| 35 #ifndef nspr_win16_defs_h___ | |
| 36 #define nspr_win16_defs_h___ | |
| 37 | |
| 38 #include <windows.h> | |
| 39 #include <winsock.h> | |
| 40 #include <errno.h> | |
| 41 #include <direct.h> | |
| 42 | |
| 43 #include "nspr.h" | |
| 44 /* $$ fix this */ | |
| 45 #define Remind(x) | |
| 46 | |
| 47 /* | |
| 48 * Internal configuration macros | |
| 49 */ | |
| 50 | |
| 51 #define PR_LINKER_ARCH "win16" | |
| 52 #define _PR_SI_SYSNAME "WIN16" | |
| 53 #define _PR_SI_ARCHITECTURE "x86" /* XXXMB hardcode for now */ | |
| 54 | |
| 55 #define HAVE_DLL | |
| 56 #define _PR_NO_PREEMPT | |
| 57 #define _PR_LOCAL_THREADS_ONLY | |
| 58 #undef _PR_GLOBAL_THREADS_ONLY | |
| 59 #undef HAVE_THREAD_AFFINITY | |
| 60 #define _PR_HAVE_ATOMIC_OPS | |
| 61 | |
| 62 /* --- Common User-Thread/Native-Thread Definitions --------------------- */ | |
| 63 | |
| 64 extern struct PRLock *_pr_schedLock; | |
| 65 extern char * _pr_top_of_task_stack; | |
| 66 | |
| 67 | |
| 68 /* --- Typedefs --- */ | |
| 69 | |
| 70 #define PR_NUM_GCREGS 9 | |
| 71 typedef PRInt32 PR_CONTEXT_TYPE[PR_NUM_GCREGS]; | |
| 72 | |
| 73 #define _MD_MAGIC_THREAD 0x22222222 | |
| 74 #define _MD_MAGIC_THREADSTACK 0x33333333 | |
| 75 #define _MD_MAGIC_SEGMENT 0x44444444 | |
| 76 #define _MD_MAGIC_DIR 0x55555555 | |
| 77 #define _MD_MAGIC_CV 0x66666666 | |
| 78 | |
| 79 | |
| 80 typedef struct _PRWin16PollDesc | |
| 81 { | |
| 82 PRInt32 osfd; | |
| 83 PRInt16 in_flags; | |
| 84 PRInt16 out_flags; | |
| 85 } _PRWin16PollDesc; | |
| 86 | |
| 87 typedef struct PRPollQueue | |
| 88 { | |
| 89 PRCList links; /* for linking PRPollQueue's together */ | |
| 90 _PRWin16PollDesc *pds; /* array of poll descriptors */ | |
| 91 PRUintn npds; /* length of the array */ | |
| 92 PRPackedBool on_ioq; /* is this on the async i/o work q? */ | |
| 93 PRIntervalTime timeout; /* timeout, in ticks */ | |
| 94 struct PRThread *thr; | |
| 95 } PRPollQueue; | |
| 96 | |
| 97 #define _PR_POLLQUEUE_PTR(_qp) \ | |
| 98 ((PRPollQueue *) ((char*) (_qp) - offsetof(PRPollQueue,links))) | |
| 99 | |
| 100 NSPR_API(PRInt32) _PR_WaitForFD(PRInt32 osfd, PRUintn how, | |
| 101 PRIntervalTime timeout); | |
| 102 NSPR_API(void) _PR_Unblock_IO_Wait(struct PRThread *thr); | |
| 103 | |
| 104 #define _PR_MD_MAX_OSFD FD_SETSIZE | |
| 105 #define _PR_IOQ(_cpu) ((_cpu)->md.ioQ) | |
| 106 #define _PR_ADD_TO_IOQ(_pq, _cpu) PR_APPEND_LINK(&_pq.links, &_PR_IOQ(_cpu
)) | |
| 107 #define _PR_FD_READ_SET(_cpu) ((_cpu)->md.fd_read_set) | |
| 108 #define _PR_FD_READ_CNT(_cpu) ((_cpu)->md.fd_read_cnt) | |
| 109 #define _PR_FD_WRITE_SET(_cpu) ((_cpu)->md.fd_write_set) | |
| 110 #define _PR_FD_WRITE_CNT(_cpu) ((_cpu)->md.fd_write_cnt) | |
| 111 #define _PR_FD_EXCEPTION_SET(_cpu) ((_cpu)->md.fd_exception_set) | |
| 112 #define _PR_FD_EXCEPTION_CNT(_cpu) ((_cpu)->md.fd_exception_cnt) | |
| 113 #define _PR_IOQ_TIMEOUT(_cpu) ((_cpu)->md.ioq_timeout) | |
| 114 #define _PR_IOQ_MAX_OSFD(_cpu) ((_cpu)->md.ioq_max_osfd) | |
| 115 | |
| 116 struct _MDCPU { | |
| 117 PRCList ioQ; | |
| 118 fd_set fd_read_set, fd_write_set, fd_exception_set; | |
| 119 PRInt16 fd_read_cnt[_PR_MD_MAX_OSFD],fd_write_cnt[_PR_MD_MAX_OSF
D], | |
| 120 fd_exception_cnt[_PR_MD_MAX_OSFD]; | |
| 121 PRUint32 ioq_timeout; | |
| 122 PRInt32 ioq_max_osfd; | |
| 123 }; | |
| 124 | |
| 125 struct _MDThread { | |
| 126 /* The overlapped structure must be first! */ | |
| 127 HANDLE blocked_sema; /* Threads block on this when waiting | |
| 128 * for IO or CondVar. | |
| 129 */ | |
| 130 PRInt32 errcode; /* preserved errno for this thread */ | |
| 131 CATCHBUF context; /* thread context for Throw() */ | |
| 132 void *SP; /* Stack pointer, used only by GarbColl */ | |
| 133 int threadNumber; /* instrumentation: order of creation */ | |
| 134 _PRWin16PollDesc thr_pd; /* poll descriptor for i/o */ | |
| 135 PRPollQueue thr_pq; /* i/o parameters
*/ | |
| 136 void *exceptionContext; /* mfc exception context */ | |
| 137 char guardBand[24]; /* don't overwrite this */ | |
| 138 PRUint32 magic; /* self identifier, for debug */ | |
| 139 }; | |
| 140 | |
| 141 struct _MDThreadStack { | |
| 142 PRUint32 magic; /* for debugging */ | |
| 143 PRIntn cxByteCount; /* number of stack bytes to move */ | |
| 144 char * stackTop; /* high address on stack */ | |
| 145 }; | |
| 146 | |
| 147 struct _MDSegment { | |
| 148 PRUint32 magic; /* for debugging */ | |
| 149 }; | |
| 150 | |
| 151 | |
| 152 struct _MDLock { | |
| 153 PRUint32 magic; /* for debugging */ | |
| 154 PRUint32 mutex; | |
| 155 }; | |
| 156 | |
| 157 struct _MDDir { | |
| 158 PRUint32 magic; /* for debugging */ | |
| 159 struct dirent *dir; | |
| 160 }; | |
| 161 | |
| 162 struct _MDCVar { | |
| 163 PRUint32 magic; | |
| 164 }; | |
| 165 | |
| 166 struct _MDSemaphore { | |
| 167 PRInt32 unused; | |
| 168 }; | |
| 169 | |
| 170 struct _MDFileDesc { | |
| 171 PRInt32 osfd; | |
| 172 }; | |
| 173 | |
| 174 struct _MDProcess { | |
| 175 HANDLE handle; | |
| 176 DWORD id; | |
| 177 }; | |
| 178 | |
| 179 /* | |
| 180 ** Microsoft 'struct _stat' | |
| 181 ** ... taken directly from msvc 1.52c's header file sys/stat.h | |
| 182 ** see PR_Stat() implemented in w16io.c | |
| 183 ** See BugSplat: 98516 | |
| 184 */ | |
| 185 #pragma pack(push) | |
| 186 #pragma pack(2) | |
| 187 | |
| 188 typedef unsigned short _ino_t; | |
| 189 typedef short _dev_t; | |
| 190 typedef long _off_t; | |
| 191 | |
| 192 typedef struct _MDMSStat { | |
| 193 _dev_t st_dev; | |
| 194 _ino_t st_ino; | |
| 195 unsigned short st_mode; | |
| 196 short st_nlink; | |
| 197 short st_uid; | |
| 198 short st_gid; | |
| 199 _dev_t st_rdev; | |
| 200 _off_t st_size; | |
| 201 time_t st_atime; | |
| 202 time_t st_mtime; | |
| 203 time_t st_ctime; | |
| 204 } _MDMSStat; | |
| 205 #pragma pack(pop) | |
| 206 | |
| 207 /* --- Errors --- */ | |
| 208 /* These are NSPR generated error codes which need to be unique from | |
| 209 * OS error codes. | |
| 210 */ | |
| 211 #define _MD_UNIQUEBASE 50000 | |
| 212 #define _MD_EINTERRUPTED _MD_UNIQUEBASE + 1 | |
| 213 #define _MD_ETIMEDOUT _MD_UNIQUEBASE + 2 | |
| 214 #define _MD_EIO _MD_UNIQUEBASE + 3 | |
| 215 | |
| 216 struct PRProcess; | |
| 217 struct PRProcessAttr; | |
| 218 | |
| 219 /* --- Create a new process --- */ | |
| 220 #define _MD_CREATE_PROCESS _PR_CreateWindowsProcess | |
| 221 extern struct PRProcess * _PR_CreateWindowsProcess( | |
| 222 const char *path, | |
| 223 char *const *argv, | |
| 224 char *const *envp, | |
| 225 const struct PRProcessAttr *attr | |
| 226 ); | |
| 227 | |
| 228 #define _MD_DETACH_PROCESS _PR_DetachWindowsProcess | |
| 229 extern PRStatus _PR_DetachWindowsProcess(struct PRProcess *process); | |
| 230 | |
| 231 /* --- Wait for a child process to terminate --- */ | |
| 232 #define _MD_WAIT_PROCESS _PR_WaitWindowsProcess | |
| 233 extern PRStatus _PR_WaitWindowsProcess(struct PRProcess *process, | |
| 234 PRInt32 *exitCode); | |
| 235 | |
| 236 #define _MD_KILL_PROCESS _PR_KillWindowsProcess | |
| 237 extern PRStatus _PR_KillWindowsProcess(struct PRProcess *process); | |
| 238 | |
| 239 | |
| 240 /* --- Misc stuff --- */ | |
| 241 | |
| 242 #define MD_ASSERTINT( x ) PR_ASSERT( (x) < 65535 ) | |
| 243 | |
| 244 /* --- IO stuff --- */ | |
| 245 #define MAX_PATH 256 | |
| 246 #define _MD_ERRNO() errno | |
| 247 #define GetLastError() errno | |
| 248 | |
| 249 #define _MD_GET_FILE_ERROR() errno | |
| 250 #define _MD_SET_FILE_ERROR(_err) errno = (_err) | |
| 251 | |
| 252 #define _MD_OPEN _PR_MD_OPEN | |
| 253 #define _MD_READ _PR_MD_READ | |
| 254 #define _MD_WRITE _PR_MD_WRITE | |
| 255 #define _MD_WRITEV _PR_MD_WRITEV | |
| 256 #define _MD_LSEEK _PR_MD_LSEEK | |
| 257 #define _MD_LSEEK64 _PR_MD_LSEEK64 | |
| 258 #define _MD_CLOSE_FILE _PR_MD_CLOSE_FILE | |
| 259 #define _MD_GETFILEINFO _PR_MD_GETFILEINFO | |
| 260 #define _MD_GETOPENFILEINFO _PR_MD_GETOPENFILEINFO | |
| 261 #define _MD_STAT _PR_MD_STAT | |
| 262 #define _MD_RENAME _PR_MD_RENAME | |
| 263 #define _MD_ACCESS _PR_MD_ACCESS | |
| 264 #define _MD_DELETE _PR_MD_DELETE | |
| 265 #define _MD_MKDIR _PR_MD_MKDIR | |
| 266 #define _MD_RMDIR _PR_MD_RMDIR | |
| 267 #define _MD_LOCKFILE _PR_MD_LOCKFILE | |
| 268 #define _MD_TLOCKFILE _PR_MD_TLOCKFILE | |
| 269 #define _MD_UNLOCKFILE _PR_MD_UNLOCKFILE | |
| 270 | |
| 271 | |
| 272 /* --- Socket IO stuff --- */ | |
| 273 #define _MD_EACCES WSAEACCES | |
| 274 #define _MD_EADDRINUSE WSAEADDRINUSE | |
| 275 #define _MD_EADDRNOTAVAIL WSAEADDRNOTAVAIL | |
| 276 #define _MD_EAFNOSUPPORT WSAEAFNOSUPPORT | |
| 277 #define _MD_EAGAIN WSAEWOULDBLOCK | |
| 278 #define _MD_EALREADY WSAEALREADY | |
| 279 #define _MD_EBADF WSAEBADF | |
| 280 #define _MD_ECONNREFUSED WSAECONNREFUSED | |
| 281 #define _MD_ECONNRESET WSAECONNRESET | |
| 282 #define _MD_EFAULT WSAEFAULT | |
| 283 #define _MD_EINPROGRESS WSAEINPROGRESS | |
| 284 #define _MD_EINTR WSAEINTR | |
| 285 #define _MD_EINVAL EINVAL | |
| 286 #define _MD_EISCONN WSAEISCONN | |
| 287 #define _MD_ENETUNREACH WSAENETUNREACH | |
| 288 #define _MD_ENOENT ENOENT | |
| 289 #define _MD_ENOTCONN WSAENOTCONN | |
| 290 #define _MD_ENOTSOCK WSAENOTSOCK | |
| 291 #define _MD_EOPNOTSUPP WSAEOPNOTSUPP | |
| 292 #define _MD_EWOULDBLOCK WSAEWOULDBLOCK | |
| 293 #define _MD_GET_SOCKET_ERROR() WSAGetLastError() | |
| 294 #define _MD_SET_SOCKET_ERROR(_err) WSASetLastError(_err) | |
| 295 | |
| 296 #define _MD_INIT_FILEDESC(fd) | |
| 297 #define _MD_MAKE_NONBLOCK _PR_MD_MAKE_NONBLOCK | |
| 298 #define _MD_SHUTDOWN _PR_MD_SHUTDOWN | |
| 299 #define _MD_LISTEN _PR_MD_LISTEN | |
| 300 #define _MD_CLOSE_SOCKET _PR_MD_CLOSE_SOCKET | |
| 301 #define _MD_SENDTO _PR_MD_SENDTO | |
| 302 #define _MD_RECVFROM _PR_MD_RECVFROM | |
| 303 #define _MD_SOCKETPAIR(s, type, proto, sv) -1 | |
| 304 #define _MD_GETSOCKNAME _PR_MD_GETSOCKNAME | |
| 305 #define _MD_GETPEERNAME _PR_MD_GETPEERNAME | |
| 306 #define _MD_GETSOCKOPT _PR_MD_GETSOCKOPT | |
| 307 #define _MD_SETSOCKOPT _PR_MD_SETSOCKOPT | |
| 308 #define _MD_SELECT select | |
| 309 #define _MD_FSYNC _PR_MD_FSYNC | |
| 310 #define _MD_SOCKETAVAILABLE _PR_MD_SOCKETAVAILABLE | |
| 311 | |
| 312 #define _MD_INIT_ATOMIC() | |
| 313 #define _MD_ATOMIC_INCREMENT(x) (*x++) | |
| 314 #define _MD_ATOMIC_ADD(ptr, val) ((*x) += val) | |
| 315 #define _MD_ATOMIC_DECREMENT(x) (*x--) | |
| 316 #define _MD_ATOMIC_SET(x,y) (*x, y) | |
| 317 | |
| 318 #define _MD_INIT_IO _PR_MD_INIT_IO | |
| 319 | |
| 320 /* win95 doesn't have async IO */ | |
| 321 #define _MD_SOCKET _PR_MD_SOCKET | |
| 322 #define _MD_CONNECT _PR_MD_CONNECT | |
| 323 #define _MD_ACCEPT _PR_MD_ACCEPT | |
| 324 #define _MD_BIND _PR_MD_BIND | |
| 325 #define _MD_RECV _PR_MD_RECV | |
| 326 #define _MD_SEND _PR_MD_SEND | |
| 327 | |
| 328 #define _MD_CHECK_FOR_EXIT() | |
| 329 | |
| 330 /* --- Scheduler stuff --- */ | |
| 331 #define _MD_PAUSE_CPU _PR_MD_PAUSE_CPU | |
| 332 | |
| 333 /* --- DIR stuff --- */ | |
| 334 #define PR_DIRECTORY_SEPARATOR '\\' | |
| 335 #define PR_DIRECTORY_SEPARATOR_STR "\\" | |
| 336 #define PR_PATH_SEPARATOR ';' | |
| 337 #define PR_PATH_SEPARATOR_STR ";" | |
| 338 #define _MD_OPEN_DIR _PR_MD_OPEN_DIR | |
| 339 #define _MD_CLOSE_DIR _PR_MD_CLOSE_DIR | |
| 340 #define _MD_READ_DIR _PR_MD_READ_DIR | |
| 341 | |
| 342 /* --- Segment stuff --- */ | |
| 343 #define _MD_INIT_SEGS() | |
| 344 #define _MD_ALLOC_SEGMENT _MD_AllocSegment | |
| 345 #define _MD_FREE_SEGMENT _MD_FreeSegment | |
| 346 | |
| 347 /* --- Environment Stuff --- */ | |
| 348 #define _MD_GET_ENV _PR_MD_GET_ENV | |
| 349 #define _MD_PUT_ENV _PR_MD_PUT_ENV | |
| 350 | |
| 351 /* --- Threading Stuff --- */ | |
| 352 #define _MD_DEFAULT_STACK_SIZE 32767L | |
| 353 #define _MD_INIT_THREAD _PR_MD_INIT_THREAD | |
| 354 #define _MD_CREATE_THREAD(t,f,p,sc,st,stsiz) (PR_SUCCESS) | |
| 355 #define _MD_YIELD _PR_MD_YIELD | |
| 356 #define _MD_SET_PRIORITY(t,p) | |
| 357 #define _MD_CLEAN_THREAD(t) | |
| 358 #define _MD_SETTHREADAFFINITYMASK _PR_MD_SETTHREADAFFINITYMASK | |
| 359 #define _MD_GETTHREADAFFINITYMASK _PR_MD_GETTHREADAFFINITYMASK | |
| 360 #define _MD_EXIT_THREAD | |
| 361 #define _MD_SUSPEND_THREAD _PR_MD_SUSPEND_THREAD | |
| 362 #define _MD_RESUME_THREAD _PR_MD_RESUME_THREAD | |
| 363 #define _MD_SUSPEND_CPU _PR_MD_SUSPEND_CPU | |
| 364 #define _MD_RESUME_CPU _PR_MD_RESUME_CPU | |
| 365 #define _MD_BEGIN_SUSPEND_ALL() | |
| 366 #define _MD_BEGIN_RESUME_ALL() | |
| 367 #define _MD_END_SUSPEND_ALL() | |
| 368 #define _MD_END_RESUME_ALL() | |
| 369 | |
| 370 /* --- Lock stuff --- */ | |
| 371 /* | |
| 372 ** Win16 does not need MD locks. | |
| 373 */ | |
| 374 #define _PR_LOCK _MD_LOCK | |
| 375 #define _PR_UNLOCK _MD_UNLOCK | |
| 376 | |
| 377 #define _MD_NEW_LOCK(l) (PR_SUCCESS) | |
| 378 #define _MD_FREE_LOCK(l) | |
| 379 #define _MD_LOCK(l) | |
| 380 #define _MD_TEST_AND_LOCK(l) (-1) | |
| 381 #define _MD_UNLOCK(l) | |
| 382 | |
| 383 /* --- lock and cv waiting --- */ | |
| 384 #define _MD_WAIT _PR_MD_WAIT | |
| 385 #define _MD_WAKEUP_WAITER(a) | |
| 386 #define _MD_WAKEUP_CPUS _PR_MD_WAKEUP_CPUS | |
| 387 | |
| 388 /* --- CVar ------------------- */ | |
| 389 #define _MD_WAIT_CV _PR_MD_WAIT_CV | |
| 390 #define _MD_NEW_CV _PR_MD_NEW_CV | |
| 391 #define _MD_FREE_CV _PR_MD_FREE_CV | |
| 392 #define _MD_NOTIFY_CV _PR_MD_NOTIFY_CV | |
| 393 #define _MD_NOTIFYALL_CV _PR_MD_NOTIFYALL_CV | |
| 394 | |
| 395 /* XXXMB- the IOQ stuff is certainly not working correctly yet. */ | |
| 396 #define _MD_IOQ_LOCK() | |
| 397 #define _MD_IOQ_UNLOCK() | |
| 398 | |
| 399 | |
| 400 /* --- Initialization stuff --- */ | |
| 401 NSPR_API(void) _MD_INIT_RUNNING_CPU(struct _PRCPU *cpu ); | |
| 402 #define _MD_START_INTERRUPTS() | |
| 403 #define _MD_STOP_INTERRUPTS() | |
| 404 #define _MD_DISABLE_CLOCK_INTERRUPTS() | |
| 405 #define _MD_ENABLE_CLOCK_INTERRUPTS() | |
| 406 #define _MD_BLOCK_CLOCK_INTERRUPTS() | |
| 407 #define _MD_UNBLOCK_CLOCK_INTERRUPTS() | |
| 408 #define _MD_EARLY_INIT _PR_MD_EARLY_INIT | |
| 409 #define _MD_FINAL_INIT _PR_MD_FINAL_INIT | |
| 410 #define _MD_INIT_CPUS() | |
| 411 | |
| 412 /* --- User Threading stuff --- */ | |
| 413 #define _MD_EXIT | |
| 414 | |
| 415 #define _MD_CLEANUP_BEFORE_EXIT _PR_MD_CLEANUP_BEFORE_EXIT | |
| 416 | |
| 417 /* --- Intervals --- */ | |
| 418 #define _MD_INTERVAL_INIT _PR_MD_INTERVAL_INIT | |
| 419 #define _MD_GET_INTERVAL _PR_MD_GET_INTERVAL | |
| 420 #define _MD_INTERVAL_PER_SEC _PR_MD_INTERVAL_PER_SEC | |
| 421 #define _MD_INTERVAL_PER_MILLISEC() (_PR_MD_INTERVAL_PER_SEC() / 1000) | |
| 422 #define _MD_INTERVAL_PER_MICROSEC() (_PR_MD_INTERVAL_PER_SEC() / 1000000) | |
| 423 | |
| 424 /* --- Scheduler stuff --- */ | |
| 425 #define LOCK_SCHEDULER() 0 | |
| 426 #define UNLOCK_SCHEDULER() 0 | |
| 427 #define _PR_LockSched() 0 | |
| 428 #define _PR_UnlockSched() 0 | |
| 429 | |
| 430 /* --- Initialization stuff --- */ | |
| 431 #define _MD_INIT_LOCKS() | |
| 432 | |
| 433 /* --- Stack stuff --- */ | |
| 434 #define _MD_INIT_STACK _PR_MD_INIT_STACK | |
| 435 #define _MD_CLEAR_STACK(stack) | |
| 436 | |
| 437 /* | |
| 438 ** Watcom needs to see this to make the linker work. | |
| 439 ** | |
| 440 */ | |
| 441 NSPR_API(void) _PR_NativeDestroyThread(PRThread *thread); | |
| 442 NSPR_API(void) _PR_UserDestroyThread(PRThread *thread); | |
| 443 | |
| 444 | |
| 445 /* | |
| 446 ** If thread emulation is used, then setjmp/longjmp stores the register | |
| 447 ** state of each thread. | |
| 448 ** | |
| 449 ** CatchBuf layout: | |
| 450 ** context[0] - IP | |
| 451 ** context[1] - CS | |
| 452 ** context[2] - SP | |
| 453 ** context[3] - BP | |
| 454 ** context[4] - SI | |
| 455 ** context[5] - DI | |
| 456 ** context[6] - DS | |
| 457 ** context[7] - ?? (maybe flags) | |
| 458 ** context[8] - SS | |
| 459 */ | |
| 460 #define PR_CONTEXT_TYPE CATCHBUF | |
| 461 #define PR_NUM_GCREGS 9 | |
| 462 | |
| 463 #define _MD_GET_SP(thread) ((thread)->md.SP) | |
| 464 #define CONTEXT(_t) ((_t)->md.context) | |
| 465 | |
| 466 /* | |
| 467 ** Initialize a thread context to run "e(o,a)" when started | |
| 468 */ | |
| 469 #define _MD_INIT_CONTEXT(_t, sp, epa, stat ) \ | |
| 470 { \ | |
| 471 *(stat) = PR_TRUE; \ | |
| 472 Catch((_t)->md.context ); \ | |
| 473 (_t)->md.context[0] = OFFSETOF(epa); \ | |
| 474 (_t)->md.context[1] = SELECTOROF(epa); \ | |
| 475 (_t)->md.context[2] = OFFSETOF(_pr_top_of_task_stack - 64); \ | |
| 476 (_t)->md.context[3] = 0; \ | |
| 477 } | |
| 478 | |
| 479 #define _MD_SWITCH_CONTEXT(_t) \ | |
| 480 if (!Catch((_t)->md.context)) { \ | |
| 481 int garbCollPlaceHolder; \ | |
| 482 (_t)->md.errcode = errno; \ | |
| 483 (_t)->md.SP = &garbCollPlaceHolder; \ | |
| 484 _PR_Schedule(); \ | |
| 485 } | |
| 486 | |
| 487 #define _MD_SAVE_CONTEXT(_t) \ | |
| 488 { \ | |
| 489 int garbCollPlaceHolder; \ | |
| 490 Catch((_t)->md.context); \ | |
| 491 (_t)->md.errcode = errno; \ | |
| 492 (_t)->md.SP = &garbCollPlaceHolder; \ | |
| 493 } | |
| 494 | |
| 495 /* | |
| 496 ** Restore a thread context, saved by _MD_SWITCH_CONTEXT | |
| 497 */ | |
| 498 #define _PR_MD_RESTORE_CONTEXT _MD_RESTORE_CONTEXT | |
| 499 | |
| 500 /* | |
| 501 * Memory-mapped files | |
| 502 */ | |
| 503 | |
| 504 struct _MDFileMap { | |
| 505 PRInt8 unused; | |
| 506 }; | |
| 507 | |
| 508 extern PRStatus _MD_CreateFileMap(struct PRFileMap *fmap, PRInt64 size); | |
| 509 #define _MD_CREATE_FILE_MAP _MD_CreateFileMap | |
| 510 | |
| 511 extern PRInt32 _MD_GetMemMapAlignment(void); | |
| 512 #define _MD_GET_MEM_MAP_ALIGNMENT _MD_GetMemMapAlignment | |
| 513 | |
| 514 extern void * _MD_MemMap(struct PRFileMap *fmap, PRInt64 offset, | |
| 515 PRUint32 len); | |
| 516 #define _MD_MEM_MAP _MD_MemMap | |
| 517 | |
| 518 extern PRStatus _MD_MemUnmap(void *addr, PRUint32 size); | |
| 519 #define _MD_MEM_UNMAP _MD_MemUnmap | |
| 520 | |
| 521 extern PRStatus _MD_CloseFileMap(struct PRFileMap *fmap); | |
| 522 #define _MD_CLOSE_FILE_MAP _MD_CloseFileMap | |
| 523 | |
| 524 | |
| 525 /* --- Error mapping ----------------------------------- */ | |
| 526 extern void _PR_MD_map_error( int err ); | |
| 527 | |
| 528 #define _PR_MD_MAP_OPENDIR_ERROR _PR_MD_map_error | |
| 529 #define _PR_MD_MAP_CLOSEDIR_ERROR _PR_MD_map_error | |
| 530 #define _PR_MD_MAP_READDIR_ERROR _PR_MD_map_error | |
| 531 #define _PR_MD_MAP_DELETE_ERROR _PR_MD_map_error | |
| 532 #define _PR_MD_MAP_STAT_ERROR _PR_MD_map_error | |
| 533 #define _PR_MD_MAP_FSTAT_ERROR _PR_MD_map_error | |
| 534 #define _PR_MD_MAP_RENAME_ERROR _PR_MD_map_error | |
| 535 #define _PR_MD_MAP_ACCESS_ERROR _PR_MD_map_error | |
| 536 #define _PR_MD_MAP_MKDIR_ERROR _PR_MD_map_error | |
| 537 #define _PR_MD_MAP_RMDIR_ERROR _PR_MD_map_error | |
| 538 #define _PR_MD_MAP_READ_ERROR _PR_MD_map_error | |
| 539 #define _PR_MD_MAP_TRANSMITFILE_ERROR _PR_MD_map_error | |
| 540 #define _PR_MD_MAP_WRITE_ERROR _PR_MD_map_error | |
| 541 #define _PR_MD_MAP_LSEEK_ERROR _PR_MD_map_error | |
| 542 #define _PR_MD_MAP_FSYNC_ERROR _PR_MD_map_error | |
| 543 #define _PR_MD_MAP_CLOSE_ERROR _PR_MD_map_error | |
| 544 #define _PR_MD_MAP_SOCKET_ERROR _PR_MD_map_error | |
| 545 #define _PR_MD_MAP_RECV_ERROR _PR_MD_map_error | |
| 546 #define _PR_MD_MAP_RECVFROM_ERROR _PR_MD_map_error | |
| 547 #define _PR_MD_MAP_SEND_ERROR _PR_MD_map_error | |
| 548 #define _PR_MD_MAP_SENDTO_ERROR _PR_MD_map_error | |
| 549 #define _PR_MD_MAP_ACCEPT_ERROR _PR_MD_map_error | |
| 550 #define _PR_MD_MAP_ACCEPTEX_ERROR _PR_MD_map_error | |
| 551 #define _PR_MD_MAP_CONNECT_ERROR _PR_MD_map_error | |
| 552 #define _PR_MD_MAP_BIND_ERROR _PR_MD_map_error | |
| 553 #define _PR_MD_MAP_LISTEN_ERROR _PR_MD_map_error | |
| 554 #define _PR_MD_MAP_SHUTDOWN_ERROR _PR_MD_map_error | |
| 555 #define _PR_MD_MAP_GETSOCKNAME_ERROR _PR_MD_map_error | |
| 556 #define _PR_MD_MAP_GETPEERNAME_ERROR _PR_MD_map_error | |
| 557 #define _PR_MD_MAP_GETSOCKOPT_ERROR _PR_MD_map_error | |
| 558 #define _PR_MD_MAP_SETSOCKOPT_ERROR _PR_MD_map_error | |
| 559 #define _PR_MD_MAP_OPEN_ERROR _PR_MD_map_error | |
| 560 #define _PR_MD_MAP_GETHOSTNAME_ERROR _PR_MD_map_error | |
| 561 #define _PR_MD_MAP_SELECT_ERROR _PR_MD_map_error | |
| 562 #define _PR_MD_MAP_LOCKF_ERROR _PR_MD_map_error | |
| 563 #define _PR_MD_MAP_WSASTARTUP_ERROR _PR_MD_map_error | |
| 564 | |
| 565 #endif /* nspr_win16_defs_h___ */ | |
| OLD | NEW |