lh | 9ed821d | 2023-04-07 01:36:19 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 1995-2020 The OpenSSL Project Authors. All Rights Reserved. |
| 3 | * |
| 4 | * Licensed under the OpenSSL license (the "License"). You may not use |
| 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 |
| 8 | */ |
| 9 | |
| 10 | #ifndef OSSL_E_OS_H |
| 11 | # define OSSL_E_OS_H |
| 12 | |
| 13 | # include <limits.h> |
| 14 | # include <openssl/opensslconf.h> |
| 15 | |
| 16 | # include <openssl/e_os2.h> |
| 17 | # include <openssl/crypto.h> |
| 18 | # include "internal/nelem.h" |
| 19 | |
| 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 | */ |
| 24 | |
| 25 | # ifndef DEVRANDOM |
| 26 | /* |
| 27 | * set this to a comma-separated list of 'random' device files to try out. By |
| 28 | * default, we will try to read at least one of these files |
| 29 | */ |
| 30 | # define DEVRANDOM "/dev/urandom", "/dev/random", "/dev/hwrng", "/dev/srandom" |
| 31 | # if defined(__linux) && !defined(__ANDROID__) |
| 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 use 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 |
| 60 | # endif |
| 61 | # if !defined(OPENSSL_NO_EGD) && !defined(DEVRANDOM_EGD) |
| 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 |
| 65 | * files listed in DEVRANDOM did not return enough randomness. |
| 66 | */ |
| 67 | # define DEVRANDOM_EGD "/var/run/egd-pool", "/dev/egd-pool", "/etc/egd-pool", "/etc/entropy" |
| 68 | # endif |
| 69 | |
| 70 | # if defined(OPENSSL_SYS_VXWORKS) || defined(OPENSSL_SYS_UEFI) |
| 71 | # define NO_CHMOD |
| 72 | # define NO_SYSLOG |
| 73 | # endif |
| 74 | |
| 75 | # define get_last_sys_error() errno |
| 76 | # define clear_sys_error() errno=0 |
| 77 | # define set_sys_error(e) errno=(e) |
| 78 | |
| 79 | /******************************************************************** |
| 80 | The Microsoft section |
| 81 | ********************************************************************/ |
| 82 | # if defined(OPENSSL_SYS_WIN32) && !defined(WIN32) |
| 83 | # define WIN32 |
| 84 | # endif |
| 85 | # if defined(OPENSSL_SYS_WINDOWS) && !defined(WINDOWS) |
| 86 | # define WINDOWS |
| 87 | # endif |
| 88 | # if defined(OPENSSL_SYS_MSDOS) && !defined(MSDOS) |
| 89 | # define MSDOS |
| 90 | # endif |
| 91 | |
| 92 | # ifdef WIN32 |
| 93 | # undef get_last_sys_error |
| 94 | # undef clear_sys_error |
| 95 | # undef set_sys_error |
| 96 | # define get_last_sys_error() GetLastError() |
| 97 | # define clear_sys_error() SetLastError(0) |
| 98 | # define set_sys_error(e) SetLastError(e) |
| 99 | # if !defined(WINNT) |
| 100 | # define WIN_CONSOLE_BUG |
| 101 | # endif |
| 102 | # else |
| 103 | # endif |
| 104 | |
| 105 | # if (defined(WINDOWS) || defined(MSDOS)) |
| 106 | |
| 107 | # ifdef __DJGPP__ |
| 108 | # include <unistd.h> |
| 109 | # include <sys/stat.h> |
| 110 | # define _setmode setmode |
| 111 | # define _O_TEXT O_TEXT |
| 112 | # define _O_BINARY O_BINARY |
| 113 | # define HAS_LFN_SUPPORT(name) (pathconf((name), _PC_NAME_MAX) > 12) |
| 114 | # undef DEVRANDOM_EGD /* Neither MS-DOS nor FreeDOS provide 'egd' sockets. */ |
| 115 | # undef DEVRANDOM |
| 116 | # define DEVRANDOM "/dev/urandom\x24" |
| 117 | # endif /* __DJGPP__ */ |
| 118 | |
| 119 | # ifndef S_IFDIR |
| 120 | # define S_IFDIR _S_IFDIR |
| 121 | # endif |
| 122 | |
| 123 | # ifndef S_IFMT |
| 124 | # define S_IFMT _S_IFMT |
| 125 | # endif |
| 126 | |
| 127 | # if !defined(WINNT) && !defined(__DJGPP__) |
| 128 | # define NO_SYSLOG |
| 129 | # endif |
| 130 | |
| 131 | # ifdef WINDOWS |
| 132 | # if !defined(_WIN32_WCE) && !defined(_WIN32_WINNT) |
| 133 | /* |
| 134 | * Defining _WIN32_WINNT here in e_os.h implies certain "discipline." |
| 135 | * Most notably we ought to check for availability of each specific |
| 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. |
| 144 | */ |
| 145 | # define _WIN32_WINNT 0x0501 |
| 146 | # endif |
| 147 | # if defined(_WIN32_WINNT) || defined(_WIN32_WCE) |
| 148 | /* |
| 149 | * Just like defining _WIN32_WINNT including winsock2.h implies |
| 150 | * certain "discipline" for maintaining [broad] binary compatibility. |
| 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 | */ |
| 155 | # include <winsock2.h> |
| 156 | # include <ws2tcpip.h> |
| 157 | /* yes, they have to be #included prior to <windows.h> */ |
| 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) |
| 169 | /* cut strings to 2GB */ |
| 170 | static __inline unsigned int _strlen31(const char *str) |
| 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> |
| 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 |
| 184 | FILE *__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'. |
| 198 | */ |
| 199 | extern FILE *_imp___iob; |
| 200 | # define stdin (&_imp___iob[0]) |
| 201 | # define stdout (&_imp___iob[1]) |
| 202 | # define stderr (&_imp___iob[2]) |
| 203 | # endif |
| 204 | # endif |
| 205 | # endif |
| 206 | # include <io.h> |
| 207 | # include <fcntl.h> |
| 208 | |
| 209 | # ifdef OPENSSL_SYS_WINCE |
| 210 | # define OPENSSL_NO_POSIX_IO |
| 211 | # endif |
| 212 | |
| 213 | # define EXIT(n) exit(n) |
| 214 | # define LIST_SEPARATOR_CHAR ';' |
| 215 | # ifndef W_OK |
| 216 | # define W_OK 2 |
| 217 | # endif |
| 218 | # ifndef R_OK |
| 219 | # define R_OK 4 |
| 220 | # endif |
| 221 | # ifdef OPENSSL_SYS_WINCE |
| 222 | # define DEFAULT_HOME "" |
| 223 | # else |
| 224 | # define DEFAULT_HOME "C:" |
| 225 | # endif |
| 226 | |
| 227 | /* Avoid Visual Studio 13 GetVersion deprecated problems */ |
| 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 |
| 235 | |
| 236 | # else /* The non-microsoft world */ |
| 237 | |
| 238 | # if defined(OPENSSL_SYS_VXWORKS) |
| 239 | # include <sys/times.h> |
| 240 | # else |
| 241 | # include <sys/time.h> |
| 242 | # endif |
| 243 | |
| 244 | # ifdef OPENSSL_SYS_VMS |
| 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 |
| 256 | # define LIST_SEPARATOR_CHAR ',' |
| 257 | /* We don't have any well-defined random devices on VMS, yet... */ |
| 258 | # undef DEVRANDOM |
| 259 | /*- |
| 260 | We need to do this since VMS has the following coding on status codes: |
| 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 |
| 264 | good, while even ones are considered errors. |
| 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 |
| 272 | the status is tagged as an error, which is what is wanted here. |
| 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 |
| 276 | POSIX. 'man perlvms' explains it further. |
| 277 | |
| 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. |
| 281 | -- Richard Levitte |
| 282 | */ |
| 283 | # define EXIT(n) exit((n) ? (((n) << 3) | 2 | 0x10000000 | 0x35a000) : 1) |
| 284 | |
| 285 | # define DEFAULT_HOME "SYS$LOGIN:" |
| 286 | |
| 287 | # else |
| 288 | /* !defined VMS */ |
| 289 | # ifdef OPENSSL_UNISTD |
| 290 | # include OPENSSL_UNISTD |
| 291 | # else |
| 292 | # include <unistd.h> |
| 293 | # endif |
| 294 | # include <sys/types.h> |
| 295 | # ifdef OPENSSL_SYS_WIN32_CYGWIN |
| 296 | # include <io.h> |
| 297 | # include <fcntl.h> |
| 298 | # endif |
| 299 | |
| 300 | # define LIST_SEPARATOR_CHAR ':' |
| 301 | # define EXIT(n) exit(n) |
| 302 | # endif |
| 303 | |
| 304 | # endif |
| 305 | |
| 306 | /***********************************************/ |
| 307 | |
| 308 | # if defined(OPENSSL_SYS_WINDOWS) |
| 309 | # define strcasecmp _stricmp |
| 310 | # define strncasecmp _strnicmp |
| 311 | # if (_MSC_VER >= 1310) && !defined(_WIN32_WCE) |
| 312 | # define open _open |
| 313 | # define fdopen _fdopen |
| 314 | # define close _close |
| 315 | # ifndef strdup |
| 316 | # define strdup _strdup |
| 317 | # endif |
| 318 | # define unlink _unlink |
| 319 | # define fileno _fileno |
| 320 | # endif |
| 321 | # else |
| 322 | # include <strings.h> |
| 323 | # endif |
| 324 | |
| 325 | /* vxworks */ |
| 326 | # if defined(OPENSSL_SYS_VXWORKS) |
| 327 | # include <ioLib.h> |
| 328 | # include <tickLib.h> |
| 329 | # include <sysLib.h> |
| 330 | # include <vxWorks.h> |
| 331 | # include <sockLib.h> |
| 332 | # include <taskLib.h> |
| 333 | |
| 334 | # define TTY_STRUCT int |
| 335 | # define sleep(a) taskDelay((a) * sysClkRateGet()) |
| 336 | |
| 337 | /* |
| 338 | * NOTE: these are implemented by helpers in database app! if the database is |
| 339 | * not linked, we need to implement them elsewhere |
| 340 | */ |
| 341 | struct hostent *gethostbyname(const char *name); |
| 342 | struct hostent *gethostbyaddr(const char *addr, int length, int type); |
| 343 | struct servent *getservbyname(const char *name, const char *proto); |
| 344 | |
| 345 | # endif |
| 346 | /* end vxworks */ |
| 347 | |
| 348 | # ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION |
| 349 | # define CRYPTO_memcmp memcmp |
| 350 | # endif |
| 351 | |
| 352 | /* unistd.h defines _POSIX_VERSION */ |
| 353 | # if !defined(OPENSSL_NO_SECURE_MEMORY) && defined(OPENSSL_SYS_UNIX) \ |
| 354 | && ( (defined(_POSIX_VERSION) && _POSIX_VERSION >= 200112L) \ |
| 355 | || defined(__sun) || defined(__hpux) || defined(__sgi) \ |
| 356 | || defined(__osf__) ) |
| 357 | # define OPENSSL_SECURE_MEMORY /* secure memory is implemented */ |
| 358 | # endif |
| 359 | #endif |