Files
pkgsrc-ng/net/gnome-netstatus/patches/patch-aa
2016-11-18 22:39:22 +01:00

43 lines
1.4 KiB
Plaintext

$NetBSD: patch-aa,v 1.5 2016/04/18 11:41:50 jperkin Exp $
Don't use SIOCGIFHWADDR on SunOS.
--- src/netstatus-iface.c.orig 2009-03-08 05:25:52.000000000 +0000
+++ src/netstatus-iface.c
@@ -1024,7 +1024,7 @@ netstatus_iface_get_hw_details (Netstatu
char **hw_addr)
{
-#ifdef SIOCGIFHWADDR
+#if defined(SIOCGIFHWADDR) && !defined(__sun)
static struct HwType *hw_type = NULL;
struct ifreq if_req;
int fd;
@@ -1121,12 +1121,6 @@ netstatus_iface_get_device_details (Nets
return TRUE;
}
-#if !defined(HAVE_SOCKADDR_SA_LEN)
-#define NETSTATUS_SA_LEN(saddr) (sizeof (struct sockaddr))
-#else
-#define NETSTATUS_SA_LEN(saddr) (MAX ((saddr)->sa_len, sizeof (struct sockaddr)))
-#endif /* HAVE_SOCKADDR_SA_LEN */
-
/* Taken From R. Stevens Unix Network Programming Vol. 1.
*
* SIOCGIFCONF does not return an error on all systems if
@@ -1220,7 +1214,12 @@ netstatus_list_interface_names (GError *
struct ifreq *if_req = (struct ifreq *) p;
gboolean loopback = FALSE;
- p += sizeof (if_req->ifr_name) + NETSTATUS_SA_LEN (&if_req->ifr_addr);
+#ifdef HAVE_SOCKADDR_SA_LEN
+ if (if_req->ifr_addr.sa_len > sizeof(if_req->ifr_ifru))
+ p += offsetof(struct ifreq, ifr_ifru) + if_req->ifr_addr.sa_len;
+ else
+#endif /* HAVE_SOCKADDR_SA_LEN */
+ p += sizeof (*if_req);
if (ioctl (fd, SIOCGIFFLAGS, if_req) < 0)
{