| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #ifndef MULTIPROCESSING_H
 | 
					
						
							|  |  |  | #define MULTIPROCESSING_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PY_SSIZE_T_CLEAN
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-04 17:20:56 +00:00
										 |  |  | #ifdef __sun
 | 
					
						
							|  |  |  | /* The control message API is only available on Solaris 
 | 
					
						
							|  |  |  |    if XPG 4.2 or later is requested. */ | 
					
						
							|  |  |  | #define _XOPEN_SOURCE 500
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #include "Python.h"
 | 
					
						
							|  |  |  | #include "structmember.h"
 | 
					
						
							|  |  |  | #include "pythread.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Platform includes and definitions | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MS_WINDOWS
 | 
					
						
							|  |  |  | #  define WIN32_LEAN_AND_MEAN
 | 
					
						
							|  |  |  | #  include <windows.h>
 | 
					
						
							|  |  |  | #  include <winsock2.h>
 | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  | #  include <process.h>               /* getpid() */
 | 
					
						
							| 
									
										
										
										
											2009-04-01 20:51:28 +00:00
										 |  |  | #  ifdef Py_DEBUG
 | 
					
						
							|  |  |  | #    include <crtdbg.h>
 | 
					
						
							|  |  |  | #  endif
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #  define SEM_HANDLE HANDLE
 | 
					
						
							|  |  |  | #  define SEM_VALUE_MAX LONG_MAX
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  include <fcntl.h>                 /* O_CREAT and O_EXCL */
 | 
					
						
							| 
									
										
										
										
											2008-11-04 20:45:29 +00:00
										 |  |  | #  include <netinet/in.h>
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #  include <sys/socket.h>
 | 
					
						
							| 
									
										
										
										
											2008-11-04 20:45:29 +00:00
										 |  |  | #  include <sys/uio.h>
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #  include <arpa/inet.h>             /* htonl() and ntohl() */
 | 
					
						
							| 
									
										
										
										
											2009-11-28 12:48:43 +00:00
										 |  |  | #  if defined(HAVE_SEM_OPEN) && !defined(POSIX_SEMAPHORES_NOT_ENABLED)
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | #    include <semaphore.h>
 | 
					
						
							|  |  |  |      typedef sem_t *SEM_HANDLE; | 
					
						
							|  |  |  | #  endif
 | 
					
						
							|  |  |  | #  define HANDLE int
 | 
					
						
							|  |  |  | #  define SOCKET int
 | 
					
						
							|  |  |  | #  define BOOL int
 | 
					
						
							|  |  |  | #  define UINT32 uint32_t
 | 
					
						
							|  |  |  | #  define INT32 int32_t
 | 
					
						
							|  |  |  | #  define TRUE 1
 | 
					
						
							|  |  |  | #  define FALSE 0
 | 
					
						
							|  |  |  | #  define INVALID_HANDLE_VALUE (-1)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-03 18:22:19 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Issue 3110 - Solaris does not define SEM_VALUE_MAX | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifndef SEM_VALUE_MAX
 | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  |     #if defined(HAVE_SYSCONF) && defined(_SC_SEM_VALUE_MAX)
 | 
					
						
							|  |  |  |         # define SEM_VALUE_MAX sysconf(_SC_SEM_VALUE_MAX)
 | 
					
						
							|  |  |  |     #elif defined(_SEM_VALUE_MAX)
 | 
					
						
							|  |  |  |         # define SEM_VALUE_MAX _SEM_VALUE_MAX
 | 
					
						
							|  |  |  |     #elif defined(_POSIX_SEM_VALUE_MAX)
 | 
					
						
							|  |  |  |         # define SEM_VALUE_MAX _POSIX_SEM_VALUE_MAX
 | 
					
						
							|  |  |  |     #else
 | 
					
						
							|  |  |  |         # define SEM_VALUE_MAX INT_MAX
 | 
					
						
							|  |  |  |     #endif
 | 
					
						
							| 
									
										
										
										
											2008-09-03 18:22:19 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Merged revisions 70908,70939,71009,71022,71036 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r70908 | jesse.noller | 2009-03-31 17:20:35 -0500 (Tue, 31 Mar 2009) | 1 line
  Issue 5619: Pass MS CRT debug flags into subprocesses
........
  r70939 | jesse.noller | 2009-03-31 22:45:50 -0500 (Tue, 31 Mar 2009) | 1 line
  Fix multiprocessing.event to match the new threading.Event API
........
  r71009 | jesse.noller | 2009-04-01 19:03:28 -0500 (Wed, 01 Apr 2009) | 1 line
  issue5545: Switch to Autoconf for multiprocessing; special thanks to Martin Lowis for help
........
  r71022 | jesse.noller | 2009-04-01 21:32:55 -0500 (Wed, 01 Apr 2009) | 1 line
  Issue 3110: Additional protection for SEM_VALUE_MAX on platforms, thanks to Martin Loewis
........
  r71036 | jesse.noller | 2009-04-01 23:22:09 -0500 (Wed, 01 Apr 2009) | 1 line
  Issue 3551: Raise ValueError if the size causes ERROR_NO_SYSTEM_RESOURCES
