Irix support
[dyninst.git] / common / h / irixHeaders.h
1 /*
2  * Copyright (c) 1998 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42 #if !defined(_irix_headers_h)
43 #define _irix_headers_h
44
45 #include <assert.h>
46 #include <stdio.h>
47 #include <string.h>
48 #include <stdlib.h>
49 #include <errno.h>
50 #include <assert.h>
51 #include <fcntl.h>
52 #include <netinet/in.h>
53 #include <netdb.h>
54 #include <sys/types.h>
55 #include <sys/mman.h>
56 #include <sys/time.h>
57 #include <unistd.h>
58 #include <sys/file.h>
59 #include <sys/socket.h>
60 #include <sys/errno.h>
61 #include <sys/wait.h>
62 #include <signal.h>
63 #include <sys/ptrace.h>
64 #include <sys/time.h>
65 #include <sys/resource.h>
66 #include <stdarg.h>
67 #include <time.h>
68 #include <sys/utsname.h>
69 #include <sys/stat.h>
70 #include <sys/un.h>
71
72 #include <rpc/types.h>
73 #include <rpc/xdr.h>
74
75 #include <strstream.h>
76
77 /* unprototyped system calls */
78 #if defined(__cplusplus)
79 extern "C" {
80 #endif
81 extern int rexec(char **ahost, int inport, char *user, 
82                  char *passwd, char *cmd, int *fd2p);
83 extern int vfork();
84 #if defined(__cplusplus)
85 };
86 #endif
87
88
89 typedef int (*P_xdrproc_t)(XDR*, ...);
90 extern char *sys_errlist[];
91
92 /* POSIX */
93 inline void P_abort (void) { abort();}
94 inline int P_close (int FILEDES) { return (close(FILEDES));}
95 inline int P_dup2 (int OLD, int NEW) { return (dup2(OLD, NEW));}
96 inline int P_execvp (const char *FILENAME, char *const ARGV[]) {
97   return (execvp(FILENAME, ARGV));}
98 inline void P__exit (int STATUS) { _exit(STATUS);}
99 inline int P_fcntl (int FILEDES, int COMMAND, int ARG2) {
100   return (fcntl(FILEDES, COMMAND, ARG2));}
101 inline FILE * P_fdopen (int FILEDES, const char *OPENTYPE) {
102   return (fdopen(FILEDES, OPENTYPE));}
103 inline FILE * P_fopen (const char *FILENAME, const char *OPENTYPE) {
104   return (fopen(FILENAME, OPENTYPE));}
105 inline int P_fstat (int FILEDES, struct stat *BUF) { return (fstat(FILEDES, BUF));}
106 inline pid_t P_getpid () { return (getpid());}
107 inline int P_kill(pid_t PID, int SIGNUM) { return (kill(PID, SIGNUM));}
108 inline off_t P_lseek (int FILEDES, off_t OFFSET, int WHENCE) {
109   return (lseek(FILEDES, OFFSET, WHENCE));}
110 inline int P_open(const char *FILENAME, int FLAGS, mode_t MODE) {
111   return (open(FILENAME, FLAGS, MODE));}
112 inline int P_pclose (FILE *STREAM) { return (pclose(STREAM));}
113 inline FILE *P_popen (const char *COMMAND, const char *MODE) {
114   return (popen(COMMAND, MODE));}
115 inline size_t P_read (int FILEDES, void *BUFFER, size_t SIZE) {
116   return (read(FILEDES, BUFFER, SIZE));}
117 inline int P_uname(struct utsname *un) { return (uname(un));}
118 inline pid_t P_wait(int *status_ptr) { return (wait(status_ptr));}
119 inline int P_waitpid(pid_t pid, int *statusp, int options) {
120   return (waitpid(pid, statusp, options));}
121 inline size_t P_write (int FILEDES, const void *BUFFER, size_t SIZE) {
122   return (write(FILEDES, BUFFER, SIZE));}
123 inline int P_chdir(const char *path) { return (chdir(path)); }
124 inline int P_putenv(const char *str) { return putenv(str); }
125
126 /* SYSTEM-V shared memory */
127 #include <sys/ipc.h>
128 #include <sys/shm.h> /* shmid_ds */
129 inline int P_shmget(key_t theKey, int size, int flags) {
130    return shmget(theKey, size, flags);
131 }
132 inline void *P_shmat(int shmid, void *addr, int flags) {
133    return shmat(shmid, (char *)addr, flags);
134 }
135 inline int P_shmdt(void *addr) {return shmdt((char*)addr);}
136 inline int P_shmctl(int shmid, int cmd, struct shmid_ds *buf) {
137    return shmctl(shmid, cmd, buf);
138 }
139
140 /* ANSI */
141 inline void P_exit (int STATUS) { exit(STATUS);}
142 inline int P_fflush(FILE *stream) { return (fflush(stream));}
143 inline char * P_fgets (char *S, int COUNT, FILE *STREAM) {
144   return (fgets(S, COUNT, STREAM));}
145 inline void * P_malloc (size_t SIZE) { return (malloc(SIZE));}
146 inline void * P_memcpy (void *A1, const void *A2, size_t SIZE) {
147   return memcpy(A1, A2, SIZE);}
148 inline void * P_memset (void *BLOCK, int C, size_t SIZE) {
149   return (memset(BLOCK, C, SIZE));}
150 inline void P_perror (const char *MESSAGE) { perror(MESSAGE);}
151 typedef void (*P_sig_handler)(int);
152 inline P_sig_handler P_signal (int SIGNUM, P_sig_handler ACTION) {
153   return (signal(SIGNUM, ACTION));}
154 inline char * P_strcat (char *TO, const char *FROM) {
155   return (strcat(TO, FROM));}
156
157 inline const char * P_strchr (const char *STRING, int C) {return (strchr(STRING, C));}
158 inline char * P_strchr (char *STRING, int C) {return (strchr(STRING, C));}
159
160 inline int P_strcmp (const char *S1, const char *S2) {
161   return (strcmp(S1, S2));}
162 inline char * P_strcpy (char *TO, const char *FROM) {
163   return (strcpy(TO, FROM));}
164 inline char *P_strdup(const char *S) { return (strdup(S));}
165 inline size_t P_strlen (const char *S) { return (strlen(S));}
166 inline char * P_strncat (char *TO, const char *FROM, size_t SIZE) {
167   return (strncat(TO, FROM, SIZE)); }
168 inline int P_strncmp (const char *S1, const char *S2, size_t SIZE) {
169   return (strncmp(S1, S2, SIZE));}
170 inline char * P_strncpy (char *TO, const char *FROM, size_t SIZE) {
171   return (strncpy(TO, FROM, SIZE));}
172
173 inline const char * P_strrchr (const char *STRING, int C) {return (strrchr(STRING, C));}
174 inline char * P_strrchr (char *STRING, int C) {return (strrchr(STRING, C));}
175
176 inline const char * P_strstr (const char *HAYSTACK, const char *NEEDLE) {return (strstr(HAYSTACK, NEEDLE));}
177 inline char * P_strstr (char *HAYSTACK, const char *NEEDLE) {return (strstr(HAYSTACK, NEEDLE));}
178
179 inline double P_strtod (const char *STRING, char **TAILPTR) {
180   return (strtod(STRING, TAILPTR));}
181 inline char * P_strtok (char *NEWSTRING, const char *DELIMITERS) {
182   return (strtok(NEWSTRING, DELIMITERS));}
183 inline long int P_strtol (const char *STRING, char **TAILPTR, int BASE) {
184   return (strtol(STRING, TAILPTR, BASE));}
185 inline unsigned long int P_strtoul(const char *STRING, char **TAILPTR, int BASE) { 
186   return (strtoul(STRING, TAILPTR, BASE));}
187
188 /* BSD */
189 inline int P_accept (int SOCK, struct sockaddr *ADDR, size_t *LENGTH_PTR) {
190   return (accept(SOCK, ADDR, (int*) LENGTH_PTR));}
191 inline int P_bind(int socket, struct sockaddr *addr, size_t len) {
192   return (bind(socket, addr, len));}
193 inline int P_connect(int socket, struct sockaddr *addr, size_t len) {
194   return (connect(socket, addr, len));}
195 inline struct hostent * P_gethostbyname (const char *NAME) {
196   return (gethostbyname(NAME));}
197 inline int P_getrusage(int i, struct rusage *ru) { 
198    return (getrusage(i, ru));}
199 inline struct servent * P_getservbyname (const char *NAME, const char *PROTO) {
200   return (getservbyname(NAME, PROTO));}
201 inline int P_getsockname (int SOCKET, struct sockaddr *ADDR, size_t *LENGTH_PTR) {
202   return (getsockname(SOCKET, ADDR, (int*) LENGTH_PTR));}
203 inline int P_getsockopt(int s, int level, int optname, void *optval, int *optlen) {
204    return getsockopt(s, level, optname, (char*)optval, optlen);}
205 inline int P_setsockopt(int s, int level, int optname, void *optval, int optlen) {
206    return setsockopt(s, level, optname, (const char*)optval, optlen);}
207
208 inline int P_gettimeofday (struct timeval *TP, struct timezone *TZP) {
209   return (gettimeofday(TP, TZP));} 
210 inline int P_listen (int socket, unsigned int n) { return (listen(socket, n));}
211 inline caddr_t P_mmap(caddr_t addr, size_t len, int prot, int flags,
212                       int fd, off_t off) {
213   return (caddr_t)(mmap(addr, len, prot, flags, fd, off));}
214 inline int P_munmap(caddr_t addr, int i) { return (munmap(addr, i));}
215 inline int P_socket (int NAMESPACE, int STYLE, int PROTOCOL) {
216   return (socket(NAMESPACE, STYLE, PROTOCOL));}
217 inline int P_socketpair(int namesp, int style, int protocol, int filedes[2]) {
218   return (socketpair(namesp, style, protocol, filedes));}
219 inline int P_pipe(int fds[2]) { return (pipe(fds)); }
220 inline int P_strcasecmp(const char *s1, const char *s2) {
221   return (strcasecmp(s1, s2));}
222 inline int P_strncasecmp (const char *S1, const char *S2, size_t N) {
223   return (strncasecmp(S1, S2,N));}
224 inline int P_endservent(void) { endservent(); return 0; }
225
226 /* Ugly */
227
228 inline int P_ptrace(int req, pid_t pid, int addr, int data) {
229   return (ptrace(req, pid, addr, data));}
230
231 inline int P_select(int wid, fd_set *rd, fd_set *wr, fd_set *ex,
232                     struct timeval *tm) {
233   return (select(wid, rd, wr, ex, tm));}
234
235 inline int P_rexec(char **ahost, u_short inport, char *user,
236                    char *passwd, char *cmd, int *fd2p) {
237   return (rexec(ahost, (int)inport, user, passwd, cmd, fd2p));}
238
239 // for matherr()
240 struct exception { // CSS
241         int type;
242         char *name;
243         double arg1;
244         double arg2;
245         double retval;
246 };
247
248
249 inline void   P_xdr_destroy(XDR *x) { xdr_destroy(x);}
250 inline bool_t P_xdr_u_char(XDR *x, u_char *uc) { return (xdr_u_char(x, uc));}
251 inline bool_t P_xdr_int(XDR *x, int *i) { return (xdr_int(x, i));}
252 inline bool_t P_xdr_double(XDR *x, double *d) {
253   return (xdr_double(x, d));}
254 inline bool_t P_xdr_u_int(XDR *x, u_int *u){
255   return (xdr_u_int(x, u));}
256 inline bool_t P_xdr_float(XDR *x, float *f) {
257   return (xdr_float(x, f));}
258 inline bool_t P_xdr_char(XDR *x, char *c) {
259   return (xdr_char(x, c));}
260 inline bool_t P_xdr_string(XDR *x, char **h, const u_int maxsize) {
261   return (xdr_string(x, h, maxsize));}
262
263 inline void P_xdrrec_create(XDR *x, const u_int send_sz, const u_int rec_sz,
264                             const caddr_t handle, 
265                             xdr_rd_func read_r, xdr_wr_func write_f) {
266   xdrrec_create(x, send_sz, rec_sz, handle, 
267                 (int (*)(void *, void *, u_int))read_r, 
268                 (int (*)(void *, void *, u_int))write_f);
269 }
270 inline bool_t P_xdrrec_endofrecord(XDR *x, int now) { 
271   return (xdrrec_endofrecord(x, now));}
272 inline bool_t P_xdrrec_skiprecord(XDR *x) { return (xdrrec_skiprecord(x));}
273 inline bool_t P_xdrrec_eof(XDR *x) { return (xdrrec_eof(x)); }
274
275 #endif