Store verify_result with sessions to avoid potential security hole.
[oweals/openssl.git] / e_os.h
1 /* e_os.h */
2 /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3  * All rights reserved.
4  *
5  * This package is an SSL implementation written
6  * by Eric Young (eay@cryptsoft.com).
7  * The implementation was written so as to conform with Netscapes SSL.
8  * 
9  * This library is free for commercial and non-commercial use as long as
10  * the following conditions are aheared to.  The following conditions
11  * apply to all code found in this distribution, be it the RC4, RSA,
12  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
13  * included with this distribution is covered by the same copyright terms
14  * except that the holder is Tim Hudson (tjh@cryptsoft.com).
15  * 
16  * Copyright remains Eric Young's, and as such any Copyright notices in
17  * the code are not to be removed.
18  * If this package is used in a product, Eric Young should be given attribution
19  * as the author of the parts of the library used.
20  * This can be in the form of a textual message at program startup or
21  * in documentation (online or textual) provided with the package.
22  * 
23  * Redistribution and use in source and binary forms, with or without
24  * modification, are permitted provided that the following conditions
25  * are met:
26  * 1. Redistributions of source code must retain the copyright
27  *    notice, this list of conditions and the following disclaimer.
28  * 2. Redistributions in binary form must reproduce the above copyright
29  *    notice, this list of conditions and the following disclaimer in the
30  *    documentation and/or other materials provided with the distribution.
31  * 3. All advertising materials mentioning features or use of this software
32  *    must display the following acknowledgement:
33  *    "This product includes cryptographic software written by
34  *     Eric Young (eay@cryptsoft.com)"
35  *    The word 'cryptographic' can be left out if the rouines from the library
36  *    being used are not cryptographic related :-).
37  * 4. If you include any Windows specific code (or a derivative thereof) from 
38  *    the apps directory (application code) you must include an acknowledgement:
39  *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
40  * 
41  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
42  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
43  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
44  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
45  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
46  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
47  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
48  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
49  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
50  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51  * SUCH DAMAGE.
52  * 
53  * The licence and distribution terms for any publically available version or
54  * derivative of this code cannot be changed.  i.e. this code cannot simply be
55  * copied and put under another distribution licence
56  * [including the GNU Public Licence.]
57  */
58
59 #ifndef HEADER_E_OS_H
60 #define HEADER_E_OS_H
61
62 #include <openssl/opensslconf.h>
63
64 #include <openssl/e_os2.h>
65 /* <openssl/e_os2.h> contains what we can justify to make visible
66  * to the outside; this file e_os.h is not part of the exported
67  * interface. */
68
69 #ifdef  __cplusplus
70 extern "C" {
71 #endif
72
73 /* Used to checking reference counts, most while doing perl5 stuff :-) */
74 #ifdef REF_PRINT
75 #undef REF_PRINT
76 #define REF_PRINT(a,b)  fprintf(stderr,"%08X:%4d:%s\n",(int)b,b->references,a)
77 #endif
78
79 #ifndef DEVRANDOM
80 /* set this to your 'random' device if you have one.
81  * My default, we will try to read this file */
82 #define DEVRANDOM "/dev/urandom"
83 #endif
84
85 #if defined(__MWERKS__) && defined(macintosh)
86 # if macintosh==1
87 #  define MAC_OS_pre_X
88 #  define NO_SYS_TYPES_H
89 #  define NO_CHMOD
90 #  define NO_SYSLOG
91 # endif
92 #endif
93
94 /********************************************************************
95  The Microsoft section
96  ********************************************************************/
97 /* The following is used becaue of the small stack in some
98  * Microsoft operating systems */
99 #if defined(WIN16) || defined(MSDOS)
100 #  define MS_STATIC     static
101 #else
102 #  define MS_STATIC
103 #endif
104
105 #if defined(WIN32) || defined(WIN16)
106 #  ifndef WINDOWS
107 #    define WINDOWS
108 #  endif
109 #  ifndef MSDOS
110 #    define MSDOS
111 #  endif
112 #endif
113
114 #ifdef WIN32
115 #define get_last_sys_error()    GetLastError()
116 #define clear_sys_error()       SetLastError(0)
117 #if !defined(WINNT)
118 #define WIN_CONSOLE_BUG
119 #endif
120 #else
121 #define get_last_sys_error()    errno
122 #define clear_sys_error()       errno=0
123 #endif
124
125 #ifdef WINDOWS
126 #define get_last_socket_error() WSAGetLastError()
127 #define clear_socket_error()    WSASetLastError(0)
128 #define readsocket(s,b,n)       recv((s),(b),(n),0)
129 #define writesocket(s,b,n)      send((s),(b),(n),0)
130 #define EADDRINUSE              WSAEADDRINUSE
131 #elif MAC_OS_pre_X
132 #define get_last_socket_error() errno
133 #define clear_socket_error()    errno=0
134 #define closesocket(s)          MacSocket_close(s)
135 #define readsocket(s,b,n)       MacSocket_recv((s),(b),(n),true)
136 #define writesocket(s,b,n)      MacSocket_send((s),(b),(n))
137 #else
138 #define get_last_socket_error() errno
139 #define clear_socket_error()    errno=0
140 #define ioctlsocket(a,b,c)      ioctl(a,b,c)
141 #define closesocket(s)          close(s)
142 #define readsocket(s,b,n)       read((s),(b),(n))
143 #define writesocket(s,b,n)      write((s),(b),(n))
144 #endif
145
146 #ifdef WIN16
147 #  define NO_FP_API
148 #  define MS_CALLBACK   _far _loadds
149 #  define MS_FAR        _far
150 #else
151 #  define MS_CALLBACK
152 #  define MS_FAR
153 #endif
154
155 #ifdef NO_STDIO
156 #  define NO_FP_API
157 #endif
158
159 #if defined(WINDOWS) || defined(MSDOS)
160
161 #ifndef S_IFDIR
162 #define S_IFDIR _S_IFDIR
163 #endif
164
165 #ifndef S_IFMT
166 #define S_IFMT  _S_IFMT
167
168 #if !defined(WINNT)
169 #define NO_SYSLOG
170 #endif
171 #define NO_DIRENT
172
173 #endif
174
175 #  ifdef WINDOWS
176 #    include <windows.h>
177 #    include <stddef.h>
178 #    include <errno.h>
179 #    include <string.h>
180 #    include <malloc.h>
181 #  endif
182 #  include <io.h>
183 #  include <fcntl.h>
184
185 #if defined (__BORLANDC__)
186 #define _setmode setmode
187 #define _O_TEXT O_TEXT
188 #define _O_BINARY O_BINARY
189 #define _int64 __int64
190 #define _kbhit kbhit
191 #endif
192
193 #if defined(WIN16) && !defined(MONOLITH) && defined(SSLEAY) && defined(_WINEXITNOPERSIST)
194 #  define EXIT(n) { if (n == 0) _wsetexit(_WINEXITNOPERSIST); return(n); }
195 #else
196 #  define EXIT(n)               return(n);
197 #endif
198 #  define LIST_SEPARATOR_CHAR ';'
199 #ifndef X_OK
200 #  define X_OK  0
201 #endif
202 #ifndef W_OK
203 #  define W_OK  2
204 #endif
205 #ifndef R_OK
206 #  define R_OK  4
207 #endif
208 #  define OPENSSL_CONF  "openssl.cnf"
209 #  define SSLEAY_CONF   OPENSSL_CONF
210 #  define NUL_DEV       "nul"
211 #  define RFILE         ".rnd"
212
213 #else /* The non-microsoft world world */
214
215 #  if defined(__VMS) && !defined(VMS)
216 #  define VMS 1
217 #  endif
218
219 #  ifdef VMS
220   /* some programs don't include stdlib, so exit() and others give implicit 
221      function warnings */
222 #    include <stdlib.h>
223 #    if defined(__DECC)
224 #      include <unistd.h>
225 #    else
226 #      include <unixlib.h>
227 #    endif
228 #    define OPENSSL_CONF        "openssl.cnf"
229 #    define SSLEAY_CONF         OPENSSL_CONF
230 #    define RFILE               ".rnd"
231 #    define LIST_SEPARATOR_CHAR ','
232 #    define NUL_DEV             "NLA0:"
233   /* We need to do this, because DEC C converts exit code 0 to 1, but not 1
234      to 0.  We will convert 1 to 3!  Also, add the inhibit message bit... */
235 #    ifndef MONOLITH
236 #      define EXIT(n)           do { int __VMS_EXIT = n; \
237                                      if (__VMS_EXIT == 1) __VMS_EXIT = 3; \
238                                      __VMS_EXIT |= 0x10000000; \
239                                      exit(n); return(n); } while(0)
240 #    else
241 #      define EXIT(n)           do { int __VMS_EXIT = n; \
242                                      if (__VMS_EXIT == 1) __VMS_EXIT = 3; \
243                                      __VMS_EXIT |= 0x10000000; \
244                                      return(n); } while(0)
245 #    endif
246 #  else
247      /* !defined VMS */
248 #    include OPENSSL_UNISTD
249 #    include <sys/types.h>
250
251 #    define OPENSSL_CONF        "openssl.cnf"
252 #    define SSLEAY_CONF         OPENSSL_CONF
253 #    define RFILE               ".rnd"
254 #    define LIST_SEPARATOR_CHAR ':'
255 #    define NUL_DEV             "/dev/null"
256 #    ifndef MONOLITH
257 #      define EXIT(n)           exit(n); return(n)
258 #    else
259 #      define EXIT(n)           return(n)
260 #    endif
261 #  endif
262
263 #  define SSLeay_getpid()       getpid()
264
265 #endif
266
267
268 /*************/
269
270 #ifdef USE_SOCKETS
271 #  if defined(WINDOWS) || defined(MSDOS)
272       /* windows world */
273
274 #    ifdef NO_SOCK
275 #      define SSLeay_Write(a,b,c)       (-1)
276 #      define SSLeay_Read(a,b,c)        (-1)
277 #      define SHUTDOWN(fd)              close(fd)
278 #      define SHUTDOWN2(fd)             close(fd)
279 #    else
280 #      include <winsock.h>
281 extern HINSTANCE _hInstance;
282 #      define SSLeay_Write(a,b,c)       send((a),(b),(c),0)
283 #      define SSLeay_Read(a,b,c)        recv((a),(b),(c),0)
284 #      define SHUTDOWN(fd)              { shutdown((fd),0); closesocket(fd); }
285 #      define SHUTDOWN2(fd)             { shutdown((fd),2); closesocket(fd); }
286 #    endif
287
288 #  elif defined(MAC_OS_pre_X)
289
290 #    include "MacSocket.h"
291 #    define SSLeay_Write(a,b,c)         MacSocket_send((a),(b),(c))
292 #    define SSLeay_Read(a,b,c)          MacSocket_recv((a),(b),(c),true)
293 #    define SHUTDOWN(fd)                MacSocket_close(fd)
294 #    define SHUTDOWN2(fd)               MacSocket_close(fd)
295
296 #  else
297
298 #    ifndef VMS
299 #      include <sys/param.h>
300 #    endif
301 #    include <sys/time.h> /* Needed under linux for FD_XXX */
302
303 #    include <netdb.h>
304 #    if defined(VMS) && !defined(__DECC)
305 #      include <socket.h>
306 #      include <in.h>
307 #    else
308 #      include <sys/socket.h>
309 #      ifdef FILIO_H
310 #        include <sys/filio.h> /* Added for FIONBIO under unixware */
311 #      endif
312 #      include <netinet/in.h>
313 #    endif
314
315 #    if defined(NeXT) || defined(_NEXT_SOURCE)
316 #      include <sys/fcntl.h>
317 #      include <sys/types.h>
318 #    endif
319
320 #    ifdef AIX
321 #      include <sys/select.h>
322 #    endif
323
324 #    if defined(sun)
325 #      include <sys/filio.h>
326 #    else
327 #      ifndef VMS
328 #        include <sys/ioctl.h>
329 #      else
330          /* ioctl is only in VMS > 7.0 and when socketshr is not used */
331 #        if !defined(TCPIP_TYPE_SOCKETSHR) && defined(__VMS_VER) && (__VMS_VER > 70000000)
332 #          include <sys/ioctl.h>
333 #        endif
334 #      endif
335 #    endif
336
337 #    ifdef VMS
338 #      include <unixio.h>
339 #      if defined(TCPIP_TYPE_SOCKETSHR)
340 #        include <socketshr.h>
341 #      endif
342 #    endif
343
344 #    define SSLeay_Read(a,b,c)     read((a),(b),(c))
345 #    define SSLeay_Write(a,b,c)    write((a),(b),(c))
346 #    define SHUTDOWN(fd)    { shutdown((fd),0); closesocket((fd)); }
347 #    define SHUTDOWN2(fd)   { shutdown((fd),2); closesocket((fd)); }
348 #    define INVALID_SOCKET      (-1)
349 #  endif
350 #endif
351
352 #if defined(THREADS) || defined(sun)
353 #ifndef _REENTRANT
354 #define _REENTRANT
355 #endif
356 #endif
357
358 /***********************************************/
359
360 /* do we need to do this for getenv.
361  * Just define getenv for use under windows */
362
363 #ifdef WIN16
364 /* How to do this needs to be thought out a bit more.... */
365 /*char *GETENV(char *);
366 #define Getenv  GETENV*/
367 #define Getenv  getenv
368 #else
369 #define Getenv getenv
370 #endif
371
372 #define DG_GCC_BUG      /* gcc < 2.6.3 on DGUX */
373
374 #ifdef sgi
375 #define IRIX_CC_BUG     /* all version of IRIX I've tested (4.* 5.*) */
376 #endif
377 #ifdef SNI
378 #define IRIX_CC_BUG     /* CDS++ up to V2.0Bsomething suffered from the same bug.*/
379 #endif
380
381 #ifdef NO_MD2
382 #define MD2_Init MD2Init
383 #define MD2_Update MD2Update
384 #define MD2_Final MD2Final
385 #define MD2_DIGEST_LENGTH 16
386 #endif
387 #ifdef NO_MD5
388 #define MD5_Init MD5Init 
389 #define MD5_Update MD5Update
390 #define MD5_Final MD5Final
391 #define MD5_DIGEST_LENGTH 16
392 #endif
393
394 #ifdef  __cplusplus
395 }
396 #endif
397
398 #endif
399