1999-05-15 13:24:16 +00:00
|
|
|
/* e_os2.h */
|
2001-02-19 16:06:34 +00:00
|
|
|
/* ====================================================================
|
|
|
|
* Copyright (c) 1998-2000 The OpenSSL Project. All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
*
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
*
|
|
|
|
* 3. All advertising materials mentioning features or use of this
|
|
|
|
* software must display the following acknowledgment:
|
|
|
|
* "This product includes software developed by the OpenSSL Project
|
|
|
|
* for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
|
|
|
|
*
|
|
|
|
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
|
|
|
|
* endorse or promote products derived from this software without
|
|
|
|
* prior written permission. For written permission, please contact
|
|
|
|
* openssl-core@openssl.org.
|
|
|
|
*
|
|
|
|
* 5. Products derived from this software may not be called "OpenSSL"
|
|
|
|
* nor may "OpenSSL" appear in their names without prior written
|
|
|
|
* permission of the OpenSSL Project.
|
|
|
|
*
|
|
|
|
* 6. Redistributions of any form whatsoever must retain the following
|
|
|
|
* acknowledgment:
|
|
|
|
* "This product includes software developed by the OpenSSL Project
|
|
|
|
* for use in the OpenSSL Toolkit (http://www.openssl.org/)"
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
|
|
|
|
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
|
|
|
|
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
|
|
|
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
* ====================================================================
|
|
|
|
*
|
|
|
|
* This product includes cryptographic software written by Eric Young
|
|
|
|
* (eay@cryptsoft.com). This product includes software written by Tim
|
|
|
|
* Hudson (tjh@cryptsoft.com).
|
|
|
|
*
|
|
|
|
*/
|
1999-05-15 13:24:16 +00:00
|
|
|
|
2001-02-22 13:59:36 +00:00
|
|
|
#include <openssl/opensslconf.h>
|
|
|
|
|
1999-05-15 13:24:16 +00:00
|
|
|
#ifndef HEADER_E_OS2_H
|
|
|
|
#define HEADER_E_OS2_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2001-02-19 16:06:34 +00:00
|
|
|
/******************************************************************************
|
|
|
|
* Detect operating systems. This probably needs completing.
|
|
|
|
* The result is that at least one OPENSSL_SYS_os macro should be defined.
|
|
|
|
* However, if none is defined, Unix is assumed.
|
|
|
|
**/
|
|
|
|
|
|
|
|
#define OPENSSL_SYS_UNIX
|
|
|
|
|
|
|
|
/* ----------------------- Macintosh, before MacOS X ----------------------- */
|
|
|
|
#if defined(__MWERKS__) && defined(macintosh) || defined(OPENSSL_SYSNAME_MAC)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_MACINTOSH_CLASSIC
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ---------------------- Microsoft operating systems ---------------------- */
|
|
|
|
|
|
|
|
/* The 16 bit environments are pretty straightforward */
|
|
|
|
#if defined(OPENSSL_SYSNAME_WIN16) || defined(OPENSSL_SYSNAME_MSDOS)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_MSDOS
|
|
|
|
#endif
|
|
|
|
#if defined(OPENSSL_SYSNAME_WIN16)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_WIN16
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* For 32 bit environment, there seems to be the CygWin environment and then
|
|
|
|
all the others that try to do the same thing Microsoft does... */
|
2002-06-13 21:44:23 +00:00
|
|
|
#if defined(OPENSSL_SYSNAME_UWIN)
|
2001-02-19 16:06:34 +00:00
|
|
|
# undef OPENSSL_SYS_UNIX
|
2002-06-13 21:44:23 +00:00
|
|
|
# define OPENSSL_SYS_WIN32_UWIN
|
2001-02-19 16:06:34 +00:00
|
|
|
#else
|
2002-06-13 21:44:23 +00:00
|
|
|
# if defined(__CYGWIN32__) || defined(OPENSSL_SYSNAME_CYGWIN32)
|
2001-02-19 16:06:34 +00:00
|
|
|
# undef OPENSSL_SYS_UNIX
|
2002-06-13 21:44:23 +00:00
|
|
|
# define OPENSSL_SYS_WIN32_CYGWIN
|
|
|
|
# else
|
|
|
|
# if defined(_WIN32) || defined(OPENSSL_SYSNAME_WIN32)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_WIN32
|
|
|
|
# endif
|
|
|
|
# if defined(OPENSSL_SYSNAME_WINNT)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_WINNT
|
|
|
|
# endif
|
2002-11-15 22:37:18 +00:00
|
|
|
# if defined(OPENSSL_SYSNAME_WINCE)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_WINCE
|
|
|
|
# endif
|
2001-02-19 16:06:34 +00:00
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Anything that tries to look like Microsoft is "Windows" */
|
2002-11-15 22:37:18 +00:00
|
|
|
#if defined(OPENSSL_SYS_WIN16) || defined(OPENSSL_SYS_WIN32) || defined(OPENSSL_SYS_WINNT) || defined(OPENSSL_SYS_WINCE)
|
2001-02-19 16:06:34 +00:00
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_WINDOWS
|
2001-02-22 13:59:36 +00:00
|
|
|
# ifndef OPENSSL_SYS_MSDOS
|
|
|
|
# define OPENSSL_SYS_MSDOS
|
|
|
|
# endif
|
2001-02-19 16:06:34 +00:00
|
|
|
#endif
|
|
|
|
|
2001-03-05 13:45:34 +00:00
|
|
|
/* DLL settings. This part is a bit tough, because it's up to the application
|
|
|
|
implementor how he or she will link the application, so it requires some
|
|
|
|
macro to be used. */
|
|
|
|
#ifdef OPENSSL_SYS_WINDOWS
|
|
|
|
# ifndef OPENSSL_OPT_WINDLL
|
|
|
|
# if defined(_WINDLL) /* This is used when building OpenSSL to indicate that
|
|
|
|
DLL linkage should be used */
|
|
|
|
# define OPENSSL_OPT_WINDLL
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2001-02-19 16:06:34 +00:00
|
|
|
/* -------------------------------- OpenVMS -------------------------------- */
|
|
|
|
#if defined(__VMS) || defined(VMS) || defined(OPENSSL_SYSNAME_VMS)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_VMS
|
|
|
|
# if defined(__DECC)
|
|
|
|
# define OPENSSL_SYS_VMS_DECC
|
2002-04-06 11:37:18 +00:00
|
|
|
# elif defined(__DECCXX)
|
|
|
|
# define OPENSSL_SYS_VMS_DECC
|
|
|
|
# define OPENSSL_SYS_VMS_DECCXX
|
2001-02-19 16:06:34 +00:00
|
|
|
# else
|
|
|
|
# define OPENSSL_SYS_VMS_NODECC
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2001-07-01 22:39:46 +00:00
|
|
|
/* --------------------------------- OS/2 ---------------------------------- */
|
|
|
|
#if defined(__EMX__) || defined(__OS2__)
|
|
|
|
# undef OPENSSL_SYS_UNIX
|
|
|
|
# define OPENSSL_SYS_OS2
|
|
|
|
#endif
|
|
|
|
|
2001-02-19 16:06:34 +00:00
|
|
|
/* --------------------------------- Unix ---------------------------------- */
|
|
|
|
#ifdef OPENSSL_SYS_UNIX
|
2001-09-27 15:41:34 +00:00
|
|
|
# if defined(linux) || defined(__linux__) || defined(OPENSSL_SYSNAME_LINUX)
|
2001-02-19 16:06:34 +00:00
|
|
|
# define OPENSSL_SYS_LINUX
|
|
|
|
# endif
|
|
|
|
# ifdef OPENSSL_SYSNAME_MPE
|
|
|
|
# define OPENSSL_SYS_MPE
|
|
|
|
# endif
|
|
|
|
# ifdef OPENSSL_SYSNAME_SNI
|
|
|
|
# define OPENSSL_SYS_SNI
|
|
|
|
# endif
|
|
|
|
# ifdef OPENSSL_SYSNAME_ULTRASPARC
|
|
|
|
# define OPENSSL_SYS_ULTRASPARC
|
|
|
|
# endif
|
|
|
|
# ifdef OPENSSL_SYSNAME_NEWS4
|
|
|
|
# define OPENSSL_SYS_NEWS4
|
|
|
|
# endif
|
|
|
|
# ifdef OPENSSL_SYSNAME_MACOSX
|
|
|
|
# define OPENSSL_SYS_MACOSX
|
|
|
|
# endif
|
2002-10-10 13:35:49 +00:00
|
|
|
# ifdef OPENSSL_SYSNAME_MACOSX_RHAPSODY
|
|
|
|
# define OPENSSL_SYS_MACOSX_RHAPSODY
|
|
|
|
# define OPENSSL_SYS_MACOSX
|
|
|
|
# endif
|
2002-11-13 16:11:14 +00:00
|
|
|
# ifdef OPENSSL_SYSNAME_SUNOS
|
|
|
|
# define OPENSSL_SYS_SUNOS
|
|
|
|
#endif
|
2001-02-19 16:06:34 +00:00
|
|
|
# if defined(_CRAY) || defined(OPENSSL_SYSNAME_CRAY)
|
|
|
|
# define OPENSSL_SYS_CRAY
|
|
|
|
# endif
|
|
|
|
# if defined(_AIX) || defined(OPENSSL_SYSNAME_AIX)
|
|
|
|
# define OPENSSL_SYS_AIX
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2002-10-09 13:40:48 +00:00
|
|
|
/* ------------------------------- VxWorks --------------------------------- */
|
|
|
|
#ifdef OPENSSL_SYSNAME_VXWORKS
|
|
|
|
# define OPENSSL_SYS_VXWORKS
|
|
|
|
#endif
|
|
|
|
|
2001-02-19 16:06:34 +00:00
|
|
|
/**
|
|
|
|
* That's it for OS-specific stuff
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
/* Specials for I/O an exit */
|
|
|
|
#ifdef OPENSSL_SYS_MSDOS
|
2003-03-20 23:14:49 +00:00
|
|
|
# define OPENSSL_NO_FP_API
|
1999-06-09 13:23:38 +00:00
|
|
|
# define OPENSSL_UNISTD_IO <io.h>
|
|
|
|
# define OPENSSL_DECLARE_EXIT extern void exit(int);
|
|
|
|
#else
|
|
|
|
# define OPENSSL_UNISTD_IO OPENSSL_UNISTD
|
|
|
|
# define OPENSSL_DECLARE_EXIT /* declared in unistd.h */
|
|
|
|
#endif
|
|
|
|
|
2000-12-31 00:15:57 +00:00
|
|
|
/* Definitions of OPENSSL_GLOBAL and OPENSSL_EXTERN, to define and declare
|
|
|
|
certain global symbols that, with some compilers under VMS, have to be
|
|
|
|
defined and declared explicitely with globaldef and globalref.
|
|
|
|
Definitions of OPENSSL_EXPORT and OPENSSL_IMPORT, to define and declare
|
|
|
|
DLL exports and imports for compilers under Win32. These are a little
|
|
|
|
more complicated to use. Basically, for any library that exports some
|
|
|
|
global variables, the following code must be present in the header file
|
|
|
|
that declares them, before OPENSSL_EXTERN is used:
|
|
|
|
|
|
|
|
#ifdef SOME_BUILD_FLAG_MACRO
|
|
|
|
# undef OPENSSL_EXTERN
|
|
|
|
# define OPENSSL_EXTERN OPENSSL_EXPORT
|
|
|
|
#endif
|
|
|
|
|
|
|
|
The default is to have OPENSSL_EXPORT, OPENSSL_IMPORT and OPENSSL_GLOBAL
|
|
|
|
have some generally sensible values, and for OPENSSL_EXTERN to have the
|
|
|
|
value OPENSSL_IMPORT.
|
|
|
|
*/
|
1999-05-15 13:24:16 +00:00
|
|
|
|
2001-02-19 16:06:34 +00:00
|
|
|
#if defined(OPENSSL_SYS_VMS_NODECC)
|
2000-12-31 00:15:57 +00:00
|
|
|
# define OPENSSL_EXPORT globalref
|
|
|
|
# define OPENSSL_IMPORT globalref
|
1999-05-15 13:24:16 +00:00
|
|
|
# define OPENSSL_GLOBAL globaldef
|
2001-03-05 13:45:34 +00:00
|
|
|
#elif defined(OPENSSL_SYS_WINDOWS) && defined(OPENSSL_OPT_WINDLL)
|
2000-12-31 00:15:57 +00:00
|
|
|
# define OPENSSL_EXPORT extern _declspec(dllexport)
|
|
|
|
# define OPENSSL_IMPORT extern _declspec(dllimport)
|
|
|
|
# define OPENSSL_GLOBAL
|
1999-05-15 13:24:16 +00:00
|
|
|
#else
|
2000-12-31 00:15:57 +00:00
|
|
|
# define OPENSSL_EXPORT extern
|
|
|
|
# define OPENSSL_IMPORT extern
|
1999-05-15 13:24:16 +00:00
|
|
|
# define OPENSSL_GLOBAL
|
|
|
|
#endif
|
2000-12-31 00:15:57 +00:00
|
|
|
#define OPENSSL_EXTERN OPENSSL_IMPORT
|
1999-05-15 13:24:16 +00:00
|
|
|
|
Introduce the possibility to access global variables through
functions on platform were that's the best way to handle exporting
global variables in shared libraries. To enable this functionality,
one must configure with "EXPORT_VAR_AS_FN" or defined the C macro
"OPENSSL_EXPORT_VAR_AS_FUNCTION" in crypto/opensslconf.h (the latter
is normally done by Configure or something similar).
To implement a global variable, use the macro OPENSSL_IMPLEMENT_GLOBAL
in the source file (foo.c) like this:
OPENSSL_IMPLEMENT_GLOBAL(int,foo)=1;
OPENSSL_IMPLEMENT_GLOBAL(double,bar);
To declare a global variable, use the macros OPENSSL_DECLARE_GLOBAL
and OPENSSL_GLOBAL_REF in the header file (foo.h) like this:
OPENSSL_DECLARE_GLOBAL(int,foo);
#define foo OPENSSL_GLOBAL_REF(foo)
OPENSSL_DECLARE_GLOBAL(double,bar);
#define bar OPENSSL_GLOBAL_REF(bar)
The #defines are very important, and therefore so is including the
header file everywere where the defined globals are used.
The macro OPENSSL_EXPORT_VAR_AS_FUNCTION also affects the definition
of ASN.1 items, but that structure is a bt different.
The largest change is in util/mkdef.pl which has been enhanced with
better and easier to understand logic to choose which symbols should
go into the Windows .def files as well as a number of fixes and code
cleanup (among others, algorithm keywords are now sorted
lexicographically to avoid constant rewrites).
2001-03-02 10:38:19 +00:00
|
|
|
/* Macros to allow global variables to be reached through function calls when
|
|
|
|
required (if a shared library version requvres it, for example.
|
|
|
|
The way it's done allows definitions like this:
|
|
|
|
|
|
|
|
// in foobar.c
|
|
|
|
OPENSSL_IMPLEMENT_GLOBAL(int,foobar) = 0;
|
|
|
|
// in foobar.h
|
|
|
|
OPENSSL_DECLARE_GLOBAL(int,foobar);
|
|
|
|
#define foobar OPENSSL_GLOBAL_REF(foobar)
|
|
|
|
*/
|
|
|
|
#ifdef OPENSSL_EXPORT_VAR_AS_FUNCTION
|
2001-05-13 17:55:30 +00:00
|
|
|
# define OPENSSL_IMPLEMENT_GLOBAL(type,name) static type _hide_##name; \
|
2001-05-12 23:57:41 +00:00
|
|
|
type *_shadow_##name(void) { return &_hide_##name; } \
|
Introduce the possibility to access global variables through
functions on platform were that's the best way to handle exporting
global variables in shared libraries. To enable this functionality,
one must configure with "EXPORT_VAR_AS_FN" or defined the C macro
"OPENSSL_EXPORT_VAR_AS_FUNCTION" in crypto/opensslconf.h (the latter
is normally done by Configure or something similar).
To implement a global variable, use the macro OPENSSL_IMPLEMENT_GLOBAL
in the source file (foo.c) like this:
OPENSSL_IMPLEMENT_GLOBAL(int,foo)=1;
OPENSSL_IMPLEMENT_GLOBAL(double,bar);
To declare a global variable, use the macros OPENSSL_DECLARE_GLOBAL
and OPENSSL_GLOBAL_REF in the header file (foo.h) like this:
OPENSSL_DECLARE_GLOBAL(int,foo);
#define foo OPENSSL_GLOBAL_REF(foo)
OPENSSL_DECLARE_GLOBAL(double,bar);
#define bar OPENSSL_GLOBAL_REF(bar)
The #defines are very important, and therefore so is including the
header file everywere where the defined globals are used.
The macro OPENSSL_EXPORT_VAR_AS_FUNCTION also affects the definition
of ASN.1 items, but that structure is a bt different.
The largest change is in util/mkdef.pl which has been enhanced with
better and easier to understand logic to choose which symbols should
go into the Windows .def files as well as a number of fixes and code
cleanup (among others, algorithm keywords are now sorted
lexicographically to avoid constant rewrites).
2001-03-02 10:38:19 +00:00
|
|
|
static type _hide_##name
|
|
|
|
# define OPENSSL_DECLARE_GLOBAL(type,name) type *_shadow_##name(void)
|
|
|
|
# define OPENSSL_GLOBAL_REF(name) (*(_shadow_##name()))
|
|
|
|
#else
|
|
|
|
# define OPENSSL_IMPLEMENT_GLOBAL(type,name) OPENSSL_GLOBAL type _shadow_##name
|
|
|
|
# define OPENSSL_DECLARE_GLOBAL(type,name) OPENSSL_EXPORT type _shadow_##name
|
|
|
|
# define OPENSSL_GLOBAL_REF(name) _shadow_##name
|
|
|
|
#endif
|
|
|
|
|
1999-05-15 13:24:16 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|