Skip to content

Commit 1beb24b

Browse files
committed
Merge branch 'PHP-5.4' into PHP-5.5
* PHP-5.4: Implements feature Bug #63472 ability to set SO_BINDTODEVICE on socket. Conflicts: ext/sockets/sockets.c
2 parents 7272e3e + a0b4348 commit 1beb24b

File tree

3 files changed

+59
-0
lines changed

3 files changed

+59
-0
lines changed

NEWS

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,10 @@ PHP NEWS
1616
. Fixed Bug #65060 (imagecreatefrom... crashes with user streams). (Remi)
1717
. Fixed Bug #65084 (imagecreatefromjpeg fails with URL). (Remi)
1818

19+
- Sockets:
20+
. Implemented FR #63472 (Setting SO_BINDTODEVICE with socket_set_option).
21+
(Damjan Cvetko)
22+
1923
20 Jun 2013, PHP 5.5.0
2024

2125
- Core:

ext/sockets/sockets.c

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -679,6 +679,9 @@ static PHP_MINIT_FUNCTION(sockets)
679679
REGISTER_LONG_CONSTANT("SO_FAMILY", SO_FAMILY, CONST_CS | CONST_PERSISTENT);
680680
#endif
681681
REGISTER_LONG_CONSTANT("SO_ERROR", SO_ERROR, CONST_CS | CONST_PERSISTENT);
682+
#ifdef SO_BINDTODEVICE
683+
REGISTER_LONG_CONSTANT("SO_BINDTODEVICE", SO_BINDTODEVICE, CONST_CS | CONST_PERSISTENT);
684+
#endif
682685
REGISTER_LONG_CONSTANT("SOL_SOCKET", SOL_SOCKET, CONST_CS | CONST_PERSISTENT);
683686
REGISTER_LONG_CONSTANT("SOMAXCONN", SOMAXCONN, CONST_CS | CONST_PERSISTENT);
684687
#ifdef TCP_NODELAY
@@ -2038,6 +2041,18 @@ PHP_FUNCTION(socket_set_option)
20382041
#endif
20392042
break;
20402043
}
2044+
#ifdef SO_BINDTODEVICE
2045+
case SO_BINDTODEVICE: {
2046+
if (Z_TYPE_PP(arg4) == IS_STRING) {
2047+
opt_ptr = Z_STRVAL_PP(arg4);
2048+
optlen = Z_STRLEN_PP(arg4);
2049+
} else {
2050+
opt_ptr = "";
2051+
optlen = 0;
2052+
}
2053+
break;
2054+
}
2055+
#endif
20412056

20422057
default:
20432058
default_case:
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
--TEST--
2+
Test if socket_set_option() works, option:SO_BINDTODEVICE
3+
--DESCRIPTION--
4+
-Bind to loopback 'lo' device (should exist)
5+
-Bind to unexisting device
6+
--SKIPIF--
7+
<?php
8+
if (!extension_loaded('sockets')) {
9+
die('SKIP sockets extension not available.');
10+
}
11+
if (!defined("SO_BINDTODEVICE")) {
12+
die('SKIP SO_BINDTODEVICE not supported on this platform.');
13+
}
14+
if (!function_exists("posix_getuid") || posix_getuid() != 0) {
15+
die('SKIP SO_BINDTODEVICE requires root permissions.');
16+
}
17+
?>
18+
--FILE--
19+
<?php
20+
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
21+
22+
if (!$socket) {
23+
die('Unable to create AF_INET socket [socket]');
24+
}
25+
// wrong params
26+
$retval_1 = socket_set_option( $socket, SOL_SOCKET, SO_BINDTODEVICE, "lo");
27+
var_dump($retval_1);
28+
$retval_2 = socket_set_option( $socket, SOL_SOCKET, SO_BINDTODEVICE, "ethIDONOTEXIST");
29+
var_dump($retval_2);
30+
31+
socket_close($socket);
32+
?>
33+
34+
--EXPECTF--
35+
bool(true)
36+
37+
Warning: socket_set_option(): unable to set socket option [19]: No such device in %s on line %d
38+
bool(false)
39+
--CREDITS--
40+
Damjan Cvetko, foreach.org

0 commit comments

Comments
 (0)