blob: 59a2f285774a175e23db07b0cf88af7ecdefacf4 [file] [log] [blame]
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001/* Socket module */
2
3/*
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004
Guido van Rossum6574b3e1991-06-25 21:36:08 +00005This module provides an interface to Berkeley socket IPC.
6
7Limitations:
8
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00009- Only AF_INET, AF_INET6 and AF_UNIX address families are supported in a
Christian Heimes043d6f62008-01-07 17:19:16 +000010 portable manner, though AF_PACKET, AF_NETLINK and AF_TIPC are supported
11 under Linux.
Guido van Rossumc4fcfa32002-06-07 03:19:37 +000012- No read/write operations (use sendall/recv or makefile instead).
13- Additional restrictions apply on some non-Unix platforms (compensated
14 for by socket.py).
Guido van Rossum6574b3e1991-06-25 21:36:08 +000015
Guido van Rossum27e177d1995-03-16 15:43:47 +000016Module interface:
Guido van Rossum6574b3e1991-06-25 21:36:08 +000017
Guido van Rossum27e177d1995-03-16 15:43:47 +000018- socket.error: exception raised for socket specific errors
Martin v. Löwis2d8d4272001-07-21 18:05:31 +000019- socket.gaierror: exception raised for getaddrinfo/getnameinfo errors,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000020 a subclass of socket.error
Martin v. Löwis2d8d4272001-07-21 18:05:31 +000021- socket.herror: exception raised for gethostby* errors,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000022 a subclass of socket.error
Guido van Rossum30a685f1991-06-27 15:51:29 +000023- socket.gethostbyname(hostname) --> host IP address (string: 'dd.dd.dd.dd')
Guido van Rossum3bbc62e1995-01-02 19:30:30 +000024- socket.gethostbyaddr(IP address) --> (hostname, [alias, ...], [IP addr, ...])
Guido van Rossum27e177d1995-03-16 15:43:47 +000025- socket.gethostname() --> host name (string: 'spam' or 'spam.domain.com')
Guido van Rossum25405c71996-12-19 16:42:52 +000026- socket.getprotobyname(protocolname) --> protocol number
Barry Warsaw11b91a02004-06-28 00:50:43 +000027- socket.getservbyname(servicename[, protocolname]) --> port number
28- socket.getservbyport(portnumber[, protocolname]) --> service name
Guido van Rossum7d0a8262007-05-21 23:13:11 +000029- socket.socket([family[, type [, proto, fileno]]]) --> new socket object
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000030 (fileno specifies a pre-existing socket file descriptor)
Dave Cole331708b2004-08-09 04:51:41 +000031- socket.socketpair([family[, type [, proto]]]) --> (socket, socket)
Guido van Rossum006bf911996-06-12 04:04:55 +000032- socket.ntohs(16 bit value) --> new int object
33- socket.ntohl(32 bit value) --> new int object
34- socket.htons(16 bit value) --> new int object
35- socket.htonl(32 bit value) --> new int object
Martin v. Löwis2d8d4272001-07-21 18:05:31 +000036- socket.getaddrinfo(host, port [, family, socktype, proto, flags])
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000037 --> List of (family, socktype, proto, canonname, sockaddr)
Martin v. Löwis2d8d4272001-07-21 18:05:31 +000038- socket.getnameinfo(sockaddr, flags) --> (host, port)
Guido van Rossum27e177d1995-03-16 15:43:47 +000039- socket.AF_INET, socket.SOCK_STREAM, etc.: constants from <socket.h>
Guido van Rossum47dfa4a2003-04-25 05:48:32 +000040- socket.has_ipv6: boolean value indicating if IPv6 is supported
Guido van Rossum5c9eb211999-08-20 18:21:51 +000041- socket.inet_aton(IP address) -> 32-bit packed IP representation
42- socket.inet_ntoa(packed IP) -> IP address string
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +000043- socket.getdefaulttimeout() -> None | float
44- socket.setdefaulttimeout(None | float)
Gregory P. Smith5ed2e772011-05-15 00:26:45 -070045- socket.if_nameindex() -> list of tuples (if_index, if_name)
46- socket.if_nametoindex(name) -> corresponding interface index
47- socket.if_indextoname(index) -> corresponding interface name
Guido van Rossum6574b3e1991-06-25 21:36:08 +000048- an Internet socket address is a pair (hostname, port)
49 where hostname can be anything recognized by gethostbyname()
50 (including the dd.dd.dd.dd notation) and port is in host byte order
51- where a hostname is returned, the dd.dd.dd.dd notation is used
Guido van Rossum27e177d1995-03-16 15:43:47 +000052- a UNIX domain socket address is a string specifying the pathname
Jeremy Hylton22308652001-02-02 03:23:09 +000053- an AF_PACKET socket address is a tuple containing a string
54 specifying the ethernet interface and an integer specifying
55 the Ethernet protocol number to be received. For example:
Jeremy Hyltondbfb6622001-02-02 19:55:17 +000056 ("eth0",0x1234). Optional 3rd,4th,5th elements in the tuple
Andrew M. Kuchlingb8e17172004-07-10 23:39:35 +000057 specify packet-type and ha-type/addr.
Christian Heimes043d6f62008-01-07 17:19:16 +000058- an AF_TIPC socket address is expressed as
59 (addr_type, v1, v2, v3 [, scope]); where addr_type can be one of:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000060 TIPC_ADDR_NAMESEQ, TIPC_ADDR_NAME, and TIPC_ADDR_ID;
Christian Heimes043d6f62008-01-07 17:19:16 +000061 and scope can be one of:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000062 TIPC_ZONE_SCOPE, TIPC_CLUSTER_SCOPE, and TIPC_NODE_SCOPE.
Christian Heimes043d6f62008-01-07 17:19:16 +000063 The meaning of v1, v2 and v3 depends on the value of addr_type:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000064 if addr_type is TIPC_ADDR_NAME:
65 v1 is the server type
66 v2 is the port identifier
67 v3 is ignored
68 if addr_type is TIPC_ADDR_NAMESEQ:
69 v1 is the server type
70 v2 is the lower port number
71 v3 is the upper port number
72 if addr_type is TIPC_ADDR_ID:
73 v1 is the node
74 v2 is the ref
75 v3 is ignored
Christian Heimes043d6f62008-01-07 17:19:16 +000076
Guido van Rossum6574b3e1991-06-25 21:36:08 +000077
Guido van Rossumc4fcfa32002-06-07 03:19:37 +000078Local naming conventions:
Guido van Rossum6574b3e1991-06-25 21:36:08 +000079
Guido van Rossumc4fcfa32002-06-07 03:19:37 +000080- names starting with sock_ are socket object methods
81- names starting with socket_ are module-level functions
82- names starting with PySocket are exported through socketmodule.h
Guido van Rossum30a685f1991-06-27 15:51:29 +000083
Guido van Rossum6574b3e1991-06-25 21:36:08 +000084*/
85
Thomas Wouters477c8d52006-05-27 19:21:47 +000086#ifdef __APPLE__
87 /*
88 * inet_aton is not available on OSX 10.3, yet we want to use a binary
89 * that was build on 10.4 or later to work on that release, weak linking
90 * comes to the rescue.
91 */
92# pragma weak inet_aton
93#endif
94
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000095#include "Python.h"
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000096#include "structmember.h"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000097
Guido van Rossum47dfa4a2003-04-25 05:48:32 +000098#undef MAX
99#define MAX(x, y) ((x) < (y) ? (y) : (x))
100
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000101/* Socket object documentation */
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000102PyDoc_STRVAR(sock_doc,
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000103"socket([family[, type[, proto]]]) -> socket object\n\
104\n\
105Open a socket of the given type. The family argument specifies the\n\
106address family; it defaults to AF_INET. The type argument specifies\n\
107whether this is a stream (SOCK_STREAM, this is the default)\n\
108or datagram (SOCK_DGRAM) socket. The protocol argument defaults to 0,\n\
109specifying the default protocol. Keyword arguments are accepted.\n\
110\n\
111A socket object represents one endpoint of a network connection.\n\
112\n\
113Methods of socket objects (keyword arguments not allowed):\n\
114\n\
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000115_accept() -- accept connection, returning new socket fd and client address\n\
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000116bind(addr) -- bind the socket to a local address\n\
117close() -- close the socket\n\
118connect(addr) -- connect the socket to a remote address\n\
119connect_ex(addr) -- connect, return an error code instead of an exception\n\
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000120_dup() -- return a new socket fd duplicated from fileno()\n\
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000121fileno() -- return underlying file descriptor\n\
122getpeername() -- return remote address [*]\n\
123getsockname() -- return local address\n\
124getsockopt(level, optname[, buflen]) -- get socket options\n\
125gettimeout() -- return timeout or None\n\
126listen(n) -- start listening for incoming connections\n\
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000127recv(buflen[, flags]) -- receive data\n\
Thomas Wouters73e5a5b2006-06-08 15:35:45 +0000128recv_into(buffer[, nbytes[, flags]]) -- receive data (into a buffer)\n\
Thomas Wouters477c8d52006-05-27 19:21:47 +0000129recvfrom(buflen[, flags]) -- receive data and sender\'s address\n\
Thomas Wouters73e5a5b2006-06-08 15:35:45 +0000130recvfrom_into(buffer[, nbytes, [, flags])\n\
Thomas Wouters477c8d52006-05-27 19:21:47 +0000131 -- receive data and sender\'s address (into a buffer)\n\
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000132sendall(data[, flags]) -- send all data\n\
133send(data[, flags]) -- send data, may not send all of it\n\
134sendto(data[, flags], addr) -- send data to a given address\n\
135setblocking(0 | 1) -- set or clear the blocking I/O flag\n\
136setsockopt(level, optname, value) -- set socket options\n\
137settimeout(None | float) -- set or clear the timeout\n\
138shutdown(how) -- shut down traffic in one or both directions\n\
Gregory P. Smith5ed2e772011-05-15 00:26:45 -0700139if_nameindex() -- return all network interface indices and names\n\
Gregory P. Smithb6471db2011-05-22 22:47:55 -0700140if_nametoindex(name) -- return the corresponding interface index\n\
141if_indextoname(index) -- return the corresponding interface name\n\
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000142\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000143 [*] not available on all platforms!");
Guido van Rossum3baaa131999-03-22 21:44:51 +0000144
Walter Dörwaldf0dfc7a2003-10-20 14:01:56 +0000145/* XXX This is a terrible mess of platform-dependent preprocessor hacks.
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000146 I hope some day someone can clean this up please... */
147
Guido van Rossum9376b741999-09-15 22:01:40 +0000148/* Hacks for gethostbyname_r(). On some non-Linux platforms, the configure
149 script doesn't get this right, so we hardcode some platform checks below.
150 On the other hand, not all Linux versions agree, so there the settings
151 computed by the configure script are needed! */
152
153#ifndef linux
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000154# undef HAVE_GETHOSTBYNAME_R_3_ARG
155# undef HAVE_GETHOSTBYNAME_R_5_ARG
156# undef HAVE_GETHOSTBYNAME_R_6_ARG
Guido van Rossum9376b741999-09-15 22:01:40 +0000157#endif
Guido van Rossume7de2061999-03-24 17:24:33 +0000158
Victor Stinner710d27e2011-08-23 10:57:32 +0200159#if defined(__OpenBSD__)
160# include <sys/uio.h>
161#endif
162
Guido van Rossum7a122991999-04-13 04:07:32 +0000163#ifndef WITH_THREAD
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000164# undef HAVE_GETHOSTBYNAME_R
Guido van Rossum7a122991999-04-13 04:07:32 +0000165#endif
166
Guido van Rossume7de2061999-03-24 17:24:33 +0000167#ifdef HAVE_GETHOSTBYNAME_R
Jesus Cea736e7fc2011-03-14 17:36:54 +0100168# if defined(_AIX)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000169# define HAVE_GETHOSTBYNAME_R_3_ARG
170# elif defined(__sun) || defined(__sgi)
171# define HAVE_GETHOSTBYNAME_R_5_ARG
172# elif defined(linux)
Guido van Rossum9376b741999-09-15 22:01:40 +0000173/* Rely on the configure script */
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000174# else
175# undef HAVE_GETHOSTBYNAME_R
176# endif
Guido van Rossume7de2061999-03-24 17:24:33 +0000177#endif
178
Guido van Rossum3eede5a2002-06-07 02:08:35 +0000179#if !defined(HAVE_GETHOSTBYNAME_R) && defined(WITH_THREAD) && \
180 !defined(MS_WINDOWS)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000181# define USE_GETHOSTBYNAME_LOCK
Guido van Rossum3baaa131999-03-22 21:44:51 +0000182#endif
183
Hye-Shik Chang9ceebd52005-09-24 14:58:47 +0000184/* To use __FreeBSD_version */
185#ifdef HAVE_SYS_PARAM_H
186#include <sys/param.h>
187#endif
Just van Rossum1040d2c2003-05-09 07:53:18 +0000188/* On systems on which getaddrinfo() is believed to not be thread-safe,
Just van Rossum09aecd72003-05-09 08:03:44 +0000189 (this includes the getaddrinfo emulation) protect access with a lock. */
Hye-Shik Chang9ceebd52005-09-24 14:58:47 +0000190#if defined(WITH_THREAD) && (defined(__APPLE__) || \
191 (defined(__FreeBSD__) && __FreeBSD_version+0 < 503000) || \
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000192 defined(__OpenBSD__) || defined(__NetBSD__) || \
193 defined(__VMS) || !defined(HAVE_GETADDRINFO))
Just van Rossum1040d2c2003-05-09 07:53:18 +0000194#define USE_GETADDRINFO_LOCK
195#endif
196
197#ifdef USE_GETADDRINFO_LOCK
198#define ACQUIRE_GETADDRINFO_LOCK PyThread_acquire_lock(netdb_lock, 1);
199#define RELEASE_GETADDRINFO_LOCK PyThread_release_lock(netdb_lock);
200#else
201#define ACQUIRE_GETADDRINFO_LOCK
202#define RELEASE_GETADDRINFO_LOCK
203#endif
204
205#if defined(USE_GETHOSTBYNAME_LOCK) || defined(USE_GETADDRINFO_LOCK)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000206# include "pythread.h"
Guido van Rossum4f199ea1998-04-09 20:56:35 +0000207#endif
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000208
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000209#if defined(PYCC_VACPP)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000210# include <types.h>
211# include <io.h>
212# include <sys/ioctl.h>
213# include <utils.h>
214# include <ctype.h>
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000215#endif
216
Martin v. Löwis9e437302002-12-06 12:57:26 +0000217#if defined(__VMS)
Martin v. Löwis79acb9e2002-12-06 12:48:53 +0000218# include <ioctl.h>
219#endif
220
Martin v. Löwis9d6c6692012-02-03 17:44:58 +0100221#ifdef __APPLE__
222# include <sys/ioctl.h>
223#endif
224
225
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000226#if defined(PYOS_OS2)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000227# define INCL_DOS
228# define INCL_DOSERRORS
229# define INCL_NOPMAPI
230# include <os2.h>
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000231#endif
232
Jeremy Hyltonfb509a32003-07-17 16:58:48 +0000233#if defined(__sgi) && _COMPILER_VERSION>700 && !_SGIAPI
Martin v. Löwis8eb92a02002-09-19 08:03:21 +0000234/* make sure that the reentrant (gethostbyaddr_r etc)
235 functions are declared correctly if compiling with
236 MIPSPro 7.x in ANSI C mode (default) */
Jeremy Hyltonfb509a32003-07-17 16:58:48 +0000237
Thomas Wouters477c8d52006-05-27 19:21:47 +0000238/* XXX Using _SGIAPI is the wrong thing,
Jeremy Hyltonfb509a32003-07-17 16:58:48 +0000239 but I don't know what the right thing is. */
Trent Mick8ea5bdf2004-09-13 17:48:41 +0000240#undef _SGIAPI /* to avoid warning */
Martin v. Löwis8eb92a02002-09-19 08:03:21 +0000241#define _SGIAPI 1
Jeremy Hyltonfb509a32003-07-17 16:58:48 +0000242
Trent Mick8ea5bdf2004-09-13 17:48:41 +0000243#undef _XOPEN_SOURCE
244#include <sys/socket.h>
245#include <sys/types.h>
246#include <netinet/in.h>
247#ifdef _SS_ALIGNSIZE
248#define HAVE_GETADDRINFO 1
249#define HAVE_GETNAMEINFO 1
250#endif
251
Jeremy Hyltonfb509a32003-07-17 16:58:48 +0000252#define HAVE_INET_PTON
253#include <netdb.h>
Martin v. Löwis8eb92a02002-09-19 08:03:21 +0000254#endif
255
Thomas Wouters477c8d52006-05-27 19:21:47 +0000256/* Irix 6.5 fails to define this variable at all. This is needed
257 for both GCC and SGI's compiler. I'd say that the SGI headers
Georg Brandldbd83392006-02-20 09:42:33 +0000258 are just busted. Same thing for Solaris. */
259#if (defined(__sgi) || defined(sun)) && !defined(INET_ADDRSTRLEN)
Anthony Baxterbab23cf2003-10-04 08:00:49 +0000260#define INET_ADDRSTRLEN 16
261#endif
262
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000263/* Generic includes */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000264#ifdef HAVE_SYS_TYPES_H
Guido van Rossumb6775db1994-08-01 11:34:53 +0000265#include <sys/types.h>
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000266#endif
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000267
Gregory P. Smith3b1f2c32011-05-15 12:18:23 -0700268#ifdef HAVE_SYS_SOCKET_H
269#include <sys/socket.h>
270#endif
271
272#ifdef HAVE_NET_IF_H
273#include <net/if.h>
274#endif
275
Marc-André Lemburg976ade62002-02-16 18:47:07 +0000276/* Generic socket object definitions and includes */
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000277#define PySocket_BUILDING_SOCKET
Marc-André Lemburgbb8b78b2002-02-16 18:44:52 +0000278#include "socketmodule.h"
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000279
280/* Addressing includes */
281
Guido van Rossum6f489d91996-06-28 20:15:15 +0000282#ifndef MS_WINDOWS
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000283
284/* Non-MS WINDOWS includes */
285# include <netdb.h>
Nick Coghlan4ecf6cf2011-08-22 15:45:19 +1000286# include <unistd.h>
Guido van Rossum5c9eb211999-08-20 18:21:51 +0000287
Guido van Rossum9376b741999-09-15 22:01:40 +0000288/* Headers needed for inet_ntoa() and inet_addr() */
Skip Montanaroeb33e5a2007-08-17 12:57:41 +0000289# if defined(PYOS_OS2) && defined(PYCC_VACPP)
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000290# include <netdb.h>
Tim Peters603c6832001-11-05 02:45:59 +0000291typedef size_t socklen_t;
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000292# else
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000293# include <arpa/inet.h>
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000294# endif
Guido van Rossum5c9eb211999-08-20 18:21:51 +0000295
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000296# include <fcntl.h>
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000297
Guido van Rossume2ae77b2001-10-24 20:42:55 +0000298#else
Guido van Rossum48a680c2001-03-02 06:34:14 +0000299
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000300/* MS_WINDOWS includes */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000301# ifdef HAVE_FCNTL_H
302# include <fcntl.h>
303# endif
Guido van Rossum48a680c2001-03-02 06:34:14 +0000304
Jeremy Hylton22308652001-02-02 03:23:09 +0000305#endif
306
Skip Montanaro7befb992004-02-10 16:50:21 +0000307#include <stddef.h>
Martin v. Löwisa45ecae2001-06-24 21:28:42 +0000308
309#ifndef offsetof
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000310# define offsetof(type, member) ((size_t)(&((type *)0)->member))
Martin v. Löwisa45ecae2001-06-24 21:28:42 +0000311#endif
312
Neal Norwitz39d22e52002-11-02 19:55:21 +0000313#ifndef O_NONBLOCK
314# define O_NONBLOCK O_NDELAY
Guido van Rossum3bbc62e1995-01-02 19:30:30 +0000315#endif
316
Trent Micka708d6e2004-09-07 17:48:26 +0000317/* include Python's addrinfo.h unless it causes trouble */
318#if defined(__sgi) && _COMPILER_VERSION>700 && defined(_SS_ALIGNSIZE)
319 /* Do not include addinfo.h on some newer IRIX versions.
320 * _SS_ALIGNSIZE is defined in sys/socket.h by 6.5.21,
321 * for example, but not by 6.5.10.
322 */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000323#elif defined(_MSC_VER) && _MSC_VER>1201
Trent Micka708d6e2004-09-07 17:48:26 +0000324 /* Do not include addrinfo.h for MSVC7 or greater. 'addrinfo' and
325 * EAI_* constants are defined in (the already included) ws2tcpip.h.
326 */
327#else
328# include "addrinfo.h"
329#endif
Jason Tishlerc246cb72004-08-09 13:25:59 +0000330
Martin v. Löwisb9ab1592001-06-24 21:18:26 +0000331#ifndef HAVE_INET_PTON
Christian Heimes96e7b3d2007-11-20 06:51:17 +0000332#if !defined(NTDDI_VERSION) || (NTDDI_VERSION < NTDDI_LONGHORN)
Guido van Rossum3eede5a2002-06-07 02:08:35 +0000333int inet_pton(int af, const char *src, void *dst);
Martin v. Löwisc925b1532001-07-21 09:42:15 +0000334const char *inet_ntop(int af, const void *src, char *dst, socklen_t size);
Martin v. Löwisb9ab1592001-06-24 21:18:26 +0000335#endif
Christian Heimesb6150692007-11-15 23:37:07 +0000336#endif
Martin v. Löwisb9ab1592001-06-24 21:18:26 +0000337
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000338#ifdef __APPLE__
339/* On OS X, getaddrinfo returns no error indication of lookup
340 failure, so we must use the emulation instead of the libinfo
341 implementation. Unfortunately, performing an autoconf test
342 for this bug would require DNS access for the machine performing
343 the configuration, which is not acceptable. Therefore, we
344 determine the bug just by checking for __APPLE__. If this bug
345 gets ever fixed, perhaps checking for sys/version.h would be
346 appropriate, which is 10/0 on the system with the bug. */
Jack Jansen84262fb2002-07-02 14:40:42 +0000347#ifndef HAVE_GETNAMEINFO
348/* This bug seems to be fixed in Jaguar. Ths easiest way I could
349 Find to check for Jaguar is that it has getnameinfo(), which
350 older releases don't have */
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000351#undef HAVE_GETADDRINFO
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000352#endif
Thomas Wouters477c8d52006-05-27 19:21:47 +0000353
354#ifdef HAVE_INET_ATON
355#define USE_INET_ATON_WEAKLINK
356#endif
357
Jack Jansen84262fb2002-07-02 14:40:42 +0000358#endif
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000359
Martin v. Löwis01dfdb32001-06-23 16:30:13 +0000360/* I know this is a bad practice, but it is the easiest... */
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000361#if !defined(HAVE_GETADDRINFO)
Martin v. Löwisfccac2e2003-05-01 05:20:46 +0000362/* avoid clashes with the C library definition of the symbol. */
363#define getaddrinfo fake_getaddrinfo
364#define gai_strerror fake_gai_strerror
365#define freeaddrinfo fake_freeaddrinfo
Martin v. Löwis01dfdb32001-06-23 16:30:13 +0000366#include "getaddrinfo.c"
367#endif
Martin v. Löwisae26dc22001-08-03 10:02:29 +0000368#if !defined(HAVE_GETNAMEINFO)
Martin v. Löwisfccac2e2003-05-01 05:20:46 +0000369#define getnameinfo fake_getnameinfo
Martin v. Löwis01dfdb32001-06-23 16:30:13 +0000370#include "getnameinfo.c"
371#endif
372
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000373#ifdef MS_WINDOWS
374/* On Windows a socket is really a handle not an fd */
375static SOCKET
376dup_socket(SOCKET handle)
377{
Daniel Stutzbach6c765282010-09-03 12:38:33 +0000378 WSAPROTOCOL_INFO info;
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000379
Daniel Stutzbach6c765282010-09-03 12:38:33 +0000380 if (WSADuplicateSocket(handle, GetCurrentProcessId(), &info))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000381 return INVALID_SOCKET;
Daniel Stutzbach6c765282010-09-03 12:38:33 +0000382
383 return WSASocket(FROM_PROTOCOL_INFO, FROM_PROTOCOL_INFO,
Antoine Pitrou9a54a262012-04-01 01:14:39 +0200384 FROM_PROTOCOL_INFO, &info, 0, WSA_FLAG_OVERLAPPED);
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000385}
Guido van Rossum2dd8ddd2000-04-21 20:33:00 +0000386#define SOCKETCLOSE closesocket
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000387#else
388/* On Unix we can use dup to duplicate the file descriptor of a socket*/
389#define dup_socket(fd) dup(fd)
Guido van Rossum6a3eb5f1994-08-18 15:42:46 +0000390#endif
391
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000392#ifdef MS_WIN32
Kristján Valur Jónsson310052c2012-03-31 13:35:00 +0000393#undef EAFNOSUPPORT
Guido van Rossum3eede5a2002-06-07 02:08:35 +0000394#define EAFNOSUPPORT WSAEAFNOSUPPORT
395#define snprintf _snprintf
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000396#endif
Fred Drakea04eaad2000-06-30 02:46:07 +0000397
Andrew MacIntyreba43e872002-03-03 03:03:52 +0000398#if defined(PYOS_OS2) && !defined(PYCC_GCC)
Guido van Rossum2dd8ddd2000-04-21 20:33:00 +0000399#define SOCKETCLOSE soclose
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000400#define NO_DUP /* Sockets are Not Actual File Handles under OS/2 */
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000401#endif
402
Guido van Rossum2dd8ddd2000-04-21 20:33:00 +0000403#ifndef SOCKETCLOSE
404#define SOCKETCLOSE close
405#endif
406
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +0000407#if (defined(HAVE_BLUETOOTH_H) || defined(HAVE_BLUETOOTH_BLUETOOTH_H)) && !defined(__NetBSD__) && !defined(__DragonFly__)
Hye-Shik Chang81268602004-02-02 06:05:24 +0000408#define USE_BLUETOOTH 1
409#if defined(__FreeBSD__)
410#define BTPROTO_L2CAP BLUETOOTH_PROTO_L2CAP
411#define BTPROTO_RFCOMM BLUETOOTH_PROTO_RFCOMM
Thomas Wouterscf297e42007-02-23 15:07:44 +0000412#define BTPROTO_HCI BLUETOOTH_PROTO_HCI
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000413#define SOL_HCI SOL_HCI_RAW
414#define HCI_FILTER SO_HCI_RAW_FILTER
Hye-Shik Chang81268602004-02-02 06:05:24 +0000415#define sockaddr_l2 sockaddr_l2cap
416#define sockaddr_rc sockaddr_rfcomm
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000417#define hci_dev hci_node
Hye-Shik Chang81268602004-02-02 06:05:24 +0000418#define _BT_L2_MEMB(sa, memb) ((sa)->l2cap_##memb)
419#define _BT_RC_MEMB(sa, memb) ((sa)->rfcomm_##memb)
Thomas Wouterscf297e42007-02-23 15:07:44 +0000420#define _BT_HCI_MEMB(sa, memb) ((sa)->hci_##memb)
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +0000421#elif defined(__NetBSD__) || defined(__DragonFly__)
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000422#define sockaddr_l2 sockaddr_bt
423#define sockaddr_rc sockaddr_bt
Thomas Wouterscf297e42007-02-23 15:07:44 +0000424#define sockaddr_hci sockaddr_bt
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000425#define sockaddr_sco sockaddr_bt
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +0000426#define SOL_HCI BTPROTO_HCI
427#define HCI_DATA_DIR SO_HCI_DIRECTION
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000428#define _BT_L2_MEMB(sa, memb) ((sa)->bt_##memb)
429#define _BT_RC_MEMB(sa, memb) ((sa)->bt_##memb)
Thomas Wouterscf297e42007-02-23 15:07:44 +0000430#define _BT_HCI_MEMB(sa, memb) ((sa)->bt_##memb)
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000431#define _BT_SCO_MEMB(sa, memb) ((sa)->bt_##memb)
Hye-Shik Chang81268602004-02-02 06:05:24 +0000432#else
Hye-Shik Chang81268602004-02-02 06:05:24 +0000433#define _BT_L2_MEMB(sa, memb) ((sa)->l2_##memb)
434#define _BT_RC_MEMB(sa, memb) ((sa)->rc_##memb)
Thomas Wouterscf297e42007-02-23 15:07:44 +0000435#define _BT_HCI_MEMB(sa, memb) ((sa)->hci_##memb)
Hye-Shik Chang81268602004-02-02 06:05:24 +0000436#define _BT_SCO_MEMB(sa, memb) ((sa)->sco_##memb)
437#endif
438#endif
439
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000440#ifdef __VMS
441/* TCP/IP Services for VMS uses a maximum send/recv buffer length */
442#define SEGMENT_SIZE (32 * 1024 -1)
443#endif
444
Charles-François Natali8b759652011-12-23 16:44:51 +0100445/* Convert "sock_addr_t *" to "struct sockaddr *". */
446#define SAS2SA(x) (&((x)->sa))
Thomas Wouters89f507f2006-12-13 04:49:30 +0000447
Martin v. Löwise9416172003-05-03 10:12:45 +0000448/*
449 * Constants for getnameinfo()
450 */
451#if !defined(NI_MAXHOST)
452#define NI_MAXHOST 1025
453#endif
454#if !defined(NI_MAXSERV)
455#define NI_MAXSERV 32
456#endif
457
Guido van Rossum7d0a8262007-05-21 23:13:11 +0000458#ifndef INVALID_SOCKET /* MS defines this */
459#define INVALID_SOCKET (-1)
460#endif
461
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000462/* XXX There's a problem here: *static* functions are not supposed to have
463 a Py prefix (or use CapitalizedWords). Later... */
464
Guido van Rossum30a685f1991-06-27 15:51:29 +0000465/* Global variable holding the exception type for errors detected
466 by this module (but not argument type or memory errors, etc.). */
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000467static PyObject *socket_herror;
468static PyObject *socket_gaierror;
Raymond Hettingeref7343c2003-06-29 03:08:05 +0000469static PyObject *socket_timeout;
Guido van Rossum30a685f1991-06-27 15:51:29 +0000470
Tim Peters643a7fc2002-02-17 04:13:21 +0000471/* A forward reference to the socket type object.
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000472 The sock_type variable contains pointers to various functions,
473 some of which call new_sockobject(), which uses sock_type, so
Tim Peters643a7fc2002-02-17 04:13:21 +0000474 there has to be a circular reference. */
Jeremy Hylton938ace62002-07-17 16:30:39 +0000475static PyTypeObject sock_type;
Guido van Rossum48a680c2001-03-02 06:34:14 +0000476
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000477#if defined(HAVE_POLL_H)
478#include <poll.h>
479#elif defined(HAVE_SYS_POLL_H)
480#include <sys/poll.h>
481#endif
482
Nick Coghlan96fe56a2011-08-22 11:55:57 +1000483/* Largest value to try to store in a socklen_t (used when handling
484 ancillary data). POSIX requires socklen_t to hold at least
485 (2**31)-1 and recommends against storing larger values, but
486 socklen_t was originally int in the BSD interface, so to be on the
487 safe side we use the smaller of (2**31)-1 and INT_MAX. */
488#if INT_MAX > 0x7fffffff
489#define SOCKLEN_T_LIMIT 0x7fffffff
490#else
491#define SOCKLEN_T_LIMIT INT_MAX
492#endif
493
Charles-François Nataliaa26b272011-08-28 17:51:43 +0200494#ifdef HAVE_POLL
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000495/* Instead of select(), we'll use poll() since poll() works on any fd. */
496#define IS_SELECTABLE(s) 1
497/* Can we call select() with this socket without a buffer overrun? */
Martin v. Löwisf84d1b92006-02-11 09:27:05 +0000498#else
Charles-François Nataliaa26b272011-08-28 17:51:43 +0200499/* If there's no timeout left, we don't have to call select, so it's a safe,
500 * little white lie. */
501#define IS_SELECTABLE(s) (_PyIsSelectable_fd((s)->sock_fd) || (s)->sock_timeout <= 0.0)
Martin v. Löwisf84d1b92006-02-11 09:27:05 +0000502#endif
Neal Norwitz082b2df2006-02-07 07:04:46 +0000503
504static PyObject*
505select_error(void)
506{
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200507 PyErr_SetString(PyExc_OSError, "unable to select on socket");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000508 return NULL;
Neal Norwitz082b2df2006-02-07 07:04:46 +0000509}
510
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000511#ifdef MS_WINDOWS
Antoine Pitrouc8f01962010-09-28 22:03:27 +0000512#ifndef WSAEAGAIN
513#define WSAEAGAIN WSAEWOULDBLOCK
514#endif
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000515#define CHECK_ERRNO(expected) \
516 (WSAGetLastError() == WSA ## expected)
517#else
518#define CHECK_ERRNO(expected) \
519 (errno == expected)
520#endif
521
Guido van Rossum30a685f1991-06-27 15:51:29 +0000522/* Convenience function to raise an error according to errno
523 and return a NULL pointer from a function. */
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000524
Guido van Rossum73624e91994-10-10 17:59:00 +0000525static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000526set_error(void)
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000527{
Guido van Rossum8d665e61996-06-26 18:22:49 +0000528#ifdef MS_WINDOWS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000529 int err_no = WSAGetLastError();
530 /* PyErr_SetExcFromWindowsErr() invokes FormatMessage() which
531 recognizes the error codes used by both GetLastError() and
532 WSAGetLastError */
533 if (err_no)
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200534 return PyErr_SetExcFromWindowsErr(PyExc_OSError, err_no);
Guido van Rossum14ed0b21994-09-29 09:50:09 +0000535#endif
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000536
Andrew MacIntyreba43e872002-03-03 03:03:52 +0000537#if defined(PYOS_OS2) && !defined(PYCC_GCC)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000538 if (sock_errno() != NO_ERROR) {
539 APIRET rc;
540 ULONG msglen;
541 char outbuf[100];
542 int myerrorcode = sock_errno();
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000543
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000544 /* Retrieve socket-related error message from MPTN.MSG file */
545 rc = DosGetMessage(NULL, 0, outbuf, sizeof(outbuf),
546 myerrorcode - SOCBASEERR + 26,
547 "mptn.msg",
548 &msglen);
549 if (rc == NO_ERROR) {
550 PyObject *v;
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000551
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000552 /* OS/2 doesn't guarantee a terminator */
553 outbuf[msglen] = '\0';
554 if (strlen(outbuf) > 0) {
555 /* If non-empty msg, trim CRLF */
556 char *lastc = &outbuf[ strlen(outbuf)-1 ];
557 while (lastc > outbuf &&
558 isspace(Py_CHARMASK(*lastc))) {
559 /* Trim trailing whitespace (CRLF) */
560 *lastc-- = '\0';
561 }
562 }
563 v = Py_BuildValue("(is)", myerrorcode, outbuf);
564 if (v != NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200565 PyErr_SetObject(PyExc_OSError, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000566 Py_DECREF(v);
567 }
568 return NULL;
569 }
570 }
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +0000571#endif
572
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200573 return PyErr_SetFromErrno(PyExc_OSError);
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000574}
575
Guido van Rossum30a685f1991-06-27 15:51:29 +0000576
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000577static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000578set_herror(int h_error)
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000579{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000580 PyObject *v;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000581
582#ifdef HAVE_HSTRERROR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000583 v = Py_BuildValue("(is)", h_error, (char *)hstrerror(h_error));
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000584#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000585 v = Py_BuildValue("(is)", h_error, "host not found");
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000586#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000587 if (v != NULL) {
588 PyErr_SetObject(socket_herror, v);
589 Py_DECREF(v);
590 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000591
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000592 return NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000593}
594
595
596static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000597set_gaierror(int error)
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000598{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000599 PyObject *v;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000600
Martin v. Löwis272cb402002-03-01 08:31:07 +0000601#ifdef EAI_SYSTEM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000602 /* EAI_SYSTEM is not available on Windows XP. */
603 if (error == EAI_SYSTEM)
604 return set_error();
Martin v. Löwis272cb402002-03-01 08:31:07 +0000605#endif
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000606
Martin v. Löwisf95dd0a2001-08-15 17:14:33 +0000607#ifdef HAVE_GAI_STRERROR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000608 v = Py_BuildValue("(is)", error, gai_strerror(error));
Martin v. Löwisf95dd0a2001-08-15 17:14:33 +0000609#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000610 v = Py_BuildValue("(is)", error, "getaddrinfo failed");
Martin v. Löwisf95dd0a2001-08-15 17:14:33 +0000611#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000612 if (v != NULL) {
613 PyErr_SetObject(socket_gaierror, v);
614 Py_DECREF(v);
615 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000616
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000617 return NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000618}
619
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000620#ifdef __VMS
621/* Function to send in segments */
622static int
623sendsegmented(int sock_fd, char *buf, int len, int flags)
624{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000625 int n = 0;
626 int remaining = len;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000627
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000628 while (remaining > 0) {
629 unsigned int segment;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000630
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000631 segment = (remaining >= SEGMENT_SIZE ? SEGMENT_SIZE : remaining);
632 n = send(sock_fd, buf, segment, flags);
633 if (n < 0) {
634 return n;
635 }
636 remaining -= segment;
637 buf += segment;
638 } /* end while */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000639
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000640 return len;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000641}
642#endif
643
Guido van Rossum3eede5a2002-06-07 02:08:35 +0000644/* Function to perform the setting of socket blocking mode
645 internally. block = (1 | 0). */
Guido van Rossum67f7a382002-06-06 21:08:16 +0000646static int
647internal_setblocking(PySocketSockObject *s, int block)
648{
Guido van Rossum67f7a382002-06-06 21:08:16 +0000649#ifndef MS_WINDOWS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000650 int delay_flag;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000651#endif
Antoine Pitroub1c54962010-10-14 15:05:38 +0000652#ifdef SOCK_NONBLOCK
653 if (block)
654 s->sock_type &= (~SOCK_NONBLOCK);
655 else
656 s->sock_type |= SOCK_NONBLOCK;
657#endif
Guido van Rossum67f7a382002-06-06 21:08:16 +0000658
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000659 Py_BEGIN_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +0000660#ifndef MS_WINDOWS
661#if defined(PYOS_OS2) && !defined(PYCC_GCC)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000662 block = !block;
663 ioctl(s->sock_fd, FIONBIO, (caddr_t)&block, sizeof(block));
Martin v. Löwis79acb9e2002-12-06 12:48:53 +0000664#elif defined(__VMS)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000665 block = !block;
666 ioctl(s->sock_fd, FIONBIO, (unsigned int *)&block);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000667#else /* !PYOS_OS2 && !__VMS */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000668 delay_flag = fcntl(s->sock_fd, F_GETFL, 0);
669 if (block)
670 delay_flag &= (~O_NONBLOCK);
671 else
672 delay_flag |= O_NONBLOCK;
673 fcntl(s->sock_fd, F_SETFL, delay_flag);
Guido van Rossum67f7a382002-06-06 21:08:16 +0000674#endif /* !PYOS_OS2 */
675#else /* MS_WINDOWS */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000676 block = !block;
677 ioctlsocket(s->sock_fd, FIONBIO, (u_long*)&block);
Guido van Rossum67f7a382002-06-06 21:08:16 +0000678#endif /* MS_WINDOWS */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000679 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +0000680
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000681 /* Since these don't return anything */
682 return 1;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000683}
684
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000685/* Do a select()/poll() on the socket, if necessary (sock_timeout > 0).
Guido van Rossum11ba0942002-06-13 15:07:44 +0000686 The argument writing indicates the direction.
Raymond Hettingeref7343c2003-06-29 03:08:05 +0000687 This does not raise an exception; we'll let our caller do that
688 after they've reacquired the interpreter lock.
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000689 Returns 1 on timeout, -1 on error, 0 otherwise. */
Raymond Hettingeref7343c2003-06-29 03:08:05 +0000690static int
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000691internal_select_ex(PySocketSockObject *s, int writing, double interval)
Guido van Rossum67f7a382002-06-06 21:08:16 +0000692{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000693 int n;
Guido van Rossum11ba0942002-06-13 15:07:44 +0000694
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000695 /* Nothing to do unless we're in timeout mode (not non-blocking) */
696 if (s->sock_timeout <= 0.0)
697 return 0;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000698
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000699 /* Guard against closed socket */
700 if (s->sock_fd < 0)
701 return 0;
Guido van Rossumad654902002-07-19 12:44:59 +0000702
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000703 /* Handling this condition here simplifies the select loops */
704 if (interval < 0.0)
705 return 1;
706
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000707 /* Prefer poll, if available, since you can poll() any fd
708 * which can't be done with select(). */
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000709#ifdef HAVE_POLL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000710 {
711 struct pollfd pollfd;
712 int timeout;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000713
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000714 pollfd.fd = s->sock_fd;
715 pollfd.events = writing ? POLLOUT : POLLIN;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000716
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000717 /* s->sock_timeout is in seconds, timeout in ms */
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000718 timeout = (int)(interval * 1000 + 0.5);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000719 n = poll(&pollfd, 1, timeout);
720 }
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000721#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000722 {
723 /* Construct the arguments to select */
724 fd_set fds;
725 struct timeval tv;
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000726 tv.tv_sec = (int)interval;
727 tv.tv_usec = (int)((interval - tv.tv_sec) * 1e6);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000728 FD_ZERO(&fds);
729 FD_SET(s->sock_fd, &fds);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000730
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000731 /* See if the socket is ready */
732 if (writing)
Antoine Pitrou19467d22010-08-17 19:33:30 +0000733 n = select(Py_SAFE_DOWNCAST(s->sock_fd+1, SOCKET_T, int),
734 NULL, &fds, NULL, &tv);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000735 else
Antoine Pitrou19467d22010-08-17 19:33:30 +0000736 n = select(Py_SAFE_DOWNCAST(s->sock_fd+1, SOCKET_T, int),
737 &fds, NULL, NULL, &tv);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000738 }
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000739#endif
Guido van Rossum39eb8fa2007-11-16 01:24:05 +0000740
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000741 if (n < 0)
742 return -1;
743 if (n == 0)
744 return 1;
745 return 0;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000746}
747
Antoine Pitrou3e1fd272010-09-28 21:23:11 +0000748static int
749internal_select(PySocketSockObject *s, int writing)
750{
751 return internal_select_ex(s, writing, s->sock_timeout);
752}
753
754/*
755 Two macros for automatic retry of select() in case of false positives
756 (for example, select() could indicate a socket is ready for reading
757 but the data then discarded by the OS because of a wrong checksum).
758 Here is an example of use:
759
760 BEGIN_SELECT_LOOP(s)
761 Py_BEGIN_ALLOW_THREADS
762 timeout = internal_select_ex(s, 0, interval);
763 if (!timeout)
764 outlen = recv(s->sock_fd, cbuf, len, flags);
765 Py_END_ALLOW_THREADS
766 if (timeout == 1) {
767 PyErr_SetString(socket_timeout, "timed out");
768 return -1;
769 }
770 END_SELECT_LOOP(s)
771*/
772
773#define BEGIN_SELECT_LOOP(s) \
774 { \
775 _PyTime_timeval now, deadline = {0, 0}; \
776 double interval = s->sock_timeout; \
777 int has_timeout = s->sock_timeout > 0.0; \
778 if (has_timeout) { \
779 _PyTime_gettimeofday(&now); \
780 deadline = now; \
781 _PyTime_ADD_SECONDS(deadline, s->sock_timeout); \
782 } \
783 while (1) { \
784 errno = 0; \
785
786#define END_SELECT_LOOP(s) \
787 if (!has_timeout || \
788 (!CHECK_ERRNO(EWOULDBLOCK) && !CHECK_ERRNO(EAGAIN))) \
789 break; \
790 _PyTime_gettimeofday(&now); \
791 interval = _PyTime_INTERVAL(now, deadline); \
792 } \
793 } \
794
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000795/* Initialize a new socket object. */
796
Tim Petersa12b4cf2002-07-18 22:38:44 +0000797static double defaulttimeout = -1.0; /* Default timeout for new sockets */
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +0000798
Martin v. Löwis1a214512008-06-11 05:26:20 +0000799static void
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000800init_sockobject(PySocketSockObject *s,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000801 SOCKET_T fd, int family, int type, int proto)
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000802{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000803 s->sock_fd = fd;
804 s->sock_family = family;
805 s->sock_type = type;
806 s->sock_proto = proto;
Guido van Rossum67f7a382002-06-06 21:08:16 +0000807
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000808 s->errorhandler = &set_error;
Antoine Pitroub1c54962010-10-14 15:05:38 +0000809#ifdef SOCK_NONBLOCK
810 if (type & SOCK_NONBLOCK)
811 s->sock_timeout = 0.0;
812 else
813#endif
814 {
815 s->sock_timeout = defaulttimeout;
816 if (defaulttimeout >= 0.0)
817 internal_setblocking(s, 0);
818 }
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +0000819
Guido van Rossum384ca9c2001-10-27 22:20:47 +0000820}
821
822
Guido van Rossum30a685f1991-06-27 15:51:29 +0000823/* Create a new socket object.
824 This just creates the object and initializes it.
825 If the creation fails, return NULL and set an exception (implicit
826 in NEWOBJ()). */
827
Guido van Rossum73624e91994-10-10 17:59:00 +0000828static PySocketSockObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +0000829new_sockobject(SOCKET_T fd, int family, int type, int proto)
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000830{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000831 PySocketSockObject *s;
832 s = (PySocketSockObject *)
833 PyType_GenericNew(&sock_type, NULL, NULL);
834 if (s != NULL)
835 init_sockobject(s, fd, family, type, proto);
836 return s;
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000837}
838
Guido van Rossum30a685f1991-06-27 15:51:29 +0000839
Guido van Rossum48a680c2001-03-02 06:34:14 +0000840/* Lock to allow python interpreter to continue, but only allow one
Just van Rossum1040d2c2003-05-09 07:53:18 +0000841 thread to be in gethostbyname or getaddrinfo */
842#if defined(USE_GETHOSTBYNAME_LOCK) || defined(USE_GETADDRINFO_LOCK)
843PyThread_type_lock netdb_lock;
Guido van Rossum4f199ea1998-04-09 20:56:35 +0000844#endif
845
846
Guido van Rossum30a685f1991-06-27 15:51:29 +0000847/* Convert a string specifying a host name or one of a few symbolic
848 names to a numeric IP address. This usually calls gethostbyname()
849 to do the work; the names "" and "<broadcast>" are special.
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000850 Return the length (IPv4 should be 4 bytes), or negative if
Guido van Rossum30a685f1991-06-27 15:51:29 +0000851 an error occurred; then an exception is raised. */
852
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000853static int
Martin v. Löwisddc6f472002-07-28 16:10:31 +0000854setipaddr(char *name, struct sockaddr *addr_ret, size_t addr_ret_size, int af)
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000855{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000856 struct addrinfo hints, *res;
857 int error;
858 int d1, d2, d3, d4;
859 char ch;
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000860
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000861 memset((void *) addr_ret, '\0', sizeof(*addr_ret));
862 if (name[0] == '\0') {
863 int siz;
864 memset(&hints, 0, sizeof(hints));
865 hints.ai_family = af;
866 hints.ai_socktype = SOCK_DGRAM; /*dummy*/
867 hints.ai_flags = AI_PASSIVE;
868 Py_BEGIN_ALLOW_THREADS
869 ACQUIRE_GETADDRINFO_LOCK
870 error = getaddrinfo(NULL, "0", &hints, &res);
871 Py_END_ALLOW_THREADS
872 /* We assume that those thread-unsafe getaddrinfo() versions
873 *are* safe regarding their return value, ie. that a
874 subsequent call to getaddrinfo() does not destroy the
875 outcome of the first call. */
876 RELEASE_GETADDRINFO_LOCK
877 if (error) {
878 set_gaierror(error);
879 return -1;
880 }
881 switch (res->ai_family) {
882 case AF_INET:
883 siz = 4;
884 break;
Martin v. Löwis44ddbde2001-12-02 10:15:37 +0000885#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000886 case AF_INET6:
887 siz = 16;
888 break;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000889#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000890 default:
891 freeaddrinfo(res);
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200892 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000893 "unsupported address family");
894 return -1;
895 }
896 if (res->ai_next) {
897 freeaddrinfo(res);
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200898 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000899 "wildcard resolved to multiple address");
900 return -1;
901 }
902 if (res->ai_addrlen < addr_ret_size)
903 addr_ret_size = res->ai_addrlen;
904 memcpy(addr_ret, res->ai_addr, addr_ret_size);
905 freeaddrinfo(res);
906 return siz;
907 }
908 if (name[0] == '<' && strcmp(name, "<broadcast>") == 0) {
909 struct sockaddr_in *sin;
910 if (af != AF_INET && af != AF_UNSPEC) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200911 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000912 "address family mismatched");
913 return -1;
914 }
915 sin = (struct sockaddr_in *)addr_ret;
916 memset((void *) sin, '\0', sizeof(*sin));
917 sin->sin_family = AF_INET;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000918#ifdef HAVE_SOCKADDR_SA_LEN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000919 sin->sin_len = sizeof(*sin);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000920#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000921 sin->sin_addr.s_addr = INADDR_BROADCAST;
922 return sizeof(sin->sin_addr);
923 }
924 if (sscanf(name, "%d.%d.%d.%d%c", &d1, &d2, &d3, &d4, &ch) == 4 &&
925 0 <= d1 && d1 <= 255 && 0 <= d2 && d2 <= 255 &&
926 0 <= d3 && d3 <= 255 && 0 <= d4 && d4 <= 255) {
927 struct sockaddr_in *sin;
928 sin = (struct sockaddr_in *)addr_ret;
929 sin->sin_addr.s_addr = htonl(
930 ((long) d1 << 24) | ((long) d2 << 16) |
931 ((long) d3 << 8) | ((long) d4 << 0));
932 sin->sin_family = AF_INET;
Anthony Baxter0e85f9d2003-05-02 15:40:46 +0000933#ifdef HAVE_SOCKADDR_SA_LEN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000934 sin->sin_len = sizeof(*sin);
Anthony Baxter0e85f9d2003-05-02 15:40:46 +0000935#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000936 return 4;
937 }
938 memset(&hints, 0, sizeof(hints));
939 hints.ai_family = af;
940 Py_BEGIN_ALLOW_THREADS
941 ACQUIRE_GETADDRINFO_LOCK
942 error = getaddrinfo(name, NULL, &hints, &res);
Martin v. Löwis7c4b5fa2001-10-25 09:04:03 +0000943#if defined(__digital__) && defined(__unix__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000944 if (error == EAI_NONAME && af == AF_UNSPEC) {
945 /* On Tru64 V5.1, numeric-to-addr conversion fails
946 if no address family is given. Assume IPv4 for now.*/
947 hints.ai_family = AF_INET;
948 error = getaddrinfo(name, NULL, &hints, &res);
949 }
Martin v. Löwis7c4b5fa2001-10-25 09:04:03 +0000950#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000951 Py_END_ALLOW_THREADS
952 RELEASE_GETADDRINFO_LOCK /* see comment in setipaddr() */
953 if (error) {
954 set_gaierror(error);
955 return -1;
956 }
957 if (res->ai_addrlen < addr_ret_size)
958 addr_ret_size = res->ai_addrlen;
959 memcpy((char *) addr_ret, res->ai_addr, addr_ret_size);
960 freeaddrinfo(res);
961 switch (addr_ret->sa_family) {
962 case AF_INET:
963 return 4;
Martin v. Löwis44ddbde2001-12-02 10:15:37 +0000964#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000965 case AF_INET6:
966 return 16;
Guido van Rossum955becc1999-03-22 20:14:53 +0000967#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000968 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200969 PyErr_SetString(PyExc_OSError, "unknown address family");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000970 return -1;
971 }
Guido van Rossum6574b3e1991-06-25 21:36:08 +0000972}
973
Guido van Rossum30a685f1991-06-27 15:51:29 +0000974
Guido van Rossum30a685f1991-06-27 15:51:29 +0000975/* Create a string object representing an IP address.
976 This is always a string of the form 'dd.dd.dd.dd' (with variable
977 size numbers). */
978
Guido van Rossum73624e91994-10-10 17:59:00 +0000979static PyObject *
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000980makeipaddr(struct sockaddr *addr, int addrlen)
Guido van Rossum30a685f1991-06-27 15:51:29 +0000981{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000982 char buf[NI_MAXHOST];
983 int error;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +0000984
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000985 error = getnameinfo(addr, addrlen, buf, sizeof(buf), NULL, 0,
986 NI_NUMERICHOST);
987 if (error) {
988 set_gaierror(error);
989 return NULL;
990 }
991 return PyUnicode_FromString(buf);
Guido van Rossum30a685f1991-06-27 15:51:29 +0000992}
993
994
Martin v. Löwis558d9bf2004-06-03 09:24:42 +0000995#ifdef USE_BLUETOOTH
996/* Convert a string representation of a Bluetooth address into a numeric
997 address. Returns the length (6), or raises an exception and returns -1 if
998 an error occurred. */
999
1000static int
1001setbdaddr(char *name, bdaddr_t *bdaddr)
1002{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001003 unsigned int b0, b1, b2, b3, b4, b5;
1004 char ch;
1005 int n;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001006
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001007 n = sscanf(name, "%X:%X:%X:%X:%X:%X%c",
1008 &b5, &b4, &b3, &b2, &b1, &b0, &ch);
1009 if (n == 6 && (b0 | b1 | b2 | b3 | b4 | b5) < 256) {
1010 bdaddr->b[0] = b0;
1011 bdaddr->b[1] = b1;
1012 bdaddr->b[2] = b2;
1013 bdaddr->b[3] = b3;
1014 bdaddr->b[4] = b4;
1015 bdaddr->b[5] = b5;
1016 return 6;
1017 } else {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001018 PyErr_SetString(PyExc_OSError, "bad bluetooth address");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001019 return -1;
1020 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001021}
1022
1023/* Create a string representation of the Bluetooth address. This is always a
1024 string of the form 'XX:XX:XX:XX:XX:XX' where XX is a two digit hexadecimal
1025 value (zero padded if necessary). */
1026
1027static PyObject *
1028makebdaddr(bdaddr_t *bdaddr)
1029{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001030 char buf[(6 * 2) + 5 + 1];
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001031
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001032 sprintf(buf, "%02X:%02X:%02X:%02X:%02X:%02X",
1033 bdaddr->b[5], bdaddr->b[4], bdaddr->b[3],
1034 bdaddr->b[2], bdaddr->b[1], bdaddr->b[0]);
1035 return PyUnicode_FromString(buf);
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001036}
1037#endif
1038
1039
Guido van Rossum30a685f1991-06-27 15:51:29 +00001040/* Create an object representing the given socket address,
1041 suitable for passing it back to bind(), connect() etc.
1042 The family field of the sockaddr structure is inspected
1043 to determine what kind of address it really is. */
1044
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001045/*ARGSUSED*/
Guido van Rossum73624e91994-10-10 17:59:00 +00001046static PyObject *
Antoine Pitrou19467d22010-08-17 19:33:30 +00001047makesockaddr(SOCKET_T sockfd, struct sockaddr *addr, size_t addrlen, int proto)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001048{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001049 if (addrlen == 0) {
1050 /* No address -- may be recvfrom() from known socket */
1051 Py_INCREF(Py_None);
1052 return Py_None;
1053 }
Guido van Rossum25bec8c1992-08-05 19:00:45 +00001054
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001055 switch (addr->sa_family) {
Guido van Rossum30a685f1991-06-27 15:51:29 +00001056
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001057 case AF_INET:
1058 {
1059 struct sockaddr_in *a;
1060 PyObject *addrobj = makeipaddr(addr, sizeof(*a));
1061 PyObject *ret = NULL;
1062 if (addrobj) {
1063 a = (struct sockaddr_in *)addr;
1064 ret = Py_BuildValue("Oi", addrobj, ntohs(a->sin_port));
1065 Py_DECREF(addrobj);
1066 }
1067 return ret;
1068 }
Guido van Rossum30a685f1991-06-27 15:51:29 +00001069
Andrew MacIntyred12dfbb2004-04-04 07:13:49 +00001070#if defined(AF_UNIX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001071 case AF_UNIX:
1072 {
1073 struct sockaddr_un *a = (struct sockaddr_un *) addr;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001074#ifdef linux
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001075 if (a->sun_path[0] == 0) { /* Linux abstract namespace */
1076 addrlen -= offsetof(struct sockaddr_un, sun_path);
1077 return PyBytes_FromStringAndSize(a->sun_path, addrlen);
1078 }
1079 else
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001080#endif /* linux */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001081 {
1082 /* regular NULL-terminated string */
Antoine Pitrou6ec29e22011-12-16 14:46:36 +01001083 return PyUnicode_DecodeFSDefault(a->sun_path);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001084 }
1085 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00001086#endif /* AF_UNIX */
1087
Martin v. Löwis11017b12006-01-14 18:12:57 +00001088#if defined(AF_NETLINK)
1089 case AF_NETLINK:
1090 {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001091 struct sockaddr_nl *a = (struct sockaddr_nl *) addr;
1092 return Py_BuildValue("II", a->nl_pid, a->nl_groups);
Martin v. Löwis11017b12006-01-14 18:12:57 +00001093 }
1094#endif /* AF_NETLINK */
1095
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00001096#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001097 case AF_INET6:
1098 {
1099 struct sockaddr_in6 *a;
1100 PyObject *addrobj = makeipaddr(addr, sizeof(*a));
1101 PyObject *ret = NULL;
1102 if (addrobj) {
1103 a = (struct sockaddr_in6 *)addr;
Charles-François Natali366999a2012-01-02 15:47:29 +01001104 ret = Py_BuildValue("OiII",
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001105 addrobj,
1106 ntohs(a->sin6_port),
Charles-François Natali366999a2012-01-02 15:47:29 +01001107 ntohl(a->sin6_flowinfo),
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001108 a->sin6_scope_id);
1109 Py_DECREF(addrobj);
1110 }
1111 return ret;
1112 }
Jeremy Hylton22308652001-02-02 03:23:09 +00001113#endif
Guido van Rossum30a685f1991-06-27 15:51:29 +00001114
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001115#ifdef USE_BLUETOOTH
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001116 case AF_BLUETOOTH:
1117 switch (proto) {
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001118
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001119 case BTPROTO_L2CAP:
1120 {
1121 struct sockaddr_l2 *a = (struct sockaddr_l2 *) addr;
1122 PyObject *addrobj = makebdaddr(&_BT_L2_MEMB(a, bdaddr));
1123 PyObject *ret = NULL;
1124 if (addrobj) {
1125 ret = Py_BuildValue("Oi",
1126 addrobj,
1127 _BT_L2_MEMB(a, psm));
1128 Py_DECREF(addrobj);
1129 }
1130 return ret;
1131 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001132
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001133 case BTPROTO_RFCOMM:
1134 {
1135 struct sockaddr_rc *a = (struct sockaddr_rc *) addr;
1136 PyObject *addrobj = makebdaddr(&_BT_RC_MEMB(a, bdaddr));
1137 PyObject *ret = NULL;
1138 if (addrobj) {
1139 ret = Py_BuildValue("Oi",
1140 addrobj,
1141 _BT_RC_MEMB(a, channel));
1142 Py_DECREF(addrobj);
1143 }
1144 return ret;
1145 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001146
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001147 case BTPROTO_HCI:
1148 {
1149 struct sockaddr_hci *a = (struct sockaddr_hci *) addr;
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001150#if defined(__NetBSD__) || defined(__DragonFly__)
1151 return makebdaddr(&_BT_HCI_MEMB(a, bdaddr));
1152#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001153 PyObject *ret = NULL;
1154 ret = Py_BuildValue("i", _BT_HCI_MEMB(a, dev));
1155 return ret;
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001156#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001157 }
Thomas Wouterscf297e42007-02-23 15:07:44 +00001158
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001159#if !defined(__FreeBSD__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001160 case BTPROTO_SCO:
1161 {
1162 struct sockaddr_sco *a = (struct sockaddr_sco *) addr;
1163 return makebdaddr(&_BT_SCO_MEMB(a, bdaddr));
1164 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001165#endif
1166
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001167 default:
1168 PyErr_SetString(PyExc_ValueError,
1169 "Unknown Bluetooth protocol");
1170 return NULL;
1171 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001172#endif
1173
Antoine Pitroub156a462010-10-27 20:13:57 +00001174#if defined(HAVE_NETPACKET_PACKET_H) && defined(SIOCGIFNAME)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001175 case AF_PACKET:
1176 {
1177 struct sockaddr_ll *a = (struct sockaddr_ll *)addr;
1178 char *ifname = "";
1179 struct ifreq ifr;
1180 /* need to look up interface name give index */
1181 if (a->sll_ifindex) {
1182 ifr.ifr_ifindex = a->sll_ifindex;
1183 if (ioctl(sockfd, SIOCGIFNAME, &ifr) == 0)
1184 ifname = ifr.ifr_name;
1185 }
1186 return Py_BuildValue("shbhy#",
1187 ifname,
1188 ntohs(a->sll_protocol),
1189 a->sll_pkttype,
1190 a->sll_hatype,
1191 a->sll_addr,
1192 a->sll_halen);
1193 }
Jeremy Hylton22308652001-02-02 03:23:09 +00001194#endif
Guido van Rossum48a680c2001-03-02 06:34:14 +00001195
Christian Heimes043d6f62008-01-07 17:19:16 +00001196#ifdef HAVE_LINUX_TIPC_H
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001197 case AF_TIPC:
1198 {
1199 struct sockaddr_tipc *a = (struct sockaddr_tipc *) addr;
1200 if (a->addrtype == TIPC_ADDR_NAMESEQ) {
1201 return Py_BuildValue("IIIII",
1202 a->addrtype,
1203 a->addr.nameseq.type,
1204 a->addr.nameseq.lower,
1205 a->addr.nameseq.upper,
1206 a->scope);
1207 } else if (a->addrtype == TIPC_ADDR_NAME) {
1208 return Py_BuildValue("IIIII",
1209 a->addrtype,
1210 a->addr.name.name.type,
1211 a->addr.name.name.instance,
1212 a->addr.name.name.instance,
1213 a->scope);
1214 } else if (a->addrtype == TIPC_ADDR_ID) {
1215 return Py_BuildValue("IIIII",
1216 a->addrtype,
1217 a->addr.id.node,
1218 a->addr.id.ref,
1219 0,
1220 a->scope);
1221 } else {
1222 PyErr_SetString(PyExc_ValueError,
1223 "Invalid address type");
1224 return NULL;
1225 }
1226 }
Christian Heimes043d6f62008-01-07 17:19:16 +00001227#endif
1228
Charles-François Natali30589c92011-10-07 22:47:08 +02001229#ifdef AF_CAN
Charles-François Natali47413c12011-10-06 19:47:44 +02001230 case AF_CAN:
1231 {
1232 struct sockaddr_can *a = (struct sockaddr_can *)addr;
1233 char *ifname = "";
1234 struct ifreq ifr;
1235 /* need to look up interface name given index */
1236 if (a->can_ifindex) {
1237 ifr.ifr_ifindex = a->can_ifindex;
1238 if (ioctl(sockfd, SIOCGIFNAME, &ifr) == 0)
1239 ifname = ifr.ifr_name;
1240 }
1241
1242 return Py_BuildValue("O&h", PyUnicode_DecodeFSDefault,
1243 ifname,
1244 a->can_family);
1245 }
1246#endif
1247
Martin v. Löwis9d6c6692012-02-03 17:44:58 +01001248#ifdef PF_SYSTEM
1249 case PF_SYSTEM:
1250 switch(proto) {
1251#ifdef SYSPROTO_CONTROL
1252 case SYSPROTO_CONTROL:
1253 {
1254 struct sockaddr_ctl *a = (struct sockaddr_ctl *)addr;
1255 return Py_BuildValue("(II)", a->sc_id, a->sc_unit);
1256 }
1257#endif
1258 default:
1259 PyErr_SetString(PyExc_ValueError,
1260 "Invalid address type");
1261 return 0;
1262 }
1263#endif
1264
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001265 /* More cases here... */
Guido van Rossum30a685f1991-06-27 15:51:29 +00001266
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001267 default:
1268 /* If we don't know the address family, don't raise an
1269 exception -- return it as an (int, bytes) tuple. */
1270 return Py_BuildValue("iy#",
1271 addr->sa_family,
1272 addr->sa_data,
1273 sizeof(addr->sa_data));
Guido van Rossum25bec8c1992-08-05 19:00:45 +00001274
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001275 }
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001276}
1277
Guido van Rossum30a685f1991-06-27 15:51:29 +00001278
1279/* Parse a socket address argument according to the socket object's
1280 address family. Return 1 if the address was in the proper format,
1281 0 of not. The address is returned through addr_ret, its length
1282 through len_ret. */
1283
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001284static int
Guido van Rossum48a680c2001-03-02 06:34:14 +00001285getsockaddrarg(PySocketSockObject *s, PyObject *args,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001286 struct sockaddr *addr_ret, int *len_ret)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001287{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001288 switch (s->sock_family) {
Guido van Rossum30a685f1991-06-27 15:51:29 +00001289
Andrew MacIntyred12dfbb2004-04-04 07:13:49 +00001290#if defined(AF_UNIX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001291 case AF_UNIX:
1292 {
1293 struct sockaddr_un* addr;
1294 char *path;
1295 int len;
Antoine Pitrou6ec29e22011-12-16 14:46:36 +01001296 int retval = 0;
1297
1298 /* PEP 383. Not using PyUnicode_FSConverter since we need to
1299 allow embedded nulls on Linux. */
1300 if (PyUnicode_Check(args)) {
1301 if ((args = PyUnicode_EncodeFSDefault(args)) == NULL)
1302 return 0;
1303 }
1304 else
1305 Py_INCREF(args);
1306 if (!PyArg_Parse(args, "y#", &path, &len))
1307 goto unix_out;
Thomas Wouters89f507f2006-12-13 04:49:30 +00001308
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001309 addr = (struct sockaddr_un*)addr_ret;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001310#ifdef linux
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001311 if (len > 0 && path[0] == 0) {
1312 /* Linux abstract namespace extension */
1313 if (len > sizeof addr->sun_path) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001314 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001315 "AF_UNIX path too long");
Antoine Pitrou6ec29e22011-12-16 14:46:36 +01001316 goto unix_out;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001317 }
1318 }
1319 else
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001320#endif /* linux */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001321 {
1322 /* regular NULL-terminated string */
1323 if (len >= sizeof addr->sun_path) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001324 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001325 "AF_UNIX path too long");
Antoine Pitrou6ec29e22011-12-16 14:46:36 +01001326 goto unix_out;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001327 }
1328 addr->sun_path[len] = 0;
1329 }
1330 addr->sun_family = s->sock_family;
1331 memcpy(addr->sun_path, path, len);
Andrew MacIntyredaedf212004-04-11 12:03:57 +00001332#if defined(PYOS_OS2)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001333 *len_ret = sizeof(*addr);
Andrew MacIntyredaedf212004-04-11 12:03:57 +00001334#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001335 *len_ret = len + offsetof(struct sockaddr_un, sun_path);
Andrew MacIntyredaedf212004-04-11 12:03:57 +00001336#endif
Antoine Pitrou6ec29e22011-12-16 14:46:36 +01001337 retval = 1;
1338 unix_out:
1339 Py_DECREF(args);
1340 return retval;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001341 }
Guido van Rossumb6775db1994-08-01 11:34:53 +00001342#endif /* AF_UNIX */
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001343
Martin v. Löwis11017b12006-01-14 18:12:57 +00001344#if defined(AF_NETLINK)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001345 case AF_NETLINK:
1346 {
1347 struct sockaddr_nl* addr;
1348 int pid, groups;
1349 addr = (struct sockaddr_nl *)addr_ret;
1350 if (!PyTuple_Check(args)) {
1351 PyErr_Format(
1352 PyExc_TypeError,
1353 "getsockaddrarg: "
1354 "AF_NETLINK address must be tuple, not %.500s",
1355 Py_TYPE(args)->tp_name);
1356 return 0;
1357 }
1358 if (!PyArg_ParseTuple(args, "II:getsockaddrarg", &pid, &groups))
1359 return 0;
1360 addr->nl_family = AF_NETLINK;
1361 addr->nl_pid = pid;
1362 addr->nl_groups = groups;
1363 *len_ret = sizeof(*addr);
1364 return 1;
1365 }
Martin v. Löwis11017b12006-01-14 18:12:57 +00001366#endif
1367
Charles-François Natali10b8cf42011-11-10 19:21:37 +01001368#ifdef AF_RDS
1369 case AF_RDS:
1370 /* RDS sockets use sockaddr_in: fall-through */
1371#endif
1372
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001373 case AF_INET:
1374 {
1375 struct sockaddr_in* addr;
1376 char *host;
1377 int port, result;
1378 if (!PyTuple_Check(args)) {
1379 PyErr_Format(
1380 PyExc_TypeError,
1381 "getsockaddrarg: "
1382 "AF_INET address must be tuple, not %.500s",
1383 Py_TYPE(args)->tp_name);
1384 return 0;
1385 }
1386 if (!PyArg_ParseTuple(args, "eti:getsockaddrarg",
1387 "idna", &host, &port))
1388 return 0;
1389 addr=(struct sockaddr_in*)addr_ret;
1390 result = setipaddr(host, (struct sockaddr *)addr,
1391 sizeof(*addr), AF_INET);
1392 PyMem_Free(host);
1393 if (result < 0)
1394 return 0;
1395 if (port < 0 || port > 0xffff) {
1396 PyErr_SetString(
1397 PyExc_OverflowError,
1398 "getsockaddrarg: port must be 0-65535.");
1399 return 0;
1400 }
1401 addr->sin_family = AF_INET;
1402 addr->sin_port = htons((short)port);
1403 *len_ret = sizeof *addr;
1404 return 1;
1405 }
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001406
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00001407#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001408 case AF_INET6:
1409 {
1410 struct sockaddr_in6* addr;
1411 char *host;
Charles-François Natali366999a2012-01-02 15:47:29 +01001412 int port, result;
1413 unsigned int flowinfo, scope_id;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001414 flowinfo = scope_id = 0;
1415 if (!PyTuple_Check(args)) {
1416 PyErr_Format(
1417 PyExc_TypeError,
1418 "getsockaddrarg: "
1419 "AF_INET6 address must be tuple, not %.500s",
1420 Py_TYPE(args)->tp_name);
1421 return 0;
1422 }
Charles-François Natali366999a2012-01-02 15:47:29 +01001423 if (!PyArg_ParseTuple(args, "eti|II",
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001424 "idna", &host, &port, &flowinfo,
1425 &scope_id)) {
1426 return 0;
1427 }
1428 addr = (struct sockaddr_in6*)addr_ret;
1429 result = setipaddr(host, (struct sockaddr *)addr,
1430 sizeof(*addr), AF_INET6);
1431 PyMem_Free(host);
1432 if (result < 0)
1433 return 0;
1434 if (port < 0 || port > 0xffff) {
1435 PyErr_SetString(
1436 PyExc_OverflowError,
1437 "getsockaddrarg: port must be 0-65535.");
1438 return 0;
1439 }
Charles-François Natali366999a2012-01-02 15:47:29 +01001440 if (flowinfo < 0 || flowinfo > 0xfffff) {
1441 PyErr_SetString(
1442 PyExc_OverflowError,
1443 "getsockaddrarg: flowinfo must be 0-1048575.");
1444 return 0;
1445 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001446 addr->sin6_family = s->sock_family;
1447 addr->sin6_port = htons((short)port);
Charles-François Natali366999a2012-01-02 15:47:29 +01001448 addr->sin6_flowinfo = htonl(flowinfo);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001449 addr->sin6_scope_id = scope_id;
1450 *len_ret = sizeof *addr;
1451 return 1;
1452 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00001453#endif
1454
Hye-Shik Chang81268602004-02-02 06:05:24 +00001455#ifdef USE_BLUETOOTH
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001456 case AF_BLUETOOTH:
1457 {
1458 switch (s->sock_proto) {
1459 case BTPROTO_L2CAP:
1460 {
1461 struct sockaddr_l2 *addr;
1462 char *straddr;
Martin v. Löwis12af0482004-01-31 12:34:17 +00001463
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001464 addr = (struct sockaddr_l2 *)addr_ret;
1465 memset(addr, 0, sizeof(struct sockaddr_l2));
1466 _BT_L2_MEMB(addr, family) = AF_BLUETOOTH;
1467 if (!PyArg_ParseTuple(args, "si", &straddr,
1468 &_BT_L2_MEMB(addr, psm))) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001469 PyErr_SetString(PyExc_OSError, "getsockaddrarg: "
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001470 "wrong format");
1471 return 0;
1472 }
1473 if (setbdaddr(straddr, &_BT_L2_MEMB(addr, bdaddr)) < 0)
1474 return 0;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001475
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001476 *len_ret = sizeof *addr;
1477 return 1;
1478 }
1479 case BTPROTO_RFCOMM:
1480 {
1481 struct sockaddr_rc *addr;
1482 char *straddr;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001483
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001484 addr = (struct sockaddr_rc *)addr_ret;
1485 _BT_RC_MEMB(addr, family) = AF_BLUETOOTH;
1486 if (!PyArg_ParseTuple(args, "si", &straddr,
1487 &_BT_RC_MEMB(addr, channel))) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001488 PyErr_SetString(PyExc_OSError, "getsockaddrarg: "
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001489 "wrong format");
1490 return 0;
1491 }
1492 if (setbdaddr(straddr, &_BT_RC_MEMB(addr, bdaddr)) < 0)
1493 return 0;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001494
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001495 *len_ret = sizeof *addr;
1496 return 1;
1497 }
1498 case BTPROTO_HCI:
1499 {
1500 struct sockaddr_hci *addr = (struct sockaddr_hci *)addr_ret;
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001501#if defined(__NetBSD__) || defined(__DragonFly__)
Alexander Belopolskye239d232010-12-08 23:31:48 +00001502 char *straddr = PyBytes_AS_STRING(args);
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001503
Alexander Belopolskye239d232010-12-08 23:31:48 +00001504 _BT_HCI_MEMB(addr, family) = AF_BLUETOOTH;
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001505 if (straddr == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001506 PyErr_SetString(PyExc_OSError, "getsockaddrarg: "
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001507 "wrong format");
1508 return 0;
1509 }
1510 if (setbdaddr(straddr, &_BT_HCI_MEMB(addr, bdaddr)) < 0)
1511 return 0;
1512#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001513 _BT_HCI_MEMB(addr, family) = AF_BLUETOOTH;
1514 if (!PyArg_ParseTuple(args, "i", &_BT_HCI_MEMB(addr, dev))) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001515 PyErr_SetString(PyExc_OSError, "getsockaddrarg: "
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001516 "wrong format");
1517 return 0;
1518 }
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00001519#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001520 *len_ret = sizeof *addr;
1521 return 1;
1522 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001523#if !defined(__FreeBSD__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001524 case BTPROTO_SCO:
1525 {
1526 struct sockaddr_sco *addr;
1527 char *straddr;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001528
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001529 addr = (struct sockaddr_sco *)addr_ret;
1530 _BT_SCO_MEMB(addr, family) = AF_BLUETOOTH;
1531 if (!PyBytes_Check(args)) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001532 PyErr_SetString(PyExc_OSError, "getsockaddrarg: "
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001533 "wrong format");
1534 return 0;
1535 }
1536 straddr = PyBytes_AS_STRING(args);
1537 if (setbdaddr(straddr, &_BT_SCO_MEMB(addr, bdaddr)) < 0)
1538 return 0;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001539
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001540 *len_ret = sizeof *addr;
1541 return 1;
1542 }
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001543#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001544 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001545 PyErr_SetString(PyExc_OSError, "getsockaddrarg: unknown Bluetooth protocol");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001546 return 0;
1547 }
1548 }
Martin v. Löwis12af0482004-01-31 12:34:17 +00001549#endif
1550
Antoine Pitroub156a462010-10-27 20:13:57 +00001551#if defined(HAVE_NETPACKET_PACKET_H) && defined(SIOCGIFINDEX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001552 case AF_PACKET:
1553 {
1554 struct sockaddr_ll* addr;
1555 struct ifreq ifr;
1556 char *interfaceName;
1557 int protoNumber;
1558 int hatype = 0;
1559 int pkttype = 0;
1560 char *haddr = NULL;
1561 unsigned int halen = 0;
Guido van Rossum48a680c2001-03-02 06:34:14 +00001562
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001563 if (!PyTuple_Check(args)) {
1564 PyErr_Format(
1565 PyExc_TypeError,
1566 "getsockaddrarg: "
1567 "AF_PACKET address must be tuple, not %.500s",
1568 Py_TYPE(args)->tp_name);
1569 return 0;
1570 }
1571 if (!PyArg_ParseTuple(args, "si|iiy#", &interfaceName,
1572 &protoNumber, &pkttype, &hatype,
1573 &haddr, &halen))
1574 return 0;
1575 strncpy(ifr.ifr_name, interfaceName, sizeof(ifr.ifr_name));
1576 ifr.ifr_name[(sizeof(ifr.ifr_name))-1] = '\0';
1577 if (ioctl(s->sock_fd, SIOCGIFINDEX, &ifr) < 0) {
1578 s->errorhandler();
1579 return 0;
1580 }
1581 if (halen > 8) {
1582 PyErr_SetString(PyExc_ValueError,
1583 "Hardware address must be 8 bytes or less");
1584 return 0;
1585 }
1586 if (protoNumber < 0 || protoNumber > 0xffff) {
1587 PyErr_SetString(
1588 PyExc_OverflowError,
1589 "getsockaddrarg: protoNumber must be 0-65535.");
1590 return 0;
1591 }
1592 addr = (struct sockaddr_ll*)addr_ret;
1593 addr->sll_family = AF_PACKET;
1594 addr->sll_protocol = htons((short)protoNumber);
1595 addr->sll_ifindex = ifr.ifr_ifindex;
1596 addr->sll_pkttype = pkttype;
1597 addr->sll_hatype = hatype;
1598 if (halen != 0) {
1599 memcpy(&addr->sll_addr, haddr, halen);
1600 }
1601 addr->sll_halen = halen;
1602 *len_ret = sizeof *addr;
1603 return 1;
1604 }
Guido van Rossum48a680c2001-03-02 06:34:14 +00001605#endif
1606
Christian Heimes043d6f62008-01-07 17:19:16 +00001607#ifdef HAVE_LINUX_TIPC_H
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001608 case AF_TIPC:
1609 {
1610 unsigned int atype, v1, v2, v3;
1611 unsigned int scope = TIPC_CLUSTER_SCOPE;
1612 struct sockaddr_tipc *addr;
Christian Heimes043d6f62008-01-07 17:19:16 +00001613
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001614 if (!PyTuple_Check(args)) {
1615 PyErr_Format(
1616 PyExc_TypeError,
1617 "getsockaddrarg: "
1618 "AF_TIPC address must be tuple, not %.500s",
1619 Py_TYPE(args)->tp_name);
1620 return 0;
1621 }
Christian Heimes043d6f62008-01-07 17:19:16 +00001622
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001623 if (!PyArg_ParseTuple(args,
1624 "IIII|I;Invalid TIPC address format",
1625 &atype, &v1, &v2, &v3, &scope))
1626 return 0;
Christian Heimes043d6f62008-01-07 17:19:16 +00001627
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001628 addr = (struct sockaddr_tipc *) addr_ret;
1629 memset(addr, 0, sizeof(struct sockaddr_tipc));
Christian Heimes043d6f62008-01-07 17:19:16 +00001630
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001631 addr->family = AF_TIPC;
1632 addr->scope = scope;
1633 addr->addrtype = atype;
Christian Heimes043d6f62008-01-07 17:19:16 +00001634
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001635 if (atype == TIPC_ADDR_NAMESEQ) {
1636 addr->addr.nameseq.type = v1;
1637 addr->addr.nameseq.lower = v2;
1638 addr->addr.nameseq.upper = v3;
1639 } else if (atype == TIPC_ADDR_NAME) {
1640 addr->addr.name.name.type = v1;
1641 addr->addr.name.name.instance = v2;
1642 } else if (atype == TIPC_ADDR_ID) {
1643 addr->addr.id.node = v1;
1644 addr->addr.id.ref = v2;
1645 } else {
1646 /* Shouldn't happen */
1647 PyErr_SetString(PyExc_TypeError, "Invalid address type");
1648 return 0;
1649 }
Christian Heimes043d6f62008-01-07 17:19:16 +00001650
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001651 *len_ret = sizeof(*addr);
Christian Heimes043d6f62008-01-07 17:19:16 +00001652
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001653 return 1;
1654 }
Christian Heimes043d6f62008-01-07 17:19:16 +00001655#endif
1656
Charles-François Natali30589c92011-10-07 22:47:08 +02001657#ifdef AF_CAN
Charles-François Natali47413c12011-10-06 19:47:44 +02001658 case AF_CAN:
1659 switch (s->sock_proto) {
1660 case CAN_RAW:
1661 {
1662 struct sockaddr_can *addr;
1663 PyObject *interfaceName;
1664 struct ifreq ifr;
1665 addr = (struct sockaddr_can *)addr_ret;
1666 Py_ssize_t len;
1667
1668 if (!PyArg_ParseTuple(args, "O&", PyUnicode_FSConverter,
1669 &interfaceName))
1670 return 0;
1671
1672 len = PyBytes_GET_SIZE(interfaceName);
1673
1674 if (len == 0) {
1675 ifr.ifr_ifindex = 0;
1676 } else if (len < sizeof(ifr.ifr_name)) {
1677 strcpy(ifr.ifr_name, PyBytes_AS_STRING(interfaceName));
1678 if (ioctl(s->sock_fd, SIOCGIFINDEX, &ifr) < 0) {
1679 s->errorhandler();
1680 Py_DECREF(interfaceName);
1681 return 0;
1682 }
1683 } else {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001684 PyErr_SetString(PyExc_OSError,
Charles-François Natali47413c12011-10-06 19:47:44 +02001685 "AF_CAN interface name too long");
1686 Py_DECREF(interfaceName);
1687 return 0;
1688 }
1689
1690 addr->can_family = AF_CAN;
1691 addr->can_ifindex = ifr.ifr_ifindex;
1692
1693 *len_ret = sizeof(*addr);
1694 Py_DECREF(interfaceName);
1695 return 1;
1696 }
1697 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001698 PyErr_SetString(PyExc_OSError,
Charles-François Natali47413c12011-10-06 19:47:44 +02001699 "getsockaddrarg: unsupported CAN protocol");
1700 return 0;
1701 }
1702#endif
Martin v. Löwis9d6c6692012-02-03 17:44:58 +01001703
1704#ifdef PF_SYSTEM
1705 case PF_SYSTEM:
1706 switch (s->sock_proto) {
1707#ifdef SYSPROTO_CONTROL
1708 case SYSPROTO_CONTROL:
1709 {
1710 struct sockaddr_ctl *addr;
1711
1712 addr = (struct sockaddr_ctl *)addr_ret;
1713 addr->sc_family = AF_SYSTEM;
1714 addr->ss_sysaddr = AF_SYS_CONTROL;
1715
1716 if (PyUnicode_Check(args)) {
1717 struct ctl_info info;
1718 PyObject *ctl_name;
1719
1720 if (!PyArg_Parse(args, "O&",
1721 PyUnicode_FSConverter, &ctl_name)) {
1722 return 0;
1723 }
1724
1725 if (PyBytes_GET_SIZE(ctl_name) > sizeof(info.ctl_name)) {
1726 PyErr_SetString(PyExc_ValueError,
1727 "provided string is too long");
1728 Py_DECREF(ctl_name);
1729 return 0;
1730 }
1731 strncpy(info.ctl_name, PyBytes_AS_STRING(ctl_name),
1732 sizeof(info.ctl_name));
1733 Py_DECREF(ctl_name);
1734
1735 if (ioctl(s->sock_fd, CTLIOCGINFO, &info)) {
1736 PyErr_SetString(PyExc_OSError,
1737 "cannot find kernel control with provided name");
1738 return 0;
1739 }
1740
1741 addr->sc_id = info.ctl_id;
1742 addr->sc_unit = 0;
1743 } else if (!PyArg_ParseTuple(args, "II",
1744 &(addr->sc_id), &(addr->sc_unit))) {
1745 PyErr_SetString(PyExc_TypeError, "getsockaddrarg: "
1746 "expected str or tuple of two ints");
1747
1748 return 0;
1749 }
1750
1751 *len_ret = sizeof(*addr);
1752 return 1;
1753 }
1754#endif
1755 default:
1756 PyErr_SetString(PyExc_OSError,
1757 "getsockaddrarg: unsupported PF_SYSTEM protocol");
1758 return 0;
1759 }
1760#endif
Charles-François Natali47413c12011-10-06 19:47:44 +02001761
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001762 /* More cases here... */
Guido van Rossum30a685f1991-06-27 15:51:29 +00001763
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001764 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001765 PyErr_SetString(PyExc_OSError, "getsockaddrarg: bad family");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001766 return 0;
Guido van Rossum30a685f1991-06-27 15:51:29 +00001767
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001768 }
Guido van Rossum6574b3e1991-06-25 21:36:08 +00001769}
1770
Guido van Rossum30a685f1991-06-27 15:51:29 +00001771
Guido van Rossum48a680c2001-03-02 06:34:14 +00001772/* Get the address length according to the socket object's address family.
Guido van Rossum710e1df1992-06-12 10:39:36 +00001773 Return 1 if the family is known, 0 otherwise. The length is returned
1774 through len_ret. */
1775
1776static int
Peter Schneider-Kamp618e25d2000-07-11 23:00:12 +00001777getsockaddrlen(PySocketSockObject *s, socklen_t *len_ret)
Guido van Rossum710e1df1992-06-12 10:39:36 +00001778{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001779 switch (s->sock_family) {
Guido van Rossum710e1df1992-06-12 10:39:36 +00001780
Andrew MacIntyred12dfbb2004-04-04 07:13:49 +00001781#if defined(AF_UNIX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001782 case AF_UNIX:
1783 {
1784 *len_ret = sizeof (struct sockaddr_un);
1785 return 1;
1786 }
Guido van Rossumb6775db1994-08-01 11:34:53 +00001787#endif /* AF_UNIX */
Martin v. Löwis11017b12006-01-14 18:12:57 +00001788#if defined(AF_NETLINK)
1789 case AF_NETLINK:
1790 {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001791 *len_ret = sizeof (struct sockaddr_nl);
1792 return 1;
Martin v. Löwis11017b12006-01-14 18:12:57 +00001793 }
1794#endif
Guido van Rossum710e1df1992-06-12 10:39:36 +00001795
Charles-François Natali10b8cf42011-11-10 19:21:37 +01001796#ifdef AF_RDS
1797 case AF_RDS:
1798 /* RDS sockets use sockaddr_in: fall-through */
1799#endif
1800
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001801 case AF_INET:
1802 {
1803 *len_ret = sizeof (struct sockaddr_in);
1804 return 1;
1805 }
Guido van Rossum710e1df1992-06-12 10:39:36 +00001806
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00001807#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001808 case AF_INET6:
1809 {
1810 *len_ret = sizeof (struct sockaddr_in6);
1811 return 1;
1812 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00001813#endif
1814
Hye-Shik Chang81268602004-02-02 06:05:24 +00001815#ifdef USE_BLUETOOTH
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001816 case AF_BLUETOOTH:
1817 {
1818 switch(s->sock_proto)
1819 {
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001820
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001821 case BTPROTO_L2CAP:
1822 *len_ret = sizeof (struct sockaddr_l2);
1823 return 1;
1824 case BTPROTO_RFCOMM:
1825 *len_ret = sizeof (struct sockaddr_rc);
1826 return 1;
1827 case BTPROTO_HCI:
1828 *len_ret = sizeof (struct sockaddr_hci);
1829 return 1;
Hye-Shik Chang81268602004-02-02 06:05:24 +00001830#if !defined(__FreeBSD__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001831 case BTPROTO_SCO:
1832 *len_ret = sizeof (struct sockaddr_sco);
1833 return 1;
Hye-Shik Chang81268602004-02-02 06:05:24 +00001834#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001835 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001836 PyErr_SetString(PyExc_OSError, "getsockaddrlen: "
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001837 "unknown BT protocol");
1838 return 0;
Martin v. Löwis558d9bf2004-06-03 09:24:42 +00001839
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001840 }
1841 }
Martin v. Löwis12af0482004-01-31 12:34:17 +00001842#endif
1843
Martin v. Löwis1ba3fd52001-08-10 20:29:40 +00001844#ifdef HAVE_NETPACKET_PACKET_H
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001845 case AF_PACKET:
1846 {
1847 *len_ret = sizeof (struct sockaddr_ll);
1848 return 1;
1849 }
Jeremy Hylton22308652001-02-02 03:23:09 +00001850#endif
Guido van Rossum48a680c2001-03-02 06:34:14 +00001851
Christian Heimes043d6f62008-01-07 17:19:16 +00001852#ifdef HAVE_LINUX_TIPC_H
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001853 case AF_TIPC:
1854 {
1855 *len_ret = sizeof (struct sockaddr_tipc);
1856 return 1;
1857 }
Christian Heimes043d6f62008-01-07 17:19:16 +00001858#endif
1859
Charles-François Natali30589c92011-10-07 22:47:08 +02001860#ifdef AF_CAN
Charles-François Natali47413c12011-10-06 19:47:44 +02001861 case AF_CAN:
1862 {
1863 *len_ret = sizeof (struct sockaddr_can);
1864 return 1;
1865 }
1866#endif
Martin v. Löwis9d6c6692012-02-03 17:44:58 +01001867
1868#ifdef PF_SYSTEM
1869 case PF_SYSTEM:
1870 switch(s->sock_proto) {
1871#ifdef SYSPROTO_CONTROL
1872 case SYSPROTO_CONTROL:
1873 *len_ret = sizeof (struct sockaddr_ctl);
1874 return 1;
1875#endif
1876 default:
1877 PyErr_SetString(PyExc_OSError, "getsockaddrlen: "
1878 "unknown PF_SYSTEM protocol");
1879 return 0;
1880 }
1881#endif
Charles-François Natali47413c12011-10-06 19:47:44 +02001882
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001883 /* More cases here... */
Guido van Rossum710e1df1992-06-12 10:39:36 +00001884
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001885 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02001886 PyErr_SetString(PyExc_OSError, "getsockaddrlen: bad family");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001887 return 0;
Guido van Rossum710e1df1992-06-12 10:39:36 +00001888
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001889 }
Guido van Rossum710e1df1992-06-12 10:39:36 +00001890}
1891
1892
Nick Coghlan96fe56a2011-08-22 11:55:57 +10001893/* Support functions for the sendmsg() and recvmsg[_into]() methods.
1894 Currently, these methods are only compiled if the RFC 2292/3542
1895 CMSG_LEN() macro is available. Older systems seem to have used
1896 sizeof(struct cmsghdr) + (length) where CMSG_LEN() is used now, so
1897 it may be possible to define CMSG_LEN() that way if it's not
1898 provided. Some architectures might need extra padding after the
1899 cmsghdr, however, and CMSG_LEN() would have to take account of
1900 this. */
1901#ifdef CMSG_LEN
1902/* If length is in range, set *result to CMSG_LEN(length) and return
1903 true; otherwise, return false. */
1904static int
1905get_CMSG_LEN(size_t length, size_t *result)
1906{
1907 size_t tmp;
1908
1909 if (length > (SOCKLEN_T_LIMIT - CMSG_LEN(0)))
1910 return 0;
1911 tmp = CMSG_LEN(length);
1912 if (tmp > SOCKLEN_T_LIMIT || tmp < length)
1913 return 0;
1914 *result = tmp;
1915 return 1;
1916}
1917
1918#ifdef CMSG_SPACE
1919/* If length is in range, set *result to CMSG_SPACE(length) and return
1920 true; otherwise, return false. */
1921static int
1922get_CMSG_SPACE(size_t length, size_t *result)
1923{
1924 size_t tmp;
1925
1926 /* Use CMSG_SPACE(1) here in order to take account of the padding
1927 necessary before *and* after the data. */
1928 if (length > (SOCKLEN_T_LIMIT - CMSG_SPACE(1)))
1929 return 0;
1930 tmp = CMSG_SPACE(length);
1931 if (tmp > SOCKLEN_T_LIMIT || tmp < length)
1932 return 0;
1933 *result = tmp;
1934 return 1;
1935}
1936#endif
1937
1938/* Return true iff msg->msg_controllen is valid, cmsgh is a valid
1939 pointer in msg->msg_control with at least "space" bytes after it,
1940 and its cmsg_len member inside the buffer. */
1941static int
1942cmsg_min_space(struct msghdr *msg, struct cmsghdr *cmsgh, size_t space)
1943{
1944 size_t cmsg_offset;
1945 static const size_t cmsg_len_end = (offsetof(struct cmsghdr, cmsg_len) +
1946 sizeof(cmsgh->cmsg_len));
1947
Charles-François Natali466517d2011-08-28 18:23:43 +02001948 /* Note that POSIX allows msg_controllen to be of signed type. */
1949 if (cmsgh == NULL || msg->msg_control == NULL || msg->msg_controllen < 0)
Nick Coghlan96fe56a2011-08-22 11:55:57 +10001950 return 0;
1951 if (space < cmsg_len_end)
1952 space = cmsg_len_end;
1953 cmsg_offset = (char *)cmsgh - (char *)msg->msg_control;
1954 return (cmsg_offset <= (size_t)-1 - space &&
1955 cmsg_offset + space <= msg->msg_controllen);
1956}
1957
1958/* If pointer CMSG_DATA(cmsgh) is in buffer msg->msg_control, set
1959 *space to number of bytes following it in the buffer and return
1960 true; otherwise, return false. Assumes cmsgh, msg->msg_control and
1961 msg->msg_controllen are valid. */
1962static int
1963get_cmsg_data_space(struct msghdr *msg, struct cmsghdr *cmsgh, size_t *space)
1964{
1965 size_t data_offset;
1966 char *data_ptr;
1967
1968 if ((data_ptr = (char *)CMSG_DATA(cmsgh)) == NULL)
1969 return 0;
1970 data_offset = data_ptr - (char *)msg->msg_control;
1971 if (data_offset > msg->msg_controllen)
1972 return 0;
1973 *space = msg->msg_controllen - data_offset;
1974 return 1;
1975}
1976
1977/* If cmsgh is invalid or not contained in the buffer pointed to by
1978 msg->msg_control, return -1. If cmsgh is valid and its associated
1979 data is entirely contained in the buffer, set *data_len to the
1980 length of the associated data and return 0. If only part of the
1981 associated data is contained in the buffer but cmsgh is otherwise
1982 valid, set *data_len to the length contained in the buffer and
1983 return 1. */
1984static int
1985get_cmsg_data_len(struct msghdr *msg, struct cmsghdr *cmsgh, size_t *data_len)
1986{
1987 size_t space, cmsg_data_len;
1988
1989 if (!cmsg_min_space(msg, cmsgh, CMSG_LEN(0)) ||
1990 cmsgh->cmsg_len < CMSG_LEN(0))
1991 return -1;
1992 cmsg_data_len = cmsgh->cmsg_len - CMSG_LEN(0);
1993 if (!get_cmsg_data_space(msg, cmsgh, &space))
1994 return -1;
1995 if (space >= cmsg_data_len) {
1996 *data_len = cmsg_data_len;
1997 return 0;
1998 }
1999 *data_len = space;
2000 return 1;
2001}
2002#endif /* CMSG_LEN */
2003
2004
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00002005/* s._accept() -> (fd, address) */
Guido van Rossum30a685f1991-06-27 15:51:29 +00002006
Guido van Rossum73624e91994-10-10 17:59:00 +00002007static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002008sock_accept(PySocketSockObject *s)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002009{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002010 sock_addr_t addrbuf;
2011 SOCKET_T newfd = INVALID_SOCKET;
2012 socklen_t addrlen;
2013 PyObject *sock = NULL;
2014 PyObject *addr = NULL;
2015 PyObject *res = NULL;
2016 int timeout;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002017 if (!getsockaddrlen(s, &addrlen))
2018 return NULL;
2019 memset(&addrbuf, 0, addrlen);
Guido van Rossum67f7a382002-06-06 21:08:16 +00002020
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002021 if (!IS_SELECTABLE(s))
2022 return select_error();
Neal Norwitz082b2df2006-02-07 07:04:46 +00002023
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002024 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002025 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002026 timeout = internal_select_ex(s, 0, interval);
Antoine Pitroub1c54962010-10-14 15:05:38 +00002027 if (!timeout) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002028 newfd = accept(s->sock_fd, SAS2SA(&addrbuf), &addrlen);
Antoine Pitroub1c54962010-10-14 15:05:38 +00002029 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002030 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00002031
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002032 if (timeout == 1) {
2033 PyErr_SetString(socket_timeout, "timed out");
2034 return NULL;
2035 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002036 END_SELECT_LOOP(s)
Raymond Hettingeref7343c2003-06-29 03:08:05 +00002037
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002038 if (newfd == INVALID_SOCKET)
2039 return s->errorhandler();
Barry Warsaw752300b1997-01-03 17:18:10 +00002040
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002041 sock = PyLong_FromSocket_t(newfd);
2042 if (sock == NULL) {
2043 SOCKETCLOSE(newfd);
2044 goto finally;
2045 }
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00002046
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002047 addr = makesockaddr(s->sock_fd, SAS2SA(&addrbuf),
2048 addrlen, s->sock_proto);
2049 if (addr == NULL)
2050 goto finally;
Barry Warsaw752300b1997-01-03 17:18:10 +00002051
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002052 res = PyTuple_Pack(2, sock, addr);
Barry Warsaw752300b1997-01-03 17:18:10 +00002053
Guido van Rossum67f7a382002-06-06 21:08:16 +00002054finally:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002055 Py_XDECREF(sock);
2056 Py_XDECREF(addr);
2057 return res;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002058}
2059
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002060PyDoc_STRVAR(accept_doc,
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00002061"_accept() -> (integer, address info)\n\
Guido van Rossum82a5c661998-07-07 20:45:43 +00002062\n\
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00002063Wait for an incoming connection. Return a new socket file descriptor\n\
2064representing the connection, and the address of the client.\n\
2065For IP sockets, the address info is a pair (hostaddr, port).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002066
Guido van Rossum11ba0942002-06-13 15:07:44 +00002067/* s.setblocking(flag) method. Argument:
2068 False -- non-blocking mode; same as settimeout(0)
2069 True -- blocking mode; same as settimeout(None)
2070*/
Guido van Rossume4485b01994-09-07 14:32:49 +00002071
Guido van Rossum73624e91994-10-10 17:59:00 +00002072static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002073sock_setblocking(PySocketSockObject *s, PyObject *arg)
Guido van Rossume4485b01994-09-07 14:32:49 +00002074{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002075 int block;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002076
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002077 block = PyLong_AsLong(arg);
2078 if (block == -1 && PyErr_Occurred())
2079 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002080
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002081 s->sock_timeout = block ? -1.0 : 0.0;
2082 internal_setblocking(s, block);
Guido van Rossume4485b01994-09-07 14:32:49 +00002083
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002084 Py_INCREF(Py_None);
2085 return Py_None;
Guido van Rossume4485b01994-09-07 14:32:49 +00002086}
Guido van Rossume4485b01994-09-07 14:32:49 +00002087
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002088PyDoc_STRVAR(setblocking_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002089"setblocking(flag)\n\
2090\n\
2091Set the socket to blocking (flag is true) or non-blocking (false).\n\
Guido van Rossum11ba0942002-06-13 15:07:44 +00002092setblocking(True) is equivalent to settimeout(None);\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002093setblocking(False) is equivalent to settimeout(0.0).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002094
Guido van Rossum11ba0942002-06-13 15:07:44 +00002095/* s.settimeout(timeout) method. Argument:
2096 None -- no timeout, blocking mode; same as setblocking(True)
2097 0.0 -- non-blocking mode; same as setblocking(False)
2098 > 0 -- timeout mode; operations time out after timeout seconds
2099 < 0 -- illegal; raises an exception
2100*/
Guido van Rossum67f7a382002-06-06 21:08:16 +00002101static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002102sock_settimeout(PySocketSockObject *s, PyObject *arg)
Guido van Rossum67f7a382002-06-06 21:08:16 +00002103{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002104 double timeout;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002105
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002106 if (arg == Py_None)
2107 timeout = -1.0;
2108 else {
2109 timeout = PyFloat_AsDouble(arg);
2110 if (timeout < 0.0) {
2111 if (!PyErr_Occurred())
2112 PyErr_SetString(PyExc_ValueError,
2113 "Timeout value out of range");
2114 return NULL;
2115 }
2116 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00002117
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002118 s->sock_timeout = timeout;
2119 internal_setblocking(s, timeout < 0.0);
Guido van Rossum67f7a382002-06-06 21:08:16 +00002120
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002121 Py_INCREF(Py_None);
2122 return Py_None;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002123}
2124
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002125PyDoc_STRVAR(settimeout_doc,
Guido van Rossum3eede5a2002-06-07 02:08:35 +00002126"settimeout(timeout)\n\
Guido van Rossum67f7a382002-06-06 21:08:16 +00002127\n\
Guido van Rossum11ba0942002-06-13 15:07:44 +00002128Set a timeout on socket operations. 'timeout' can be a float,\n\
2129giving in seconds, or None. Setting a timeout of None disables\n\
2130the timeout feature and is equivalent to setblocking(1).\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002131Setting a timeout of zero is the same as setblocking(0).");
Guido van Rossum67f7a382002-06-06 21:08:16 +00002132
Guido van Rossum3eede5a2002-06-07 02:08:35 +00002133/* s.gettimeout() method.
2134 Returns the timeout associated with a socket. */
Guido van Rossum67f7a382002-06-06 21:08:16 +00002135static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002136sock_gettimeout(PySocketSockObject *s)
Guido van Rossum67f7a382002-06-06 21:08:16 +00002137{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002138 if (s->sock_timeout < 0.0) {
2139 Py_INCREF(Py_None);
2140 return Py_None;
2141 }
2142 else
2143 return PyFloat_FromDouble(s->sock_timeout);
Guido van Rossum67f7a382002-06-06 21:08:16 +00002144}
2145
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002146PyDoc_STRVAR(gettimeout_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00002147"gettimeout() -> timeout\n\
Guido van Rossum67f7a382002-06-06 21:08:16 +00002148\n\
Ezio Melotti388c9452011-08-14 08:28:57 +03002149Returns the timeout in seconds (float) associated with socket \n\
Guido van Rossum67f7a382002-06-06 21:08:16 +00002150operations. A timeout of None indicates that timeouts on socket \n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002151operations are disabled.");
Guido van Rossume4485b01994-09-07 14:32:49 +00002152
Guido van Rossumaee08791992-09-08 09:05:33 +00002153/* s.setsockopt() method.
2154 With an integer third argument, sets an integer option.
2155 With a string third argument, sets an option from a buffer;
2156 use optional built-in module 'struct' to encode the string. */
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002157
Guido van Rossum73624e91994-10-10 17:59:00 +00002158static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002159sock_setsockopt(PySocketSockObject *s, PyObject *args)
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002160{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002161 int level;
2162 int optname;
2163 int res;
2164 char *buf;
2165 int buflen;
2166 int flag;
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002167
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002168 if (PyArg_ParseTuple(args, "iii:setsockopt",
2169 &level, &optname, &flag)) {
2170 buf = (char *) &flag;
2171 buflen = sizeof flag;
2172 }
2173 else {
2174 PyErr_Clear();
2175 if (!PyArg_ParseTuple(args, "iiy#:setsockopt",
2176 &level, &optname, &buf, &buflen))
2177 return NULL;
2178 }
2179 res = setsockopt(s->sock_fd, level, optname, (void *)buf, buflen);
2180 if (res < 0)
2181 return s->errorhandler();
2182 Py_INCREF(Py_None);
2183 return Py_None;
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002184}
2185
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002186PyDoc_STRVAR(setsockopt_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002187"setsockopt(level, option, value)\n\
2188\n\
2189Set a socket option. See the Unix manual for level and option.\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002190The value argument can either be an integer or a string.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002191
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002192
Guido van Rossumaee08791992-09-08 09:05:33 +00002193/* s.getsockopt() method.
2194 With two arguments, retrieves an integer option.
2195 With a third integer argument, retrieves a string buffer of that size;
2196 use optional built-in module 'struct' to decode the string. */
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002197
Guido van Rossum73624e91994-10-10 17:59:00 +00002198static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002199sock_getsockopt(PySocketSockObject *s, PyObject *args)
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002200{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002201 int level;
2202 int optname;
2203 int res;
2204 PyObject *buf;
2205 socklen_t buflen = 0;
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002206
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002207 if (!PyArg_ParseTuple(args, "ii|i:getsockopt",
2208 &level, &optname, &buflen))
2209 return NULL;
Guido van Rossum48a680c2001-03-02 06:34:14 +00002210
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002211 if (buflen == 0) {
2212 int flag = 0;
2213 socklen_t flagsize = sizeof flag;
2214 res = getsockopt(s->sock_fd, level, optname,
2215 (void *)&flag, &flagsize);
2216 if (res < 0)
2217 return s->errorhandler();
2218 return PyLong_FromLong(flag);
2219 }
Martin v. Löwis79acb9e2002-12-06 12:48:53 +00002220#ifdef __VMS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002221 /* socklen_t is unsigned so no negative test is needed,
2222 test buflen == 0 is previously done */
2223 if (buflen > 1024) {
Martin v. Löwis79acb9e2002-12-06 12:48:53 +00002224#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002225 if (buflen <= 0 || buflen > 1024) {
Martin v. Löwis79acb9e2002-12-06 12:48:53 +00002226#endif
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02002227 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002228 "getsockopt buflen out of range");
2229 return NULL;
2230 }
2231 buf = PyBytes_FromStringAndSize((char *)NULL, buflen);
2232 if (buf == NULL)
2233 return NULL;
2234 res = getsockopt(s->sock_fd, level, optname,
2235 (void *)PyBytes_AS_STRING(buf), &buflen);
2236 if (res < 0) {
2237 Py_DECREF(buf);
2238 return s->errorhandler();
2239 }
2240 _PyBytes_Resize(&buf, buflen);
2241 return buf;
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002242}
2243
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002244PyDoc_STRVAR(getsockopt_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002245"getsockopt(level, option[, buffersize]) -> value\n\
2246\n\
2247Get a socket option. See the Unix manual for level and option.\n\
2248If a nonzero buffersize argument is given, the return value is a\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002249string of that length; otherwise it is an integer.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002250
Guido van Rossum0e69587d1992-06-05 15:11:30 +00002251
Fred Drake728819a2000-07-01 03:40:12 +00002252/* s.bind(sockaddr) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00002253
Guido van Rossum73624e91994-10-10 17:59:00 +00002254static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002255sock_bind(PySocketSockObject *s, PyObject *addro)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002256{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002257 sock_addr_t addrbuf;
2258 int addrlen;
2259 int res;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00002260
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002261 if (!getsockaddrarg(s, addro, SAS2SA(&addrbuf), &addrlen))
2262 return NULL;
2263 Py_BEGIN_ALLOW_THREADS
2264 res = bind(s->sock_fd, SAS2SA(&addrbuf), addrlen);
2265 Py_END_ALLOW_THREADS
2266 if (res < 0)
2267 return s->errorhandler();
2268 Py_INCREF(Py_None);
2269 return Py_None;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002270}
2271
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002272PyDoc_STRVAR(bind_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002273"bind(address)\n\
2274\n\
2275Bind the socket to a local address. For IP sockets, the address is a\n\
Jeremy Hylton22308652001-02-02 03:23:09 +00002276pair (host, port); the host must refer to the local host. For raw packet\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002277sockets the address is a tuple (ifname, proto [,pkttype [,hatype]])");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002278
Guido van Rossum30a685f1991-06-27 15:51:29 +00002279
2280/* s.close() method.
2281 Set the file descriptor to -1 so operations tried subsequently
2282 will surely fail. */
2283
Guido van Rossum73624e91994-10-10 17:59:00 +00002284static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002285sock_close(PySocketSockObject *s)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002286{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002287 SOCKET_T fd;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00002288
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002289 if ((fd = s->sock_fd) != -1) {
2290 s->sock_fd = -1;
2291 Py_BEGIN_ALLOW_THREADS
2292 (void) SOCKETCLOSE(fd);
2293 Py_END_ALLOW_THREADS
2294 }
2295 Py_INCREF(Py_None);
2296 return Py_None;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002297}
2298
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002299PyDoc_STRVAR(close_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002300"close()\n\
2301\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002302Close the socket. It cannot be used after this call.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002303
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002304static PyObject *
Antoine Pitrou6e451df2010-08-09 20:39:54 +00002305sock_detach(PySocketSockObject *s)
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002306{
Antoine Pitrou6e451df2010-08-09 20:39:54 +00002307 SOCKET_T fd = s->sock_fd;
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002308 s->sock_fd = -1;
Antoine Pitrou6e451df2010-08-09 20:39:54 +00002309 return PyLong_FromSocket_t(fd);
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002310}
2311
Antoine Pitrou6e451df2010-08-09 20:39:54 +00002312PyDoc_STRVAR(detach_doc,
2313"detach()\n\
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002314\n\
2315Close the socket object without closing the underlying file descriptor.\
2316The object cannot be used after this call, but the file descriptor\
Antoine Pitrou6e451df2010-08-09 20:39:54 +00002317can be reused for other purposes. The file descriptor is returned.");
Antoine Pitroue43f9d02010-08-08 23:24:50 +00002318
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002319static int
Raymond Hettingeref7343c2003-06-29 03:08:05 +00002320internal_connect(PySocketSockObject *s, struct sockaddr *addr, int addrlen,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002321 int *timeoutp)
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002322{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002323 int res, timeout;
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002324
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002325 timeout = 0;
2326 res = connect(s->sock_fd, addr, addrlen);
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002327
2328#ifdef MS_WINDOWS
2329
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002330 if (s->sock_timeout > 0.0) {
2331 if (res < 0 && WSAGetLastError() == WSAEWOULDBLOCK &&
2332 IS_SELECTABLE(s)) {
2333 /* This is a mess. Best solution: trust select */
2334 fd_set fds;
2335 fd_set fds_exc;
2336 struct timeval tv;
2337 tv.tv_sec = (int)s->sock_timeout;
2338 tv.tv_usec = (int)((s->sock_timeout - tv.tv_sec) * 1e6);
2339 FD_ZERO(&fds);
2340 FD_SET(s->sock_fd, &fds);
2341 FD_ZERO(&fds_exc);
2342 FD_SET(s->sock_fd, &fds_exc);
Antoine Pitrou19467d22010-08-17 19:33:30 +00002343 res = select(Py_SAFE_DOWNCAST(s->sock_fd+1, SOCKET_T, int),
2344 NULL, &fds, &fds_exc, &tv);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002345 if (res == 0) {
2346 res = WSAEWOULDBLOCK;
2347 timeout = 1;
2348 } else if (res > 0) {
2349 if (FD_ISSET(s->sock_fd, &fds))
2350 /* The socket is in the writable set - this
2351 means connected */
2352 res = 0;
2353 else {
2354 /* As per MS docs, we need to call getsockopt()
2355 to get the underlying error */
2356 int res_size = sizeof res;
2357 /* It must be in the exception set */
2358 assert(FD_ISSET(s->sock_fd, &fds_exc));
2359 if (0 == getsockopt(s->sock_fd, SOL_SOCKET, SO_ERROR,
2360 (char *)&res, &res_size))
2361 /* getsockopt also clears WSAGetLastError,
2362 so reset it back. */
2363 WSASetLastError(res);
2364 else
2365 res = WSAGetLastError();
2366 }
2367 }
2368 /* else if (res < 0) an error occurred */
2369 }
2370 }
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002371
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002372 if (res < 0)
2373 res = WSAGetLastError();
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002374
2375#else
2376
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002377 if (s->sock_timeout > 0.0) {
2378 if (res < 0 && errno == EINPROGRESS && IS_SELECTABLE(s)) {
2379 timeout = internal_select(s, 1);
2380 if (timeout == 0) {
2381 /* Bug #1019808: in case of an EINPROGRESS,
2382 use getsockopt(SO_ERROR) to get the real
2383 error. */
2384 socklen_t res_size = sizeof res;
2385 (void)getsockopt(s->sock_fd, SOL_SOCKET,
2386 SO_ERROR, &res, &res_size);
2387 if (res == EISCONN)
2388 res = 0;
2389 errno = res;
2390 }
2391 else if (timeout == -1) {
2392 res = errno; /* had error */
2393 }
2394 else
2395 res = EWOULDBLOCK; /* timed out */
2396 }
2397 }
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002398
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002399 if (res < 0)
2400 res = errno;
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002401
2402#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002403 *timeoutp = timeout;
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002404
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002405 return res;
Guido van Rossum7b8bac12002-06-13 16:07:04 +00002406}
Guido van Rossum30a685f1991-06-27 15:51:29 +00002407
Fred Drake728819a2000-07-01 03:40:12 +00002408/* s.connect(sockaddr) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00002409
Guido van Rossum73624e91994-10-10 17:59:00 +00002410static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002411sock_connect(PySocketSockObject *s, PyObject *addro)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002412{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002413 sock_addr_t addrbuf;
2414 int addrlen;
2415 int res;
2416 int timeout;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00002417
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002418 if (!getsockaddrarg(s, addro, SAS2SA(&addrbuf), &addrlen))
2419 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002420
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002421 Py_BEGIN_ALLOW_THREADS
2422 res = internal_connect(s, SAS2SA(&addrbuf), addrlen, &timeout);
2423 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00002424
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002425 if (timeout == 1) {
2426 PyErr_SetString(socket_timeout, "timed out");
2427 return NULL;
2428 }
2429 if (res != 0)
2430 return s->errorhandler();
2431 Py_INCREF(Py_None);
2432 return Py_None;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002433}
2434
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002435PyDoc_STRVAR(connect_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002436"connect(address)\n\
2437\n\
2438Connect the socket to a remote address. For IP sockets, the address\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002439is a pair (host, port).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002440
Guido van Rossum30a685f1991-06-27 15:51:29 +00002441
Fred Drake728819a2000-07-01 03:40:12 +00002442/* s.connect_ex(sockaddr) method */
Guido van Rossumfc4255d1997-11-19 18:57:13 +00002443
2444static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002445sock_connect_ex(PySocketSockObject *s, PyObject *addro)
Guido van Rossumfc4255d1997-11-19 18:57:13 +00002446{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002447 sock_addr_t addrbuf;
2448 int addrlen;
2449 int res;
2450 int timeout;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00002451
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002452 if (!getsockaddrarg(s, addro, SAS2SA(&addrbuf), &addrlen))
2453 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002454
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002455 Py_BEGIN_ALLOW_THREADS
2456 res = internal_connect(s, SAS2SA(&addrbuf), addrlen, &timeout);
2457 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00002458
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002459 /* Signals are not errors (though they may raise exceptions). Adapted
2460 from PyErr_SetFromErrnoWithFilenameObject(). */
Thomas Wouters0e3f5912006-08-11 14:57:12 +00002461#ifdef EINTR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002462 if (res == EINTR && PyErr_CheckSignals())
2463 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00002464#endif
2465
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002466 return PyLong_FromLong((long) res);
Guido van Rossumfc4255d1997-11-19 18:57:13 +00002467}
2468
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002469PyDoc_STRVAR(connect_ex_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00002470"connect_ex(address) -> errno\n\
Guido van Rossum82a5c661998-07-07 20:45:43 +00002471\n\
2472This is like connect(address), but returns an error code (the errno value)\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002473instead of raising an exception when an error occurs.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002474
Guido van Rossumfc4255d1997-11-19 18:57:13 +00002475
Guido van Rossumed233a51992-06-23 09:07:03 +00002476/* s.fileno() method */
2477
Guido van Rossum73624e91994-10-10 17:59:00 +00002478static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002479sock_fileno(PySocketSockObject *s)
Guido van Rossumed233a51992-06-23 09:07:03 +00002480{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002481 return PyLong_FromSocket_t(s->sock_fd);
Guido van Rossumed233a51992-06-23 09:07:03 +00002482}
2483
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002484PyDoc_STRVAR(fileno_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002485"fileno() -> integer\n\
2486\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002487Return the integer file descriptor of the socket.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002488
Guido van Rossumed233a51992-06-23 09:07:03 +00002489
Guido van Rossumc89705d1992-11-26 08:54:07 +00002490/* s.getsockname() method */
2491
Guido van Rossum73624e91994-10-10 17:59:00 +00002492static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002493sock_getsockname(PySocketSockObject *s)
Guido van Rossumc89705d1992-11-26 08:54:07 +00002494{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002495 sock_addr_t addrbuf;
2496 int res;
2497 socklen_t addrlen;
Guido van Rossumff3ab422000-04-24 15:16:03 +00002498
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002499 if (!getsockaddrlen(s, &addrlen))
2500 return NULL;
2501 memset(&addrbuf, 0, addrlen);
2502 Py_BEGIN_ALLOW_THREADS
2503 res = getsockname(s->sock_fd, SAS2SA(&addrbuf), &addrlen);
2504 Py_END_ALLOW_THREADS
2505 if (res < 0)
2506 return s->errorhandler();
2507 return makesockaddr(s->sock_fd, SAS2SA(&addrbuf), addrlen,
2508 s->sock_proto);
Guido van Rossumc89705d1992-11-26 08:54:07 +00002509}
2510
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002511PyDoc_STRVAR(getsockname_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002512"getsockname() -> address info\n\
2513\n\
2514Return the address of the local endpoint. For IP sockets, the address\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002515info is a pair (hostaddr, port).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002516
Guido van Rossumc89705d1992-11-26 08:54:07 +00002517
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002518#ifdef HAVE_GETPEERNAME /* Cray APP doesn't have this :-( */
Guido van Rossumc89705d1992-11-26 08:54:07 +00002519/* s.getpeername() method */
2520
Guido van Rossum73624e91994-10-10 17:59:00 +00002521static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002522sock_getpeername(PySocketSockObject *s)
Guido van Rossumc89705d1992-11-26 08:54:07 +00002523{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002524 sock_addr_t addrbuf;
2525 int res;
2526 socklen_t addrlen;
Guido van Rossumff3ab422000-04-24 15:16:03 +00002527
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002528 if (!getsockaddrlen(s, &addrlen))
2529 return NULL;
2530 memset(&addrbuf, 0, addrlen);
2531 Py_BEGIN_ALLOW_THREADS
2532 res = getpeername(s->sock_fd, SAS2SA(&addrbuf), &addrlen);
2533 Py_END_ALLOW_THREADS
2534 if (res < 0)
2535 return s->errorhandler();
2536 return makesockaddr(s->sock_fd, SAS2SA(&addrbuf), addrlen,
2537 s->sock_proto);
Guido van Rossumc89705d1992-11-26 08:54:07 +00002538}
Guido van Rossum82a5c661998-07-07 20:45:43 +00002539
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002540PyDoc_STRVAR(getpeername_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002541"getpeername() -> address info\n\
2542\n\
2543Return the address of the remote endpoint. For IP sockets, the address\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002544info is a pair (hostaddr, port).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002545
Guido van Rossumb6775db1994-08-01 11:34:53 +00002546#endif /* HAVE_GETPEERNAME */
Guido van Rossumc89705d1992-11-26 08:54:07 +00002547
2548
Guido van Rossum30a685f1991-06-27 15:51:29 +00002549/* s.listen(n) method */
2550
Guido van Rossum73624e91994-10-10 17:59:00 +00002551static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002552sock_listen(PySocketSockObject *s, PyObject *arg)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002553{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002554 int backlog;
2555 int res;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00002556
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002557 backlog = PyLong_AsLong(arg);
2558 if (backlog == -1 && PyErr_Occurred())
2559 return NULL;
2560 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou1be815a2011-05-10 19:16:29 +02002561 /* To avoid problems on systems that don't allow a negative backlog
2562 * (which doesn't make sense anyway) we force a minimum value of 0. */
2563 if (backlog < 0)
2564 backlog = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002565 res = listen(s->sock_fd, backlog);
2566 Py_END_ALLOW_THREADS
2567 if (res < 0)
2568 return s->errorhandler();
2569 Py_INCREF(Py_None);
2570 return Py_None;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002571}
2572
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002573PyDoc_STRVAR(listen_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002574"listen(backlog)\n\
2575\n\
2576Enable a server to accept connections. The backlog argument must be at\n\
Antoine Pitrou1be815a2011-05-10 19:16:29 +02002577least 0 (if it is lower, it is set to 0); it specifies the number of\n\
2578unaccepted connections that the system will allow before refusing new\n\
2579connections.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002580
2581
Thomas Wouters477c8d52006-05-27 19:21:47 +00002582/*
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002583 * This is the guts of the recv() and recv_into() methods, which reads into a
Thomas Wouters902d6eb2007-01-09 23:18:33 +00002584 * char buffer. If you have any inc/dec ref to do to the objects that contain
Thomas Wouters477c8d52006-05-27 19:21:47 +00002585 * the buffer, do it in the caller. This function returns the number of bytes
Ezio Melotti13925002011-03-16 11:05:33 +02002586 * successfully read. If there was an error, it returns -1. Note that it is
Thomas Wouters477c8d52006-05-27 19:21:47 +00002587 * also possible that we return a number of bytes smaller than the request
2588 * bytes.
2589 */
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002590
Antoine Pitrou19467d22010-08-17 19:33:30 +00002591static Py_ssize_t
2592sock_recv_guts(PySocketSockObject *s, char* cbuf, Py_ssize_t len, int flags)
Thomas Wouters477c8d52006-05-27 19:21:47 +00002593{
Antoine Pitrou19467d22010-08-17 19:33:30 +00002594 Py_ssize_t outlen = -1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002595 int timeout;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002596#ifdef __VMS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002597 int remaining;
2598 char *read_buf;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002599#endif
2600
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002601 if (!IS_SELECTABLE(s)) {
2602 select_error();
2603 return -1;
2604 }
2605 if (len == 0) {
2606 /* If 0 bytes were requested, do nothing. */
2607 return 0;
2608 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002609
2610#ifndef __VMS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002611 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002612 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002613 timeout = internal_select_ex(s, 0, interval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002614 if (!timeout)
2615 outlen = recv(s->sock_fd, cbuf, len, flags);
2616 Py_END_ALLOW_THREADS
Thomas Wouters477c8d52006-05-27 19:21:47 +00002617
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002618 if (timeout == 1) {
2619 PyErr_SetString(socket_timeout, "timed out");
2620 return -1;
2621 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002622 END_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002623 if (outlen < 0) {
2624 /* Note: the call to errorhandler() ALWAYS indirectly returned
2625 NULL, so ignore its return value */
2626 s->errorhandler();
2627 return -1;
2628 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002629#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002630 read_buf = cbuf;
2631 remaining = len;
2632 while (remaining != 0) {
2633 unsigned int segment;
2634 int nread = -1;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002635
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002636 segment = remaining /SEGMENT_SIZE;
2637 if (segment != 0) {
2638 segment = SEGMENT_SIZE;
2639 }
2640 else {
2641 segment = remaining;
2642 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002643
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002644 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002645 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002646 timeout = internal_select_ex(s, 0, interval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002647 if (!timeout)
2648 nread = recv(s->sock_fd, read_buf, segment, flags);
2649 Py_END_ALLOW_THREADS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002650 if (timeout == 1) {
2651 PyErr_SetString(socket_timeout, "timed out");
2652 return -1;
2653 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002654 END_SELECT_LOOP(s)
2655
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002656 if (nread < 0) {
2657 s->errorhandler();
2658 return -1;
2659 }
2660 if (nread != remaining) {
2661 read_buf += nread;
2662 break;
2663 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002664
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002665 remaining -= segment;
2666 read_buf += segment;
2667 }
2668 outlen = read_buf - cbuf;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002669#endif /* !__VMS */
2670
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002671 return outlen;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002672}
2673
Guido van Rossum48a680c2001-03-02 06:34:14 +00002674
Guido van Rossumeb6b33a1993-05-25 09:38:27 +00002675/* s.recv(nbytes [,flags]) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00002676
Guido van Rossum73624e91994-10-10 17:59:00 +00002677static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00002678sock_recv(PySocketSockObject *s, PyObject *args)
Guido van Rossum30a685f1991-06-27 15:51:29 +00002679{
Antoine Pitrou19467d22010-08-17 19:33:30 +00002680 Py_ssize_t recvlen, outlen;
2681 int flags = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002682 PyObject *buf;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002683
Antoine Pitrou19467d22010-08-17 19:33:30 +00002684 if (!PyArg_ParseTuple(args, "n|i:recv", &recvlen, &flags))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002685 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002686
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002687 if (recvlen < 0) {
2688 PyErr_SetString(PyExc_ValueError,
2689 "negative buffersize in recv");
2690 return NULL;
2691 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00002692
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002693 /* Allocate a new string. */
2694 buf = PyBytes_FromStringAndSize((char *) 0, recvlen);
2695 if (buf == NULL)
2696 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002697
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002698 /* Call the guts */
2699 outlen = sock_recv_guts(s, PyBytes_AS_STRING(buf), recvlen, flags);
2700 if (outlen < 0) {
2701 /* An error occurred, release the string and return an
2702 error. */
2703 Py_DECREF(buf);
2704 return NULL;
2705 }
2706 if (outlen != recvlen) {
2707 /* We did not read as many bytes as we anticipated, resize the
2708 string if possible and be successful. */
2709 _PyBytes_Resize(&buf, outlen);
2710 }
Martin v. Löwis79acb9e2002-12-06 12:48:53 +00002711
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002712 return buf;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002713}
2714
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002715PyDoc_STRVAR(recv_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002716"recv(buffersize[, flags]) -> data\n\
2717\n\
2718Receive up to buffersize bytes from the socket. For the optional flags\n\
2719argument, see the Unix manual. When no data is available, block until\n\
2720at least one byte is available or until the remote end is closed. When\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002721the remote end is closed and all data is read, return the empty string.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002722
Guido van Rossum30a685f1991-06-27 15:51:29 +00002723
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002724/* s.recv_into(buffer, [nbytes [,flags]]) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00002725
Thomas Wouters477c8d52006-05-27 19:21:47 +00002726static PyObject*
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002727sock_recv_into(PySocketSockObject *s, PyObject *args, PyObject *kwds)
Thomas Wouters477c8d52006-05-27 19:21:47 +00002728{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002729 static char *kwlist[] = {"buffer", "nbytes", "flags", 0};
Thomas Wouters477c8d52006-05-27 19:21:47 +00002730
Antoine Pitrou19467d22010-08-17 19:33:30 +00002731 int flags = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002732 Py_buffer pbuf;
2733 char *buf;
Antoine Pitrou19467d22010-08-17 19:33:30 +00002734 Py_ssize_t buflen, readlen, recvlen = 0;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002735
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002736 /* Get the buffer's memory */
Antoine Pitrou19467d22010-08-17 19:33:30 +00002737 if (!PyArg_ParseTupleAndKeywords(args, kwds, "w*|ni:recv_into", kwlist,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002738 &pbuf, &recvlen, &flags))
2739 return NULL;
2740 buf = pbuf.buf;
2741 buflen = pbuf.len;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002742
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002743 if (recvlen < 0) {
2744 PyBuffer_Release(&pbuf);
2745 PyErr_SetString(PyExc_ValueError,
2746 "negative buffersize in recv_into");
2747 return NULL;
2748 }
2749 if (recvlen == 0) {
2750 /* If nbytes was not specified, use the buffer's length */
2751 recvlen = buflen;
2752 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002753
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002754 /* Check if the buffer is large enough */
2755 if (buflen < recvlen) {
2756 PyBuffer_Release(&pbuf);
2757 PyErr_SetString(PyExc_ValueError,
2758 "buffer too small for requested bytes");
2759 return NULL;
2760 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002761
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002762 /* Call the guts */
2763 readlen = sock_recv_guts(s, buf, recvlen, flags);
2764 if (readlen < 0) {
2765 /* Return an error. */
2766 PyBuffer_Release(&pbuf);
2767 return NULL;
2768 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002769
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002770 PyBuffer_Release(&pbuf);
2771 /* Return the number of bytes read. Note that we do not do anything
2772 special here in the case that readlen < recvlen. */
2773 return PyLong_FromSsize_t(readlen);
Thomas Wouters477c8d52006-05-27 19:21:47 +00002774}
2775
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002776PyDoc_STRVAR(recv_into_doc,
2777"recv_into(buffer, [nbytes[, flags]]) -> nbytes_read\n\
Thomas Wouters477c8d52006-05-27 19:21:47 +00002778\n\
2779A version of recv() that stores its data into a buffer rather than creating \n\
2780a new string. Receive up to buffersize bytes from the socket. If buffersize \n\
2781is not specified (or 0), receive up to the size available in the given buffer.\n\
2782\n\
2783See recv() for documentation about the flags.");
2784
2785
2786/*
Christian Heimes99170a52007-12-19 02:07:34 +00002787 * This is the guts of the recvfrom() and recvfrom_into() methods, which reads
2788 * into a char buffer. If you have any inc/def ref to do to the objects that
2789 * contain the buffer, do it in the caller. This function returns the number
Ezio Melotti13925002011-03-16 11:05:33 +02002790 * of bytes successfully read. If there was an error, it returns -1. Note
Christian Heimes99170a52007-12-19 02:07:34 +00002791 * that it is also possible that we return a number of bytes smaller than the
2792 * request bytes.
Thomas Wouters477c8d52006-05-27 19:21:47 +00002793 *
2794 * 'addr' is a return value for the address object. Note that you must decref
2795 * it yourself.
2796 */
Antoine Pitrou19467d22010-08-17 19:33:30 +00002797static Py_ssize_t
2798sock_recvfrom_guts(PySocketSockObject *s, char* cbuf, Py_ssize_t len, int flags,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002799 PyObject** addr)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002800{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002801 sock_addr_t addrbuf;
2802 int timeout;
Antoine Pitrou19467d22010-08-17 19:33:30 +00002803 Py_ssize_t n = -1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002804 socklen_t addrlen;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002805
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002806 *addr = NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002807
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002808 if (!getsockaddrlen(s, &addrlen))
2809 return -1;
Guido van Rossum67f7a382002-06-06 21:08:16 +00002810
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002811 if (!IS_SELECTABLE(s)) {
2812 select_error();
2813 return -1;
2814 }
Neal Norwitz082b2df2006-02-07 07:04:46 +00002815
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002816 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002817 Py_BEGIN_ALLOW_THREADS
2818 memset(&addrbuf, 0, addrlen);
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002819 timeout = internal_select_ex(s, 0, interval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002820 if (!timeout) {
Guido van Rossum8d665e61996-06-26 18:22:49 +00002821#ifndef MS_WINDOWS
Andrew MacIntyreba43e872002-03-03 03:03:52 +00002822#if defined(PYOS_OS2) && !defined(PYCC_GCC)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002823 n = recvfrom(s->sock_fd, cbuf, len, flags,
2824 SAS2SA(&addrbuf), &addrlen);
Guido van Rossum32c575d1997-12-02 20:37:32 +00002825#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002826 n = recvfrom(s->sock_fd, cbuf, len, flags,
2827 (void *) &addrbuf, &addrlen);
Guido van Rossum32c575d1997-12-02 20:37:32 +00002828#endif
Guido van Rossum6a3eb5f1994-08-18 15:42:46 +00002829#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002830 n = recvfrom(s->sock_fd, cbuf, len, flags,
2831 SAS2SA(&addrbuf), &addrlen);
Guido van Rossum6a3eb5f1994-08-18 15:42:46 +00002832#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002833 }
2834 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00002835
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002836 if (timeout == 1) {
2837 PyErr_SetString(socket_timeout, "timed out");
2838 return -1;
2839 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00002840 END_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002841 if (n < 0) {
2842 s->errorhandler();
2843 return -1;
2844 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00002845
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002846 if (!(*addr = makesockaddr(s->sock_fd, SAS2SA(&addrbuf),
2847 addrlen, s->sock_proto)))
2848 return -1;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002849
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002850 return n;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002851}
2852
2853/* s.recvfrom(nbytes [,flags]) method */
2854
2855static PyObject *
2856sock_recvfrom(PySocketSockObject *s, PyObject *args)
2857{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002858 PyObject *buf = NULL;
2859 PyObject *addr = NULL;
2860 PyObject *ret = NULL;
Antoine Pitrou19467d22010-08-17 19:33:30 +00002861 int flags = 0;
2862 Py_ssize_t recvlen, outlen;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002863
Antoine Pitrou19467d22010-08-17 19:33:30 +00002864 if (!PyArg_ParseTuple(args, "n|i:recvfrom", &recvlen, &flags))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002865 return NULL;
Guido van Rossum48a680c2001-03-02 06:34:14 +00002866
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002867 if (recvlen < 0) {
2868 PyErr_SetString(PyExc_ValueError,
2869 "negative buffersize in recvfrom");
2870 return NULL;
2871 }
Guido van Rossumd8faa362007-04-27 19:54:29 +00002872
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002873 buf = PyBytes_FromStringAndSize((char *) 0, recvlen);
2874 if (buf == NULL)
2875 return NULL;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002876
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002877 outlen = sock_recvfrom_guts(s, PyBytes_AS_STRING(buf),
2878 recvlen, flags, &addr);
2879 if (outlen < 0) {
2880 goto finally;
2881 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002882
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002883 if (outlen != recvlen) {
2884 /* We did not read as many bytes as we anticipated, resize the
Ezio Melotti13925002011-03-16 11:05:33 +02002885 string if possible and be successful. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002886 if (_PyBytes_Resize(&buf, outlen) < 0)
Ezio Melotti13925002011-03-16 11:05:33 +02002887 /* Oopsy, not so successful after all. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002888 goto finally;
2889 }
Barry Warsaw752300b1997-01-03 17:18:10 +00002890
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002891 ret = PyTuple_Pack(2, buf, addr);
Guido van Rossum67f7a382002-06-06 21:08:16 +00002892
2893finally:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002894 Py_XDECREF(buf);
2895 Py_XDECREF(addr);
2896 return ret;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00002897}
2898
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002899PyDoc_STRVAR(recvfrom_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00002900"recvfrom(buffersize[, flags]) -> (data, address info)\n\
2901\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00002902Like recv(buffersize, flags) but also return the sender's address info.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00002903
Thomas Wouters477c8d52006-05-27 19:21:47 +00002904
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002905/* s.recvfrom_into(buffer[, nbytes [,flags]]) method */
Thomas Wouters477c8d52006-05-27 19:21:47 +00002906
2907static PyObject *
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002908sock_recvfrom_into(PySocketSockObject *s, PyObject *args, PyObject* kwds)
Thomas Wouters477c8d52006-05-27 19:21:47 +00002909{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002910 static char *kwlist[] = {"buffer", "nbytes", "flags", 0};
Thomas Wouters477c8d52006-05-27 19:21:47 +00002911
Antoine Pitrou19467d22010-08-17 19:33:30 +00002912 int flags = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002913 Py_buffer pbuf;
2914 char *buf;
Antoine Pitrou19467d22010-08-17 19:33:30 +00002915 Py_ssize_t readlen, buflen, recvlen = 0;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002916
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002917 PyObject *addr = NULL;
Thomas Wouters477c8d52006-05-27 19:21:47 +00002918
Antoine Pitrou19467d22010-08-17 19:33:30 +00002919 if (!PyArg_ParseTupleAndKeywords(args, kwds, "w*|ni:recvfrom_into",
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002920 kwlist, &pbuf,
2921 &recvlen, &flags))
2922 return NULL;
2923 buf = pbuf.buf;
2924 buflen = pbuf.len;
2925 assert(buf != 0 && buflen > 0);
Thomas Wouters477c8d52006-05-27 19:21:47 +00002926
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002927 if (recvlen < 0) {
2928 PyBuffer_Release(&pbuf);
2929 PyErr_SetString(PyExc_ValueError,
2930 "negative buffersize in recvfrom_into");
2931 return NULL;
2932 }
2933 if (recvlen == 0) {
2934 /* If nbytes was not specified, use the buffer's length */
2935 recvlen = buflen;
2936 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002937
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002938 readlen = sock_recvfrom_guts(s, buf, recvlen, flags, &addr);
2939 if (readlen < 0) {
2940 PyBuffer_Release(&pbuf);
2941 /* Return an error */
2942 Py_XDECREF(addr);
2943 return NULL;
2944 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00002945
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002946 PyBuffer_Release(&pbuf);
2947 /* Return the number of bytes read and the address. Note that we do
2948 not do anything special here in the case that readlen < recvlen. */
Antoine Pitrou19467d22010-08-17 19:33:30 +00002949 return Py_BuildValue("nN", readlen, addr);
Thomas Wouters477c8d52006-05-27 19:21:47 +00002950}
2951
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002952PyDoc_STRVAR(recvfrom_into_doc,
2953"recvfrom_into(buffer[, nbytes[, flags]]) -> (nbytes, address info)\n\
Thomas Wouters477c8d52006-05-27 19:21:47 +00002954\n\
Thomas Wouters73e5a5b2006-06-08 15:35:45 +00002955Like recv_into(buffer[, nbytes[, flags]]) but also return the sender's address info.");
Thomas Wouters477c8d52006-05-27 19:21:47 +00002956
2957
Nick Coghlan96fe56a2011-08-22 11:55:57 +10002958/* The sendmsg() and recvmsg[_into]() methods require a working
2959 CMSG_LEN(). See the comment near get_CMSG_LEN(). */
2960#ifdef CMSG_LEN
2961/*
2962 * Call recvmsg() with the supplied iovec structures, flags, and
2963 * ancillary data buffer size (controllen). Returns the tuple return
2964 * value for recvmsg() or recvmsg_into(), with the first item provided
2965 * by the supplied makeval() function. makeval() will be called with
2966 * the length read and makeval_data as arguments, and must return a
2967 * new reference (which will be decrefed if there is a subsequent
2968 * error). On error, closes any file descriptors received via
2969 * SCM_RIGHTS.
2970 */
2971static PyObject *
2972sock_recvmsg_guts(PySocketSockObject *s, struct iovec *iov, int iovlen,
2973 int flags, Py_ssize_t controllen,
2974 PyObject *(*makeval)(ssize_t, void *), void *makeval_data)
2975{
2976 ssize_t bytes_received = -1;
2977 int timeout;
2978 sock_addr_t addrbuf;
2979 socklen_t addrbuflen;
Charles-François Natalie9e95ae2011-08-24 21:40:53 +02002980 struct msghdr msg = {0};
Nick Coghlan96fe56a2011-08-22 11:55:57 +10002981 PyObject *cmsg_list = NULL, *retval = NULL;
2982 void *controlbuf = NULL;
2983 struct cmsghdr *cmsgh;
2984 size_t cmsgdatalen = 0;
2985 int cmsg_status;
2986
2987 /* XXX: POSIX says that msg_name and msg_namelen "shall be
2988 ignored" when the socket is connected (Linux fills them in
2989 anyway for AF_UNIX sockets at least). Normally msg_namelen
2990 seems to be set to 0 if there's no address, but try to
2991 initialize msg_name to something that won't be mistaken for a
2992 real address if that doesn't happen. */
2993 if (!getsockaddrlen(s, &addrbuflen))
2994 return NULL;
2995 memset(&addrbuf, 0, addrbuflen);
2996 SAS2SA(&addrbuf)->sa_family = AF_UNSPEC;
2997
2998 if (controllen < 0 || controllen > SOCKLEN_T_LIMIT) {
2999 PyErr_SetString(PyExc_ValueError,
3000 "invalid ancillary data buffer length");
3001 return NULL;
3002 }
3003 if (controllen > 0 && (controlbuf = PyMem_Malloc(controllen)) == NULL)
3004 return PyErr_NoMemory();
3005
3006 /* Make the system call. */
3007 if (!IS_SELECTABLE(s)) {
3008 select_error();
3009 goto finally;
3010 }
3011
3012 BEGIN_SELECT_LOOP(s)
3013 Py_BEGIN_ALLOW_THREADS;
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003014 msg.msg_name = SAS2SA(&addrbuf);
3015 msg.msg_namelen = addrbuflen;
3016 msg.msg_iov = iov;
3017 msg.msg_iovlen = iovlen;
3018 msg.msg_control = controlbuf;
3019 msg.msg_controllen = controllen;
3020 timeout = internal_select_ex(s, 0, interval);
3021 if (!timeout)
3022 bytes_received = recvmsg(s->sock_fd, &msg, flags);
3023 Py_END_ALLOW_THREADS;
3024 if (timeout == 1) {
3025 PyErr_SetString(socket_timeout, "timed out");
3026 goto finally;
3027 }
3028 END_SELECT_LOOP(s)
3029
3030 if (bytes_received < 0) {
3031 s->errorhandler();
3032 goto finally;
3033 }
3034
3035 /* Make list of (level, type, data) tuples from control messages. */
3036 if ((cmsg_list = PyList_New(0)) == NULL)
3037 goto err_closefds;
3038 /* Check for empty ancillary data as old CMSG_FIRSTHDR()
3039 implementations didn't do so. */
3040 for (cmsgh = ((msg.msg_controllen > 0) ? CMSG_FIRSTHDR(&msg) : NULL);
3041 cmsgh != NULL; cmsgh = CMSG_NXTHDR(&msg, cmsgh)) {
3042 PyObject *bytes, *tuple;
3043 int tmp;
3044
3045 cmsg_status = get_cmsg_data_len(&msg, cmsgh, &cmsgdatalen);
3046 if (cmsg_status != 0) {
3047 if (PyErr_WarnEx(PyExc_RuntimeWarning,
3048 "received malformed or improperly-truncated "
3049 "ancillary data", 1) == -1)
3050 goto err_closefds;
3051 }
3052 if (cmsg_status < 0)
3053 break;
3054 if (cmsgdatalen > PY_SSIZE_T_MAX) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003055 PyErr_SetString(PyExc_OSError, "control message too long");
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003056 goto err_closefds;
3057 }
3058
3059 bytes = PyBytes_FromStringAndSize((char *)CMSG_DATA(cmsgh),
3060 cmsgdatalen);
3061 tuple = Py_BuildValue("iiN", (int)cmsgh->cmsg_level,
3062 (int)cmsgh->cmsg_type, bytes);
3063 if (tuple == NULL)
3064 goto err_closefds;
3065 tmp = PyList_Append(cmsg_list, tuple);
3066 Py_DECREF(tuple);
3067 if (tmp != 0)
3068 goto err_closefds;
3069
3070 if (cmsg_status != 0)
3071 break;
3072 }
3073
3074 retval = Py_BuildValue("NOiN",
3075 (*makeval)(bytes_received, makeval_data),
3076 cmsg_list,
3077 (int)msg.msg_flags,
3078 makesockaddr(s->sock_fd, SAS2SA(&addrbuf),
3079 ((msg.msg_namelen > addrbuflen) ?
3080 addrbuflen : msg.msg_namelen),
3081 s->sock_proto));
3082 if (retval == NULL)
3083 goto err_closefds;
3084
3085finally:
3086 Py_XDECREF(cmsg_list);
3087 PyMem_Free(controlbuf);
3088 return retval;
3089
3090err_closefds:
3091#ifdef SCM_RIGHTS
3092 /* Close all descriptors coming from SCM_RIGHTS, so they don't leak. */
3093 for (cmsgh = ((msg.msg_controllen > 0) ? CMSG_FIRSTHDR(&msg) : NULL);
3094 cmsgh != NULL; cmsgh = CMSG_NXTHDR(&msg, cmsgh)) {
3095 cmsg_status = get_cmsg_data_len(&msg, cmsgh, &cmsgdatalen);
3096 if (cmsg_status < 0)
3097 break;
3098 if (cmsgh->cmsg_level == SOL_SOCKET &&
3099 cmsgh->cmsg_type == SCM_RIGHTS) {
3100 size_t numfds;
3101 int *fdp;
3102
3103 numfds = cmsgdatalen / sizeof(int);
3104 fdp = (int *)CMSG_DATA(cmsgh);
3105 while (numfds-- > 0)
3106 close(*fdp++);
3107 }
3108 if (cmsg_status != 0)
3109 break;
3110 }
3111#endif /* SCM_RIGHTS */
3112 goto finally;
3113}
3114
3115
3116static PyObject *
3117makeval_recvmsg(ssize_t received, void *data)
3118{
3119 PyObject **buf = data;
3120
3121 if (received < PyBytes_GET_SIZE(*buf))
3122 _PyBytes_Resize(buf, received);
3123 Py_XINCREF(*buf);
3124 return *buf;
3125}
3126
3127/* s.recvmsg(bufsize[, ancbufsize[, flags]]) method */
3128
3129static PyObject *
3130sock_recvmsg(PySocketSockObject *s, PyObject *args)
3131{
3132 Py_ssize_t bufsize, ancbufsize = 0;
3133 int flags = 0;
3134 struct iovec iov;
3135 PyObject *buf = NULL, *retval = NULL;
3136
3137 if (!PyArg_ParseTuple(args, "n|ni:recvmsg", &bufsize, &ancbufsize, &flags))
3138 return NULL;
3139
3140 if (bufsize < 0) {
3141 PyErr_SetString(PyExc_ValueError, "negative buffer size in recvmsg()");
3142 return NULL;
3143 }
3144 if ((buf = PyBytes_FromStringAndSize(NULL, bufsize)) == NULL)
3145 return NULL;
3146 iov.iov_base = PyBytes_AS_STRING(buf);
3147 iov.iov_len = bufsize;
3148
3149 /* Note that we're passing a pointer to *our pointer* to the bytes
3150 object here (&buf); makeval_recvmsg() may incref the object, or
3151 deallocate it and set our pointer to NULL. */
3152 retval = sock_recvmsg_guts(s, &iov, 1, flags, ancbufsize,
3153 &makeval_recvmsg, &buf);
3154 Py_XDECREF(buf);
3155 return retval;
3156}
3157
3158PyDoc_STRVAR(recvmsg_doc,
3159"recvmsg(bufsize[, ancbufsize[, flags]]) -> (data, ancdata, msg_flags, address)\n\
3160\n\
3161Receive normal data (up to bufsize bytes) and ancillary data from the\n\
3162socket. The ancbufsize argument sets the size in bytes of the\n\
3163internal buffer used to receive the ancillary data; it defaults to 0,\n\
3164meaning that no ancillary data will be received. Appropriate buffer\n\
3165sizes for ancillary data can be calculated using CMSG_SPACE() or\n\
3166CMSG_LEN(), and items which do not fit into the buffer might be\n\
3167truncated or discarded. The flags argument defaults to 0 and has the\n\
3168same meaning as for recv().\n\
3169\n\
3170The return value is a 4-tuple: (data, ancdata, msg_flags, address).\n\
3171The data item is a bytes object holding the non-ancillary data\n\
3172received. The ancdata item is a list of zero or more tuples\n\
3173(cmsg_level, cmsg_type, cmsg_data) representing the ancillary data\n\
3174(control messages) received: cmsg_level and cmsg_type are integers\n\
3175specifying the protocol level and protocol-specific type respectively,\n\
3176and cmsg_data is a bytes object holding the associated data. The\n\
3177msg_flags item is the bitwise OR of various flags indicating\n\
3178conditions on the received message; see your system documentation for\n\
3179details. If the receiving socket is unconnected, address is the\n\
3180address of the sending socket, if available; otherwise, its value is\n\
3181unspecified.\n\
3182\n\
3183If recvmsg() raises an exception after the system call returns, it\n\
3184will first attempt to close any file descriptors received via the\n\
3185SCM_RIGHTS mechanism.");
3186
3187
3188static PyObject *
3189makeval_recvmsg_into(ssize_t received, void *data)
3190{
3191 return PyLong_FromSsize_t(received);
3192}
3193
3194/* s.recvmsg_into(buffers[, ancbufsize[, flags]]) method */
3195
3196static PyObject *
3197sock_recvmsg_into(PySocketSockObject *s, PyObject *args)
3198{
3199 Py_ssize_t ancbufsize = 0;
3200 int flags = 0;
3201 struct iovec *iovs = NULL;
3202 Py_ssize_t i, nitems, nbufs = 0;
3203 Py_buffer *bufs = NULL;
3204 PyObject *buffers_arg, *fast, *retval = NULL;
3205
3206 if (!PyArg_ParseTuple(args, "O|ni:recvmsg_into",
3207 &buffers_arg, &ancbufsize, &flags))
3208 return NULL;
3209
3210 if ((fast = PySequence_Fast(buffers_arg,
3211 "recvmsg_into() argument 1 must be an "
3212 "iterable")) == NULL)
3213 return NULL;
3214 nitems = PySequence_Fast_GET_SIZE(fast);
3215 if (nitems > INT_MAX) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003216 PyErr_SetString(PyExc_OSError, "recvmsg_into() argument 1 is too long");
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003217 goto finally;
3218 }
3219
3220 /* Fill in an iovec for each item, and save the Py_buffer
3221 structs to release afterwards. */
3222 if (nitems > 0 && ((iovs = PyMem_New(struct iovec, nitems)) == NULL ||
3223 (bufs = PyMem_New(Py_buffer, nitems)) == NULL)) {
3224 PyErr_NoMemory();
3225 goto finally;
3226 }
3227 for (; nbufs < nitems; nbufs++) {
3228 if (!PyArg_Parse(PySequence_Fast_GET_ITEM(fast, nbufs),
3229 "w*;recvmsg_into() argument 1 must be an iterable "
3230 "of single-segment read-write buffers",
3231 &bufs[nbufs]))
3232 goto finally;
3233 iovs[nbufs].iov_base = bufs[nbufs].buf;
3234 iovs[nbufs].iov_len = bufs[nbufs].len;
3235 }
3236
3237 retval = sock_recvmsg_guts(s, iovs, nitems, flags, ancbufsize,
3238 &makeval_recvmsg_into, NULL);
3239finally:
3240 for (i = 0; i < nbufs; i++)
3241 PyBuffer_Release(&bufs[i]);
3242 PyMem_Free(bufs);
3243 PyMem_Free(iovs);
3244 Py_DECREF(fast);
3245 return retval;
3246}
3247
3248PyDoc_STRVAR(recvmsg_into_doc,
3249"recvmsg_into(buffers[, ancbufsize[, flags]]) -> (nbytes, ancdata, msg_flags, address)\n\
3250\n\
3251Receive normal data and ancillary data from the socket, scattering the\n\
3252non-ancillary data into a series of buffers. The buffers argument\n\
3253must be an iterable of objects that export writable buffers\n\
3254(e.g. bytearray objects); these will be filled with successive chunks\n\
3255of the non-ancillary data until it has all been written or there are\n\
3256no more buffers. The ancbufsize argument sets the size in bytes of\n\
3257the internal buffer used to receive the ancillary data; it defaults to\n\
32580, meaning that no ancillary data will be received. Appropriate\n\
3259buffer sizes for ancillary data can be calculated using CMSG_SPACE()\n\
3260or CMSG_LEN(), and items which do not fit into the buffer might be\n\
3261truncated or discarded. The flags argument defaults to 0 and has the\n\
3262same meaning as for recv().\n\
3263\n\
3264The return value is a 4-tuple: (nbytes, ancdata, msg_flags, address).\n\
3265The nbytes item is the total number of bytes of non-ancillary data\n\
3266written into the buffers. The ancdata item is a list of zero or more\n\
3267tuples (cmsg_level, cmsg_type, cmsg_data) representing the ancillary\n\
3268data (control messages) received: cmsg_level and cmsg_type are\n\
3269integers specifying the protocol level and protocol-specific type\n\
3270respectively, and cmsg_data is a bytes object holding the associated\n\
3271data. The msg_flags item is the bitwise OR of various flags\n\
3272indicating conditions on the received message; see your system\n\
3273documentation for details. If the receiving socket is unconnected,\n\
3274address is the address of the sending socket, if available; otherwise,\n\
3275its value is unspecified.\n\
3276\n\
3277If recvmsg_into() raises an exception after the system call returns,\n\
3278it will first attempt to close any file descriptors received via the\n\
3279SCM_RIGHTS mechanism.");
3280#endif /* CMSG_LEN */
3281
3282
Guido van Rossumeb6b33a1993-05-25 09:38:27 +00003283/* s.send(data [,flags]) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00003284
Guido van Rossum73624e91994-10-10 17:59:00 +00003285static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003286sock_send(PySocketSockObject *s, PyObject *args)
Guido van Rossum30a685f1991-06-27 15:51:29 +00003287{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003288 char *buf;
Antoine Pitrou19467d22010-08-17 19:33:30 +00003289 Py_ssize_t len, n = -1;
3290 int flags = 0, timeout;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003291 Py_buffer pbuf;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003292
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003293 if (!PyArg_ParseTuple(args, "y*|i:send", &pbuf, &flags))
3294 return NULL;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003295
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003296 if (!IS_SELECTABLE(s)) {
3297 PyBuffer_Release(&pbuf);
3298 return select_error();
3299 }
3300 buf = pbuf.buf;
3301 len = pbuf.len;
Neal Norwitz082b2df2006-02-07 07:04:46 +00003302
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003303 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003304 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003305 timeout = internal_select_ex(s, 1, interval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003306 if (!timeout)
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003307#ifdef __VMS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003308 n = sendsegmented(s->sock_fd, buf, len, flags);
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003309#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003310 n = send(s->sock_fd, buf, len, flags);
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003311#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003312 Py_END_ALLOW_THREADS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003313 if (timeout == 1) {
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003314 PyBuffer_Release(&pbuf);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003315 PyErr_SetString(socket_timeout, "timed out");
3316 return NULL;
3317 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003318 END_SELECT_LOOP(s)
3319
3320 PyBuffer_Release(&pbuf);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003321 if (n < 0)
3322 return s->errorhandler();
Antoine Pitrou19467d22010-08-17 19:33:30 +00003323 return PyLong_FromSsize_t(n);
Guido van Rossum30a685f1991-06-27 15:51:29 +00003324}
3325
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003326PyDoc_STRVAR(send_doc,
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003327"send(data[, flags]) -> count\n\
Guido van Rossum82a5c661998-07-07 20:45:43 +00003328\n\
3329Send a data string to the socket. For the optional flags\n\
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003330argument, see the Unix manual. Return the number of bytes\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003331sent; this may be less than len(data) if the network is busy.");
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003332
3333
3334/* s.sendall(data [,flags]) method */
3335
3336static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003337sock_sendall(PySocketSockObject *s, PyObject *args)
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003338{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003339 char *buf;
Antoine Pitrou19467d22010-08-17 19:33:30 +00003340 Py_ssize_t len, n = -1;
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003341 int flags = 0, timeout, saved_errno;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003342 Py_buffer pbuf;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003343
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003344 if (!PyArg_ParseTuple(args, "y*|i:sendall", &pbuf, &flags))
3345 return NULL;
3346 buf = pbuf.buf;
3347 len = pbuf.len;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003348
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003349 if (!IS_SELECTABLE(s)) {
3350 PyBuffer_Release(&pbuf);
3351 return select_error();
3352 }
Neal Norwitz082b2df2006-02-07 07:04:46 +00003353
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003354 do {
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003355 Py_BEGIN_ALLOW_THREADS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003356 timeout = internal_select(s, 1);
3357 n = -1;
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003358 if (!timeout) {
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003359#ifdef __VMS
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003360 n = sendsegmented(s->sock_fd, buf, len, flags);
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003361#else
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003362 n = send(s->sock_fd, buf, len, flags);
Thomas Wouters0e3f5912006-08-11 14:57:12 +00003363#endif
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003364 }
3365 Py_END_ALLOW_THREADS
3366 if (timeout == 1) {
3367 PyBuffer_Release(&pbuf);
3368 PyErr_SetString(socket_timeout, "timed out");
3369 return NULL;
3370 }
3371 /* PyErr_CheckSignals() might change errno */
3372 saved_errno = errno;
3373 /* We must run our signal handlers before looping again.
3374 send() can return a successful partial write when it is
3375 interrupted, so we can't restrict ourselves to EINTR. */
3376 if (PyErr_CheckSignals()) {
3377 PyBuffer_Release(&pbuf);
3378 return NULL;
3379 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003380 if (n < 0) {
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003381 /* If interrupted, try again */
3382 if (saved_errno == EINTR)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003383 continue;
Antoine Pitrou6d7df632010-09-27 17:52:25 +00003384 else
3385 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003386 }
3387 buf += n;
3388 len -= n;
3389 } while (len > 0);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003390 PyBuffer_Release(&pbuf);
Guido van Rossum67f7a382002-06-06 21:08:16 +00003391
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003392 if (n < 0)
3393 return s->errorhandler();
Guido van Rossum67f7a382002-06-06 21:08:16 +00003394
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003395 Py_INCREF(Py_None);
3396 return Py_None;
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003397}
3398
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003399PyDoc_STRVAR(sendall_doc,
Guido van Rossum9f7a5392001-10-26 03:25:00 +00003400"sendall(data[, flags])\n\
3401\n\
3402Send a data string to the socket. For the optional flags\n\
3403argument, see the Unix manual. This calls send() repeatedly\n\
3404until all data is sent. If an error occurs, it's impossible\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003405to tell how much data has been sent.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00003406
Guido van Rossum30a685f1991-06-27 15:51:29 +00003407
Guido van Rossumeb6b33a1993-05-25 09:38:27 +00003408/* s.sendto(data, [flags,] sockaddr) method */
Guido van Rossum30a685f1991-06-27 15:51:29 +00003409
Guido van Rossum73624e91994-10-10 17:59:00 +00003410static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003411sock_sendto(PySocketSockObject *s, PyObject *args)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003412{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003413 Py_buffer pbuf;
3414 PyObject *addro;
3415 char *buf;
Antoine Pitrou5e981412011-03-17 22:38:37 +01003416 Py_ssize_t len, arglen;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003417 sock_addr_t addrbuf;
3418 int addrlen, n = -1, flags, timeout;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003419
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003420 flags = 0;
Antoine Pitrou5e981412011-03-17 22:38:37 +01003421 arglen = PyTuple_Size(args);
3422 switch (arglen) {
3423 case 2:
3424 PyArg_ParseTuple(args, "y*O:sendto", &pbuf, &addro);
3425 break;
3426 case 3:
3427 PyArg_ParseTuple(args, "y*iO:sendto",
3428 &pbuf, &flags, &addro);
3429 break;
3430 default:
3431 PyErr_Format(PyExc_TypeError,
3432 "sendto() takes 2 or 3 arguments (%d given)",
3433 arglen);
Victor Stinner77af1722011-05-26 14:05:59 +02003434 return NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003435 }
Antoine Pitrou5e981412011-03-17 22:38:37 +01003436 if (PyErr_Occurred())
3437 return NULL;
3438
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003439 buf = pbuf.buf;
3440 len = pbuf.len;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003441
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003442 if (!IS_SELECTABLE(s)) {
3443 PyBuffer_Release(&pbuf);
3444 return select_error();
3445 }
Neal Norwitz082b2df2006-02-07 07:04:46 +00003446
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003447 if (!getsockaddrarg(s, addro, SAS2SA(&addrbuf), &addrlen)) {
3448 PyBuffer_Release(&pbuf);
3449 return NULL;
3450 }
Thomas Wouters89f507f2006-12-13 04:49:30 +00003451
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003452 BEGIN_SELECT_LOOP(s)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003453 Py_BEGIN_ALLOW_THREADS
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003454 timeout = internal_select_ex(s, 1, interval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003455 if (!timeout)
3456 n = sendto(s->sock_fd, buf, len, flags, SAS2SA(&addrbuf), addrlen);
3457 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00003458
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003459 if (timeout == 1) {
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003460 PyBuffer_Release(&pbuf);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003461 PyErr_SetString(socket_timeout, "timed out");
3462 return NULL;
3463 }
Antoine Pitrou3e1fd272010-09-28 21:23:11 +00003464 END_SELECT_LOOP(s)
3465 PyBuffer_Release(&pbuf);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003466 if (n < 0)
3467 return s->errorhandler();
Antoine Pitrou19467d22010-08-17 19:33:30 +00003468 return PyLong_FromSsize_t(n);
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003469}
3470
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003471PyDoc_STRVAR(sendto_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00003472"sendto(data[, flags], address) -> count\n\
Guido van Rossum82a5c661998-07-07 20:45:43 +00003473\n\
3474Like send(data, flags) but allows specifying the destination address.\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003475For IP sockets, the address is a pair (hostaddr, port).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00003476
Guido van Rossum30a685f1991-06-27 15:51:29 +00003477
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003478/* The sendmsg() and recvmsg[_into]() methods require a working
3479 CMSG_LEN(). See the comment near get_CMSG_LEN(). */
3480#ifdef CMSG_LEN
3481/* s.sendmsg(buffers[, ancdata[, flags[, address]]]) method */
3482
3483static PyObject *
3484sock_sendmsg(PySocketSockObject *s, PyObject *args)
3485{
3486 Py_ssize_t i, ndataparts, ndatabufs = 0, ncmsgs, ncmsgbufs = 0;
3487 Py_buffer *databufs = NULL;
3488 struct iovec *iovs = NULL;
3489 sock_addr_t addrbuf;
Charles-François Natalie9e95ae2011-08-24 21:40:53 +02003490 struct msghdr msg = {0};
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003491 struct cmsginfo {
3492 int level;
3493 int type;
3494 Py_buffer data;
3495 } *cmsgs = NULL;
3496 void *controlbuf = NULL;
3497 size_t controllen, controllen_last;
3498 ssize_t bytes_sent = -1;
3499 int addrlen, timeout, flags = 0;
3500 PyObject *data_arg, *cmsg_arg = NULL, *addr_arg = NULL, *data_fast = NULL,
3501 *cmsg_fast = NULL, *retval = NULL;
3502
3503 if (!PyArg_ParseTuple(args, "O|OiO:sendmsg",
3504 &data_arg, &cmsg_arg, &flags, &addr_arg))
3505 return NULL;
3506
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003507 /* Parse destination address. */
3508 if (addr_arg != NULL && addr_arg != Py_None) {
3509 if (!getsockaddrarg(s, addr_arg, SAS2SA(&addrbuf), &addrlen))
3510 goto finally;
3511 msg.msg_name = &addrbuf;
3512 msg.msg_namelen = addrlen;
3513 }
3514
3515 /* Fill in an iovec for each message part, and save the Py_buffer
3516 structs to release afterwards. */
3517 if ((data_fast = PySequence_Fast(data_arg,
3518 "sendmsg() argument 1 must be an "
3519 "iterable")) == NULL)
3520 goto finally;
3521 ndataparts = PySequence_Fast_GET_SIZE(data_fast);
3522 if (ndataparts > INT_MAX) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003523 PyErr_SetString(PyExc_OSError, "sendmsg() argument 1 is too long");
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003524 goto finally;
3525 }
3526 msg.msg_iovlen = ndataparts;
3527 if (ndataparts > 0 &&
3528 ((msg.msg_iov = iovs = PyMem_New(struct iovec, ndataparts)) == NULL ||
3529 (databufs = PyMem_New(Py_buffer, ndataparts)) == NULL)) {
3530 PyErr_NoMemory();
3531 goto finally;
3532 }
3533 for (; ndatabufs < ndataparts; ndatabufs++) {
3534 if (!PyArg_Parse(PySequence_Fast_GET_ITEM(data_fast, ndatabufs),
3535 "y*;sendmsg() argument 1 must be an iterable of "
3536 "buffer-compatible objects",
3537 &databufs[ndatabufs]))
3538 goto finally;
3539 iovs[ndatabufs].iov_base = databufs[ndatabufs].buf;
3540 iovs[ndatabufs].iov_len = databufs[ndatabufs].len;
3541 }
3542
3543 if (cmsg_arg == NULL)
3544 ncmsgs = 0;
3545 else {
3546 if ((cmsg_fast = PySequence_Fast(cmsg_arg,
3547 "sendmsg() argument 2 must be an "
3548 "iterable")) == NULL)
3549 goto finally;
3550 ncmsgs = PySequence_Fast_GET_SIZE(cmsg_fast);
3551 }
3552
3553#ifndef CMSG_SPACE
3554 if (ncmsgs > 1) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003555 PyErr_SetString(PyExc_OSError,
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003556 "sending multiple control messages is not supported "
3557 "on this system");
3558 goto finally;
3559 }
3560#endif
3561 /* Save level, type and Py_buffer for each control message,
3562 and calculate total size. */
3563 if (ncmsgs > 0 && (cmsgs = PyMem_New(struct cmsginfo, ncmsgs)) == NULL) {
3564 PyErr_NoMemory();
3565 goto finally;
3566 }
3567 controllen = controllen_last = 0;
3568 while (ncmsgbufs < ncmsgs) {
3569 size_t bufsize, space;
3570
3571 if (!PyArg_Parse(PySequence_Fast_GET_ITEM(cmsg_fast, ncmsgbufs),
3572 "(iiy*):[sendmsg() ancillary data items]",
3573 &cmsgs[ncmsgbufs].level,
3574 &cmsgs[ncmsgbufs].type,
3575 &cmsgs[ncmsgbufs].data))
3576 goto finally;
3577 bufsize = cmsgs[ncmsgbufs++].data.len;
3578
3579#ifdef CMSG_SPACE
3580 if (!get_CMSG_SPACE(bufsize, &space)) {
3581#else
3582 if (!get_CMSG_LEN(bufsize, &space)) {
3583#endif
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003584 PyErr_SetString(PyExc_OSError, "ancillary data item too large");
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003585 goto finally;
3586 }
3587 controllen += space;
3588 if (controllen > SOCKLEN_T_LIMIT || controllen < controllen_last) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02003589 PyErr_SetString(PyExc_OSError, "too much ancillary data");
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003590 goto finally;
3591 }
3592 controllen_last = controllen;
3593 }
3594
3595 /* Construct ancillary data block from control message info. */
3596 if (ncmsgbufs > 0) {
3597 struct cmsghdr *cmsgh = NULL;
3598
3599 if ((msg.msg_control = controlbuf =
3600 PyMem_Malloc(controllen)) == NULL) {
3601 PyErr_NoMemory();
3602 goto finally;
3603 }
3604 msg.msg_controllen = controllen;
3605
3606 /* Need to zero out the buffer as a workaround for glibc's
3607 CMSG_NXTHDR() implementation. After getting the pointer to
3608 the next header, it checks its (uninitialized) cmsg_len
3609 member to see if the "message" fits in the buffer, and
3610 returns NULL if it doesn't. Zero-filling the buffer
3611 ensures that that doesn't happen. */
3612 memset(controlbuf, 0, controllen);
3613
3614 for (i = 0; i < ncmsgbufs; i++) {
3615 size_t msg_len, data_len = cmsgs[i].data.len;
3616 int enough_space = 0;
3617
3618 cmsgh = (i == 0) ? CMSG_FIRSTHDR(&msg) : CMSG_NXTHDR(&msg, cmsgh);
3619 if (cmsgh == NULL) {
3620 PyErr_Format(PyExc_RuntimeError,
3621 "unexpected NULL result from %s()",
3622 (i == 0) ? "CMSG_FIRSTHDR" : "CMSG_NXTHDR");
3623 goto finally;
3624 }
3625 if (!get_CMSG_LEN(data_len, &msg_len)) {
3626 PyErr_SetString(PyExc_RuntimeError,
3627 "item size out of range for CMSG_LEN()");
3628 goto finally;
3629 }
3630 if (cmsg_min_space(&msg, cmsgh, msg_len)) {
3631 size_t space;
3632
3633 cmsgh->cmsg_len = msg_len;
3634 if (get_cmsg_data_space(&msg, cmsgh, &space))
3635 enough_space = (space >= data_len);
3636 }
3637 if (!enough_space) {
3638 PyErr_SetString(PyExc_RuntimeError,
3639 "ancillary data does not fit in calculated "
3640 "space");
3641 goto finally;
3642 }
3643 cmsgh->cmsg_level = cmsgs[i].level;
3644 cmsgh->cmsg_type = cmsgs[i].type;
3645 memcpy(CMSG_DATA(cmsgh), cmsgs[i].data.buf, data_len);
3646 }
3647 }
3648
3649 /* Make the system call. */
3650 if (!IS_SELECTABLE(s)) {
3651 select_error();
3652 goto finally;
3653 }
3654
3655 BEGIN_SELECT_LOOP(s)
3656 Py_BEGIN_ALLOW_THREADS;
3657 timeout = internal_select_ex(s, 1, interval);
3658 if (!timeout)
3659 bytes_sent = sendmsg(s->sock_fd, &msg, flags);
3660 Py_END_ALLOW_THREADS;
3661 if (timeout == 1) {
3662 PyErr_SetString(socket_timeout, "timed out");
3663 goto finally;
3664 }
3665 END_SELECT_LOOP(s)
3666
3667 if (bytes_sent < 0) {
3668 s->errorhandler();
3669 goto finally;
3670 }
3671 retval = PyLong_FromSsize_t(bytes_sent);
3672
3673finally:
3674 PyMem_Free(controlbuf);
3675 for (i = 0; i < ncmsgbufs; i++)
3676 PyBuffer_Release(&cmsgs[i].data);
3677 PyMem_Free(cmsgs);
3678 Py_XDECREF(cmsg_fast);
3679 for (i = 0; i < ndatabufs; i++)
3680 PyBuffer_Release(&databufs[i]);
3681 PyMem_Free(databufs);
3682 PyMem_Free(iovs);
3683 Py_XDECREF(data_fast);
3684 return retval;
3685}
3686
3687PyDoc_STRVAR(sendmsg_doc,
3688"sendmsg(buffers[, ancdata[, flags[, address]]]) -> count\n\
3689\n\
3690Send normal and ancillary data to the socket, gathering the\n\
3691non-ancillary data from a series of buffers and concatenating it into\n\
3692a single message. The buffers argument specifies the non-ancillary\n\
3693data as an iterable of buffer-compatible objects (e.g. bytes objects).\n\
3694The ancdata argument specifies the ancillary data (control messages)\n\
3695as an iterable of zero or more tuples (cmsg_level, cmsg_type,\n\
3696cmsg_data), where cmsg_level and cmsg_type are integers specifying the\n\
3697protocol level and protocol-specific type respectively, and cmsg_data\n\
3698is a buffer-compatible object holding the associated data. The flags\n\
3699argument defaults to 0 and has the same meaning as for send(). If\n\
3700address is supplied and not None, it sets a destination address for\n\
3701the message. The return value is the number of bytes of non-ancillary\n\
3702data sent.");
3703#endif /* CMSG_LEN */
3704
3705
Guido van Rossum30a685f1991-06-27 15:51:29 +00003706/* s.shutdown(how) method */
3707
Guido van Rossum73624e91994-10-10 17:59:00 +00003708static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003709sock_shutdown(PySocketSockObject *s, PyObject *arg)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003710{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003711 int how;
3712 int res;
Jeremy Hyltonae0013d2001-10-11 16:36:35 +00003713
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003714 how = PyLong_AsLong(arg);
3715 if (how == -1 && PyErr_Occurred())
3716 return NULL;
3717 Py_BEGIN_ALLOW_THREADS
3718 res = shutdown(s->sock_fd, how);
3719 Py_END_ALLOW_THREADS
3720 if (res < 0)
3721 return s->errorhandler();
3722 Py_INCREF(Py_None);
3723 return Py_None;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003724}
3725
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00003726PyDoc_STRVAR(shutdown_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00003727"shutdown(flag)\n\
3728\n\
Martin v. Löwis94681fc2003-11-27 19:40:22 +00003729Shut down the reading side of the socket (flag == SHUT_RD), the writing side\n\
3730of the socket (flag == SHUT_WR), or both ends (flag == SHUT_RDWR).");
Guido van Rossum82a5c661998-07-07 20:45:43 +00003731
Amaury Forgeot d'Arc3d17a5c2008-06-13 01:09:34 +00003732#if defined(MS_WINDOWS) && defined(SIO_RCVALL)
Christian Heimesfaf2f632008-01-06 16:59:19 +00003733static PyObject*
3734sock_ioctl(PySocketSockObject *s, PyObject *arg)
3735{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003736 unsigned long cmd = SIO_RCVALL;
3737 PyObject *argO;
3738 DWORD recv;
Christian Heimesfaf2f632008-01-06 16:59:19 +00003739
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003740 if (!PyArg_ParseTuple(arg, "kO:ioctl", &cmd, &argO))
3741 return NULL;
Christian Heimesfaf2f632008-01-06 16:59:19 +00003742
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003743 switch (cmd) {
3744 case SIO_RCVALL: {
3745 unsigned int option = RCVALL_ON;
3746 if (!PyArg_ParseTuple(arg, "kI:ioctl", &cmd, &option))
3747 return NULL;
3748 if (WSAIoctl(s->sock_fd, cmd, &option, sizeof(option),
3749 NULL, 0, &recv, NULL, NULL) == SOCKET_ERROR) {
3750 return set_error();
3751 }
3752 return PyLong_FromUnsignedLong(recv); }
3753 case SIO_KEEPALIVE_VALS: {
3754 struct tcp_keepalive ka;
3755 if (!PyArg_ParseTuple(arg, "k(kkk):ioctl", &cmd,
3756 &ka.onoff, &ka.keepalivetime, &ka.keepaliveinterval))
3757 return NULL;
3758 if (WSAIoctl(s->sock_fd, cmd, &ka, sizeof(ka),
3759 NULL, 0, &recv, NULL, NULL) == SOCKET_ERROR) {
3760 return set_error();
3761 }
3762 return PyLong_FromUnsignedLong(recv); }
3763 default:
3764 PyErr_Format(PyExc_ValueError, "invalid ioctl command %d", cmd);
3765 return NULL;
3766 }
Christian Heimesfaf2f632008-01-06 16:59:19 +00003767}
3768PyDoc_STRVAR(sock_ioctl_doc,
3769"ioctl(cmd, option) -> long\n\
3770\n\
Kristján Valur Jónsson847ec752009-09-27 21:10:38 +00003771Control the socket with WSAIoctl syscall. Currently supported 'cmd' values are\n\
3772SIO_RCVALL: 'option' must be one of the socket.RCVALL_* constants.\n\
3773SIO_KEEPALIVE_VALS: 'option' is a tuple of (onoff, timeout, interval).");
Christian Heimesfaf2f632008-01-06 16:59:19 +00003774
3775#endif
Guido van Rossum30a685f1991-06-27 15:51:29 +00003776
3777/* List of methods for socket objects */
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003778
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003779static PyMethodDef sock_methods[] = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003780 {"_accept", (PyCFunction)sock_accept, METH_NOARGS,
3781 accept_doc},
3782 {"bind", (PyCFunction)sock_bind, METH_O,
3783 bind_doc},
3784 {"close", (PyCFunction)sock_close, METH_NOARGS,
3785 close_doc},
3786 {"connect", (PyCFunction)sock_connect, METH_O,
3787 connect_doc},
3788 {"connect_ex", (PyCFunction)sock_connect_ex, METH_O,
3789 connect_ex_doc},
Antoine Pitrou6e451df2010-08-09 20:39:54 +00003790 {"detach", (PyCFunction)sock_detach, METH_NOARGS,
3791 detach_doc},
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003792 {"fileno", (PyCFunction)sock_fileno, METH_NOARGS,
3793 fileno_doc},
Guido van Rossumb6775db1994-08-01 11:34:53 +00003794#ifdef HAVE_GETPEERNAME
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003795 {"getpeername", (PyCFunction)sock_getpeername,
3796 METH_NOARGS, getpeername_doc},
Guido van Rossum9575a441993-04-07 14:06:14 +00003797#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003798 {"getsockname", (PyCFunction)sock_getsockname,
3799 METH_NOARGS, getsockname_doc},
3800 {"getsockopt", (PyCFunction)sock_getsockopt, METH_VARARGS,
3801 getsockopt_doc},
Amaury Forgeot d'Arc3d17a5c2008-06-13 01:09:34 +00003802#if defined(MS_WINDOWS) && defined(SIO_RCVALL)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003803 {"ioctl", (PyCFunction)sock_ioctl, METH_VARARGS,
3804 sock_ioctl_doc},
Christian Heimesfaf2f632008-01-06 16:59:19 +00003805#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003806 {"listen", (PyCFunction)sock_listen, METH_O,
3807 listen_doc},
3808 {"recv", (PyCFunction)sock_recv, METH_VARARGS,
3809 recv_doc},
3810 {"recv_into", (PyCFunction)sock_recv_into, METH_VARARGS | METH_KEYWORDS,
3811 recv_into_doc},
3812 {"recvfrom", (PyCFunction)sock_recvfrom, METH_VARARGS,
3813 recvfrom_doc},
3814 {"recvfrom_into", (PyCFunction)sock_recvfrom_into, METH_VARARGS | METH_KEYWORDS,
3815 recvfrom_into_doc},
3816 {"send", (PyCFunction)sock_send, METH_VARARGS,
3817 send_doc},
3818 {"sendall", (PyCFunction)sock_sendall, METH_VARARGS,
3819 sendall_doc},
3820 {"sendto", (PyCFunction)sock_sendto, METH_VARARGS,
3821 sendto_doc},
3822 {"setblocking", (PyCFunction)sock_setblocking, METH_O,
3823 setblocking_doc},
3824 {"settimeout", (PyCFunction)sock_settimeout, METH_O,
3825 settimeout_doc},
3826 {"gettimeout", (PyCFunction)sock_gettimeout, METH_NOARGS,
3827 gettimeout_doc},
3828 {"setsockopt", (PyCFunction)sock_setsockopt, METH_VARARGS,
3829 setsockopt_doc},
3830 {"shutdown", (PyCFunction)sock_shutdown, METH_O,
3831 shutdown_doc},
Nick Coghlan96fe56a2011-08-22 11:55:57 +10003832#ifdef CMSG_LEN
3833 {"recvmsg", (PyCFunction)sock_recvmsg, METH_VARARGS,
3834 recvmsg_doc},
3835 {"recvmsg_into", (PyCFunction)sock_recvmsg_into, METH_VARARGS,
3836 recvmsg_into_doc,},
3837 {"sendmsg", (PyCFunction)sock_sendmsg, METH_VARARGS,
3838 sendmsg_doc},
3839#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003840 {NULL, NULL} /* sentinel */
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003841};
3842
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00003843/* SockObject members */
3844static PyMemberDef sock_memberlist[] = {
3845 {"family", T_INT, offsetof(PySocketSockObject, sock_family), READONLY, "the socket family"},
3846 {"type", T_INT, offsetof(PySocketSockObject, sock_type), READONLY, "the socket type"},
3847 {"proto", T_INT, offsetof(PySocketSockObject, sock_proto), READONLY, "the socket protocol"},
3848 {"timeout", T_DOUBLE, offsetof(PySocketSockObject, sock_timeout), READONLY, "the socket timeout"},
3849 {0},
3850};
Guido van Rossum30a685f1991-06-27 15:51:29 +00003851
Guido van Rossum73624e91994-10-10 17:59:00 +00003852/* Deallocate a socket object in response to the last Py_DECREF().
Guido van Rossum30a685f1991-06-27 15:51:29 +00003853 First close the file description. */
3854
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003855static void
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003856sock_dealloc(PySocketSockObject *s)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003857{
Antoine Pitroue033e062010-10-29 10:38:18 +00003858 if (s->sock_fd != -1) {
3859 PyObject *exc, *val, *tb;
3860 Py_ssize_t old_refcount = Py_REFCNT(s);
3861 ++Py_REFCNT(s);
3862 PyErr_Fetch(&exc, &val, &tb);
3863 if (PyErr_WarnFormat(PyExc_ResourceWarning, 1,
3864 "unclosed %R", s))
3865 /* Spurious errors can appear at shutdown */
3866 if (PyErr_ExceptionMatches(PyExc_Warning))
3867 PyErr_WriteUnraisable((PyObject *) s);
3868 PyErr_Restore(exc, val, tb);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003869 (void) SOCKETCLOSE(s->sock_fd);
Antoine Pitroue033e062010-10-29 10:38:18 +00003870 Py_REFCNT(s) = old_refcount;
3871 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003872 Py_TYPE(s)->tp_free((PyObject *)s);
Guido van Rossum6574b3e1991-06-25 21:36:08 +00003873}
3874
Guido van Rossum30a685f1991-06-27 15:51:29 +00003875
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00003876static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003877sock_repr(PySocketSockObject *s)
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00003878{
Fred Drakea04eaad2000-06-30 02:46:07 +00003879#if SIZEOF_SOCKET_T > SIZEOF_LONG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003880 if (s->sock_fd > LONG_MAX) {
3881 /* this can occur on Win64, and actually there is a special
3882 ugly printf formatter for decimal pointer length integer
3883 printing, only bother if necessary*/
3884 PyErr_SetString(PyExc_OverflowError,
3885 "no printf formatter to display "
3886 "the socket descriptor in decimal");
3887 return NULL;
3888 }
Fred Drakea04eaad2000-06-30 02:46:07 +00003889#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003890 return PyUnicode_FromFormat(
3891 "<socket object, fd=%ld, family=%d, type=%d, proto=%d>",
3892 (long)s->sock_fd, s->sock_family,
3893 s->sock_type,
3894 s->sock_proto);
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00003895}
3896
3897
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003898/* Create a new, uninitialized socket object. */
3899
3900static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003901sock_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003902{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003903 PyObject *new;
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003904
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003905 new = type->tp_alloc(type, 0);
3906 if (new != NULL) {
3907 ((PySocketSockObject *)new)->sock_fd = -1;
3908 ((PySocketSockObject *)new)->sock_timeout = -1.0;
3909 ((PySocketSockObject *)new)->errorhandler = &set_error;
3910 }
3911 return new;
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003912}
3913
3914
3915/* Initialize a new socket object. */
3916
3917/*ARGSUSED*/
3918static int
Andrew MacIntyre7aec4a22002-06-13 11:53:52 +00003919sock_initobj(PyObject *self, PyObject *args, PyObject *kwds)
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003920{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003921 PySocketSockObject *s = (PySocketSockObject *)self;
3922 PyObject *fdobj = NULL;
3923 SOCKET_T fd = INVALID_SOCKET;
3924 int family = AF_INET, type = SOCK_STREAM, proto = 0;
3925 static char *keywords[] = {"family", "type", "proto", "fileno", 0};
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003926
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003927 if (!PyArg_ParseTupleAndKeywords(args, kwds,
3928 "|iiiO:socket", keywords,
3929 &family, &type, &proto, &fdobj))
3930 return -1;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003931
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003932 if (fdobj != NULL && fdobj != Py_None) {
3933 fd = PyLong_AsSocket_t(fdobj);
3934 if (fd == (SOCKET_T)(-1) && PyErr_Occurred())
3935 return -1;
3936 if (fd == INVALID_SOCKET) {
3937 PyErr_SetString(PyExc_ValueError,
3938 "can't use invalid socket value");
3939 return -1;
3940 }
3941 }
3942 else {
3943 Py_BEGIN_ALLOW_THREADS
3944 fd = socket(family, type, proto);
3945 Py_END_ALLOW_THREADS
Guido van Rossum67f7a382002-06-06 21:08:16 +00003946
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003947 if (fd == INVALID_SOCKET) {
3948 set_error();
3949 return -1;
3950 }
3951 }
3952 init_sockobject(s, fd, family, type, proto);
Guido van Rossum67f7a382002-06-06 21:08:16 +00003953
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003954 return 0;
Guido van Rossum67f7a382002-06-06 21:08:16 +00003955
Guido van Rossum384ca9c2001-10-27 22:20:47 +00003956}
3957
3958
Guido van Rossumb6775db1994-08-01 11:34:53 +00003959/* Type object for socket objects. */
Guido van Rossum30a685f1991-06-27 15:51:29 +00003960
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00003961static PyTypeObject sock_type = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003962 PyVarObject_HEAD_INIT(0, 0) /* Must fill in type value later */
3963 "_socket.socket", /* tp_name */
3964 sizeof(PySocketSockObject), /* tp_basicsize */
3965 0, /* tp_itemsize */
3966 (destructor)sock_dealloc, /* tp_dealloc */
3967 0, /* tp_print */
3968 0, /* tp_getattr */
3969 0, /* tp_setattr */
3970 0, /* tp_reserved */
3971 (reprfunc)sock_repr, /* tp_repr */
3972 0, /* tp_as_number */
3973 0, /* tp_as_sequence */
3974 0, /* tp_as_mapping */
3975 0, /* tp_hash */
3976 0, /* tp_call */
3977 0, /* tp_str */
3978 PyObject_GenericGetAttr, /* tp_getattro */
3979 0, /* tp_setattro */
3980 0, /* tp_as_buffer */
3981 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
3982 sock_doc, /* tp_doc */
3983 0, /* tp_traverse */
3984 0, /* tp_clear */
3985 0, /* tp_richcompare */
3986 0, /* tp_weaklistoffset */
3987 0, /* tp_iter */
3988 0, /* tp_iternext */
3989 sock_methods, /* tp_methods */
3990 sock_memberlist, /* tp_members */
3991 0, /* tp_getset */
3992 0, /* tp_base */
3993 0, /* tp_dict */
3994 0, /* tp_descr_get */
3995 0, /* tp_descr_set */
3996 0, /* tp_dictoffset */
3997 sock_initobj, /* tp_init */
3998 PyType_GenericAlloc, /* tp_alloc */
3999 sock_new, /* tp_new */
4000 PyObject_Del, /* tp_free */
Guido van Rossum6574b3e1991-06-25 21:36:08 +00004001};
4002
Guido van Rossum30a685f1991-06-27 15:51:29 +00004003
Guido van Rossum81194471991-07-27 21:42:02 +00004004/* Python interface to gethostname(). */
4005
4006/*ARGSUSED*/
Guido van Rossum73624e91994-10-10 17:59:00 +00004007static PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00004008socket_gethostname(PyObject *self, PyObject *unused)
Guido van Rossum81194471991-07-27 21:42:02 +00004009{
Martin v. Löwis72f48422010-10-29 18:20:08 +00004010#ifdef MS_WINDOWS
4011 /* Don't use winsock's gethostname, as this returns the ANSI
4012 version of the hostname, whereas we need a Unicode string.
4013 Otherwise, gethostname apparently also returns the DNS name. */
Hirokazu Yamamoto09fff7a2010-11-05 17:24:13 +00004014 wchar_t buf[MAX_COMPUTERNAME_LENGTH + 1];
Victor Stinner63941882011-09-29 00:42:28 +02004015 DWORD size = Py_ARRAY_LENGTH(buf);
Victor Stinner74168972011-11-17 01:11:36 +01004016 wchar_t *name;
Hirokazu Yamamoto09fff7a2010-11-05 17:24:13 +00004017 PyObject *result;
Victor Stinner74168972011-11-17 01:11:36 +01004018
4019 if (GetComputerNameExW(ComputerNamePhysicalDnsHostname, buf, &size))
Victor Stinner9d3b93b2011-11-22 02:27:30 +01004020 return PyUnicode_FromWideChar(buf, size);
Victor Stinner74168972011-11-17 01:11:36 +01004021
4022 if (GetLastError() != ERROR_MORE_DATA)
4023 return PyErr_SetFromWindowsErr(0);
4024
4025 if (size == 0)
4026 return PyUnicode_New(0, 0);
4027
4028 /* MSDN says ERROR_MORE_DATA may occur because DNS allows longer
4029 names */
4030 name = PyMem_Malloc(size * sizeof(wchar_t));
4031 if (!name)
4032 return NULL;
4033 if (!GetComputerNameExW(ComputerNamePhysicalDnsHostname,
4034 name,
4035 &size))
4036 {
4037 PyMem_Free(name);
4038 return PyErr_SetFromWindowsErr(0);
Martin v. Löwis72f48422010-10-29 18:20:08 +00004039 }
Victor Stinner74168972011-11-17 01:11:36 +01004040
4041 result = PyUnicode_FromWideChar(name, size);
4042 PyMem_Free(name);
4043 return result;
Martin v. Löwis72f48422010-10-29 18:20:08 +00004044#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004045 char buf[1024];
4046 int res;
4047 Py_BEGIN_ALLOW_THREADS
4048 res = gethostname(buf, (int) sizeof buf - 1);
4049 Py_END_ALLOW_THREADS
4050 if (res < 0)
4051 return set_error();
4052 buf[sizeof buf - 1] = '\0';
4053 return PyUnicode_FromString(buf);
Martin v. Löwis72f48422010-10-29 18:20:08 +00004054#endif
Guido van Rossum81194471991-07-27 21:42:02 +00004055}
Guido van Rossumff4949e1992-08-05 19:58:53 +00004056
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004057PyDoc_STRVAR(gethostname_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004058"gethostname() -> string\n\
4059\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004060Return the current host name.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004061
Antoine Pitrou061cfb52011-02-28 22:25:22 +00004062#ifdef HAVE_SETHOSTNAME
4063PyDoc_STRVAR(sethostname_doc,
4064"sethostname(name)\n\n\
4065Sets the hostname to name.");
4066
4067static PyObject *
4068socket_sethostname(PyObject *self, PyObject *args)
4069{
4070 PyObject *hnobj;
4071 Py_buffer buf;
4072 int res, flag = 0;
4073
4074 if (!PyArg_ParseTuple(args, "S:sethostname", &hnobj)) {
4075 PyErr_Clear();
4076 if (!PyArg_ParseTuple(args, "O&:sethostname",
4077 PyUnicode_FSConverter, &hnobj))
4078 return NULL;
4079 flag = 1;
4080 }
4081 res = PyObject_GetBuffer(hnobj, &buf, PyBUF_SIMPLE);
4082 if (!res) {
4083 res = sethostname(buf.buf, buf.len);
4084 PyBuffer_Release(&buf);
4085 }
4086 if (flag)
4087 Py_DECREF(hnobj);
4088 if (res)
4089 return set_error();
4090 Py_RETURN_NONE;
4091}
4092#endif
Guido van Rossumff4949e1992-08-05 19:58:53 +00004093
Guido van Rossum30a685f1991-06-27 15:51:29 +00004094/* Python interface to gethostbyname(name). */
4095
4096/*ARGSUSED*/
Guido van Rossum73624e91994-10-10 17:59:00 +00004097static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004098socket_gethostbyname(PyObject *self, PyObject *args)
Guido van Rossum30a685f1991-06-27 15:51:29 +00004099{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004100 char *name;
4101 sock_addr_t addrbuf;
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004102 PyObject *ret = NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004103
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004104 if (!PyArg_ParseTuple(args, "et:gethostbyname", "idna", &name))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004105 return NULL;
4106 if (setipaddr(name, SAS2SA(&addrbuf), sizeof(addrbuf), AF_INET) < 0)
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004107 goto finally;
4108 ret = makeipaddr(SAS2SA(&addrbuf), sizeof(struct sockaddr_in));
4109finally:
4110 PyMem_Free(name);
4111 return ret;
Guido van Rossum30a685f1991-06-27 15:51:29 +00004112}
4113
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004114PyDoc_STRVAR(gethostbyname_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004115"gethostbyname(host) -> address\n\
4116\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004117Return the IP address (a string of the form '255.255.255.255') for a host.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004118
4119
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004120/* Convenience function common to gethostbyname_ex and gethostbyaddr */
4121
4122static PyObject *
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004123gethost_common(struct hostent *h, struct sockaddr *addr, int alen, int af)
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004124{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004125 char **pch;
4126 PyObject *rtn_tuple = (PyObject *)NULL;
4127 PyObject *name_list = (PyObject *)NULL;
4128 PyObject *addr_list = (PyObject *)NULL;
4129 PyObject *tmp;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004130
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004131 if (h == NULL) {
4132 /* Let's get real error message to return */
4133 set_herror(h_errno);
4134 return NULL;
4135 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004136
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004137 if (h->h_addrtype != af) {
4138 /* Let's get real error message to return */
Victor Stinner1f33f2b2011-12-17 04:45:09 +01004139 errno = EAFNOSUPPORT;
4140 PyErr_SetFromErrno(PyExc_OSError);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004141 return NULL;
4142 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004143
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004144 switch (af) {
Guido van Rossum67f7a382002-06-06 21:08:16 +00004145
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004146 case AF_INET:
4147 if (alen < sizeof(struct sockaddr_in))
4148 return NULL;
4149 break;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004150
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00004151#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004152 case AF_INET6:
4153 if (alen < sizeof(struct sockaddr_in6))
4154 return NULL;
4155 break;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004156#endif
Guido van Rossum67f7a382002-06-06 21:08:16 +00004157
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004158 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004159
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004160 if ((name_list = PyList_New(0)) == NULL)
4161 goto err;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004162
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004163 if ((addr_list = PyList_New(0)) == NULL)
4164 goto err;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004165
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004166 /* SF #1511317: h_aliases can be NULL */
4167 if (h->h_aliases) {
4168 for (pch = h->h_aliases; *pch != NULL; pch++) {
4169 int status;
4170 tmp = PyUnicode_FromString(*pch);
4171 if (tmp == NULL)
4172 goto err;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004173
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004174 status = PyList_Append(name_list, tmp);
4175 Py_DECREF(tmp);
Guido van Rossum67f7a382002-06-06 21:08:16 +00004176
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004177 if (status)
4178 goto err;
4179 }
4180 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004181
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004182 for (pch = h->h_addr_list; *pch != NULL; pch++) {
4183 int status;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004184
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004185 switch (af) {
Guido van Rossum67f7a382002-06-06 21:08:16 +00004186
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004187 case AF_INET:
4188 {
4189 struct sockaddr_in sin;
4190 memset(&sin, 0, sizeof(sin));
4191 sin.sin_family = af;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004192#ifdef HAVE_SOCKADDR_SA_LEN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004193 sin.sin_len = sizeof(sin);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004194#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004195 memcpy(&sin.sin_addr, *pch, sizeof(sin.sin_addr));
4196 tmp = makeipaddr((struct sockaddr *)&sin, sizeof(sin));
Guido van Rossum67f7a382002-06-06 21:08:16 +00004197
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004198 if (pch == h->h_addr_list && alen >= sizeof(sin))
4199 memcpy((char *) addr, &sin, sizeof(sin));
4200 break;
4201 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004202
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00004203#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004204 case AF_INET6:
4205 {
4206 struct sockaddr_in6 sin6;
4207 memset(&sin6, 0, sizeof(sin6));
4208 sin6.sin6_family = af;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004209#ifdef HAVE_SOCKADDR_SA_LEN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004210 sin6.sin6_len = sizeof(sin6);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004211#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004212 memcpy(&sin6.sin6_addr, *pch, sizeof(sin6.sin6_addr));
4213 tmp = makeipaddr((struct sockaddr *)&sin6,
4214 sizeof(sin6));
Guido van Rossum67f7a382002-06-06 21:08:16 +00004215
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004216 if (pch == h->h_addr_list && alen >= sizeof(sin6))
4217 memcpy((char *) addr, &sin6, sizeof(sin6));
4218 break;
4219 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004220#endif
Guido van Rossum67f7a382002-06-06 21:08:16 +00004221
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004222 default: /* can't happen */
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004223 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004224 "unsupported address family");
4225 return NULL;
4226 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004227
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004228 if (tmp == NULL)
4229 goto err;
Guido van Rossum67f7a382002-06-06 21:08:16 +00004230
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004231 status = PyList_Append(addr_list, tmp);
4232 Py_DECREF(tmp);
Guido van Rossum67f7a382002-06-06 21:08:16 +00004233
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004234 if (status)
4235 goto err;
4236 }
Guido van Rossum67f7a382002-06-06 21:08:16 +00004237
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004238 rtn_tuple = Py_BuildValue("sOO", h->h_name, name_list, addr_list);
Guido van Rossum67f7a382002-06-06 21:08:16 +00004239
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004240 err:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004241 Py_XDECREF(name_list);
4242 Py_XDECREF(addr_list);
4243 return rtn_tuple;
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004244}
4245
4246
4247/* Python interface to gethostbyname_ex(name). */
4248
4249/*ARGSUSED*/
4250static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004251socket_gethostbyname_ex(PyObject *self, PyObject *args)
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004252{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004253 char *name;
4254 struct hostent *h;
Charles-François Natali8b759652011-12-23 16:44:51 +01004255 sock_addr_t addr;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004256 struct sockaddr *sa;
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004257 PyObject *ret = NULL;
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004258#ifdef HAVE_GETHOSTBYNAME_R
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004259 struct hostent hp_allocated;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004260#ifdef HAVE_GETHOSTBYNAME_R_3_ARG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004261 struct hostent_data data;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004262#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004263 char buf[16384];
4264 int buf_len = (sizeof buf) - 1;
4265 int errnop;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004266#endif
Ross Lagerwall8c159762012-03-06 21:36:18 +02004267#ifdef HAVE_GETHOSTBYNAME_R_3_ARG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004268 int result;
Guido van Rossume9cd07b1999-03-15 21:40:14 +00004269#endif
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004270#endif /* HAVE_GETHOSTBYNAME_R */
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004271
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004272 if (!PyArg_ParseTuple(args, "et:gethostbyname_ex", "idna", &name))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004273 return NULL;
Charles-François Natali8b759652011-12-23 16:44:51 +01004274 if (setipaddr(name, SAS2SA(&addr), sizeof(addr), AF_INET) < 0)
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004275 goto finally;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004276 Py_BEGIN_ALLOW_THREADS
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004277#ifdef HAVE_GETHOSTBYNAME_R
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004278#if defined(HAVE_GETHOSTBYNAME_R_6_ARG)
Ross Lagerwall8c159762012-03-06 21:36:18 +02004279 gethostbyname_r(name, &hp_allocated, buf, buf_len,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004280 &h, &errnop);
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004281#elif defined(HAVE_GETHOSTBYNAME_R_5_ARG)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004282 h = gethostbyname_r(name, &hp_allocated, buf, buf_len, &errnop);
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004283#else /* HAVE_GETHOSTBYNAME_R_3_ARG */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004284 memset((void *) &data, '\0', sizeof(data));
4285 result = gethostbyname_r(name, &hp_allocated, &data);
4286 h = (result != 0) ? NULL : &hp_allocated;
Guido van Rossume9cd07b1999-03-15 21:40:14 +00004287#endif
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004288#else /* not HAVE_GETHOSTBYNAME_R */
Guido van Rossum3baaa131999-03-22 21:44:51 +00004289#ifdef USE_GETHOSTBYNAME_LOCK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004290 PyThread_acquire_lock(netdb_lock, 1);
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004291#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004292 h = gethostbyname(name);
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004293#endif /* HAVE_GETHOSTBYNAME_R */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004294 Py_END_ALLOW_THREADS
4295 /* Some C libraries would require addr.__ss_family instead of
4296 addr.ss_family.
4297 Therefore, we cast the sockaddr_storage into sockaddr to
4298 access sa_family. */
Charles-François Natali8b759652011-12-23 16:44:51 +01004299 sa = SAS2SA(&addr);
4300 ret = gethost_common(h, SAS2SA(&addr), sizeof(addr),
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004301 sa->sa_family);
Guido van Rossum3baaa131999-03-22 21:44:51 +00004302#ifdef USE_GETHOSTBYNAME_LOCK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004303 PyThread_release_lock(netdb_lock);
Guido van Rossum955becc1999-03-22 20:14:53 +00004304#endif
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004305finally:
4306 PyMem_Free(name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004307 return ret;
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004308}
4309
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004310PyDoc_STRVAR(ghbn_ex_doc,
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004311"gethostbyname_ex(host) -> (name, aliaslist, addresslist)\n\
4312\n\
4313Return the true host name, a list of aliases, and a list of IP addresses,\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004314for a host. The host argument is a string giving a host name or IP number.");
Guido van Rossum7d896ab1998-08-04 22:16:43 +00004315
4316
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00004317/* Python interface to gethostbyaddr(IP). */
4318
4319/*ARGSUSED*/
4320static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004321socket_gethostbyaddr(PyObject *self, PyObject *args)
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00004322{
Charles-François Natali8b759652011-12-23 16:44:51 +01004323 sock_addr_t addr;
4324 struct sockaddr *sa = SAS2SA(&addr);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004325 char *ip_num;
4326 struct hostent *h;
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004327 PyObject *ret = NULL;
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004328#ifdef HAVE_GETHOSTBYNAME_R
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004329 struct hostent hp_allocated;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004330#ifdef HAVE_GETHOSTBYNAME_R_3_ARG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004331 struct hostent_data data;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004332#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004333 /* glibcs up to 2.10 assume that the buf argument to
4334 gethostbyaddr_r is 8-byte aligned, which at least llvm-gcc
4335 does not ensure. The attribute below instructs the compiler
4336 to maintain this alignment. */
4337 char buf[16384] Py_ALIGNED(8);
4338 int buf_len = (sizeof buf) - 1;
4339 int errnop;
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004340#endif
Ross Lagerwall8c159762012-03-06 21:36:18 +02004341#ifdef HAVE_GETHOSTBYNAME_R_3_ARG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004342 int result;
Guido van Rossume9cd07b1999-03-15 21:40:14 +00004343#endif
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004344#endif /* HAVE_GETHOSTBYNAME_R */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004345 char *ap;
4346 int al;
4347 int af;
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00004348
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004349 if (!PyArg_ParseTuple(args, "et:gethostbyaddr", "idna", &ip_num))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004350 return NULL;
4351 af = AF_UNSPEC;
4352 if (setipaddr(ip_num, sa, sizeof(addr), af) < 0)
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004353 goto finally;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004354 af = sa->sa_family;
4355 ap = NULL;
Brett Cannonb94767f2011-02-22 20:15:44 +00004356 /* al = 0; */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004357 switch (af) {
4358 case AF_INET:
4359 ap = (char *)&((struct sockaddr_in *)sa)->sin_addr;
4360 al = sizeof(((struct sockaddr_in *)sa)->sin_addr);
4361 break;
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00004362#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004363 case AF_INET6:
4364 ap = (char *)&((struct sockaddr_in6 *)sa)->sin6_addr;
4365 al = sizeof(((struct sockaddr_in6 *)sa)->sin6_addr);
4366 break;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004367#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004368 default:
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004369 PyErr_SetString(PyExc_OSError, "unsupported address family");
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004370 goto finally;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004371 }
4372 Py_BEGIN_ALLOW_THREADS
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004373#ifdef HAVE_GETHOSTBYNAME_R
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004374#if defined(HAVE_GETHOSTBYNAME_R_6_ARG)
Ross Lagerwall8c159762012-03-06 21:36:18 +02004375 gethostbyaddr_r(ap, al, af,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004376 &hp_allocated, buf, buf_len,
4377 &h, &errnop);
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004378#elif defined(HAVE_GETHOSTBYNAME_R_5_ARG)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004379 h = gethostbyaddr_r(ap, al, af,
4380 &hp_allocated, buf, buf_len, &errnop);
Guido van Rossum7b6c71f1999-03-24 17:20:40 +00004381#else /* HAVE_GETHOSTBYNAME_R_3_ARG */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004382 memset((void *) &data, '\0', sizeof(data));
4383 result = gethostbyaddr_r(ap, al, af, &hp_allocated, &data);
4384 h = (result != 0) ? NULL : &hp_allocated;
Guido van Rossume9cd07b1999-03-15 21:40:14 +00004385#endif
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004386#else /* not HAVE_GETHOSTBYNAME_R */
Guido van Rossum3baaa131999-03-22 21:44:51 +00004387#ifdef USE_GETHOSTBYNAME_LOCK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004388 PyThread_acquire_lock(netdb_lock, 1);
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004389#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004390 h = gethostbyaddr(ap, al, af);
Guido van Rossum4f199ea1998-04-09 20:56:35 +00004391#endif /* HAVE_GETHOSTBYNAME_R */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004392 Py_END_ALLOW_THREADS
Charles-François Natali8b759652011-12-23 16:44:51 +01004393 ret = gethost_common(h, SAS2SA(&addr), sizeof(addr), af);
Guido van Rossum3baaa131999-03-22 21:44:51 +00004394#ifdef USE_GETHOSTBYNAME_LOCK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004395 PyThread_release_lock(netdb_lock);
Guido van Rossum3baaa131999-03-22 21:44:51 +00004396#endif
Martin v. Löwisfc0275a2010-08-22 19:33:47 +00004397finally:
4398 PyMem_Free(ip_num);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004399 return ret;
Guido van Rossum3bbc62e1995-01-02 19:30:30 +00004400}
4401
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004402PyDoc_STRVAR(gethostbyaddr_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004403"gethostbyaddr(host) -> (name, aliaslist, addresslist)\n\
4404\n\
4405Return the true host name, a list of aliases, and a list of IP addresses,\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004406for a host. The host argument is a string giving a host name or IP number.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004407
Guido van Rossum30a685f1991-06-27 15:51:29 +00004408
4409/* Python interface to getservbyname(name).
4410 This only returns the port number, since the other info is already
4411 known or not useful (like the list of aliases). */
4412
4413/*ARGSUSED*/
Guido van Rossum73624e91994-10-10 17:59:00 +00004414static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004415socket_getservbyname(PyObject *self, PyObject *args)
Guido van Rossum30a685f1991-06-27 15:51:29 +00004416{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004417 char *name, *proto=NULL;
4418 struct servent *sp;
4419 if (!PyArg_ParseTuple(args, "s|s:getservbyname", &name, &proto))
4420 return NULL;
4421 Py_BEGIN_ALLOW_THREADS
4422 sp = getservbyname(name, proto);
4423 Py_END_ALLOW_THREADS
4424 if (sp == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004425 PyErr_SetString(PyExc_OSError, "service/proto not found");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004426 return NULL;
4427 }
4428 return PyLong_FromLong((long) ntohs(sp->s_port));
Guido van Rossum30a685f1991-06-27 15:51:29 +00004429}
4430
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004431PyDoc_STRVAR(getservbyname_doc,
Barry Warsaw11b91a02004-06-28 00:50:43 +00004432"getservbyname(servicename[, protocolname]) -> integer\n\
Guido van Rossum82a5c661998-07-07 20:45:43 +00004433\n\
4434Return a port number from a service name and protocol name.\n\
Barry Warsaw11b91a02004-06-28 00:50:43 +00004435The optional protocol name, if given, should be 'tcp' or 'udp',\n\
4436otherwise any protocol will match.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004437
Guido van Rossum30a685f1991-06-27 15:51:29 +00004438
Barry Warsaw11b91a02004-06-28 00:50:43 +00004439/* Python interface to getservbyport(port).
4440 This only returns the service name, since the other info is already
4441 known or not useful (like the list of aliases). */
4442
4443/*ARGSUSED*/
4444static PyObject *
4445socket_getservbyport(PyObject *self, PyObject *args)
4446{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004447 int port;
4448 char *proto=NULL;
4449 struct servent *sp;
4450 if (!PyArg_ParseTuple(args, "i|s:getservbyport", &port, &proto))
4451 return NULL;
4452 if (port < 0 || port > 0xffff) {
4453 PyErr_SetString(
4454 PyExc_OverflowError,
4455 "getservbyport: port must be 0-65535.");
4456 return NULL;
4457 }
4458 Py_BEGIN_ALLOW_THREADS
4459 sp = getservbyport(htons((short)port), proto);
4460 Py_END_ALLOW_THREADS
4461 if (sp == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004462 PyErr_SetString(PyExc_OSError, "port/proto not found");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004463 return NULL;
4464 }
4465 return PyUnicode_FromString(sp->s_name);
Barry Warsaw11b91a02004-06-28 00:50:43 +00004466}
4467
4468PyDoc_STRVAR(getservbyport_doc,
4469"getservbyport(port[, protocolname]) -> string\n\
4470\n\
4471Return the service name from a port number and protocol name.\n\
4472The optional protocol name, if given, should be 'tcp' or 'udp',\n\
4473otherwise any protocol will match.");
4474
Guido van Rossum3901d851996-12-19 16:35:04 +00004475/* Python interface to getprotobyname(name).
4476 This only returns the protocol number, since the other info is
4477 already known or not useful (like the list of aliases). */
4478
4479/*ARGSUSED*/
4480static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004481socket_getprotobyname(PyObject *self, PyObject *args)
Guido van Rossum3901d851996-12-19 16:35:04 +00004482{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004483 char *name;
4484 struct protoent *sp;
4485 if (!PyArg_ParseTuple(args, "s:getprotobyname", &name))
4486 return NULL;
4487 Py_BEGIN_ALLOW_THREADS
4488 sp = getprotobyname(name);
4489 Py_END_ALLOW_THREADS
4490 if (sp == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004491 PyErr_SetString(PyExc_OSError, "protocol not found");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004492 return NULL;
4493 }
4494 return PyLong_FromLong((long) sp->p_proto);
Guido van Rossum3901d851996-12-19 16:35:04 +00004495}
4496
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004497PyDoc_STRVAR(getprotobyname_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004498"getprotobyname(name) -> integer\n\
4499\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004500Return the protocol number for the named protocol. (Rarely used.)");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004501
Guido van Rossum3901d851996-12-19 16:35:04 +00004502
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00004503#ifndef NO_DUP
4504/* dup() function for socket fds */
4505
4506static PyObject *
4507socket_dup(PyObject *self, PyObject *fdobj)
4508{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004509 SOCKET_T fd, newfd;
4510 PyObject *newfdobj;
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00004511
4512
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004513 fd = PyLong_AsSocket_t(fdobj);
4514 if (fd == (SOCKET_T)(-1) && PyErr_Occurred())
4515 return NULL;
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00004516
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004517 newfd = dup_socket(fd);
4518 if (newfd == INVALID_SOCKET)
4519 return set_error();
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00004520
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004521 newfdobj = PyLong_FromSocket_t(newfd);
4522 if (newfdobj == NULL)
4523 SOCKETCLOSE(newfd);
4524 return newfdobj;
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00004525}
4526
4527PyDoc_STRVAR(dup_doc,
4528"dup(integer) -> integer\n\
4529\n\
4530Duplicate an integer socket file descriptor. This is like os.dup(), but for\n\
4531sockets; on some platforms os.dup() won't work for socket file descriptors.");
4532#endif
4533
4534
Dave Cole331708b2004-08-09 04:51:41 +00004535#ifdef HAVE_SOCKETPAIR
4536/* Create a pair of sockets using the socketpair() function.
Dave Cole07fda7e2004-08-23 05:16:23 +00004537 Arguments as for socket() except the default family is AF_UNIX if
Dave Colee8bbfe42004-08-26 00:51:16 +00004538 defined on the platform; otherwise, the default is AF_INET. */
Dave Cole331708b2004-08-09 04:51:41 +00004539
4540/*ARGSUSED*/
4541static PyObject *
4542socket_socketpair(PyObject *self, PyObject *args)
4543{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004544 PySocketSockObject *s0 = NULL, *s1 = NULL;
4545 SOCKET_T sv[2];
4546 int family, type = SOCK_STREAM, proto = 0;
4547 PyObject *res = NULL;
Dave Cole331708b2004-08-09 04:51:41 +00004548
4549#if defined(AF_UNIX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004550 family = AF_UNIX;
Dave Cole331708b2004-08-09 04:51:41 +00004551#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004552 family = AF_INET;
Dave Cole331708b2004-08-09 04:51:41 +00004553#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004554 if (!PyArg_ParseTuple(args, "|iii:socketpair",
4555 &family, &type, &proto))
4556 return NULL;
4557 /* Create a pair of socket fds */
4558 if (socketpair(family, type, proto, sv) < 0)
4559 return set_error();
4560 s0 = new_sockobject(sv[0], family, type, proto);
4561 if (s0 == NULL)
4562 goto finally;
4563 s1 = new_sockobject(sv[1], family, type, proto);
4564 if (s1 == NULL)
4565 goto finally;
4566 res = PyTuple_Pack(2, s0, s1);
Dave Cole331708b2004-08-09 04:51:41 +00004567
4568finally:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004569 if (res == NULL) {
4570 if (s0 == NULL)
4571 SOCKETCLOSE(sv[0]);
4572 if (s1 == NULL)
4573 SOCKETCLOSE(sv[1]);
4574 }
4575 Py_XDECREF(s0);
4576 Py_XDECREF(s1);
4577 return res;
Dave Cole331708b2004-08-09 04:51:41 +00004578}
4579
4580PyDoc_STRVAR(socketpair_doc,
4581"socketpair([family[, type[, proto]]]) -> (socket object, socket object)\n\
4582\n\
4583Create a pair of socket objects from the sockets returned by the platform\n\
4584socketpair() function.\n\
Dave Cole07fda7e2004-08-23 05:16:23 +00004585The arguments are the same as for socket() except the default family is\n\
Dave Colee8bbfe42004-08-26 00:51:16 +00004586AF_UNIX if defined on the platform; otherwise, the default is AF_INET.");
Dave Cole331708b2004-08-09 04:51:41 +00004587
4588#endif /* HAVE_SOCKETPAIR */
4589
4590
Guido van Rossum006bf911996-06-12 04:04:55 +00004591static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004592socket_ntohs(PyObject *self, PyObject *args)
Guido van Rossum006bf911996-06-12 04:04:55 +00004593{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004594 int x1, x2;
Guido van Rossum006bf911996-06-12 04:04:55 +00004595
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004596 if (!PyArg_ParseTuple(args, "i:ntohs", &x1)) {
4597 return NULL;
4598 }
4599 if (x1 < 0) {
4600 PyErr_SetString(PyExc_OverflowError,
4601 "can't convert negative number to unsigned long");
4602 return NULL;
4603 }
4604 x2 = (unsigned int)ntohs((unsigned short)x1);
4605 return PyLong_FromLong(x2);
Guido van Rossum006bf911996-06-12 04:04:55 +00004606}
4607
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004608PyDoc_STRVAR(ntohs_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004609"ntohs(integer) -> integer\n\
4610\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004611Convert a 16-bit integer from network to host byte order.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004612
4613
Guido van Rossum006bf911996-06-12 04:04:55 +00004614static PyObject *
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004615socket_ntohl(PyObject *self, PyObject *arg)
Guido van Rossum006bf911996-06-12 04:04:55 +00004616{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004617 unsigned long x;
Guido van Rossum006bf911996-06-12 04:04:55 +00004618
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004619 if (PyLong_Check(arg)) {
4620 x = PyLong_AsUnsignedLong(arg);
4621 if (x == (unsigned long) -1 && PyErr_Occurred())
4622 return NULL;
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004623#if SIZEOF_LONG > 4
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004624 {
4625 unsigned long y;
4626 /* only want the trailing 32 bits */
4627 y = x & 0xFFFFFFFFUL;
4628 if (y ^ x)
4629 return PyErr_Format(PyExc_OverflowError,
4630 "long int larger than 32 bits");
4631 x = y;
4632 }
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004633#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004634 }
4635 else
4636 return PyErr_Format(PyExc_TypeError,
4637 "expected int/long, %s found",
4638 Py_TYPE(arg)->tp_name);
4639 if (x == (unsigned long) -1 && PyErr_Occurred())
4640 return NULL;
4641 return PyLong_FromUnsignedLong(ntohl(x));
Guido van Rossum006bf911996-06-12 04:04:55 +00004642}
4643
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004644PyDoc_STRVAR(ntohl_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004645"ntohl(integer) -> integer\n\
4646\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004647Convert a 32-bit integer from network to host byte order.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004648
4649
Guido van Rossum006bf911996-06-12 04:04:55 +00004650static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004651socket_htons(PyObject *self, PyObject *args)
Guido van Rossum006bf911996-06-12 04:04:55 +00004652{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004653 int x1, x2;
Guido van Rossum006bf911996-06-12 04:04:55 +00004654
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004655 if (!PyArg_ParseTuple(args, "i:htons", &x1)) {
4656 return NULL;
4657 }
4658 if (x1 < 0) {
4659 PyErr_SetString(PyExc_OverflowError,
4660 "can't convert negative number to unsigned long");
4661 return NULL;
4662 }
4663 x2 = (unsigned int)htons((unsigned short)x1);
4664 return PyLong_FromLong(x2);
Guido van Rossum006bf911996-06-12 04:04:55 +00004665}
4666
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004667PyDoc_STRVAR(htons_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004668"htons(integer) -> integer\n\
4669\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004670Convert a 16-bit integer from host to network byte order.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004671
4672
Guido van Rossum006bf911996-06-12 04:04:55 +00004673static PyObject *
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004674socket_htonl(PyObject *self, PyObject *arg)
Guido van Rossum006bf911996-06-12 04:04:55 +00004675{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004676 unsigned long x;
Guido van Rossum006bf911996-06-12 04:04:55 +00004677
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004678 if (PyLong_Check(arg)) {
4679 x = PyLong_AsUnsignedLong(arg);
4680 if (x == (unsigned long) -1 && PyErr_Occurred())
4681 return NULL;
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004682#if SIZEOF_LONG > 4
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004683 {
4684 unsigned long y;
4685 /* only want the trailing 32 bits */
4686 y = x & 0xFFFFFFFFUL;
4687 if (y ^ x)
4688 return PyErr_Format(PyExc_OverflowError,
4689 "long int larger than 32 bits");
4690 x = y;
4691 }
Jeremy Hyltonc075e192002-07-25 16:01:12 +00004692#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004693 }
4694 else
4695 return PyErr_Format(PyExc_TypeError,
4696 "expected int/long, %s found",
4697 Py_TYPE(arg)->tp_name);
4698 return PyLong_FromUnsignedLong(htonl((unsigned long)x));
Guido van Rossum006bf911996-06-12 04:04:55 +00004699}
4700
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004701PyDoc_STRVAR(htonl_doc,
Guido van Rossum82a5c661998-07-07 20:45:43 +00004702"htonl(integer) -> integer\n\
4703\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004704Convert a 32-bit integer from host to network byte order.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00004705
Guido van Rossum3eede5a2002-06-07 02:08:35 +00004706/* socket.inet_aton() and socket.inet_ntoa() functions. */
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004707
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004708PyDoc_STRVAR(inet_aton_doc,
Guido van Rossum7d0a8262007-05-21 23:13:11 +00004709"inet_aton(string) -> bytes giving packed 32-bit IP representation\n\
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004710\n\
Guido van Rossumc6a164b1999-08-20 19:11:27 +00004711Convert an IP address in string format (123.45.67.89) to the 32-bit packed\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004712binary format used in low-level network functions.");
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004713
4714static PyObject*
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004715socket_inet_aton(PyObject *self, PyObject *args)
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004716{
Guido van Rossuma2e48551999-09-09 15:42:59 +00004717#ifndef INADDR_NONE
4718#define INADDR_NONE (-1)
4719#endif
Neal Norwitz88f115b2003-02-13 02:15:42 +00004720#ifdef HAVE_INET_ATON
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004721 struct in_addr buf;
Thomas Wouters477c8d52006-05-27 19:21:47 +00004722#endif
4723
4724#if !defined(HAVE_INET_ATON) || defined(USE_INET_ATON_WEAKLINK)
Benjamin Petersonf91df042009-02-13 02:50:59 +00004725#if (SIZEOF_INT != 4)
4726#error "Not sure if in_addr_t exists and int is not 32-bits."
4727#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004728 /* Have to use inet_addr() instead */
4729 unsigned int packed_addr;
Tim Peters1df9fdd2003-02-13 03:13:40 +00004730#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004731 char *ip_addr;
Guido van Rossumc6a164b1999-08-20 19:11:27 +00004732
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004733 if (!PyArg_ParseTuple(args, "s:inet_aton", &ip_addr))
4734 return NULL;
Guido van Rossumad05cdf2003-02-12 23:08:22 +00004735
Tim Peters1df9fdd2003-02-13 03:13:40 +00004736
4737#ifdef HAVE_INET_ATON
Thomas Wouters477c8d52006-05-27 19:21:47 +00004738
4739#ifdef USE_INET_ATON_WEAKLINK
4740 if (inet_aton != NULL) {
4741#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004742 if (inet_aton(ip_addr, &buf))
4743 return PyBytes_FromStringAndSize((char *)(&buf),
4744 sizeof(buf));
Guido van Rossumad05cdf2003-02-12 23:08:22 +00004745
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004746 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004747 "illegal IP address string passed to inet_aton");
4748 return NULL;
Guido van Rossumad05cdf2003-02-12 23:08:22 +00004749
Thomas Wouters477c8d52006-05-27 19:21:47 +00004750#ifdef USE_INET_ATON_WEAKLINK
4751 } else {
4752#endif
4753
4754#endif
4755
4756#if !defined(HAVE_INET_ATON) || defined(USE_INET_ATON_WEAKLINK)
4757
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004758 /* special-case this address as inet_addr might return INADDR_NONE
4759 * for this */
4760 if (strcmp(ip_addr, "255.255.255.255") == 0) {
4761 packed_addr = 0xFFFFFFFF;
4762 } else {
Thomas Wouters477c8d52006-05-27 19:21:47 +00004763
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004764 packed_addr = inet_addr(ip_addr);
Guido van Rossumc6a164b1999-08-20 19:11:27 +00004765
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004766 if (packed_addr == INADDR_NONE) { /* invalid address */
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004767 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004768 "illegal IP address string passed to inet_aton");
4769 return NULL;
4770 }
4771 }
4772 return PyBytes_FromStringAndSize((char *) &packed_addr,
4773 sizeof(packed_addr));
Thomas Wouters477c8d52006-05-27 19:21:47 +00004774
4775#ifdef USE_INET_ATON_WEAKLINK
4776 }
4777#endif
4778
Guido van Rossumad05cdf2003-02-12 23:08:22 +00004779#endif
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004780}
4781
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004782PyDoc_STRVAR(inet_ntoa_doc,
Fred Drakee0661342000-03-07 14:05:16 +00004783"inet_ntoa(packed_ip) -> ip_address_string\n\
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004784\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00004785Convert an IP address from 32-bit packed binary format to string format");
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004786
4787static PyObject*
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00004788socket_inet_ntoa(PyObject *self, PyObject *args)
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004789{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004790 char *packed_str;
4791 int addr_len;
4792 struct in_addr packed_addr;
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004793
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004794 if (!PyArg_ParseTuple(args, "y#:inet_ntoa", &packed_str, &addr_len)) {
4795 return NULL;
4796 }
Guido van Rossum48a680c2001-03-02 06:34:14 +00004797
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004798 if (addr_len != sizeof(packed_addr)) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004799 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004800 "packed IP wrong length for inet_ntoa");
4801 return NULL;
4802 }
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004803
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004804 memcpy(&packed_addr, packed_str, addr_len);
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004805
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004806 return PyUnicode_FromString(inet_ntoa(packed_addr));
Guido van Rossum5c9eb211999-08-20 18:21:51 +00004807}
Guido van Rossum82a5c661998-07-07 20:45:43 +00004808
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004809#ifdef HAVE_INET_PTON
4810
4811PyDoc_STRVAR(inet_pton_doc,
4812"inet_pton(af, ip) -> packed IP address string\n\
4813\n\
4814Convert an IP address from string format to a packed string suitable\n\
4815for use with low-level network functions.");
4816
4817static PyObject *
4818socket_inet_pton(PyObject *self, PyObject *args)
4819{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004820 int af;
4821 char* ip;
4822 int retval;
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004823#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004824 char packed[MAX(sizeof(struct in_addr), sizeof(struct in6_addr))];
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004825#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004826 char packed[sizeof(struct in_addr)];
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004827#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004828 if (!PyArg_ParseTuple(args, "is:inet_pton", &af, &ip)) {
4829 return NULL;
4830 }
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004831
Martin v. Löwis04697e82004-06-02 12:35:29 +00004832#if !defined(ENABLE_IPV6) && defined(AF_INET6)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004833 if(af == AF_INET6) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004834 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004835 "can't use AF_INET6, IPv6 is disabled");
4836 return NULL;
4837 }
Thomas Wouters477c8d52006-05-27 19:21:47 +00004838#endif
Martin v. Löwis10649092003-08-05 06:25:06 +00004839
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004840 retval = inet_pton(af, ip, packed);
4841 if (retval < 0) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004842 PyErr_SetFromErrno(PyExc_OSError);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004843 return NULL;
4844 } else if (retval == 0) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004845 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004846 "illegal IP address string passed to inet_pton");
4847 return NULL;
4848 } else if (af == AF_INET) {
4849 return PyBytes_FromStringAndSize(packed,
4850 sizeof(struct in_addr));
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004851#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004852 } else if (af == AF_INET6) {
4853 return PyBytes_FromStringAndSize(packed,
4854 sizeof(struct in6_addr));
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004855#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004856 } else {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004857 PyErr_SetString(PyExc_OSError, "unknown address family");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004858 return NULL;
4859 }
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004860}
Thomas Wouters477c8d52006-05-27 19:21:47 +00004861
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004862PyDoc_STRVAR(inet_ntop_doc,
4863"inet_ntop(af, packed_ip) -> string formatted IP address\n\
4864\n\
4865Convert a packed IP address of the given family to string format.");
4866
4867static PyObject *
4868socket_inet_ntop(PyObject *self, PyObject *args)
4869{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004870 int af;
4871 char* packed;
4872 int len;
4873 const char* retval;
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004874#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004875 char ip[MAX(INET_ADDRSTRLEN, INET6_ADDRSTRLEN) + 1];
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004876#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004877 char ip[INET_ADDRSTRLEN + 1];
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004878#endif
Thomas Wouters477c8d52006-05-27 19:21:47 +00004879
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004880 /* Guarantee NUL-termination for PyUnicode_FromString() below */
4881 memset((void *) &ip[0], '\0', sizeof(ip));
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004882
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004883 if (!PyArg_ParseTuple(args, "iy#:inet_ntop", &af, &packed, &len)) {
4884 return NULL;
4885 }
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004886
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004887 if (af == AF_INET) {
4888 if (len != sizeof(struct in_addr)) {
4889 PyErr_SetString(PyExc_ValueError,
4890 "invalid length of packed IP address string");
4891 return NULL;
4892 }
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004893#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004894 } else if (af == AF_INET6) {
4895 if (len != sizeof(struct in6_addr)) {
4896 PyErr_SetString(PyExc_ValueError,
4897 "invalid length of packed IP address string");
4898 return NULL;
4899 }
Martin v. Löwisa94568a2003-05-10 07:36:56 +00004900#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004901 } else {
4902 PyErr_Format(PyExc_ValueError,
4903 "unknown address family %d", af);
4904 return NULL;
4905 }
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004906
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004907 retval = inet_ntop(af, packed, ip, sizeof(ip));
4908 if (!retval) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004909 PyErr_SetFromErrno(PyExc_OSError);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004910 return NULL;
4911 } else {
4912 return PyUnicode_FromString(retval);
4913 }
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004914
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004915 /* NOTREACHED */
4916 PyErr_SetString(PyExc_RuntimeError, "invalid handling of inet_ntop");
4917 return NULL;
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00004918}
4919
4920#endif /* HAVE_INET_PTON */
4921
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004922/* Python interface to getaddrinfo(host, port). */
4923
4924/*ARGSUSED*/
4925static PyObject *
Giampaolo Rodolàccfb91c2010-08-17 15:30:23 +00004926socket_getaddrinfo(PyObject *self, PyObject *args, PyObject* kwargs)
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004927{
Victor Stinner77af1722011-05-26 14:05:59 +02004928 static char* kwnames[] = {"host", "port", "family", "type", "proto",
Giampaolo Rodolàccfb91c2010-08-17 15:30:23 +00004929 "flags", 0};
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004930 struct addrinfo hints, *res;
4931 struct addrinfo *res0 = NULL;
4932 PyObject *hobj = NULL;
4933 PyObject *pobj = (PyObject *)NULL;
4934 char pbuf[30];
4935 char *hptr, *pptr;
4936 int family, socktype, protocol, flags;
4937 int error;
4938 PyObject *all = (PyObject *)NULL;
4939 PyObject *idna = NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004940
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004941 family = socktype = protocol = flags = 0;
4942 family = AF_UNSPEC;
Victor Stinner77af1722011-05-26 14:05:59 +02004943 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "OO|iiii:getaddrinfo",
Giampaolo Rodolàccfb91c2010-08-17 15:30:23 +00004944 kwnames, &hobj, &pobj, &family, &socktype,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004945 &protocol, &flags)) {
4946 return NULL;
4947 }
4948 if (hobj == Py_None) {
4949 hptr = NULL;
4950 } else if (PyUnicode_Check(hobj)) {
Martin v. Löwisbd928fe2011-10-14 10:20:37 +02004951 _Py_IDENTIFIER(encode);
Martin v. Löwisafe55bb2011-10-09 10:38:36 +02004952
4953 idna = _PyObject_CallMethodId(hobj, &PyId_encode, "s", "idna");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004954 if (!idna)
4955 return NULL;
4956 assert(PyBytes_Check(idna));
4957 hptr = PyBytes_AS_STRING(idna);
4958 } else if (PyBytes_Check(hobj)) {
4959 hptr = PyBytes_AsString(hobj);
4960 } else {
4961 PyErr_SetString(PyExc_TypeError,
4962 "getaddrinfo() argument 1 must be string or None");
4963 return NULL;
4964 }
4965 if (PyLong_CheckExact(pobj)) {
4966 long value = PyLong_AsLong(pobj);
4967 if (value == -1 && PyErr_Occurred())
4968 goto err;
4969 PyOS_snprintf(pbuf, sizeof(pbuf), "%ld", value);
4970 pptr = pbuf;
4971 } else if (PyUnicode_Check(pobj)) {
4972 pptr = _PyUnicode_AsString(pobj);
Alexander Belopolskye239d232010-12-08 23:31:48 +00004973 if (pptr == NULL)
4974 goto err;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004975 } else if (PyBytes_Check(pobj)) {
Alexander Belopolskye239d232010-12-08 23:31:48 +00004976 pptr = PyBytes_AS_STRING(pobj);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004977 } else if (pobj == Py_None) {
4978 pptr = (char *)NULL;
4979 } else {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02004980 PyErr_SetString(PyExc_OSError, "Int or String expected");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004981 goto err;
4982 }
4983 memset(&hints, 0, sizeof(hints));
4984 hints.ai_family = family;
4985 hints.ai_socktype = socktype;
4986 hints.ai_protocol = protocol;
4987 hints.ai_flags = flags;
4988 Py_BEGIN_ALLOW_THREADS
4989 ACQUIRE_GETADDRINFO_LOCK
4990 error = getaddrinfo(hptr, pptr, &hints, &res0);
4991 Py_END_ALLOW_THREADS
4992 RELEASE_GETADDRINFO_LOCK /* see comment in setipaddr() */
4993 if (error) {
4994 set_gaierror(error);
4995 goto err;
4996 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00004997
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004998 if ((all = PyList_New(0)) == NULL)
4999 goto err;
5000 for (res = res0; res; res = res->ai_next) {
5001 PyObject *single;
5002 PyObject *addr =
5003 makesockaddr(-1, res->ai_addr, res->ai_addrlen, protocol);
5004 if (addr == NULL)
5005 goto err;
5006 single = Py_BuildValue("iiisO", res->ai_family,
5007 res->ai_socktype, res->ai_protocol,
5008 res->ai_canonname ? res->ai_canonname : "",
5009 addr);
5010 Py_DECREF(addr);
5011 if (single == NULL)
5012 goto err;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005013
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005014 if (PyList_Append(all, single))
5015 goto err;
5016 Py_XDECREF(single);
5017 }
5018 Py_XDECREF(idna);
5019 if (res0)
5020 freeaddrinfo(res0);
5021 return all;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005022 err:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005023 Py_XDECREF(all);
5024 Py_XDECREF(idna);
5025 if (res0)
5026 freeaddrinfo(res0);
5027 return (PyObject *)NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005028}
5029
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00005030PyDoc_STRVAR(getaddrinfo_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00005031"getaddrinfo(host, port [, family, socktype, proto, flags])\n\
5032 -> list of (family, socktype, proto, canonname, sockaddr)\n\
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005033\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00005034Resolve host and port into addrinfo struct.");
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005035
5036/* Python interface to getnameinfo(sa, flags). */
5037
5038/*ARGSUSED*/
5039static PyObject *
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005040socket_getnameinfo(PyObject *self, PyObject *args)
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005041{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005042 PyObject *sa = (PyObject *)NULL;
5043 int flags;
5044 char *hostp;
Charles-François Natali366999a2012-01-02 15:47:29 +01005045 int port;
5046 unsigned int flowinfo, scope_id;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005047 char hbuf[NI_MAXHOST], pbuf[NI_MAXSERV];
5048 struct addrinfo hints, *res = NULL;
5049 int error;
5050 PyObject *ret = (PyObject *)NULL;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005051
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005052 flags = flowinfo = scope_id = 0;
5053 if (!PyArg_ParseTuple(args, "Oi:getnameinfo", &sa, &flags))
5054 return NULL;
5055 if (!PyTuple_Check(sa)) {
5056 PyErr_SetString(PyExc_TypeError,
5057 "getnameinfo() argument 1 must be a tuple");
5058 return NULL;
5059 }
Charles-François Natali366999a2012-01-02 15:47:29 +01005060 if (!PyArg_ParseTuple(sa, "si|II",
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005061 &hostp, &port, &flowinfo, &scope_id))
5062 return NULL;
Charles-François Natali366999a2012-01-02 15:47:29 +01005063 if (flowinfo < 0 || flowinfo > 0xfffff) {
5064 PyErr_SetString(PyExc_OverflowError,
5065 "getsockaddrarg: flowinfo must be 0-1048575.");
5066 return NULL;
5067 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005068 PyOS_snprintf(pbuf, sizeof(pbuf), "%d", port);
5069 memset(&hints, 0, sizeof(hints));
5070 hints.ai_family = AF_UNSPEC;
5071 hints.ai_socktype = SOCK_DGRAM; /* make numeric port happy */
Martin v. Löwis112c0f32010-08-25 07:38:15 +00005072 hints.ai_flags = AI_NUMERICHOST; /* don't do any name resolution */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005073 Py_BEGIN_ALLOW_THREADS
5074 ACQUIRE_GETADDRINFO_LOCK
5075 error = getaddrinfo(hostp, pbuf, &hints, &res);
5076 Py_END_ALLOW_THREADS
5077 RELEASE_GETADDRINFO_LOCK /* see comment in setipaddr() */
5078 if (error) {
5079 set_gaierror(error);
5080 goto fail;
5081 }
5082 if (res->ai_next) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005083 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005084 "sockaddr resolved to multiple addresses");
5085 goto fail;
5086 }
5087 switch (res->ai_family) {
5088 case AF_INET:
5089 {
5090 if (PyTuple_GET_SIZE(sa) != 2) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005091 PyErr_SetString(PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005092 "IPv4 sockaddr must be 2 tuple");
5093 goto fail;
5094 }
5095 break;
5096 }
Martin v. Löwis44ddbde2001-12-02 10:15:37 +00005097#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005098 case AF_INET6:
5099 {
5100 struct sockaddr_in6 *sin6;
5101 sin6 = (struct sockaddr_in6 *)res->ai_addr;
Charles-François Natali366999a2012-01-02 15:47:29 +01005102 sin6->sin6_flowinfo = htonl(flowinfo);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005103 sin6->sin6_scope_id = scope_id;
5104 break;
5105 }
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005106#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005107 }
Antoine Pitrou19467d22010-08-17 19:33:30 +00005108 error = getnameinfo(res->ai_addr, (socklen_t) res->ai_addrlen,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005109 hbuf, sizeof(hbuf), pbuf, sizeof(pbuf), flags);
5110 if (error) {
5111 set_gaierror(error);
5112 goto fail;
5113 }
5114 ret = Py_BuildValue("ss", hbuf, pbuf);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005115
5116fail:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005117 if (res)
5118 freeaddrinfo(res);
5119 return ret;
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005120}
5121
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00005122PyDoc_STRVAR(getnameinfo_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00005123"getnameinfo(sockaddr, flags) --> (host, port)\n\
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005124\n\
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00005125Get host and port for a sockaddr.");
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005126
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005127
5128/* Python API to getting and setting the default timeout value. */
5129
5130static PyObject *
5131socket_getdefaulttimeout(PyObject *self)
5132{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005133 if (defaulttimeout < 0.0) {
5134 Py_INCREF(Py_None);
5135 return Py_None;
5136 }
5137 else
5138 return PyFloat_FromDouble(defaulttimeout);
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005139}
5140
5141PyDoc_STRVAR(getdefaulttimeout_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00005142"getdefaulttimeout() -> timeout\n\
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005143\n\
Ezio Melotti388c9452011-08-14 08:28:57 +03005144Returns the default timeout in seconds (float) for new socket objects.\n\
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005145A value of None indicates that new socket objects have no timeout.\n\
5146When the socket module is first imported, the default is None.");
5147
5148static PyObject *
5149socket_setdefaulttimeout(PyObject *self, PyObject *arg)
5150{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005151 double timeout;
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005152
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005153 if (arg == Py_None)
5154 timeout = -1.0;
5155 else {
5156 timeout = PyFloat_AsDouble(arg);
5157 if (timeout < 0.0) {
5158 if (!PyErr_Occurred())
5159 PyErr_SetString(PyExc_ValueError,
5160 "Timeout value out of range");
5161 return NULL;
5162 }
5163 }
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005164
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005165 defaulttimeout = timeout;
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005166
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005167 Py_INCREF(Py_None);
5168 return Py_None;
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005169}
5170
5171PyDoc_STRVAR(setdefaulttimeout_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00005172"setdefaulttimeout(timeout)\n\
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005173\n\
Ezio Melotti388c9452011-08-14 08:28:57 +03005174Set the default timeout in seconds (float) for new socket objects.\n\
Guido van Rossum9d0c8ce2002-07-18 17:08:35 +00005175A value of None indicates that new socket objects have no timeout.\n\
5176When the socket module is first imported, the default is None.");
5177
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005178#ifdef HAVE_IF_NAMEINDEX
5179/* Python API for getting interface indices and names */
5180
5181static PyObject *
5182socket_if_nameindex(PyObject *self, PyObject *arg)
5183{
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005184 PyObject *list;
Charles-François Natali60713592011-05-20 16:55:06 +02005185 int i;
5186 struct if_nameindex *ni;
Victor Stinner77af1722011-05-26 14:05:59 +02005187
Charles-François Natali60713592011-05-20 16:55:06 +02005188 ni = if_nameindex();
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005189 if (ni == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005190 PyErr_SetFromErrno(PyExc_OSError);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005191 return NULL;
5192 }
5193
5194 list = PyList_New(0);
5195 if (list == NULL) {
5196 if_freenameindex(ni);
5197 return NULL;
5198 }
5199
Charles-François Natali60713592011-05-20 16:55:06 +02005200 for (i = 0; ni[i].if_index != 0 && i < INT_MAX; i++) {
5201 PyObject *ni_tuple = Py_BuildValue("IO&",
5202 ni[i].if_index, PyUnicode_DecodeFSDefault, ni[i].if_name);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005203
5204 if (ni_tuple == NULL || PyList_Append(list, ni_tuple) == -1) {
5205 Py_XDECREF(ni_tuple);
Charles-François Natali60713592011-05-20 16:55:06 +02005206 Py_DECREF(list);
5207 if_freenameindex(ni);
5208 return NULL;
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005209 }
5210 Py_DECREF(ni_tuple);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005211 }
5212
5213 if_freenameindex(ni);
5214 return list;
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005215}
5216
5217PyDoc_STRVAR(if_nameindex_doc,
5218"if_nameindex()\n\
5219\n\
5220Returns a list of network interface information (index, name) tuples.");
5221
Charles-François Natali60713592011-05-20 16:55:06 +02005222static PyObject *
5223socket_if_nametoindex(PyObject *self, PyObject *args)
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005224{
Charles-François Natali60713592011-05-20 16:55:06 +02005225 PyObject *oname;
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005226 unsigned long index;
5227
Charles-François Natali60713592011-05-20 16:55:06 +02005228 if (!PyArg_ParseTuple(args, "O&:if_nametoindex",
5229 PyUnicode_FSConverter, &oname))
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005230 return NULL;
5231
Charles-François Natali60713592011-05-20 16:55:06 +02005232 index = if_nametoindex(PyBytes_AS_STRING(oname));
5233 Py_DECREF(oname);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005234 if (index == 0) {
Charles-François Natali60713592011-05-20 16:55:06 +02005235 /* if_nametoindex() doesn't set errno */
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005236 PyErr_SetString(PyExc_OSError, "no interface with this name");
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005237 return NULL;
5238 }
5239
5240 return PyLong_FromUnsignedLong(index);
5241}
5242
5243PyDoc_STRVAR(if_nametoindex_doc,
5244"if_nametoindex(if_name)\n\
5245\n\
5246Returns the interface index corresponding to the interface name if_name.");
5247
Charles-François Natali60713592011-05-20 16:55:06 +02005248static PyObject *
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005249socket_if_indextoname(PyObject *self, PyObject *arg)
5250{
Charles-François Natali60713592011-05-20 16:55:06 +02005251 unsigned long index;
5252 char name[IF_NAMESIZE + 1];
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005253
Charles-François Natali60713592011-05-20 16:55:06 +02005254 index = PyLong_AsUnsignedLong(arg);
5255 if (index == (unsigned long) -1)
5256 return NULL;
5257
5258 if (if_indextoname(index, name) == NULL) {
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005259 PyErr_SetFromErrno(PyExc_OSError);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005260 return NULL;
5261 }
5262
Charles-François Natali60713592011-05-20 16:55:06 +02005263 return PyUnicode_DecodeFSDefault(name);
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005264}
5265
5266PyDoc_STRVAR(if_indextoname_doc,
5267"if_indextoname(if_index)\n\
5268\n\
5269Returns the interface name corresponding to the interface index if_index.");
5270
5271#endif /* HAVE_IF_NAMEINDEX */
5272
5273
Nick Coghlan96fe56a2011-08-22 11:55:57 +10005274#ifdef CMSG_LEN
5275/* Python interface to CMSG_LEN(length). */
5276
5277static PyObject *
5278socket_CMSG_LEN(PyObject *self, PyObject *args)
5279{
5280 Py_ssize_t length;
5281 size_t result;
5282
5283 if (!PyArg_ParseTuple(args, "n:CMSG_LEN", &length))
5284 return NULL;
5285 if (length < 0 || !get_CMSG_LEN(length, &result)) {
5286 PyErr_Format(PyExc_OverflowError, "CMSG_LEN() argument out of range");
5287 return NULL;
5288 }
5289 return PyLong_FromSize_t(result);
5290}
5291
5292PyDoc_STRVAR(CMSG_LEN_doc,
5293"CMSG_LEN(length) -> control message length\n\
5294\n\
5295Return the total length, without trailing padding, of an ancillary\n\
5296data item with associated data of the given length. This value can\n\
5297often be used as the buffer size for recvmsg() to receive a single\n\
5298item of ancillary data, but RFC 3542 requires portable applications to\n\
5299use CMSG_SPACE() and thus include space for padding, even when the\n\
5300item will be the last in the buffer. Raises OverflowError if length\n\
5301is outside the permissible range of values.");
5302
5303
5304#ifdef CMSG_SPACE
5305/* Python interface to CMSG_SPACE(length). */
5306
5307static PyObject *
5308socket_CMSG_SPACE(PyObject *self, PyObject *args)
5309{
5310 Py_ssize_t length;
5311 size_t result;
5312
5313 if (!PyArg_ParseTuple(args, "n:CMSG_SPACE", &length))
5314 return NULL;
5315 if (length < 0 || !get_CMSG_SPACE(length, &result)) {
5316 PyErr_SetString(PyExc_OverflowError,
5317 "CMSG_SPACE() argument out of range");
5318 return NULL;
5319 }
5320 return PyLong_FromSize_t(result);
5321}
5322
5323PyDoc_STRVAR(CMSG_SPACE_doc,
5324"CMSG_SPACE(length) -> buffer size\n\
5325\n\
5326Return the buffer size needed for recvmsg() to receive an ancillary\n\
5327data item with associated data of the given length, along with any\n\
5328trailing padding. The buffer space needed to receive multiple items\n\
5329is the sum of the CMSG_SPACE() values for their associated data\n\
5330lengths. Raises OverflowError if length is outside the permissible\n\
5331range of values.");
5332#endif /* CMSG_SPACE */
5333#endif /* CMSG_LEN */
5334
5335
Guido van Rossum30a685f1991-06-27 15:51:29 +00005336/* List of functions exported by this module. */
5337
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005338static PyMethodDef socket_methods[] = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005339 {"gethostbyname", socket_gethostbyname,
5340 METH_VARARGS, gethostbyname_doc},
5341 {"gethostbyname_ex", socket_gethostbyname_ex,
5342 METH_VARARGS, ghbn_ex_doc},
5343 {"gethostbyaddr", socket_gethostbyaddr,
5344 METH_VARARGS, gethostbyaddr_doc},
5345 {"gethostname", socket_gethostname,
5346 METH_NOARGS, gethostname_doc},
Antoine Pitrou061cfb52011-02-28 22:25:22 +00005347#ifdef HAVE_SETHOSTNAME
5348 {"sethostname", socket_sethostname,
5349 METH_VARARGS, sethostname_doc},
5350#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005351 {"getservbyname", socket_getservbyname,
5352 METH_VARARGS, getservbyname_doc},
5353 {"getservbyport", socket_getservbyport,
5354 METH_VARARGS, getservbyport_doc},
5355 {"getprotobyname", socket_getprotobyname,
5356 METH_VARARGS, getprotobyname_doc},
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00005357#ifndef NO_DUP
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005358 {"dup", socket_dup,
5359 METH_O, dup_doc},
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00005360#endif
Dave Cole331708b2004-08-09 04:51:41 +00005361#ifdef HAVE_SOCKETPAIR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005362 {"socketpair", socket_socketpair,
5363 METH_VARARGS, socketpair_doc},
Dave Cole331708b2004-08-09 04:51:41 +00005364#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005365 {"ntohs", socket_ntohs,
5366 METH_VARARGS, ntohs_doc},
5367 {"ntohl", socket_ntohl,
5368 METH_O, ntohl_doc},
5369 {"htons", socket_htons,
5370 METH_VARARGS, htons_doc},
5371 {"htonl", socket_htonl,
5372 METH_O, htonl_doc},
5373 {"inet_aton", socket_inet_aton,
5374 METH_VARARGS, inet_aton_doc},
5375 {"inet_ntoa", socket_inet_ntoa,
5376 METH_VARARGS, inet_ntoa_doc},
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005377#ifdef HAVE_INET_PTON
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005378 {"inet_pton", socket_inet_pton,
5379 METH_VARARGS, inet_pton_doc},
5380 {"inet_ntop", socket_inet_ntop,
5381 METH_VARARGS, inet_ntop_doc},
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005382#endif
Giampaolo Rodolàccfb91c2010-08-17 15:30:23 +00005383 {"getaddrinfo", (PyCFunction)socket_getaddrinfo,
5384 METH_VARARGS | METH_KEYWORDS, getaddrinfo_doc},
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005385 {"getnameinfo", socket_getnameinfo,
5386 METH_VARARGS, getnameinfo_doc},
5387 {"getdefaulttimeout", (PyCFunction)socket_getdefaulttimeout,
5388 METH_NOARGS, getdefaulttimeout_doc},
5389 {"setdefaulttimeout", socket_setdefaulttimeout,
5390 METH_O, setdefaulttimeout_doc},
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005391#ifdef HAVE_IF_NAMEINDEX
5392 {"if_nameindex", socket_if_nameindex,
5393 METH_NOARGS, if_nameindex_doc},
5394 {"if_nametoindex", socket_if_nametoindex,
Charles-François Natali60713592011-05-20 16:55:06 +02005395 METH_VARARGS, if_nametoindex_doc},
Gregory P. Smith5ed2e772011-05-15 00:26:45 -07005396 {"if_indextoname", socket_if_indextoname,
5397 METH_O, if_indextoname_doc},
5398#endif
Nick Coghlan96fe56a2011-08-22 11:55:57 +10005399#ifdef CMSG_LEN
5400 {"CMSG_LEN", socket_CMSG_LEN,
5401 METH_VARARGS, CMSG_LEN_doc},
5402#ifdef CMSG_SPACE
5403 {"CMSG_SPACE", socket_CMSG_SPACE,
5404 METH_VARARGS, CMSG_SPACE_doc},
5405#endif
5406#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005407 {NULL, NULL} /* Sentinel */
Guido van Rossum6574b3e1991-06-25 21:36:08 +00005408};
5409
Guido van Rossum30a685f1991-06-27 15:51:29 +00005410
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005411#ifdef MS_WINDOWS
5412#define OS_INIT_DEFINED
5413
5414/* Additional initialization and cleanup for Windows */
Guido van Rossumbe32c891996-06-20 16:25:29 +00005415
5416static void
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005417os_cleanup(void)
Guido van Rossumbe32c891996-06-20 16:25:29 +00005418{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005419 WSACleanup();
Guido van Rossumbe32c891996-06-20 16:25:29 +00005420}
5421
5422static int
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005423os_init(void)
Guido van Rossumbe32c891996-06-20 16:25:29 +00005424{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005425 WSADATA WSAData;
5426 int ret;
5427 ret = WSAStartup(0x0101, &WSAData);
5428 switch (ret) {
5429 case 0: /* No error */
5430 Py_AtExit(os_cleanup);
5431 return 1; /* Success */
5432 case WSASYSNOTREADY:
5433 PyErr_SetString(PyExc_ImportError,
5434 "WSAStartup failed: network not ready");
5435 break;
5436 case WSAVERNOTSUPPORTED:
5437 case WSAEINVAL:
5438 PyErr_SetString(
5439 PyExc_ImportError,
5440 "WSAStartup failed: requested version not supported");
5441 break;
5442 default:
5443 PyErr_Format(PyExc_ImportError, "WSAStartup failed: error code %d", ret);
5444 break;
5445 }
5446 return 0; /* Failure */
Guido van Rossumbe32c891996-06-20 16:25:29 +00005447}
5448
Guido van Rossum8d665e61996-06-26 18:22:49 +00005449#endif /* MS_WINDOWS */
Guido van Rossumbe32c891996-06-20 16:25:29 +00005450
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005451
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005452#ifdef PYOS_OS2
5453#define OS_INIT_DEFINED
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005454
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005455/* Additional initialization for OS/2 */
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005456
5457static int
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005458os_init(void)
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005459{
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005460#ifndef PYCC_GCC
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005461 int rc = sock_init();
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005462
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005463 if (rc == 0) {
5464 return 1; /* Success */
5465 }
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005466
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005467 PyErr_Format(PyExc_ImportError, "OS/2 TCP/IP Error# %d", sock_errno());
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005468
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005469 return 0; /* Failure */
Andrew MacIntyreba43e872002-03-03 03:03:52 +00005470#else
Ezio Melotti13925002011-03-16 11:05:33 +02005471 /* No need to initialize sockets with GCC/EMX */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005472 return 1; /* Success */
Andrew MacIntyreba43e872002-03-03 03:03:52 +00005473#endif
Guido van Rossum8e9ebfd1997-11-22 21:53:48 +00005474}
5475
5476#endif /* PYOS_OS2 */
5477
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005478
5479#ifndef OS_INIT_DEFINED
5480static int
5481os_init(void)
5482{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005483 return 1; /* Success */
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005484}
5485#endif
5486
5487
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +00005488/* C API table - always add new things to the end for binary
5489 compatibility. */
5490static
5491PySocketModule_APIObject PySocketModuleAPI =
5492{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005493 &sock_type,
Antoine Pitrouc4df7842010-12-03 19:59:41 +00005494 NULL,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005495 NULL
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +00005496};
5497
Guido van Rossum3eede5a2002-06-07 02:08:35 +00005498
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005499/* Initialize the _socket module.
Guido van Rossum3eede5a2002-06-07 02:08:35 +00005500
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005501 This module is actually called "_socket", and there's a wrapper
Guido van Rossum7d0a8262007-05-21 23:13:11 +00005502 "socket.py" which implements some additional functionality.
5503 The import of "_socket" may fail with an ImportError exception if
5504 os-specific initialization fails. On Windows, this does WINSOCK
Ezio Melotti13925002011-03-16 11:05:33 +02005505 initialization. When WINSOCK is initialized successfully, a call to
Guido van Rossum7d0a8262007-05-21 23:13:11 +00005506 WSACleanup() is scheduled to be made at exit time.
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005507*/
Guido van Rossum3eede5a2002-06-07 02:08:35 +00005508
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +00005509PyDoc_STRVAR(socket_doc,
Guido van Rossum22a97152002-08-08 20:37:08 +00005510"Implementation module for socket operations.\n\
5511\n\
5512See the socket module for documentation.");
Guido van Rossum82a5c661998-07-07 20:45:43 +00005513
Martin v. Löwis1a214512008-06-11 05:26:20 +00005514static struct PyModuleDef socketmodule = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005515 PyModuleDef_HEAD_INIT,
5516 PySocket_MODULE_NAME,
5517 socket_doc,
5518 -1,
5519 socket_methods,
5520 NULL,
5521 NULL,
5522 NULL,
5523 NULL
Martin v. Löwis1a214512008-06-11 05:26:20 +00005524};
5525
Mark Hammondfe51c6d2002-08-02 02:27:13 +00005526PyMODINIT_FUNC
Martin v. Löwis1a214512008-06-11 05:26:20 +00005527PyInit__socket(void)
Guido van Rossum6574b3e1991-06-25 21:36:08 +00005528{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005529 PyObject *m, *has_ipv6;
Fred Drake4baedc12002-04-01 14:53:37 +00005530
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005531 if (!os_init())
5532 return NULL;
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005533
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005534 Py_TYPE(&sock_type) = &PyType_Type;
5535 m = PyModule_Create(&socketmodule);
5536 if (m == NULL)
5537 return NULL;
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00005538
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005539 Py_INCREF(PyExc_OSError);
5540 PySocketModuleAPI.error = PyExc_OSError;
5541 Py_INCREF(PyExc_OSError);
5542 PyModule_AddObject(m, "error", PyExc_OSError);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005543 socket_herror = PyErr_NewException("socket.herror",
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005544 PyExc_OSError, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005545 if (socket_herror == NULL)
5546 return NULL;
5547 Py_INCREF(socket_herror);
5548 PyModule_AddObject(m, "herror", socket_herror);
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005549 socket_gaierror = PyErr_NewException("socket.gaierror", PyExc_OSError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005550 NULL);
5551 if (socket_gaierror == NULL)
5552 return NULL;
5553 Py_INCREF(socket_gaierror);
5554 PyModule_AddObject(m, "gaierror", socket_gaierror);
5555 socket_timeout = PyErr_NewException("socket.timeout",
Antoine Pitrou6b4883d2011-10-12 02:54:14 +02005556 PyExc_OSError, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005557 if (socket_timeout == NULL)
5558 return NULL;
Antoine Pitrouc4df7842010-12-03 19:59:41 +00005559 PySocketModuleAPI.timeout_error = socket_timeout;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005560 Py_INCREF(socket_timeout);
5561 PyModule_AddObject(m, "timeout", socket_timeout);
5562 Py_INCREF((PyObject *)&sock_type);
5563 if (PyModule_AddObject(m, "SocketType",
5564 (PyObject *)&sock_type) != 0)
5565 return NULL;
5566 Py_INCREF((PyObject *)&sock_type);
5567 if (PyModule_AddObject(m, "socket",
5568 (PyObject *)&sock_type) != 0)
5569 return NULL;
Guido van Rossum09be4091999-08-09 14:40:40 +00005570
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005571#ifdef ENABLE_IPV6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005572 has_ipv6 = Py_True;
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005573#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005574 has_ipv6 = Py_False;
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005575#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005576 Py_INCREF(has_ipv6);
5577 PyModule_AddObject(m, "has_ipv6", has_ipv6);
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00005578
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005579 /* Export C API */
5580 if (PyModule_AddObject(m, PySocket_CAPI_NAME,
5581 PyCapsule_New(&PySocketModuleAPI, PySocket_CAPSULE_NAME, NULL)
5582 ) != 0)
5583 return NULL;
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +00005584
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005585 /* Address families (we only support AF_INET and AF_UNIX) */
Guido van Rossum09be4091999-08-09 14:40:40 +00005586#ifdef AF_UNSPEC
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005587 PyModule_AddIntConstant(m, "AF_UNSPEC", AF_UNSPEC);
Guido van Rossum09be4091999-08-09 14:40:40 +00005588#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005589 PyModule_AddIntConstant(m, "AF_INET", AF_INET);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005590#ifdef AF_INET6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005591 PyModule_AddIntConstant(m, "AF_INET6", AF_INET6);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00005592#endif /* AF_INET6 */
Andrew MacIntyred12dfbb2004-04-04 07:13:49 +00005593#if defined(AF_UNIX)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005594 PyModule_AddIntConstant(m, "AF_UNIX", AF_UNIX);
Guido van Rossumb6775db1994-08-01 11:34:53 +00005595#endif /* AF_UNIX */
Guido van Rossum09be4091999-08-09 14:40:40 +00005596#ifdef AF_AX25
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005597 /* Amateur Radio AX.25 */
5598 PyModule_AddIntConstant(m, "AF_AX25", AF_AX25);
Guido van Rossum09be4091999-08-09 14:40:40 +00005599#endif
5600#ifdef AF_IPX
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005601 PyModule_AddIntConstant(m, "AF_IPX", AF_IPX); /* Novell IPX */
Guido van Rossum09be4091999-08-09 14:40:40 +00005602#endif
5603#ifdef AF_APPLETALK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005604 /* Appletalk DDP */
5605 PyModule_AddIntConstant(m, "AF_APPLETALK", AF_APPLETALK);
Guido van Rossum09be4091999-08-09 14:40:40 +00005606#endif
5607#ifdef AF_NETROM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005608 /* Amateur radio NetROM */
5609 PyModule_AddIntConstant(m, "AF_NETROM", AF_NETROM);
Guido van Rossum09be4091999-08-09 14:40:40 +00005610#endif
5611#ifdef AF_BRIDGE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005612 /* Multiprotocol bridge */
5613 PyModule_AddIntConstant(m, "AF_BRIDGE", AF_BRIDGE);
Guido van Rossum09be4091999-08-09 14:40:40 +00005614#endif
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005615#ifdef AF_ATMPVC
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005616 /* ATM PVCs */
5617 PyModule_AddIntConstant(m, "AF_ATMPVC", AF_ATMPVC);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005618#endif
Guido van Rossum09be4091999-08-09 14:40:40 +00005619#ifdef AF_AAL5
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005620 /* Reserved for Werner's ATM */
5621 PyModule_AddIntConstant(m, "AF_AAL5", AF_AAL5);
Guido van Rossum09be4091999-08-09 14:40:40 +00005622#endif
5623#ifdef AF_X25
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005624 /* Reserved for X.25 project */
5625 PyModule_AddIntConstant(m, "AF_X25", AF_X25);
Guido van Rossum09be4091999-08-09 14:40:40 +00005626#endif
5627#ifdef AF_INET6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005628 PyModule_AddIntConstant(m, "AF_INET6", AF_INET6); /* IP version 6 */
Guido van Rossum09be4091999-08-09 14:40:40 +00005629#endif
5630#ifdef AF_ROSE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005631 /* Amateur Radio X.25 PLP */
5632 PyModule_AddIntConstant(m, "AF_ROSE", AF_ROSE);
Guido van Rossum09be4091999-08-09 14:40:40 +00005633#endif
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005634#ifdef AF_DECnet
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005635 /* Reserved for DECnet project */
5636 PyModule_AddIntConstant(m, "AF_DECnet", AF_DECnet);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005637#endif
5638#ifdef AF_NETBEUI
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005639 /* Reserved for 802.2LLC project */
5640 PyModule_AddIntConstant(m, "AF_NETBEUI", AF_NETBEUI);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005641#endif
5642#ifdef AF_SECURITY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005643 /* Security callback pseudo AF */
5644 PyModule_AddIntConstant(m, "AF_SECURITY", AF_SECURITY);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005645#endif
5646#ifdef AF_KEY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005647 /* PF_KEY key management API */
5648 PyModule_AddIntConstant(m, "AF_KEY", AF_KEY);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005649#endif
5650#ifdef AF_NETLINK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005651 /* */
5652 PyModule_AddIntConstant(m, "AF_NETLINK", AF_NETLINK);
5653 PyModule_AddIntConstant(m, "NETLINK_ROUTE", NETLINK_ROUTE);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005654#ifdef NETLINK_SKIP
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005655 PyModule_AddIntConstant(m, "NETLINK_SKIP", NETLINK_SKIP);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005656#endif
5657#ifdef NETLINK_W1
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005658 PyModule_AddIntConstant(m, "NETLINK_W1", NETLINK_W1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005659#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005660 PyModule_AddIntConstant(m, "NETLINK_USERSOCK", NETLINK_USERSOCK);
5661 PyModule_AddIntConstant(m, "NETLINK_FIREWALL", NETLINK_FIREWALL);
Guido van Rossum668a94a2006-02-21 01:07:27 +00005662#ifdef NETLINK_TCPDIAG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005663 PyModule_AddIntConstant(m, "NETLINK_TCPDIAG", NETLINK_TCPDIAG);
Guido van Rossum668a94a2006-02-21 01:07:27 +00005664#endif
5665#ifdef NETLINK_NFLOG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005666 PyModule_AddIntConstant(m, "NETLINK_NFLOG", NETLINK_NFLOG);
Guido van Rossum668a94a2006-02-21 01:07:27 +00005667#endif
Neal Norwitz65851662006-01-16 04:31:40 +00005668#ifdef NETLINK_XFRM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005669 PyModule_AddIntConstant(m, "NETLINK_XFRM", NETLINK_XFRM);
Neal Norwitz65851662006-01-16 04:31:40 +00005670#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005671#ifdef NETLINK_ARPD
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005672 PyModule_AddIntConstant(m, "NETLINK_ARPD", NETLINK_ARPD);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005673#endif
5674#ifdef NETLINK_ROUTE6
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005675 PyModule_AddIntConstant(m, "NETLINK_ROUTE6", NETLINK_ROUTE6);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005676#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005677 PyModule_AddIntConstant(m, "NETLINK_IP6_FW", NETLINK_IP6_FW);
Thomas Wouterscf297e42007-02-23 15:07:44 +00005678#ifdef NETLINK_DNRTMSG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005679 PyModule_AddIntConstant(m, "NETLINK_DNRTMSG", NETLINK_DNRTMSG);
Guido van Rossum39eb8fa2007-11-16 01:24:05 +00005680#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005681#ifdef NETLINK_TAPBASE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005682 PyModule_AddIntConstant(m, "NETLINK_TAPBASE", NETLINK_TAPBASE);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005683#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00005684#endif /* AF_NETLINK */
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005685#ifdef AF_ROUTE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005686 /* Alias to emulate 4.4BSD */
5687 PyModule_AddIntConstant(m, "AF_ROUTE", AF_ROUTE);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005688#endif
5689#ifdef AF_ASH
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005690 /* Ash */
5691 PyModule_AddIntConstant(m, "AF_ASH", AF_ASH);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005692#endif
5693#ifdef AF_ECONET
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005694 /* Acorn Econet */
5695 PyModule_AddIntConstant(m, "AF_ECONET", AF_ECONET);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005696#endif
5697#ifdef AF_ATMSVC
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005698 /* ATM SVCs */
5699 PyModule_AddIntConstant(m, "AF_ATMSVC", AF_ATMSVC);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005700#endif
5701#ifdef AF_SNA
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005702 /* Linux SNA Project (nutters!) */
5703 PyModule_AddIntConstant(m, "AF_SNA", AF_SNA);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005704#endif
5705#ifdef AF_IRDA
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005706 /* IRDA sockets */
5707 PyModule_AddIntConstant(m, "AF_IRDA", AF_IRDA);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005708#endif
5709#ifdef AF_PPPOX
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005710 /* PPPoX sockets */
5711 PyModule_AddIntConstant(m, "AF_PPPOX", AF_PPPOX);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005712#endif
5713#ifdef AF_WANPIPE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005714 /* Wanpipe API Sockets */
5715 PyModule_AddIntConstant(m, "AF_WANPIPE", AF_WANPIPE);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005716#endif
5717#ifdef AF_LLC
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005718 /* Linux LLC */
5719 PyModule_AddIntConstant(m, "AF_LLC", AF_LLC);
Martin v. Löwis81aec4b2004-07-19 17:01:20 +00005720#endif
Martin v. Löwis12af0482004-01-31 12:34:17 +00005721
Hye-Shik Chang81268602004-02-02 06:05:24 +00005722#ifdef USE_BLUETOOTH
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005723 PyModule_AddIntConstant(m, "AF_BLUETOOTH", AF_BLUETOOTH);
5724 PyModule_AddIntConstant(m, "BTPROTO_L2CAP", BTPROTO_L2CAP);
5725 PyModule_AddIntConstant(m, "BTPROTO_HCI", BTPROTO_HCI);
5726 PyModule_AddIntConstant(m, "SOL_HCI", SOL_HCI);
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00005727#if !defined(__NetBSD__) && !defined(__DragonFly__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005728 PyModule_AddIntConstant(m, "HCI_FILTER", HCI_FILTER);
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00005729#endif
Hye-Shik Chang81268602004-02-02 06:05:24 +00005730#if !defined(__FreeBSD__)
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00005731#if !defined(__NetBSD__) && !defined(__DragonFly__)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005732 PyModule_AddIntConstant(m, "HCI_TIME_STAMP", HCI_TIME_STAMP);
Gregory P. Smith3e85dfd2010-10-17 00:43:10 +00005733#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005734 PyModule_AddIntConstant(m, "HCI_DATA_DIR", HCI_DATA_DIR);
5735 PyModule_AddIntConstant(m, "BTPROTO_SCO", BTPROTO_SCO);
Hye-Shik Chang81268602004-02-02 06:05:24 +00005736#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005737 PyModule_AddIntConstant(m, "BTPROTO_RFCOMM", BTPROTO_RFCOMM);
5738 PyModule_AddStringConstant(m, "BDADDR_ANY", "00:00:00:00:00:00");
5739 PyModule_AddStringConstant(m, "BDADDR_LOCAL", "00:00:00:FF:FF:FF");
Martin v. Löwis12af0482004-01-31 12:34:17 +00005740#endif
5741
Charles-François Natali47413c12011-10-06 19:47:44 +02005742#ifdef AF_CAN
5743 /* Controller Area Network */
5744 PyModule_AddIntConstant(m, "AF_CAN", AF_CAN);
5745#endif
5746#ifdef PF_CAN
5747 /* Controller Area Network */
5748 PyModule_AddIntConstant(m, "PF_CAN", PF_CAN);
5749#endif
5750
Charles-François Natali10b8cf42011-11-10 19:21:37 +01005751/* Reliable Datagram Sockets */
5752#ifdef AF_RDS
5753 PyModule_AddIntConstant(m, "AF_RDS", AF_RDS);
5754#endif
5755#ifdef PF_RDS
5756 PyModule_AddIntConstant(m, "PF_RDS", PF_RDS);
5757#endif
5758
Martin v. Löwis9d6c6692012-02-03 17:44:58 +01005759/* Kernel event messages */
5760#ifdef PF_SYSTEM
5761 PyModule_AddIntConstant(m, "PF_SYSTEM", PF_SYSTEM);
5762#endif
5763#ifdef AF_SYSTEM
5764 PyModule_AddIntConstant(m, "AF_SYSTEM", AF_SYSTEM);
5765#endif
5766
Antoine Pitroub156a462010-10-27 20:13:57 +00005767#ifdef AF_PACKET
5768 PyModule_AddIntMacro(m, AF_PACKET);
5769#endif
5770#ifdef PF_PACKET
5771 PyModule_AddIntMacro(m, PF_PACKET);
5772#endif
5773#ifdef PACKET_HOST
5774 PyModule_AddIntMacro(m, PACKET_HOST);
5775#endif
5776#ifdef PACKET_BROADCAST
5777 PyModule_AddIntMacro(m, PACKET_BROADCAST);
5778#endif
5779#ifdef PACKET_MULTICAST
5780 PyModule_AddIntMacro(m, PACKET_MULTICAST);
5781#endif
5782#ifdef PACKET_OTHERHOST
5783 PyModule_AddIntMacro(m, PACKET_OTHERHOST);
5784#endif
5785#ifdef PACKET_OUTGOING
5786 PyModule_AddIntMacro(m, PACKET_OUTGOING);
5787#endif
5788#ifdef PACKET_LOOPBACK
5789 PyModule_AddIntMacro(m, PACKET_LOOPBACK);
5790#endif
5791#ifdef PACKET_FASTROUTE
5792 PyModule_AddIntMacro(m, PACKET_FASTROUTE);
Guido van Rossum48a680c2001-03-02 06:34:14 +00005793#endif
Guido van Rossum09be4091999-08-09 14:40:40 +00005794
Christian Heimes043d6f62008-01-07 17:19:16 +00005795#ifdef HAVE_LINUX_TIPC_H
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005796 PyModule_AddIntConstant(m, "AF_TIPC", AF_TIPC);
Christian Heimes043d6f62008-01-07 17:19:16 +00005797
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005798 /* for addresses */
5799 PyModule_AddIntConstant(m, "TIPC_ADDR_NAMESEQ", TIPC_ADDR_NAMESEQ);
5800 PyModule_AddIntConstant(m, "TIPC_ADDR_NAME", TIPC_ADDR_NAME);
5801 PyModule_AddIntConstant(m, "TIPC_ADDR_ID", TIPC_ADDR_ID);
Christian Heimes043d6f62008-01-07 17:19:16 +00005802
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005803 PyModule_AddIntConstant(m, "TIPC_ZONE_SCOPE", TIPC_ZONE_SCOPE);
5804 PyModule_AddIntConstant(m, "TIPC_CLUSTER_SCOPE", TIPC_CLUSTER_SCOPE);
5805 PyModule_AddIntConstant(m, "TIPC_NODE_SCOPE", TIPC_NODE_SCOPE);
Christian Heimes043d6f62008-01-07 17:19:16 +00005806
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005807 /* for setsockopt() */
5808 PyModule_AddIntConstant(m, "SOL_TIPC", SOL_TIPC);
5809 PyModule_AddIntConstant(m, "TIPC_IMPORTANCE", TIPC_IMPORTANCE);
5810 PyModule_AddIntConstant(m, "TIPC_SRC_DROPPABLE", TIPC_SRC_DROPPABLE);
5811 PyModule_AddIntConstant(m, "TIPC_DEST_DROPPABLE",
5812 TIPC_DEST_DROPPABLE);
5813 PyModule_AddIntConstant(m, "TIPC_CONN_TIMEOUT", TIPC_CONN_TIMEOUT);
Christian Heimes043d6f62008-01-07 17:19:16 +00005814
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005815 PyModule_AddIntConstant(m, "TIPC_LOW_IMPORTANCE",
5816 TIPC_LOW_IMPORTANCE);
5817 PyModule_AddIntConstant(m, "TIPC_MEDIUM_IMPORTANCE",
5818 TIPC_MEDIUM_IMPORTANCE);
5819 PyModule_AddIntConstant(m, "TIPC_HIGH_IMPORTANCE",
5820 TIPC_HIGH_IMPORTANCE);
5821 PyModule_AddIntConstant(m, "TIPC_CRITICAL_IMPORTANCE",
5822 TIPC_CRITICAL_IMPORTANCE);
Christian Heimes043d6f62008-01-07 17:19:16 +00005823
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005824 /* for subscriptions */
5825 PyModule_AddIntConstant(m, "TIPC_SUB_PORTS", TIPC_SUB_PORTS);
5826 PyModule_AddIntConstant(m, "TIPC_SUB_SERVICE", TIPC_SUB_SERVICE);
Christian Heimes25bb7832008-01-11 16:17:00 +00005827#ifdef TIPC_SUB_CANCEL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005828 /* doesn't seem to be available everywhere */
5829 PyModule_AddIntConstant(m, "TIPC_SUB_CANCEL", TIPC_SUB_CANCEL);
Christian Heimes25bb7832008-01-11 16:17:00 +00005830#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005831 PyModule_AddIntConstant(m, "TIPC_WAIT_FOREVER", TIPC_WAIT_FOREVER);
5832 PyModule_AddIntConstant(m, "TIPC_PUBLISHED", TIPC_PUBLISHED);
5833 PyModule_AddIntConstant(m, "TIPC_WITHDRAWN", TIPC_WITHDRAWN);
5834 PyModule_AddIntConstant(m, "TIPC_SUBSCR_TIMEOUT", TIPC_SUBSCR_TIMEOUT);
5835 PyModule_AddIntConstant(m, "TIPC_CFG_SRV", TIPC_CFG_SRV);
5836 PyModule_AddIntConstant(m, "TIPC_TOP_SRV", TIPC_TOP_SRV);
Christian Heimes043d6f62008-01-07 17:19:16 +00005837#endif
5838
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005839 /* Socket types */
5840 PyModule_AddIntConstant(m, "SOCK_STREAM", SOCK_STREAM);
5841 PyModule_AddIntConstant(m, "SOCK_DGRAM", SOCK_DGRAM);
Guido van Rossumbcc20741998-08-04 22:53:56 +00005842/* We have incomplete socket support. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005843 PyModule_AddIntConstant(m, "SOCK_RAW", SOCK_RAW);
5844 PyModule_AddIntConstant(m, "SOCK_SEQPACKET", SOCK_SEQPACKET);
Martin v. Löwiscf8f47e2002-12-11 13:10:57 +00005845#if defined(SOCK_RDM)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005846 PyModule_AddIntConstant(m, "SOCK_RDM", SOCK_RDM);
Guido van Rossumbcc20741998-08-04 22:53:56 +00005847#endif
Antoine Pitroub1c54962010-10-14 15:05:38 +00005848#ifdef SOCK_CLOEXEC
5849 PyModule_AddIntConstant(m, "SOCK_CLOEXEC", SOCK_CLOEXEC);
5850#endif
5851#ifdef SOCK_NONBLOCK
5852 PyModule_AddIntConstant(m, "SOCK_NONBLOCK", SOCK_NONBLOCK);
5853#endif
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005854
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005855#ifdef SO_DEBUG
5856 PyModule_AddIntConstant(m, "SO_DEBUG", SO_DEBUG);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005857#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005858#ifdef SO_ACCEPTCONN
5859 PyModule_AddIntConstant(m, "SO_ACCEPTCONN", SO_ACCEPTCONN);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005860#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005861#ifdef SO_REUSEADDR
5862 PyModule_AddIntConstant(m, "SO_REUSEADDR", SO_REUSEADDR);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005863#endif
Andrew M. Kuchling42851ab2004-07-10 14:19:21 +00005864#ifdef SO_EXCLUSIVEADDRUSE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005865 PyModule_AddIntConstant(m, "SO_EXCLUSIVEADDRUSE", SO_EXCLUSIVEADDRUSE);
Andrew M. Kuchling42851ab2004-07-10 14:19:21 +00005866#endif
5867
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005868#ifdef SO_KEEPALIVE
5869 PyModule_AddIntConstant(m, "SO_KEEPALIVE", SO_KEEPALIVE);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005870#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005871#ifdef SO_DONTROUTE
5872 PyModule_AddIntConstant(m, "SO_DONTROUTE", SO_DONTROUTE);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005873#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005874#ifdef SO_BROADCAST
5875 PyModule_AddIntConstant(m, "SO_BROADCAST", SO_BROADCAST);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005876#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005877#ifdef SO_USELOOPBACK
5878 PyModule_AddIntConstant(m, "SO_USELOOPBACK", SO_USELOOPBACK);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005879#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005880#ifdef SO_LINGER
5881 PyModule_AddIntConstant(m, "SO_LINGER", SO_LINGER);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005882#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005883#ifdef SO_OOBINLINE
5884 PyModule_AddIntConstant(m, "SO_OOBINLINE", SO_OOBINLINE);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005885#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005886#ifdef SO_REUSEPORT
5887 PyModule_AddIntConstant(m, "SO_REUSEPORT", SO_REUSEPORT);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005888#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005889#ifdef SO_SNDBUF
5890 PyModule_AddIntConstant(m, "SO_SNDBUF", SO_SNDBUF);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005891#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005892#ifdef SO_RCVBUF
5893 PyModule_AddIntConstant(m, "SO_RCVBUF", SO_RCVBUF);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005894#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005895#ifdef SO_SNDLOWAT
5896 PyModule_AddIntConstant(m, "SO_SNDLOWAT", SO_SNDLOWAT);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005897#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005898#ifdef SO_RCVLOWAT
5899 PyModule_AddIntConstant(m, "SO_RCVLOWAT", SO_RCVLOWAT);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005900#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005901#ifdef SO_SNDTIMEO
5902 PyModule_AddIntConstant(m, "SO_SNDTIMEO", SO_SNDTIMEO);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005903#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005904#ifdef SO_RCVTIMEO
5905 PyModule_AddIntConstant(m, "SO_RCVTIMEO", SO_RCVTIMEO);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005906#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005907#ifdef SO_ERROR
5908 PyModule_AddIntConstant(m, "SO_ERROR", SO_ERROR);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005909#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005910#ifdef SO_TYPE
5911 PyModule_AddIntConstant(m, "SO_TYPE", SO_TYPE);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005912#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005913#ifdef SO_SETFIB
5914 PyModule_AddIntConstant(m, "SO_SETFIB", SO_SETFIB);
Larry Hastingsf0f37952010-04-02 11:47:10 +00005915#endif
Nick Coghlan96fe56a2011-08-22 11:55:57 +10005916#ifdef SO_PASSCRED
5917 PyModule_AddIntConstant(m, "SO_PASSCRED", SO_PASSCRED);
5918#endif
5919#ifdef SO_PEERCRED
5920 PyModule_AddIntConstant(m, "SO_PEERCRED", SO_PEERCRED);
5921#endif
5922#ifdef LOCAL_PEERCRED
5923 PyModule_AddIntConstant(m, "LOCAL_PEERCRED", LOCAL_PEERCRED);
5924#endif
Victor Stinnercb98bed2011-10-25 13:45:48 +02005925#ifdef SO_BINDTODEVICE
5926 PyModule_AddIntMacro(m, SO_BINDTODEVICE);
5927#endif
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005928
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005929 /* Maximum number of connections for "listen" */
5930#ifdef SOMAXCONN
5931 PyModule_AddIntConstant(m, "SOMAXCONN", SOMAXCONN);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005932#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005933 PyModule_AddIntConstant(m, "SOMAXCONN", 5); /* Common value */
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005934#endif
5935
Nick Coghlan96fe56a2011-08-22 11:55:57 +10005936 /* Ancilliary message types */
5937#ifdef SCM_RIGHTS
5938 PyModule_AddIntConstant(m, "SCM_RIGHTS", SCM_RIGHTS);
5939#endif
5940#ifdef SCM_CREDENTIALS
5941 PyModule_AddIntConstant(m, "SCM_CREDENTIALS", SCM_CREDENTIALS);
5942#endif
5943#ifdef SCM_CREDS
5944 PyModule_AddIntConstant(m, "SCM_CREDS", SCM_CREDS);
5945#endif
5946
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005947 /* Flags for send, recv */
5948#ifdef MSG_OOB
5949 PyModule_AddIntConstant(m, "MSG_OOB", MSG_OOB);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005950#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005951#ifdef MSG_PEEK
5952 PyModule_AddIntConstant(m, "MSG_PEEK", MSG_PEEK);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005953#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005954#ifdef MSG_DONTROUTE
5955 PyModule_AddIntConstant(m, "MSG_DONTROUTE", MSG_DONTROUTE);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005956#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005957#ifdef MSG_DONTWAIT
5958 PyModule_AddIntConstant(m, "MSG_DONTWAIT", MSG_DONTWAIT);
Guido van Rossum2c8bcb82000-04-25 21:34:53 +00005959#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005960#ifdef MSG_EOR
5961 PyModule_AddIntConstant(m, "MSG_EOR", MSG_EOR);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005962#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005963#ifdef MSG_TRUNC
5964 PyModule_AddIntConstant(m, "MSG_TRUNC", MSG_TRUNC);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005965#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005966#ifdef MSG_CTRUNC
5967 PyModule_AddIntConstant(m, "MSG_CTRUNC", MSG_CTRUNC);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005968#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005969#ifdef MSG_WAITALL
5970 PyModule_AddIntConstant(m, "MSG_WAITALL", MSG_WAITALL);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005971#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005972#ifdef MSG_BTAG
5973 PyModule_AddIntConstant(m, "MSG_BTAG", MSG_BTAG);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005974#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005975#ifdef MSG_ETAG
5976 PyModule_AddIntConstant(m, "MSG_ETAG", MSG_ETAG);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00005977#endif
Nick Coghlan96fe56a2011-08-22 11:55:57 +10005978#ifdef MSG_NOSIGNAL
5979 PyModule_AddIntConstant(m, "MSG_NOSIGNAL", MSG_NOSIGNAL);
5980#endif
5981#ifdef MSG_NOTIFICATION
5982 PyModule_AddIntConstant(m, "MSG_NOTIFICATION", MSG_NOTIFICATION);
5983#endif
5984#ifdef MSG_CMSG_CLOEXEC
5985 PyModule_AddIntConstant(m, "MSG_CMSG_CLOEXEC", MSG_CMSG_CLOEXEC);
5986#endif
5987#ifdef MSG_ERRQUEUE
5988 PyModule_AddIntConstant(m, "MSG_ERRQUEUE", MSG_ERRQUEUE);
5989#endif
5990#ifdef MSG_CONFIRM
5991 PyModule_AddIntConstant(m, "MSG_CONFIRM", MSG_CONFIRM);
5992#endif
5993#ifdef MSG_MORE
5994 PyModule_AddIntConstant(m, "MSG_MORE", MSG_MORE);
5995#endif
5996#ifdef MSG_EOF
5997 PyModule_AddIntConstant(m, "MSG_EOF", MSG_EOF);
5998#endif
5999#ifdef MSG_BCAST
6000 PyModule_AddIntConstant(m, "MSG_BCAST", MSG_BCAST);
6001#endif
6002#ifdef MSG_MCAST
6003 PyModule_AddIntConstant(m, "MSG_MCAST", MSG_MCAST);
6004#endif
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006005
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006006 /* Protocol level and numbers, usable for [gs]etsockopt */
6007#ifdef SOL_SOCKET
6008 PyModule_AddIntConstant(m, "SOL_SOCKET", SOL_SOCKET);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006009#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006010#ifdef SOL_IP
6011 PyModule_AddIntConstant(m, "SOL_IP", SOL_IP);
Guido van Rossum09be4091999-08-09 14:40:40 +00006012#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006013 PyModule_AddIntConstant(m, "SOL_IP", 0);
Guido van Rossum09be4091999-08-09 14:40:40 +00006014#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006015#ifdef SOL_IPX
6016 PyModule_AddIntConstant(m, "SOL_IPX", SOL_IPX);
Guido van Rossum09be4091999-08-09 14:40:40 +00006017#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006018#ifdef SOL_AX25
6019 PyModule_AddIntConstant(m, "SOL_AX25", SOL_AX25);
Guido van Rossum09be4091999-08-09 14:40:40 +00006020#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006021#ifdef SOL_ATALK
6022 PyModule_AddIntConstant(m, "SOL_ATALK", SOL_ATALK);
Guido van Rossum09be4091999-08-09 14:40:40 +00006023#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006024#ifdef SOL_NETROM
6025 PyModule_AddIntConstant(m, "SOL_NETROM", SOL_NETROM);
Guido van Rossum09be4091999-08-09 14:40:40 +00006026#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006027#ifdef SOL_ROSE
6028 PyModule_AddIntConstant(m, "SOL_ROSE", SOL_ROSE);
Guido van Rossum09be4091999-08-09 14:40:40 +00006029#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006030#ifdef SOL_TCP
6031 PyModule_AddIntConstant(m, "SOL_TCP", SOL_TCP);
Guido van Rossum09be4091999-08-09 14:40:40 +00006032#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006033 PyModule_AddIntConstant(m, "SOL_TCP", 6);
Guido van Rossum09be4091999-08-09 14:40:40 +00006034#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006035#ifdef SOL_UDP
6036 PyModule_AddIntConstant(m, "SOL_UDP", SOL_UDP);
Guido van Rossum09be4091999-08-09 14:40:40 +00006037#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006038 PyModule_AddIntConstant(m, "SOL_UDP", 17);
Guido van Rossum09be4091999-08-09 14:40:40 +00006039#endif
Charles-François Natali47413c12011-10-06 19:47:44 +02006040#ifdef SOL_CAN_BASE
6041 PyModule_AddIntConstant(m, "SOL_CAN_BASE", SOL_CAN_BASE);
6042#endif
6043#ifdef SOL_CAN_RAW
6044 PyModule_AddIntConstant(m, "SOL_CAN_RAW", SOL_CAN_RAW);
6045 PyModule_AddIntConstant(m, "CAN_RAW", CAN_RAW);
6046#endif
6047#ifdef HAVE_LINUX_CAN_H
6048 PyModule_AddIntConstant(m, "CAN_EFF_FLAG", CAN_EFF_FLAG);
6049 PyModule_AddIntConstant(m, "CAN_RTR_FLAG", CAN_RTR_FLAG);
6050 PyModule_AddIntConstant(m, "CAN_ERR_FLAG", CAN_ERR_FLAG);
6051
6052 PyModule_AddIntConstant(m, "CAN_SFF_MASK", CAN_SFF_MASK);
6053 PyModule_AddIntConstant(m, "CAN_EFF_MASK", CAN_EFF_MASK);
6054 PyModule_AddIntConstant(m, "CAN_ERR_MASK", CAN_ERR_MASK);
6055#endif
6056#ifdef HAVE_LINUX_CAN_RAW_H
6057 PyModule_AddIntConstant(m, "CAN_RAW_FILTER", CAN_RAW_FILTER);
6058 PyModule_AddIntConstant(m, "CAN_RAW_ERR_FILTER", CAN_RAW_ERR_FILTER);
6059 PyModule_AddIntConstant(m, "CAN_RAW_LOOPBACK", CAN_RAW_LOOPBACK);
6060 PyModule_AddIntConstant(m, "CAN_RAW_RECV_OWN_MSGS", CAN_RAW_RECV_OWN_MSGS);
6061#endif
Charles-François Natali10b8cf42011-11-10 19:21:37 +01006062#ifdef SOL_RDS
6063 PyModule_AddIntConstant(m, "SOL_RDS", SOL_RDS);
6064#endif
6065#ifdef RDS_CANCEL_SENT_TO
6066 PyModule_AddIntConstant(m, "RDS_CANCEL_SENT_TO", RDS_CANCEL_SENT_TO);
6067#endif
6068#ifdef RDS_GET_MR
6069 PyModule_AddIntConstant(m, "RDS_GET_MR", RDS_GET_MR);
6070#endif
6071#ifdef RDS_FREE_MR
6072 PyModule_AddIntConstant(m, "RDS_FREE_MR", RDS_FREE_MR);
6073#endif
6074#ifdef RDS_RECVERR
6075 PyModule_AddIntConstant(m, "RDS_RECVERR", RDS_RECVERR);
6076#endif
6077#ifdef RDS_CONG_MONITOR
6078 PyModule_AddIntConstant(m, "RDS_CONG_MONITOR", RDS_CONG_MONITOR);
6079#endif
6080#ifdef RDS_GET_MR_FOR_DEST
6081 PyModule_AddIntConstant(m, "RDS_GET_MR_FOR_DEST", RDS_GET_MR_FOR_DEST);
6082#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006083#ifdef IPPROTO_IP
6084 PyModule_AddIntConstant(m, "IPPROTO_IP", IPPROTO_IP);
Guido van Rossum578de301998-05-28 20:18:18 +00006085#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006086 PyModule_AddIntConstant(m, "IPPROTO_IP", 0);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006087#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006088#ifdef IPPROTO_HOPOPTS
6089 PyModule_AddIntConstant(m, "IPPROTO_HOPOPTS", IPPROTO_HOPOPTS);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006090#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006091#ifdef IPPROTO_ICMP
6092 PyModule_AddIntConstant(m, "IPPROTO_ICMP", IPPROTO_ICMP);
Guido van Rossum578de301998-05-28 20:18:18 +00006093#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006094 PyModule_AddIntConstant(m, "IPPROTO_ICMP", 1);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006095#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006096#ifdef IPPROTO_IGMP
6097 PyModule_AddIntConstant(m, "IPPROTO_IGMP", IPPROTO_IGMP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006098#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006099#ifdef IPPROTO_GGP
6100 PyModule_AddIntConstant(m, "IPPROTO_GGP", IPPROTO_GGP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006101#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006102#ifdef IPPROTO_IPV4
6103 PyModule_AddIntConstant(m, "IPPROTO_IPV4", IPPROTO_IPV4);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006104#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006105#ifdef IPPROTO_IPV6
6106 PyModule_AddIntConstant(m, "IPPROTO_IPV6", IPPROTO_IPV6);
Martin v. Löwisa0f17342003-10-03 13:56:20 +00006107#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006108#ifdef IPPROTO_IPIP
6109 PyModule_AddIntConstant(m, "IPPROTO_IPIP", IPPROTO_IPIP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006110#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006111#ifdef IPPROTO_TCP
6112 PyModule_AddIntConstant(m, "IPPROTO_TCP", IPPROTO_TCP);
Guido van Rossum578de301998-05-28 20:18:18 +00006113#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006114 PyModule_AddIntConstant(m, "IPPROTO_TCP", 6);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006115#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006116#ifdef IPPROTO_EGP
6117 PyModule_AddIntConstant(m, "IPPROTO_EGP", IPPROTO_EGP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006118#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006119#ifdef IPPROTO_PUP
6120 PyModule_AddIntConstant(m, "IPPROTO_PUP", IPPROTO_PUP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006121#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006122#ifdef IPPROTO_UDP
6123 PyModule_AddIntConstant(m, "IPPROTO_UDP", IPPROTO_UDP);
Guido van Rossum578de301998-05-28 20:18:18 +00006124#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006125 PyModule_AddIntConstant(m, "IPPROTO_UDP", 17);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006126#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006127#ifdef IPPROTO_IDP
6128 PyModule_AddIntConstant(m, "IPPROTO_IDP", IPPROTO_IDP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006129#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006130#ifdef IPPROTO_HELLO
6131 PyModule_AddIntConstant(m, "IPPROTO_HELLO", IPPROTO_HELLO);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006132#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006133#ifdef IPPROTO_ND
6134 PyModule_AddIntConstant(m, "IPPROTO_ND", IPPROTO_ND);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006135#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006136#ifdef IPPROTO_TP
6137 PyModule_AddIntConstant(m, "IPPROTO_TP", IPPROTO_TP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006138#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006139#ifdef IPPROTO_IPV6
6140 PyModule_AddIntConstant(m, "IPPROTO_IPV6", IPPROTO_IPV6);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006141#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006142#ifdef IPPROTO_ROUTING
6143 PyModule_AddIntConstant(m, "IPPROTO_ROUTING", IPPROTO_ROUTING);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006144#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006145#ifdef IPPROTO_FRAGMENT
6146 PyModule_AddIntConstant(m, "IPPROTO_FRAGMENT", IPPROTO_FRAGMENT);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006147#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006148#ifdef IPPROTO_RSVP
6149 PyModule_AddIntConstant(m, "IPPROTO_RSVP", IPPROTO_RSVP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006150#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006151#ifdef IPPROTO_GRE
6152 PyModule_AddIntConstant(m, "IPPROTO_GRE", IPPROTO_GRE);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006153#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006154#ifdef IPPROTO_ESP
6155 PyModule_AddIntConstant(m, "IPPROTO_ESP", IPPROTO_ESP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006156#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006157#ifdef IPPROTO_AH
6158 PyModule_AddIntConstant(m, "IPPROTO_AH", IPPROTO_AH);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006159#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006160#ifdef IPPROTO_MOBILE
6161 PyModule_AddIntConstant(m, "IPPROTO_MOBILE", IPPROTO_MOBILE);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006162#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006163#ifdef IPPROTO_ICMPV6
6164 PyModule_AddIntConstant(m, "IPPROTO_ICMPV6", IPPROTO_ICMPV6);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006165#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006166#ifdef IPPROTO_NONE
6167 PyModule_AddIntConstant(m, "IPPROTO_NONE", IPPROTO_NONE);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006168#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006169#ifdef IPPROTO_DSTOPTS
6170 PyModule_AddIntConstant(m, "IPPROTO_DSTOPTS", IPPROTO_DSTOPTS);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006171#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006172#ifdef IPPROTO_XTP
6173 PyModule_AddIntConstant(m, "IPPROTO_XTP", IPPROTO_XTP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006174#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006175#ifdef IPPROTO_EON
6176 PyModule_AddIntConstant(m, "IPPROTO_EON", IPPROTO_EON);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006177#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006178#ifdef IPPROTO_PIM
6179 PyModule_AddIntConstant(m, "IPPROTO_PIM", IPPROTO_PIM);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006180#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006181#ifdef IPPROTO_IPCOMP
6182 PyModule_AddIntConstant(m, "IPPROTO_IPCOMP", IPPROTO_IPCOMP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006183#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006184#ifdef IPPROTO_VRRP
6185 PyModule_AddIntConstant(m, "IPPROTO_VRRP", IPPROTO_VRRP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006186#endif
Nick Coghlan96fe56a2011-08-22 11:55:57 +10006187#ifdef IPPROTO_SCTP
6188 PyModule_AddIntConstant(m, "IPPROTO_SCTP", IPPROTO_SCTP);
6189#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006190#ifdef IPPROTO_BIP
6191 PyModule_AddIntConstant(m, "IPPROTO_BIP", IPPROTO_BIP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006192#endif
6193/**/
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006194#ifdef IPPROTO_RAW
6195 PyModule_AddIntConstant(m, "IPPROTO_RAW", IPPROTO_RAW);
Guido van Rossum578de301998-05-28 20:18:18 +00006196#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006197 PyModule_AddIntConstant(m, "IPPROTO_RAW", 255);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006198#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006199#ifdef IPPROTO_MAX
6200 PyModule_AddIntConstant(m, "IPPROTO_MAX", IPPROTO_MAX);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006201#endif
6202
Martin v. Löwis9d6c6692012-02-03 17:44:58 +01006203#ifdef SYSPROTO_CONTROL
6204 PyModule_AddIntConstant(m, "SYSPROTO_CONTROL", SYSPROTO_CONTROL);
6205#endif
6206
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006207 /* Some port configuration */
6208#ifdef IPPORT_RESERVED
6209 PyModule_AddIntConstant(m, "IPPORT_RESERVED", IPPORT_RESERVED);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006210#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006211 PyModule_AddIntConstant(m, "IPPORT_RESERVED", 1024);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006212#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006213#ifdef IPPORT_USERRESERVED
6214 PyModule_AddIntConstant(m, "IPPORT_USERRESERVED", IPPORT_USERRESERVED);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006215#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006216 PyModule_AddIntConstant(m, "IPPORT_USERRESERVED", 5000);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006217#endif
6218
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006219 /* Some reserved IP v.4 addresses */
6220#ifdef INADDR_ANY
6221 PyModule_AddIntConstant(m, "INADDR_ANY", INADDR_ANY);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006222#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006223 PyModule_AddIntConstant(m, "INADDR_ANY", 0x00000000);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006224#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006225#ifdef INADDR_BROADCAST
6226 PyModule_AddIntConstant(m, "INADDR_BROADCAST", INADDR_BROADCAST);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006227#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006228 PyModule_AddIntConstant(m, "INADDR_BROADCAST", 0xffffffff);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006229#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006230#ifdef INADDR_LOOPBACK
6231 PyModule_AddIntConstant(m, "INADDR_LOOPBACK", INADDR_LOOPBACK);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006232#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006233 PyModule_AddIntConstant(m, "INADDR_LOOPBACK", 0x7F000001);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006234#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006235#ifdef INADDR_UNSPEC_GROUP
6236 PyModule_AddIntConstant(m, "INADDR_UNSPEC_GROUP", INADDR_UNSPEC_GROUP);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006237#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006238 PyModule_AddIntConstant(m, "INADDR_UNSPEC_GROUP", 0xe0000000);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006239#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006240#ifdef INADDR_ALLHOSTS_GROUP
6241 PyModule_AddIntConstant(m, "INADDR_ALLHOSTS_GROUP",
6242 INADDR_ALLHOSTS_GROUP);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006243#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006244 PyModule_AddIntConstant(m, "INADDR_ALLHOSTS_GROUP", 0xe0000001);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006245#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006246#ifdef INADDR_MAX_LOCAL_GROUP
6247 PyModule_AddIntConstant(m, "INADDR_MAX_LOCAL_GROUP",
6248 INADDR_MAX_LOCAL_GROUP);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006249#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006250 PyModule_AddIntConstant(m, "INADDR_MAX_LOCAL_GROUP", 0xe00000ff);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006251#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006252#ifdef INADDR_NONE
6253 PyModule_AddIntConstant(m, "INADDR_NONE", INADDR_NONE);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006254#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006255 PyModule_AddIntConstant(m, "INADDR_NONE", 0xffffffff);
Guido van Rossum5f05eb41995-02-17 15:11:07 +00006256#endif
6257
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006258 /* IPv4 [gs]etsockopt options */
6259#ifdef IP_OPTIONS
6260 PyModule_AddIntConstant(m, "IP_OPTIONS", IP_OPTIONS);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006261#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006262#ifdef IP_HDRINCL
6263 PyModule_AddIntConstant(m, "IP_HDRINCL", IP_HDRINCL);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006264#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006265#ifdef IP_TOS
6266 PyModule_AddIntConstant(m, "IP_TOS", IP_TOS);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006267#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006268#ifdef IP_TTL
6269 PyModule_AddIntConstant(m, "IP_TTL", IP_TTL);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006270#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006271#ifdef IP_RECVOPTS
6272 PyModule_AddIntConstant(m, "IP_RECVOPTS", IP_RECVOPTS);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006273#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006274#ifdef IP_RECVRETOPTS
6275 PyModule_AddIntConstant(m, "IP_RECVRETOPTS", IP_RECVRETOPTS);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006276#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006277#ifdef IP_RECVDSTADDR
6278 PyModule_AddIntConstant(m, "IP_RECVDSTADDR", IP_RECVDSTADDR);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006279#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006280#ifdef IP_RETOPTS
6281 PyModule_AddIntConstant(m, "IP_RETOPTS", IP_RETOPTS);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006282#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006283#ifdef IP_MULTICAST_IF
6284 PyModule_AddIntConstant(m, "IP_MULTICAST_IF", IP_MULTICAST_IF);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006285#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006286#ifdef IP_MULTICAST_TTL
6287 PyModule_AddIntConstant(m, "IP_MULTICAST_TTL", IP_MULTICAST_TTL);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006288#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006289#ifdef IP_MULTICAST_LOOP
6290 PyModule_AddIntConstant(m, "IP_MULTICAST_LOOP", IP_MULTICAST_LOOP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006291#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006292#ifdef IP_ADD_MEMBERSHIP
6293 PyModule_AddIntConstant(m, "IP_ADD_MEMBERSHIP", IP_ADD_MEMBERSHIP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006294#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006295#ifdef IP_DROP_MEMBERSHIP
6296 PyModule_AddIntConstant(m, "IP_DROP_MEMBERSHIP", IP_DROP_MEMBERSHIP);
Guido van Rossum3fdf58b1995-02-07 15:39:52 +00006297#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006298#ifdef IP_DEFAULT_MULTICAST_TTL
6299 PyModule_AddIntConstant(m, "IP_DEFAULT_MULTICAST_TTL",
6300 IP_DEFAULT_MULTICAST_TTL);
Guido van Rossum09be4091999-08-09 14:40:40 +00006301#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006302#ifdef IP_DEFAULT_MULTICAST_LOOP
6303 PyModule_AddIntConstant(m, "IP_DEFAULT_MULTICAST_LOOP",
6304 IP_DEFAULT_MULTICAST_LOOP);
Guido van Rossum09be4091999-08-09 14:40:40 +00006305#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006306#ifdef IP_MAX_MEMBERSHIPS
6307 PyModule_AddIntConstant(m, "IP_MAX_MEMBERSHIPS", IP_MAX_MEMBERSHIPS);
Guido van Rossum09be4091999-08-09 14:40:40 +00006308#endif
Charles-François Natali564a42c2011-12-17 14:59:56 +01006309#ifdef IP_TRANSPARENT
6310 PyModule_AddIntConstant(m, "IP_TRANSPARENT", IP_TRANSPARENT);
6311#endif
Guido van Rossum09be4091999-08-09 14:40:40 +00006312
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006313 /* IPv6 [gs]etsockopt options, defined in RFC2553 */
6314#ifdef IPV6_JOIN_GROUP
6315 PyModule_AddIntConstant(m, "IPV6_JOIN_GROUP", IPV6_JOIN_GROUP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006316#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006317#ifdef IPV6_LEAVE_GROUP
6318 PyModule_AddIntConstant(m, "IPV6_LEAVE_GROUP", IPV6_LEAVE_GROUP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006319#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006320#ifdef IPV6_MULTICAST_HOPS
6321 PyModule_AddIntConstant(m, "IPV6_MULTICAST_HOPS", IPV6_MULTICAST_HOPS);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006322#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006323#ifdef IPV6_MULTICAST_IF
6324 PyModule_AddIntConstant(m, "IPV6_MULTICAST_IF", IPV6_MULTICAST_IF);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006325#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006326#ifdef IPV6_MULTICAST_LOOP
6327 PyModule_AddIntConstant(m, "IPV6_MULTICAST_LOOP", IPV6_MULTICAST_LOOP);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006328#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006329#ifdef IPV6_UNICAST_HOPS
6330 PyModule_AddIntConstant(m, "IPV6_UNICAST_HOPS", IPV6_UNICAST_HOPS);
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006331#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006332 /* Additional IPV6 socket options, defined in RFC 3493 */
Martin v. Löwisda91d022003-12-30 11:14:01 +00006333#ifdef IPV6_V6ONLY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006334 PyModule_AddIntConstant(m, "IPV6_V6ONLY", IPV6_V6ONLY);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006335#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006336 /* Advanced IPV6 socket options, from RFC 3542 */
Martin v. Löwisda91d022003-12-30 11:14:01 +00006337#ifdef IPV6_CHECKSUM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006338 PyModule_AddIntConstant(m, "IPV6_CHECKSUM", IPV6_CHECKSUM);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006339#endif
6340#ifdef IPV6_DONTFRAG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006341 PyModule_AddIntConstant(m, "IPV6_DONTFRAG", IPV6_DONTFRAG);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006342#endif
6343#ifdef IPV6_DSTOPTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006344 PyModule_AddIntConstant(m, "IPV6_DSTOPTS", IPV6_DSTOPTS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006345#endif
6346#ifdef IPV6_HOPLIMIT
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006347 PyModule_AddIntConstant(m, "IPV6_HOPLIMIT", IPV6_HOPLIMIT);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006348#endif
6349#ifdef IPV6_HOPOPTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006350 PyModule_AddIntConstant(m, "IPV6_HOPOPTS", IPV6_HOPOPTS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006351#endif
6352#ifdef IPV6_NEXTHOP
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006353 PyModule_AddIntConstant(m, "IPV6_NEXTHOP", IPV6_NEXTHOP);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006354#endif
6355#ifdef IPV6_PATHMTU
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006356 PyModule_AddIntConstant(m, "IPV6_PATHMTU", IPV6_PATHMTU);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006357#endif
6358#ifdef IPV6_PKTINFO
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006359 PyModule_AddIntConstant(m, "IPV6_PKTINFO", IPV6_PKTINFO);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006360#endif
6361#ifdef IPV6_RECVDSTOPTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006362 PyModule_AddIntConstant(m, "IPV6_RECVDSTOPTS", IPV6_RECVDSTOPTS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006363#endif
6364#ifdef IPV6_RECVHOPLIMIT
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006365 PyModule_AddIntConstant(m, "IPV6_RECVHOPLIMIT", IPV6_RECVHOPLIMIT);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006366#endif
6367#ifdef IPV6_RECVHOPOPTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006368 PyModule_AddIntConstant(m, "IPV6_RECVHOPOPTS", IPV6_RECVHOPOPTS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006369#endif
6370#ifdef IPV6_RECVPKTINFO
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006371 PyModule_AddIntConstant(m, "IPV6_RECVPKTINFO", IPV6_RECVPKTINFO);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006372#endif
6373#ifdef IPV6_RECVRTHDR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006374 PyModule_AddIntConstant(m, "IPV6_RECVRTHDR", IPV6_RECVRTHDR);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006375#endif
6376#ifdef IPV6_RECVTCLASS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006377 PyModule_AddIntConstant(m, "IPV6_RECVTCLASS", IPV6_RECVTCLASS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006378#endif
6379#ifdef IPV6_RTHDR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006380 PyModule_AddIntConstant(m, "IPV6_RTHDR", IPV6_RTHDR);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006381#endif
6382#ifdef IPV6_RTHDRDSTOPTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006383 PyModule_AddIntConstant(m, "IPV6_RTHDRDSTOPTS", IPV6_RTHDRDSTOPTS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006384#endif
6385#ifdef IPV6_RTHDR_TYPE_0
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006386 PyModule_AddIntConstant(m, "IPV6_RTHDR_TYPE_0", IPV6_RTHDR_TYPE_0);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006387#endif
6388#ifdef IPV6_RECVPATHMTU
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006389 PyModule_AddIntConstant(m, "IPV6_RECVPATHMTU", IPV6_RECVPATHMTU);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006390#endif
6391#ifdef IPV6_TCLASS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006392 PyModule_AddIntConstant(m, "IPV6_TCLASS", IPV6_TCLASS);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006393#endif
6394#ifdef IPV6_USE_MIN_MTU
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006395 PyModule_AddIntConstant(m, "IPV6_USE_MIN_MTU", IPV6_USE_MIN_MTU);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006396#endif
Martin v. Löwisbcf4b352001-08-04 22:37:23 +00006397
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006398 /* TCP options */
6399#ifdef TCP_NODELAY
6400 PyModule_AddIntConstant(m, "TCP_NODELAY", TCP_NODELAY);
Guido van Rossum09be4091999-08-09 14:40:40 +00006401#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006402#ifdef TCP_MAXSEG
6403 PyModule_AddIntConstant(m, "TCP_MAXSEG", TCP_MAXSEG);
Guido van Rossum09be4091999-08-09 14:40:40 +00006404#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006405#ifdef TCP_CORK
6406 PyModule_AddIntConstant(m, "TCP_CORK", TCP_CORK);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006407#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006408#ifdef TCP_KEEPIDLE
6409 PyModule_AddIntConstant(m, "TCP_KEEPIDLE", TCP_KEEPIDLE);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006410#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006411#ifdef TCP_KEEPINTVL
6412 PyModule_AddIntConstant(m, "TCP_KEEPINTVL", TCP_KEEPINTVL);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006413#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006414#ifdef TCP_KEEPCNT
6415 PyModule_AddIntConstant(m, "TCP_KEEPCNT", TCP_KEEPCNT);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006416#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006417#ifdef TCP_SYNCNT
6418 PyModule_AddIntConstant(m, "TCP_SYNCNT", TCP_SYNCNT);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006419#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006420#ifdef TCP_LINGER2
6421 PyModule_AddIntConstant(m, "TCP_LINGER2", TCP_LINGER2);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006422#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006423#ifdef TCP_DEFER_ACCEPT
6424 PyModule_AddIntConstant(m, "TCP_DEFER_ACCEPT", TCP_DEFER_ACCEPT);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006425#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006426#ifdef TCP_WINDOW_CLAMP
6427 PyModule_AddIntConstant(m, "TCP_WINDOW_CLAMP", TCP_WINDOW_CLAMP);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006428#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006429#ifdef TCP_INFO
6430 PyModule_AddIntConstant(m, "TCP_INFO", TCP_INFO);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006431#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006432#ifdef TCP_QUICKACK
6433 PyModule_AddIntConstant(m, "TCP_QUICKACK", TCP_QUICKACK);
Martin v. Löwis3cde2cb2001-12-22 15:05:32 +00006434#endif
6435
Guido van Rossum09be4091999-08-09 14:40:40 +00006436
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006437 /* IPX options */
6438#ifdef IPX_TYPE
6439 PyModule_AddIntConstant(m, "IPX_TYPE", IPX_TYPE);
Guido van Rossum09be4091999-08-09 14:40:40 +00006440#endif
Guido van Rossum4f199ea1998-04-09 20:56:35 +00006441
Charles-François Natali10b8cf42011-11-10 19:21:37 +01006442/* Reliable Datagram Sockets */
6443#ifdef RDS_CMSG_RDMA_ARGS
6444 PyModule_AddIntConstant(m, "RDS_CMSG_RDMA_ARGS", RDS_CMSG_RDMA_ARGS);
6445#endif
6446#ifdef RDS_CMSG_RDMA_DEST
6447 PyModule_AddIntConstant(m, "RDS_CMSG_RDMA_DEST", RDS_CMSG_RDMA_DEST);
6448#endif
6449#ifdef RDS_CMSG_RDMA_MAP
6450 PyModule_AddIntConstant(m, "RDS_CMSG_RDMA_MAP", RDS_CMSG_RDMA_MAP);
6451#endif
6452#ifdef RDS_CMSG_RDMA_STATUS
6453 PyModule_AddIntConstant(m, "RDS_CMSG_RDMA_STATUS", RDS_CMSG_RDMA_STATUS);
6454#endif
6455#ifdef RDS_CMSG_RDMA_UPDATE
6456 PyModule_AddIntConstant(m, "RDS_CMSG_RDMA_UPDATE", RDS_CMSG_RDMA_UPDATE);
6457#endif
6458#ifdef RDS_RDMA_READWRITE
6459 PyModule_AddIntConstant(m, "RDS_RDMA_READWRITE", RDS_RDMA_READWRITE);
6460#endif
6461#ifdef RDS_RDMA_FENCE
6462 PyModule_AddIntConstant(m, "RDS_RDMA_FENCE", RDS_RDMA_FENCE);
6463#endif
6464#ifdef RDS_RDMA_INVALIDATE
6465 PyModule_AddIntConstant(m, "RDS_RDMA_INVALIDATE", RDS_RDMA_INVALIDATE);
6466#endif
6467#ifdef RDS_RDMA_USE_ONCE
6468 PyModule_AddIntConstant(m, "RDS_RDMA_USE_ONCE", RDS_RDMA_USE_ONCE);
6469#endif
6470#ifdef RDS_RDMA_DONTWAIT
6471 PyModule_AddIntConstant(m, "RDS_RDMA_DONTWAIT", RDS_RDMA_DONTWAIT);
6472#endif
6473#ifdef RDS_RDMA_NOTIFY_ME
6474 PyModule_AddIntConstant(m, "RDS_RDMA_NOTIFY_ME", RDS_RDMA_NOTIFY_ME);
6475#endif
6476#ifdef RDS_RDMA_SILENT
6477 PyModule_AddIntConstant(m, "RDS_RDMA_SILENT", RDS_RDMA_SILENT);
6478#endif
6479
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006480 /* get{addr,name}info parameters */
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006481#ifdef EAI_ADDRFAMILY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006482 PyModule_AddIntConstant(m, "EAI_ADDRFAMILY", EAI_ADDRFAMILY);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006483#endif
6484#ifdef EAI_AGAIN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006485 PyModule_AddIntConstant(m, "EAI_AGAIN", EAI_AGAIN);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006486#endif
6487#ifdef EAI_BADFLAGS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006488 PyModule_AddIntConstant(m, "EAI_BADFLAGS", EAI_BADFLAGS);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006489#endif
6490#ifdef EAI_FAIL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006491 PyModule_AddIntConstant(m, "EAI_FAIL", EAI_FAIL);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006492#endif
6493#ifdef EAI_FAMILY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006494 PyModule_AddIntConstant(m, "EAI_FAMILY", EAI_FAMILY);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006495#endif
6496#ifdef EAI_MEMORY
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006497 PyModule_AddIntConstant(m, "EAI_MEMORY", EAI_MEMORY);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006498#endif
6499#ifdef EAI_NODATA
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006500 PyModule_AddIntConstant(m, "EAI_NODATA", EAI_NODATA);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006501#endif
6502#ifdef EAI_NONAME
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006503 PyModule_AddIntConstant(m, "EAI_NONAME", EAI_NONAME);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006504#endif
Martin v. Löwisda91d022003-12-30 11:14:01 +00006505#ifdef EAI_OVERFLOW
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006506 PyModule_AddIntConstant(m, "EAI_OVERFLOW", EAI_OVERFLOW);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006507#endif
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006508#ifdef EAI_SERVICE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006509 PyModule_AddIntConstant(m, "EAI_SERVICE", EAI_SERVICE);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006510#endif
6511#ifdef EAI_SOCKTYPE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006512 PyModule_AddIntConstant(m, "EAI_SOCKTYPE", EAI_SOCKTYPE);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006513#endif
6514#ifdef EAI_SYSTEM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006515 PyModule_AddIntConstant(m, "EAI_SYSTEM", EAI_SYSTEM);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006516#endif
6517#ifdef EAI_BADHINTS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006518 PyModule_AddIntConstant(m, "EAI_BADHINTS", EAI_BADHINTS);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006519#endif
6520#ifdef EAI_PROTOCOL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006521 PyModule_AddIntConstant(m, "EAI_PROTOCOL", EAI_PROTOCOL);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006522#endif
6523#ifdef EAI_MAX
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006524 PyModule_AddIntConstant(m, "EAI_MAX", EAI_MAX);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006525#endif
6526#ifdef AI_PASSIVE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006527 PyModule_AddIntConstant(m, "AI_PASSIVE", AI_PASSIVE);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006528#endif
6529#ifdef AI_CANONNAME
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006530 PyModule_AddIntConstant(m, "AI_CANONNAME", AI_CANONNAME);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006531#endif
6532#ifdef AI_NUMERICHOST
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006533 PyModule_AddIntConstant(m, "AI_NUMERICHOST", AI_NUMERICHOST);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006534#endif
Martin v. Löwisda91d022003-12-30 11:14:01 +00006535#ifdef AI_NUMERICSERV
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006536 PyModule_AddIntConstant(m, "AI_NUMERICSERV", AI_NUMERICSERV);
Martin v. Löwisda91d022003-12-30 11:14:01 +00006537#endif
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006538#ifdef AI_MASK
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006539 PyModule_AddIntConstant(m, "AI_MASK", AI_MASK);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006540#endif
6541#ifdef AI_ALL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006542 PyModule_AddIntConstant(m, "AI_ALL", AI_ALL);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006543#endif
6544#ifdef AI_V4MAPPED_CFG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006545 PyModule_AddIntConstant(m, "AI_V4MAPPED_CFG", AI_V4MAPPED_CFG);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006546#endif
6547#ifdef AI_ADDRCONFIG
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006548 PyModule_AddIntConstant(m, "AI_ADDRCONFIG", AI_ADDRCONFIG);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006549#endif
6550#ifdef AI_V4MAPPED
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006551 PyModule_AddIntConstant(m, "AI_V4MAPPED", AI_V4MAPPED);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006552#endif
6553#ifdef AI_DEFAULT
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006554 PyModule_AddIntConstant(m, "AI_DEFAULT", AI_DEFAULT);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006555#endif
6556#ifdef NI_MAXHOST
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006557 PyModule_AddIntConstant(m, "NI_MAXHOST", NI_MAXHOST);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006558#endif
6559#ifdef NI_MAXSERV
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006560 PyModule_AddIntConstant(m, "NI_MAXSERV", NI_MAXSERV);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006561#endif
6562#ifdef NI_NOFQDN
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006563 PyModule_AddIntConstant(m, "NI_NOFQDN", NI_NOFQDN);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006564#endif
6565#ifdef NI_NUMERICHOST
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006566 PyModule_AddIntConstant(m, "NI_NUMERICHOST", NI_NUMERICHOST);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006567#endif
6568#ifdef NI_NAMEREQD
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006569 PyModule_AddIntConstant(m, "NI_NAMEREQD", NI_NAMEREQD);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006570#endif
6571#ifdef NI_NUMERICSERV
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006572 PyModule_AddIntConstant(m, "NI_NUMERICSERV", NI_NUMERICSERV);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006573#endif
6574#ifdef NI_DGRAM
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006575 PyModule_AddIntConstant(m, "NI_DGRAM", NI_DGRAM);
Martin v. Löwis2d8d4272001-07-21 18:05:31 +00006576#endif
6577
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006578 /* shutdown() parameters */
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006579#ifdef SHUT_RD
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006580 PyModule_AddIntConstant(m, "SHUT_RD", SHUT_RD);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006581#elif defined(SD_RECEIVE)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006582 PyModule_AddIntConstant(m, "SHUT_RD", SD_RECEIVE);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006583#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006584 PyModule_AddIntConstant(m, "SHUT_RD", 0);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006585#endif
6586#ifdef SHUT_WR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006587 PyModule_AddIntConstant(m, "SHUT_WR", SHUT_WR);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006588#elif defined(SD_SEND)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006589 PyModule_AddIntConstant(m, "SHUT_WR", SD_SEND);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006590#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006591 PyModule_AddIntConstant(m, "SHUT_WR", 1);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006592#endif
6593#ifdef SHUT_RDWR
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006594 PyModule_AddIntConstant(m, "SHUT_RDWR", SHUT_RDWR);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006595#elif defined(SD_BOTH)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006596 PyModule_AddIntConstant(m, "SHUT_RDWR", SD_BOTH);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006597#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006598 PyModule_AddIntConstant(m, "SHUT_RDWR", 2);
Martin v. Löwis94681fc2003-11-27 19:40:22 +00006599#endif
6600
Christian Heimesfaf2f632008-01-06 16:59:19 +00006601#ifdef SIO_RCVALL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006602 {
6603 DWORD codes[] = {SIO_RCVALL, SIO_KEEPALIVE_VALS};
6604 const char *names[] = {"SIO_RCVALL", "SIO_KEEPALIVE_VALS"};
6605 int i;
Victor Stinner63941882011-09-29 00:42:28 +02006606 for(i = 0; i<Py_ARRAY_LENGTH(codes); ++i) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006607 PyObject *tmp;
6608 tmp = PyLong_FromUnsignedLong(codes[i]);
6609 if (tmp == NULL)
6610 return NULL;
6611 PyModule_AddObject(m, names[i], tmp);
6612 }
6613 }
6614 PyModule_AddIntConstant(m, "RCVALL_OFF", RCVALL_OFF);
6615 PyModule_AddIntConstant(m, "RCVALL_ON", RCVALL_ON);
6616 PyModule_AddIntConstant(m, "RCVALL_SOCKETLEVELONLY", RCVALL_SOCKETLEVELONLY);
Amaury Forgeot d'Arc762681b2008-06-12 23:03:41 +00006617#ifdef RCVALL_IPLEVEL
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006618 PyModule_AddIntConstant(m, "RCVALL_IPLEVEL", RCVALL_IPLEVEL);
Amaury Forgeot d'Arc762681b2008-06-12 23:03:41 +00006619#endif
6620#ifdef RCVALL_MAX
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006621 PyModule_AddIntConstant(m, "RCVALL_MAX", RCVALL_MAX);
Amaury Forgeot d'Arc762681b2008-06-12 23:03:41 +00006622#endif
Christian Heimesfaf2f632008-01-06 16:59:19 +00006623#endif /* _MSTCPIP_ */
6624
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006625 /* Initialize gethostbyname lock */
Just van Rossum1040d2c2003-05-09 07:53:18 +00006626#if defined(USE_GETHOSTBYNAME_LOCK) || defined(USE_GETADDRINFO_LOCK)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006627 netdb_lock = PyThread_allocate_lock();
Guido van Rossum4f199ea1998-04-09 20:56:35 +00006628#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006629 return m;
Guido van Rossum6574b3e1991-06-25 21:36:08 +00006630}
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006631
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00006632
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006633#ifndef HAVE_INET_PTON
Christian Heimes96e7b3d2007-11-20 06:51:17 +00006634#if !defined(NTDDI_VERSION) || (NTDDI_VERSION < NTDDI_LONGHORN)
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00006635
6636/* Simplistic emulation code for inet_pton that only works for IPv4 */
Guido van Rossum47dfa4a2003-04-25 05:48:32 +00006637/* These are not exposed because they do not set errno properly */
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00006638
Guido van Rossum3eede5a2002-06-07 02:08:35 +00006639int
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00006640inet_pton(int af, const char *src, void *dst)
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006641{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006642 if (af == AF_INET) {
Benjamin Petersonf91df042009-02-13 02:50:59 +00006643#if (SIZEOF_INT != 4)
6644#error "Not sure if in_addr_t exists and int is not 32-bits."
6645#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006646 unsigned int packed_addr;
6647 packed_addr = inet_addr(src);
6648 if (packed_addr == INADDR_NONE)
6649 return 0;
6650 memcpy(dst, &packed_addr, 4);
6651 return 1;
6652 }
6653 /* Should set errno to EAFNOSUPPORT */
6654 return -1;
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006655}
6656
Martin v. Löwisc925b1532001-07-21 09:42:15 +00006657const char *
6658inet_ntop(int af, const void *src, char *dst, socklen_t size)
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006659{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00006660 if (af == AF_INET) {
6661 struct in_addr packed_addr;
6662 if (size < 16)
6663 /* Should set errno to ENOSPC. */
6664 return NULL;
6665 memcpy(&packed_addr, src, sizeof(packed_addr));
6666 return strncpy(dst, inet_ntoa(packed_addr), size);
6667 }
6668 /* Should set errno to EAFNOSUPPORT */
6669 return NULL;
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006670}
Guido van Rossumc4fcfa32002-06-07 03:19:37 +00006671
Martin v. Löwisb9ab1592001-06-24 21:18:26 +00006672#endif
Christian Heimesb6150692007-11-15 23:37:07 +00006673#endif