diff options
author | Andrew M. Kuchling <amk@amk.ca> | 2004-07-10 23:39:35 (GMT) |
---|---|---|
committer | Andrew M. Kuchling <amk@amk.ca> | 2004-07-10 23:39:35 (GMT) |
commit | b8e1717041e21d2cc4a5d18fe2e948dc475f0d6e (patch) | |
tree | 74833341a10d4ae641d8ee1470b4cb8b8c3e0803 /Modules/socketmodule.c | |
parent | e6f8a89d1a7f530d68a69b9867535d4fd7707846 (diff) | |
download | cpython-b8e1717041e21d2cc4a5d18fe2e948dc475f0d6e.zip cpython-b8e1717041e21d2cc4a5d18fe2e948dc475f0d6e.tar.gz cpython-b8e1717041e21d2cc4a5d18fe2e948dc475f0d6e.tar.bz2 |
[Patch #947352 from Jason Andryuk] Add support for AF_PACKET hardware addresses
Diffstat (limited to 'Modules/socketmodule.c')
-rw-r--r-- | Modules/socketmodule.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/Modules/socketmodule.c b/Modules/socketmodule.c index 1b17e31..463cd8e 100644 --- a/Modules/socketmodule.c +++ b/Modules/socketmodule.c @@ -50,9 +50,7 @@ Module interface: specifying the ethernet interface and an integer specifying the Ethernet protocol number to be received. For example: ("eth0",0x1234). Optional 3rd,4th,5th elements in the tuple - specify packet-type and ha-type/addr -- these are ignored by - networking code, but accepted since they are returned by the - getsockname() method. + specify packet-type and ha-type/addr. Local naming conventions: @@ -1223,10 +1221,12 @@ getsockaddrarg(PySocketSockObject *s, PyObject *args, int protoNumber; int hatype = 0; int pkttype = 0; - char *haddr; + char *haddr = NULL; + unsigned int halen = 0; - if (!PyArg_ParseTuple(args, "si|iis", &interfaceName, - &protoNumber, &pkttype, &hatype, &haddr)) + if (!PyArg_ParseTuple(args, "si|iis#", &interfaceName, + &protoNumber, &pkttype, &hatype, + &haddr, &halen)) return 0; strncpy(ifr.ifr_name, interfaceName, sizeof(ifr.ifr_name)); ifr.ifr_name[(sizeof(ifr.ifr_name))-1] = '\0'; @@ -1240,6 +1240,15 @@ getsockaddrarg(PySocketSockObject *s, PyObject *args, addr->sll_ifindex = ifr.ifr_ifindex; addr->sll_pkttype = pkttype; addr->sll_hatype = hatype; + if (halen > 8) { + PyErr_SetString(PyExc_ValueError, + "Hardware address must be 8 bytes or less"); + return 0; + } + if (halen != 0) { + memcpy(&addr->sll_addr, haddr, halen); + } + addr->sll_halen = halen; *addr_ret = (struct sockaddr *) addr; *len_ret = sizeof *addr; return 1; |