From 6b6a8cefad468dc1dfc92da06ccb45363e346736 Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Sat, 2 Dec 2000 21:29:00 +0000 Subject: [PATCH] * net.cc (get_inet_addr ): Close AF_UNIX socket file after reading. --- winsup/cygwin/ChangeLog | 4 ++++ winsup/cygwin/net.cc | 32 ++++++++++++++++++-------------- 2 files changed, 22 insertions(+), 14 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 312ba6db4..8565c254f 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,7 @@ +Sat Dec 2 22:26:00 2000 Corinna Vinschen + + * net.cc (get_inet_addr ): Close AF_UNIX socket file after reading. + Wed Nov 29 18:25:53 2000 Kazuhiro Fujieda * cygheap.cc (chgheap_root::operator =): Check root dir properly. diff --git a/winsup/cygwin/net.cc b/winsup/cygwin/net.cc index 1832eb1fc..08d076a6d 100644 --- a/winsup/cygwin/net.cc +++ b/winsup/cygwin/net.cc @@ -387,22 +387,26 @@ static int get_inet_addr (const struct sockaddr *in, int inlen, } else if (in->sa_family == AF_UNIX) { - sockaddr_in sin; - char buf[32]; - - memset (buf, 0, sizeof buf); - int fd = open (in->sa_data, O_RDONLY); + int fd = _open (in->sa_data, O_RDONLY); if (fd == -1) return 0; - if (read (fd, buf, sizeof buf) == -1) - return 0; - sin.sin_family = AF_INET; - sscanf (buf + strlen (SOCKET_COOKIE), "%hu", &sin.sin_port); - sin.sin_port = htons (sin.sin_port); - sin.sin_addr.s_addr = htonl (INADDR_LOOPBACK); - *out = sin; - *outlen = sizeof sin; - return 1; + + int ret = 0; + char buf[32]; + memset (buf, 0, sizeof buf); + if (read (fd, buf, sizeof buf) != -1) + { + sockaddr_in sin; + sin.sin_family = AF_INET; + sscanf (buf + strlen (SOCKET_COOKIE), "%hu", &sin.sin_port); + sin.sin_port = htons (sin.sin_port); + sin.sin_addr.s_addr = htonl (INADDR_LOOPBACK); + *out = sin; + *outlen = sizeof sin; + ret = 1; + } + _close (fd); + return ret; } else {