]> git.ipfire.org Git - thirdparty/openssl.git/blame - e_os.h
Fix memleaks in KDF implementations
[thirdparty/openssl.git] / e_os.h
CommitLineData
b6cff313 1/*
0d664759 2 * Copyright 1995-2018 The OpenSSL Project Authors. All Rights Reserved.
0f113f3e 3 *
402dd558 4 * Licensed under the Apache License 2.0 (the "License"). You may not use
b6cff313
RS
5 * this file except in compliance with the License. You can obtain a copy
6 * in the file LICENSE in the source distribution or at
7 * https://www.openssl.org/source/license.html
d02b48c6
RE
8 */
9
10#ifndef HEADER_E_OS_H
0f113f3e 11# define HEADER_E_OS_H
d02b48c6 12
07016a8a 13# include <limits.h>
0f113f3e 14# include <openssl/opensslconf.h>
06018c46 15
0f113f3e 16# include <openssl/e_os2.h>
98d132cf 17# include <openssl/crypto.h>
176db6dc 18# include "internal/nelem.h"
b99fe5f4 19
0f113f3e
MC
20/*
21 * <openssl/e_os2.h> contains what we can justify to make visible to the
22 * outside; this file e_os.h is not part of the exported interface.
23 */
fa470a84 24
0f113f3e
MC
25# ifndef DEVRANDOM
26/*
f367ac2b 27 * set this to a comma-separated list of 'random' device files to try out. By
0f113f3e
MC
28 * default, we will try to read at least one of these files
29 */
38023b87 30# define DEVRANDOM "/dev/urandom", "/dev/random", "/dev/hwrng", "/dev/srandom"
280cc018 31# if defined(__linux) && !defined(__ANDROID__)
3a577750
P
32# ifndef DEVRANDOM_WAIT
33# define DEVRANDOM_WAIT "/dev/random"
34# endif
35/*
36 * Linux kernels 4.8 and later changes how their random device works and there
37 * is no reliable way to tell that /dev/urandom has been seeded -- getentropy(2)
38 * should be used instead.
39 */
40# ifndef DEVRANDOM_SAFE_KERNEL
41# define DEVRANDOM_SAFE_KERNEL 4, 8
42# endif
43/*
44 * Some operating systems do not permit select(2) on their random devices,
45 * defining this to zero will force the used of read(2) to extract one byte
46 * from /dev/random.
47 */
48# ifndef DEVRANDM_WAIT_USE_SELECT
49# define DEVRANDM_WAIT_USE_SELECT 1
50# endif
51/*
52 * Define the shared memory identifier used to indicate if the operating
53 * system has properly seeded the DEVRANDOM source.
54 */
55# ifndef OPENSSL_RAND_SEED_DEVRANDOM_SHM_ID
56# define OPENSSL_RAND_SEED_DEVRANDOM_SHM_ID 114
57# endif
58
59# endif
0f113f3e 60# endif
0423f812 61# if !defined(OPENSSL_NO_EGD) && !defined(DEVRANDOM_EGD)
0f113f3e
MC
62/*
63 * set this to a comma-separated list of 'egd' sockets to try out. These
64 * sockets will be tried in the order listed in case accessing the device
f367ac2b 65 * files listed in DEVRANDOM did not return enough randomness.
0f113f3e 66 */
38023b87 67# define DEVRANDOM_EGD "/var/run/egd-pool", "/dev/egd-pool", "/etc/egd-pool", "/etc/entropy"
0f113f3e 68# endif
d02b48c6 69
cff55b90 70# if defined(OPENSSL_SYS_VXWORKS) || defined(OPENSSL_SYS_UEFI)
3e83e686
RL
71# define NO_CHMOD
72# define NO_SYSLOG
0f113f3e
MC
73# endif
74
0e97f1e1
RS
75# define get_last_sys_error() errno
76# define clear_sys_error() errno=0
71b1ceff 77# define set_sys_error(e) errno=(e)
0e97f1e1 78
d02b48c6
RE
79/********************************************************************
80 The Microsoft section
81 ********************************************************************/
0f113f3e 82# if defined(OPENSSL_SYS_WIN32) && !defined(WIN32)
b8384651 83# define WIN32
0f113f3e
MC
84# endif
85# if defined(OPENSSL_SYS_WINDOWS) && !defined(WINDOWS)
cf1b7d96 86# define WINDOWS
0f113f3e
MC
87# endif
88# if defined(OPENSSL_SYS_MSDOS) && !defined(MSDOS)
cf1b7d96 89# define MSDOS
0f113f3e 90# endif
d02b48c6 91
0f113f3e 92# ifdef WIN32
0e97f1e1
RS
93# undef get_last_sys_error
94# undef clear_sys_error
71b1ceff 95# undef set_sys_error
0f113f3e
MC
96# define get_last_sys_error() GetLastError()
97# define clear_sys_error() SetLastError(0)
71b1ceff 98# define set_sys_error(e) SetLastError(e)
0f113f3e
MC
99# if !defined(WINNT)
100# define WIN_CONSOLE_BUG
101# endif
102# else
0f113f3e 103# endif
58964a49 104
0f113f3e 105# if (defined(WINDOWS) || defined(MSDOS))
d02b48c6 106
f642ebc1 107# ifdef __DJGPP__
0f113f3e
MC
108# include <unistd.h>
109# include <sys/stat.h>
0f113f3e
MC
110# define _setmode setmode
111# define _O_TEXT O_TEXT
112# define _O_BINARY O_BINARY
2c25ebd1
RL
113# define HAS_LFN_SUPPORT(name) (pathconf((name), _PC_NAME_MAX) > 12)
114# undef DEVRANDOM_EGD /* Neither MS-DOS nor FreeDOS provide 'egd' sockets. */
0f113f3e
MC
115# undef DEVRANDOM
116# define DEVRANDOM "/dev/urandom\x24"
117# endif /* __DJGPP__ */
f642ebc1 118
0056ef5d 119# ifndef S_IFDIR
0f113f3e 120# define S_IFDIR _S_IFDIR
0056ef5d 121# endif
6e064240 122
0056ef5d 123# ifndef S_IFMT
0f113f3e 124# define S_IFMT _S_IFMT
0056ef5d 125# endif
6e064240 126
f642ebc1 127# if !defined(WINNT) && !defined(__DJGPP__)
0f113f3e 128# define NO_SYSLOG
0056ef5d 129# endif
d02b48c6 130
d02b48c6 131# ifdef WINDOWS
0f113f3e 132# if !defined(_WIN32_WCE) && !defined(_WIN32_WINNT)
e476f942 133 /*
0f113f3e
MC
134 * Defining _WIN32_WINNT here in e_os.h implies certain "discipline."
135 * Most notably we ought to check for availability of each specific
0ee05b73
AP
136 * routine that was introduced after denoted _WIN32_WINNT with
137 * GetProcAddress(). Normally newer functions are masked with higher
138 * _WIN32_WINNT in SDK headers. So that if you wish to use them in
139 * some module, you'd need to override _WIN32_WINNT definition in
140 * the target module in order to "reach for" prototypes, but replace
141 * calls to new functions with indirect calls. Alternatively it
142 * might be possible to achieve the goal by /DELAYLOAD-ing .DLLs
143 * and check for current OS version instead.
0f113f3e 144 */
0ee05b73 145# define _WIN32_WINNT 0x0501
0f113f3e 146# endif
2469e76b 147# if defined(_WIN32_WINNT) || defined(_WIN32_WCE)
61aa2134
AP
148 /*
149 * Just like defining _WIN32_WINNT including winsock2.h implies
8711efb4 150 * certain "discipline" for maintaining [broad] binary compatibility.
61aa2134
AP
151 * As long as structures are invariant among Winsock versions,
152 * it's sufficient to check for specific Winsock2 API availability
153 * at run-time [DSO_global_lookup is recommended]...
154 */
0f113f3e
MC
155# include <winsock2.h>
156# include <ws2tcpip.h>
8711efb4 157 /* yes, they have to be #included prior to <windows.h> */
0f113f3e
MC
158# endif
159# include <windows.h>
160# include <stdio.h>
161# include <stddef.h>
162# include <errno.h>
163# if defined(_WIN32_WCE) && !defined(EACCES)
164# define EACCES 13
165# endif
166# include <string.h>
167# ifdef _WIN64
168# define strlen(s) _strlen31(s)
1875e6db 169/* cut strings to 2GB */
55c7a4cf 170static __inline unsigned int _strlen31(const char *str)
0f113f3e
MC
171{
172 unsigned int len = 0;
173 while (*str && len < 0x80000000U)
174 str++, len++;
175 return len & 0x7FFFFFFF;
176}
177# endif
178# include <malloc.h>
0f113f3e
MC
179# if defined(_MSC_VER) && !defined(_WIN32_WCE) && !defined(_DLL) && defined(stdin)
180# if _MSC_VER>=1300 && _MSC_VER<1600
181# undef stdin
182# undef stdout
183# undef stderr
184FILE *__iob_func();
185# define stdin (&__iob_func()[0])
186# define stdout (&__iob_func()[1])
187# define stderr (&__iob_func()[2])
188# elif _MSC_VER<1300 && defined(I_CAN_LIVE_WITH_LNK4049)
189# undef stdin
190# undef stdout
191# undef stderr
192 /*
193 * pre-1300 has __p__iob(), but it's available only in msvcrt.lib,
194 * or in other words with /MD. Declaring implicit import, i.e. with
195 * _imp_ prefix, works correctly with all compiler options, but
196 * without /MD results in LINK warning LNK4049: 'locally defined
197 * symbol "__iob" imported'.
e527201f 198 */
0f113f3e
MC
199extern FILE *_imp___iob;
200# define stdin (&_imp___iob[0])
201# define stdout (&_imp___iob[1])
202# define stderr (&_imp___iob[2])
e527201f 203# endif
0f113f3e 204# endif
d02b48c6 205# endif
0f113f3e
MC
206# include <io.h>
207# include <fcntl.h>
d02b48c6 208
0bf23d9b 209# ifdef OPENSSL_SYS_WINCE
0f113f3e 210# define OPENSSL_NO_POSIX_IO
0bf23d9b
RL
211# endif
212
be7b4458 213# define EXIT(n) exit(n)
d02b48c6 214# define LIST_SEPARATOR_CHAR ';'
0056ef5d 215# ifndef W_OK
0f113f3e 216# define W_OK 2
0056ef5d
RL
217# endif
218# ifndef R_OK
0f113f3e 219# define R_OK 4
0056ef5d 220# endif
0bf23d9b 221# ifdef OPENSSL_SYS_WINCE
0f113f3e 222# define DEFAULT_HOME ""
0bf23d9b 223# else
0f113f3e 224# define DEFAULT_HOME "C:"
0bf23d9b 225# endif
d02b48c6 226
86d21d0b 227/* Avoid Visual Studio 13 GetVersion deprecated problems */
0f113f3e
MC
228# if defined(_MSC_VER) && _MSC_VER>=1800
229# define check_winnt() (1)
230# define check_win_minplat(x) (1)
231# else
232# define check_winnt() (GetVersion() < 0x80000000)
233# define check_win_minplat(x) (LOBYTE(LOWORD(GetVersion())) >= (x))
234# endif
f511b25a 235
0f113f3e 236# else /* The non-microsoft world */
d02b48c6 237
4cff10dc 238# if defined(OPENSSL_SYS_VXWORKS)
61783db5 239# include <time.h>
4cff10dc
P
240# else
241# include <sys/time.h>
242# endif
243
cf1b7d96 244# ifdef OPENSSL_SYS_VMS
0f113f3e
MC
245# define VMS 1
246 /*
247 * some programs don't include stdlib, so exit() and others give implicit
248 * function warnings
249 */
250# include <stdlib.h>
251# if defined(__DECC)
252# include <unistd.h>
253# else
254# include <unixlib.h>
255# endif
0f113f3e 256# define LIST_SEPARATOR_CHAR ','
0c61e299 257 /* We don't have any well-defined random devices on VMS, yet... */
0f113f3e 258# undef DEVRANDOM
1d97c843
TH
259 /*-
260 We need to do this since VMS has the following coding on status codes:
511e596b
RL
261
262 Bits 0-2: status type: 0 = warning, 1 = success, 2 = error, 3 = info ...
263 The important thing to know is that odd numbers are considered
0f113f3e 264 good, while even ones are considered errors.
511e596b
RL
265 Bits 3-15: actual status number
266 Bits 16-27: facility number. 0 is considered "unknown"
267 Bits 28-31: control bits. If bit 28 is set, the shell won't try to
268 output the message (which, for random codes, just looks ugly)
269
270 So, what we do here is to change 0 to 1 to get the default success status,
271 and everything else is shifted up to fit into the status number field, and
f625d383 272 the status is tagged as an error, which is what is wanted here.
c3944a99
RL
273
274 Finally, we add the VMS C facility code 0x35a000, because there are some
275 programs, such as Perl, that will reinterpret the code back to something
46d08509 276 POSIX. 'man perlvms' explains it further.
f625d383 277
c3944a99
RL
278 NOTE: the perlvms manual wants to turn all codes 2 to 255 into success
279 codes (status type = 1). I couldn't disagree more. Fortunately, the
280 status type doesn't seem to bother Perl.
511e596b
RL
281 -- Richard Levitte
282 */
f625d383
RL
283# define EXIT(n) exit((n) ? (((n) << 3) | 2 | 0x10000000 | 0x35a000) : 1)
284
b8f304f7
RL
285# define DEFAULT_HOME "SYS$LOGIN:"
286
d02b48c6 287# else
06018c46 288 /* !defined VMS */
6b10d29c 289# include <unistd.h>
b379fe6c 290# include <sys/types.h>
0f113f3e
MC
291# ifdef OPENSSL_SYS_WIN32_CYGWIN
292# include <io.h>
293# include <fcntl.h>
294# endif
295
0f113f3e 296# define LIST_SEPARATOR_CHAR ':'
0f113f3e 297# define EXIT(n) exit(n)
d02b48c6 298# endif
d02b48c6 299
0f113f3e 300# endif
7d7d2cbc 301
d02b48c6
RE
302/***********************************************/
303
0f113f3e 304# if defined(OPENSSL_SYS_WINDOWS)
e6fa67fa
RL
305# define strcasecmp _stricmp
306# define strncasecmp _strnicmp
dc6b5c7b
RL
307# if (_MSC_VER >= 1310)
308# define open _open
309# define fdopen _fdopen
310# define close _close
8d95ca36
M
311# ifndef strdup
312# define strdup _strdup
313# endif
dc6b5c7b 314# define unlink _unlink
2e38091c 315# define fileno _fileno
dc6b5c7b 316# endif
7233bea2
RL
317# else
318# include <strings.h>
0f113f3e 319# endif
3bfd99bf 320
6a89a25c 321/* vxworks */
0f113f3e
MC
322# if defined(OPENSSL_SYS_VXWORKS)
323# include <ioLib.h>
324# include <tickLib.h>
325# include <sysLib.h>
0f113f3e
MC
326# include <vxWorks.h>
327# include <sockLib.h>
328# include <taskLib.h>
6a89a25c 329
0e97f1e1
RS
330# define TTY_STRUCT int
331# define sleep(a) taskDelay((a) * sysClkRateGet())
6a89a25c 332
0f113f3e
MC
333/*
334 * NOTE: these are implemented by helpers in database app! if the database is
a303e9a6 335 * not linked, we need to implement them elsewhere
0f113f3e 336 */
6a89a25c
RL
337struct hostent *gethostbyname(const char *name);
338struct hostent *gethostbyaddr(const char *addr, int length, int type);
339struct servent *getservbyname(const char *name, const char *proto);
340
0f113f3e 341# endif
6a89a25c
RL
342/* end vxworks */
343
8529b156
DMSP
344# ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION
345# define CRYPTO_memcmp memcmp
346# endif
43c56417 347
8529b156
DMSP
348/* unistd.h defines _POSIX_VERSION */
349# if !defined(OPENSSL_NO_SECURE_MEMORY) && defined(OPENSSL_SYS_UNIX) \
350 && ( (defined(_POSIX_VERSION) && _POSIX_VERSION >= 200112L) \
351 || defined(__sun) || defined(__hpux) || defined(__sgi) \
352 || defined(__osf__) )
353# define OPENSSL_SECURE_MEMORY /* secure memory is implemented */
354# endif
d02b48c6 355#endif