import gdb-2000-01-10 snapshot
[deliverable/binutils-gdb.git] / gdb / config / i386 / tm-i386v42mp.h
index 29c4ba0495ede2f712ecae6b70841c520a4cc782..40d1c129a36b5c123be511b19236fa585965fb7a 100644 (file)
 
 #include "i386/tm-i386v4.h"
 
-/* procfs on this architecture has multiple fds (ctl, as, map, status)
-   including a control fd */
+/* define to select for other sysv4.2mp weirdness (see procfs.c) */
 
-#ifndef HAVE_MULTIPLE_PROC_FDS
-#define HAVE_MULTIPLE_PROC_FDS
-#endif
+#define UNIXWARE
 
-/* procfs on this architecture communicates with read/write instead
-   of ioctl */
+/* The following macros extract process and lwp/thread ids from a
+   composite id.
 
-#define PROCFS_USE_READ_WRITE
+   For consistency with UnixWare core files, allocate bits 0-15 for
+   process ids and bits 16 and up for lwp ids.  Reserve bit 31 for
+   negative return values to indicate exceptions, and use bit 30 as a
+   flag to indicate a user-mode thread, leaving 14 bits for lwp
+   ids. */
 
-/* define to select for other sysv4.2mp weirdness */
+/* Number of bits in composite id allocated to process number. */
+#define PIDBITS 16
 
-#define UNIXWARE
+/* Return the process id stored in composite PID. */
+#define PIDGET(PID)             (((PID) & ((1 << PIDBITS) - 1)))
+
+/* Return the thread or lwp id stored in composite PID. */
+#define TIDGET(PID)             (((PID) & 0x3fffffff) >> PIDBITS)
+#define LIDGET(PID)             TIDGET(PID)
+
+/* Construct a composite id from lwp LID and the process portion of
+   composite PID. */
+#define MERGEPID(PID, LID)      (PIDGET(PID) | ((LID) << PIDBITS))
+#define MKLID(PID, LID)         MERGEPID(PID, LID)
+
+/* Construct a composite id from thread TID and the process portion of
+   composite PID. */
+#define MKTID(PID, TID)         (MERGEPID(PID, TID) | 0x40000000)
+
+/* Return whether PID contains a user-space thread id. */
+#define ISTID(PID)              ((PID) & 0x40000000)
 
 #endif /* ifndef TM_I386V42MP_H */
This page took 0.024053 seconds and 4 git commands to generate.