1
1
openmpi/opal/win32/win_compat.h

337 строки
9.6 KiB
C
Исходник Обычный вид История

/*
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation. All rights reserved.
* Copyright (c) 2004-2006 The University of Tennessee and The University
* of Tennessee Research Foundation. All rights
* reserved.
2015-06-23 20:59:57 -07:00
* Copyright (c) 2004-2009 High Performance Computing Center Stuttgart,
* University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2005 The Regents of the University of California.
* All rights reserved.
* Copyright (c) 2014 Cisco Systems, Inc. All rights reserved.
* $COPYRIGHT$
2015-06-23 20:59:57 -07:00
*
* Additional copyrights may follow
2015-06-23 20:59:57 -07:00
*
* $HEADER$
*/
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-) WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic. This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
#ifndef OPAL_WIN_COMPAT_H
#define OPAL_WIN_COMPAT_H
/**
* don't complain about all the deprecated functions.
*/
#define _CRT_SECURE_NO_DEPRECATE
/**
* Allow usage of some recent functions (such as SwitchToThread)
* 0x0400 - for SwitchToThread
* 0x0500 - for using Event Objects
*/
#define _WIN32_WINNT 0x0502
/**
* Windows does not define the exact same names in stat.h
* Redefine them to our names.
* Supposedly, links are not available
*/
#define S_IFLNK 0xFFFF /* identifies the file as a symbolic link */
#define S_IXUSR _S_IEXEC /* execute/search permission, owner */
#define S_IRUSR _S_IREAD /* read permission, owner */
#define S_IWUSR _S_IWRITE /* write permission, owner */
/**
* Define it in order to get access to the "secure" version of rand.
*/
#define _CRT_RAND_S
2015-06-23 20:59:57 -07:00
/* It is always better to include windows.h with the lean and mean option.
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-) WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic. This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
So, include it with that option and then include some which are required.
Note: this file is included only on windows */
#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif /* WIN32_LEAN_AND_MEAN */
#ifndef VC_EXTRALEAN
#define VC_EXTRALEAN
#endif /* VC_EXTRALEAN */
#include <windows.h>
2015-06-23 20:59:57 -07:00
/* FD_SETSIZE determines how many sockets windows can select() on. If not defined
before including winsock2.h, it is defined to be 64. We are going to go ahead and
make it 1024 for now. PLEASE CHECK IF THIS IS RIGHT */
#define FD_SETSIZE 1024
/* other utility header files */
#include <shellapi.h>
#include <winsock2.h>
#include <ws2tcpip.h>
#include <process.h>
#include <signal.h>
#include <conio.h>
#include <fcntl.h>
#include <stdint.h>
/**
* For all file io operations
*/
#include <direct.h>
#include <io.h>
#include <stdlib.h>
/* for alloca */
#include <malloc.h>
#define STDIN_FILENO 0
#define STDOUT_FILENO 1
#define STDERR_FILENO 2
typedef unsigned short mode_t;
typedef long ssize_t;
typedef DWORD in_port_t;
typedef char* caddr_t;
typedef unsigned int uint;
#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif
#ifdef _MSC_VER
#if defined(OMPI_BUILDING) && OMPI_BUILDING
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-) WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic. This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
#include "opal/win32/opal_uio.h"
#include "opal/win32/opal_time.h"
#include "opal/win32/opal_utsname.h"
#include "opal/win32/opal_util.h"
#include "opal/win32/opal_misc.h"
#include "opal/win32/opal_inet.h"
#include "opal/win32/opal_socket.h"
#endif
/* Defines for the access functions */
#define F_OK 0x00
#define R_OK 0x04
#define W_OK 0x02
#define X_OK R_OK /* no execution right on Windows */
#define S_IRWXU (_S_IREAD | _S_IWRITE | _S_IEXEC)
/**
* Microsoft compiler complain about non conformance of the default UNIX function.
* Non conformance to the POSIX standard, and they suggest to use the version
* starting with an _ instead. So, in order to keep cl.exe happy (and quiet) we can
* use the followings defines.
*/
#define getpid _getpid
#define strdup _strdup
#define putenv _putenv
#define getcwd _getcwd
#define rmdir _rmdir
#define chdir _chdir
#define chmod _chmod
#define access _access
#define open _open
#define close _close
#define unlink _unlink
#define dup2 _dup2
#define dup _dup
2015-06-23 20:59:57 -07:00
#define write _write
#define read _read
#define fileno _fileno
#define isatty _isatty
#define execvp _execvp
#define S_ISDIR(STAT_MODE) ((STAT_MODE) & _S_IFDIR)
#define S_ISREG(STAT_MODE) ((STAT_MODE) & _S_IFREG)
#define strncasecmp _strnicmp
#define strcasecmp _stricmp
#define umask _umask
#define getch _getch
#define random rand
#define strtok_r strtok_s
#define srand48 srand
#define lrand48 rand
#define usleep(t) Sleep(t/1000)
#define posix_memalign(p, a, s) *p=_aligned_malloc(s,a)
#else
#undef WSABASEERR
/* in MinGW, PACKED is defined to __attribute__((packed)), will have problem for our basic types */
#undef PACKED
#define pthread_atfork
#include <winsock.h>
#if defined(OMPI_BUILDING) && OMPI_BUILDING
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-) WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic. This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
#include "opal/win32/opal_uio.h"
#include "opal/win32/opal_utsname.h"
#include "opal/win32/opal_util.h"
#include "opal/win32/opal_inet.h"
#include "opal/win32/opal_misc.h"
#include "opal/win32/opal_socket.h"
#endif
#define strtok_r(s,d,p) *p = strtok(s,d)
#endif
#define MAXPATHLEN _MAX_PATH
#define MAXHOSTNAMELEN _MAX_PATH
#define PATH_MAX _MAX_PATH
#define WTERMSIG(EXIT_CODE) (1)
#define WIFEXITED(EXIT_CODE) (1)
#define WEXITSTATUS(EXIT_CODE) (EXIT_CODE)
#define WIFSIGNALED(EXIT_CODE) (0)
#define WIFSTOPPED(EXIT_CODE) (0)
#define WSTOPSIG(EXIT_CODE) (11)
#define mkdir(PATH, MODE) _mkdir((PATH))
#define nanosleep(tp, rem) Sleep(*tp.tv_sec*1000+*tp.tv_nsec/1000000)
#define pipe(array_fd) _pipe(array_fd, 1024, O_BINARY )
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-) WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic. This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
#define inet_ntop opal_inet_ntop
#define inet_pton opal_inet_pton
#define lstat stat
#ifndef UINT64_MAX
#define UINT64_MAX 0xffffffffffffffffULL /* 18446744073709551615ULL */
#endif
#ifndef UINT64_MIN
#define UINT64_MIN 0
#endif
#ifndef INT64_MAX
#define INT64_MAX 0x7fffffffffffffffLL /*9223372036854775807LL*/
#endif
#ifndef INT64_MIN
#define INT64_MIN (-0x7fffffffffffffffLL - 1) /* (-9223372036854775807 - 1) */
#endif
#ifndef UINT32_MAX
#define UINT32_MAX 0xffffffff /* 4294967295U */
#endif
#ifndef UINT32_MIN
#define UINT32_MIN 0
#endif
#ifndef INT32_MAX
#define INT32_MAX 0x7fffffff /* 2147483647 */
#endif
#ifndef INT32_MIN
#define INT32_MIN (-0x7fffffff - 1) /* (-2147483647 - 1) */
#endif
#ifndef UINT16_MAX
#define UINT16_MAX 0xffff /* 65535U */
#endif
#ifndef UINT16_MIN
#define UINT16_MIN 0
#endif
#ifndef INT16_MAX
#define INT16_MAX 0x7fff /* 32767 */
#endif
#ifndef INT16_MIN
#define INT16_MIN (-0x7fff - 1) /* (-32768) */
#endif
#ifndef UINT8_MAX
#define UINT8_MAX 0xff /* 255U */
#endif
#ifndef UINT8_MIN
#define UINT8_MIN 0
#endif
#ifndef INT8_MAX
#define INT8_MAX 0x7f /* 127 */
#endif
#ifndef INT8_MIN
#define INT8_MIN (-0x7f - 1) /* (-128) */
#endif
/* Make sure we let the compiler know that we support __func__ */
#if !defined(HAVE_DECL___FUNC__)
#define HAVE_DECL___FUNC__ 1
#endif
/*#define strncpy strncpy_s*/
/*#define sprintf sprintf_s*/
/* Ugly signal mapping since windows doesn't support the full spectrum
* just a very small subset... :/
* http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vclib/html/_crt_raise.asp
* http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnucmg/html/UCMGch09.asp
*/
#define SIGHUP 1
/* 2 is used for SIGINT on windows */
#define SIGQUIT 3
/* 4 is used for SIGILL on windows */
#define SIGTRAP 5
#define SIGIOT 6
#define SIGBUS 7
/* 8 is used for SIGFPE on windows */
#define SIGKILL 9
#define SIGUSR1 10
/* 11 is used for SIGSEGV on windows */
2015-06-23 20:59:57 -07:00
#define SIGUSR2 12
#define SIGPIPE 13
#define SIGALRM 14
/* 15 is used for SIGTERM on windows */
#define SIGSTKFLT 16
#define SIGCHLD 17
#define SIGCONT 18
#define SIGSTOP 19
#define SIGTSTP 20
/* 21 is used for SIGBREAK on windows */
/* 22 is used for SIGABRT on windows */
#define SIGTTIN 23
#define SIGTTOU 24
#define SIGURG 25
#define SIGXCPU 26
#define SIGXFSZ 27
#define SIGVTALRM 28
#define SIGPROF 29
#define SIGWINCH 30
#define SIGIO 31
2015-06-23 20:59:57 -07:00
/* Note:
* The two defines below are likely to break the orte_wait
* functionality. The proper method of replacing these bits
* of functionality is left for further investigated.
*/
#define WUNTRACED 0
#define WNOHANG 0
#define sigset_t int
#define in_addr_t uint32_t
2015-06-23 20:59:57 -07:00
/* Need to define _Bool here for different version of VS.
The definition in opal_config_bottom.h won't help,
as long as we have a mixed C and C++ projects in one solution. */
#if defined(_MSC_VER) && _MSC_VER < 1600
#define _Bool BOOL
#else
#define _Bool bool
#endif
/*
* No syslog.h on Windows, but these have to be defined somehow.
* There could also be a notifier component later for Windows.
*/
#define LOG_EMERG 0
#define LOG_ALERT 1
#define LOG_CRIT 2
#define LOG_ERR 3
#define LOG_WARNING 4
#define LOG_NOTICE 5
#define LOG_INFO 6
#define LOG_DEBUG 7
/*
* Mask these to Windows equivalents
*/
#define bzero(p, l) memset(p, 0, l)
#define bcopy(s, t, l) memmove(t, s, l)
#define isblank(c) (c == ' ' || c == '\t')?1:0
/*
* OMPI functions that need to be redefined.
*/
#define ompi_debugger_notify_abort(x)
#define ompi_wait_for_debugger(x)
#endif /* compat */