aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/unix/sysv/linux/ifreq.h
diff options
context:
space:
mode:
Diffstat (limited to 'sysdeps/unix/sysv/linux/ifreq.h')
-rw-r--r--sysdeps/unix/sysv/linux/ifreq.h21
1 files changed, 13 insertions, 8 deletions
diff --git a/sysdeps/unix/sysv/linux/ifreq.h b/sysdeps/unix/sysv/linux/ifreq.h
index b38342534d..216c1f3373 100644
--- a/sysdeps/unix/sysv/linux/ifreq.h
+++ b/sysdeps/unix/sysv/linux/ifreq.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1999,2002 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Andreas Jaeger <aj@suse.de>.
@@ -34,21 +34,23 @@ static int old_siocgifconf;
static inline void
-__ifreq (struct ifreq **ifreqs, int *num_ifs)
+__ifreq (struct ifreq **ifreqs, int *num_ifs, int sockfd)
{
- int fd = __opensock ();
+ int fd = sockfd;
struct ifconf ifc;
int rq_len;
int nifs;
# define RQ_IFS 4
if (fd < 0)
+ fd = __opensock ();
+ if (fd < 0)
{
*num_ifs = 0;
*ifreqs = NULL;
return;
}
-
+
ifc.ifc_buf = NULL;
/* We may be able to get the needed buffer size directly, rather than
@@ -79,8 +81,9 @@ __ifreq (struct ifreq **ifreqs, int *num_ifs)
{
if (ifc.ifc_buf)
free (ifc.ifc_buf);
-
- __close (fd);
+
+ if (fd != sockfd)
+ __close (fd);
*num_ifs = 0;
*ifreqs = NULL;
@@ -91,14 +94,16 @@ __ifreq (struct ifreq **ifreqs, int *num_ifs)
while (ifc.ifc_len == rq_len && old_siocgifconf);
nifs = ifc.ifc_len / sizeof (struct ifreq);
- __close (fd);
+
+ if (fd != sockfd)
+ __close (fd);
*num_ifs = nifs;
*ifreqs = realloc (ifc.ifc_buf, nifs * sizeof (struct ifreq));
}
static inline void
-__if_freereq (struct ifreq *ifreqs)
+__if_freereq (struct ifreq *ifreqs, int num_ifs)
{
free (ifreqs);
}