]> granicus.if.org Git - php/commitdiff
MFH: zerofill socket structs
authorAntony Dovgal <tony2001@php.net>
Sun, 25 Feb 2007 22:59:32 +0000 (22:59 +0000)
committerAntony Dovgal <tony2001@php.net>
Sun, 25 Feb 2007 22:59:32 +0000 (22:59 +0000)
ext/sockets/sockets.c

index 72bca7f63d8b5e71190bb099dd1352f78d4018d3..9c1a691f52f495bb4593a1522f08ae92347ce3fb 100644 (file)
@@ -1118,6 +1118,8 @@ PHP_FUNCTION(socket_connect)
                                php_error_docref(NULL TSRMLS_CC, E_WARNING, "Socket of type AF_INET6 requires 3 arguments");
                                RETURN_FALSE;
                        }
+                       
+                       memset(&sin6, 0, sizeof(struct sockaddr_in6));
 
                        sin6.sin6_family = AF_INET6;
                        sin6.sin6_port   = htons((unsigned short int)port);
@@ -1134,6 +1136,8 @@ PHP_FUNCTION(socket_connect)
                                php_error_docref(NULL TSRMLS_CC, E_WARNING, "Socket of type AF_INET requires 3 arguments");
                                RETURN_FALSE;
                        }
+                       
+                       memset(&sin, 0, sizeof(struct sockaddr_in));
 
                        sin.sin_family = AF_INET;
                        sin.sin_port   = htons((unsigned short int)port);
@@ -1146,6 +1150,8 @@ PHP_FUNCTION(socket_connect)
                        break;
 
                case AF_UNIX:
+                       memset(&s_un, 0, sizeof(struct sockaddr_un));
+                       
                        s_un.sun_family = AF_UNIX;
                        snprintf(s_un.sun_path, 108, "%s", addr);
                        retval = connect(php_sock->bsd_socket, (struct sockaddr *) &s_un, SUN_LEN(&s_un));