2008-06-14 03:28:21 +08:00
|
|
|
#ifndef MULTIPROCESSING_H
|
|
|
|
#define MULTIPROCESSING_H
|
|
|
|
|
|
|
|
#define PY_SSIZE_T_CLEAN
|
|
|
|
|
2010-06-05 01:20:56 +08:00
|
|
|
#ifdef __sun
|
2011-02-23 04:15:44 +08:00
|
|
|
/* The control message API is only available on Solaris
|
2010-06-05 01:20:56 +08:00
|
|
|
if XPG 4.2 or later is requested. */
|
|
|
|
#define _XOPEN_SOURCE 500
|
|
|
|
#endif
|
|
|
|
|
2008-06-14 03:28:21 +08: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 23:52:27 +08:00
|
|
|
# include <process.h> /* getpid() */
|
2009-04-02 04:51:28 +08:00
|
|
|
# ifdef Py_DEBUG
|
|
|
|
# include <crtdbg.h>
|
|
|
|
# endif
|
2008-06-14 03:28:21 +08:00
|
|
|
# define SEM_HANDLE HANDLE
|
|
|
|
# define SEM_VALUE_MAX LONG_MAX
|
|
|
|
#else
|
|
|
|
# include <fcntl.h> /* O_CREAT and O_EXCL */
|
2008-11-05 04:45:29 +08:00
|
|
|
# include <netinet/in.h>
|
2008-06-14 03:28:21 +08:00
|
|
|
# include <sys/socket.h>
|
2008-11-05 04:45:29 +08:00
|
|
|
# include <sys/uio.h>
|
2008-06-14 03:28:21 +08:00
|
|
|
# include <arpa/inet.h> /* htonl() and ntohl() */
|
2009-11-28 20:48:43 +08:00
|
|
|
# if defined(HAVE_SEM_OPEN) && !defined(POSIX_SEMAPHORES_NOT_ENABLED)
|
2008-06-14 03:28:21 +08: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-04 02:22:19 +08:00
|
|
|
/*
|
|
|
|
* Issue 3110 - Solaris does not define SEM_VALUE_MAX
|
|
|
|
*/
|
|
|
|
#ifndef SEM_VALUE_MAX
|
2010-05-09 23:52:27 +08: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-04 02:22:19 +08: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-06 05:24:58 +08:00
|
|
|
|
2008-06-14 03:28:21 +08: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 23:52:27 +08:00
|
|
|
PyObject_HEAD
|
|
|
|
HANDLE handle;
|
|
|
|
int flags;
|
|
|
|
PyObject *weakreflist;
|
|
|
|
char buffer[CONNECTION_BUFFER_SIZE];
|
2008-06-14 03:28:21 +08: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 */
|