........
											
										 
											2009-04-05 21:24:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Make sure Py_ssize_t available | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if PY_VERSION_HEX < 0x02050000 && !defined(PY_SSIZE_T_MIN)
 | 
					
						
							|  |  |  |    typedef int Py_ssize_t; | 
					
						
							|  |  |  | #  define PY_SSIZE_T_MAX INT_MAX
 | 
					
						
							|  |  |  | #  define PY_SSIZE_T_MIN INT_MIN
 | 
					
						
							|  |  |  | #  define F_PY_SSIZE_T "i"
 | 
					
						
							|  |  |  | #  define PyInt_FromSsize_t(n) PyInt_FromLong((long)n)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  define F_PY_SSIZE_T "n"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Format codes | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if SIZEOF_VOID_P == SIZEOF_LONG
 | 
					
						
							|  |  |  | #  define F_POINTER "k"
 | 
					
						
							|  |  |  | #  define T_POINTER T_ULONG
 | 
					
						
							|  |  |  | #elif defined(HAVE_LONG_LONG) && (SIZEOF_VOID_P == SIZEOF_LONG_LONG)
 | 
					
						
							|  |  |  | #  define F_POINTER "K"
 | 
					
						
							|  |  |  | #  define T_POINTER T_ULONGLONG
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  error "can't find format code for unsigned integer of same size as void*"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MS_WINDOWS
 | 
					
						
							|  |  |  | #  define F_HANDLE F_POINTER
 | 
					
						
							|  |  |  | #  define T_HANDLE T_POINTER
 | 
					
						
							|  |  |  | #  define F_SEM_HANDLE F_HANDLE
 | 
					
						
							|  |  |  | #  define T_SEM_HANDLE T_HANDLE
 | 
					
						
							|  |  |  | #  define F_DWORD "k"
 | 
					
						
							|  |  |  | #  define T_DWORD T_ULONG
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  define F_HANDLE "i"
 | 
					
						
							|  |  |  | #  define T_HANDLE T_INT
 | 
					
						
							|  |  |  | #  define F_SEM_HANDLE F_POINTER
 | 
					
						
							|  |  |  | #  define T_SEM_HANDLE T_POINTER
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if PY_VERSION_HEX >= 0x03000000
 | 
					
						
							|  |  |  | #  define F_RBUFFER "y"
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  define F_RBUFFER "s"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Error codes which can be returned by functions called without GIL | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MP_SUCCESS (0)
 | 
					
						
							|  |  |  | #define MP_STANDARD_ERROR (-1)
 | 
					
						
							|  |  |  | #define MP_MEMORY_ERROR (-1001)
 | 
					
						
							|  |  |  | #define MP_END_OF_FILE (-1002)
 | 
					
						
							|  |  |  | #define MP_EARLY_END_OF_FILE (-1003)
 | 
					
						
							|  |  |  | #define MP_BAD_MESSAGE_LENGTH (-1004)
 | 
					
						
							|  |  |  | #define MP_SOCKET_ERROR (-1005)
 | 
					
						
							|  |  |  | #define MP_EXCEPTION_HAS_BEEN_SET (-1006)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyObject *mp_SetError(PyObject *Type, int num); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Externs - not all will really exist on all platforms | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern PyObject *pickle_dumps; | 
					
						
							|  |  |  | extern PyObject *pickle_loads; | 
					
						
							|  |  |  | extern PyObject *pickle_protocol; | 
					
						
							|  |  |  | extern PyObject *BufferTooShort; | 
					
						
							|  |  |  | extern PyTypeObject SemLockType; | 
					
						
							|  |  |  | extern PyTypeObject ConnectionType; | 
					
						
							|  |  |  | extern PyTypeObject PipeConnectionType; | 
					
						
							|  |  |  | extern HANDLE sigint_event; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Py3k compatibility | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if PY_VERSION_HEX >= 0x03000000
 | 
					
						
							|  |  |  | #  define PICKLE_MODULE "pickle"
 | 
					
						
							|  |  |  | #  define FROM_FORMAT PyUnicode_FromFormat
 | 
					
						
							|  |  |  | #  define PyInt_FromLong PyLong_FromLong
 | 
					
						
							|  |  |  | #  define PyInt_FromSsize_t PyLong_FromSsize_t
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  define PICKLE_MODULE "cPickle"
 | 
					
						
							|  |  |  | #  define FROM_FORMAT PyString_FromFormat
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef PyVarObject_HEAD_INIT
 | 
					
						
							|  |  |  | #  define PyVarObject_HEAD_INIT(type, size) PyObject_HEAD_INIT(type) size,
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef Py_TPFLAGS_HAVE_WEAKREFS
 | 
					
						
							|  |  |  | #  define Py_TPFLAGS_HAVE_WEAKREFS 0
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Connection definition | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CONNECTION_BUFFER_SIZE 1024
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  |     PyObject_HEAD | 
					
						
							|  |  |  |     HANDLE handle; | 
					
						
							|  |  |  |     int flags; | 
					
						
							|  |  |  |     PyObject *weakreflist; | 
					
						
							|  |  |  |     char buffer[CONNECTION_BUFFER_SIZE]; | 
					
						
							| 
									
										
										
										
											2008-06-13 19:28:21 +00:00
										 |  |  | } ConnectionObject; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Miscellaneous | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MAX_MESSAGE_LENGTH 0x7fffffff
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef MIN
 | 
					
						
							|  |  |  | #  define MIN(x, y) ((x) < (y) ? x : y)
 | 
					
						
							|  |  |  | #  define MAX(x, y) ((x) > (y) ? x : y)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* MULTIPROCESSING_H */
 |