1 /* $NetBSD: getifaddrs_w32.c,v 1.1.1.2 2014/04/24 12:45:52 pettai Exp $ */
3 /***********************************************************************
4 * Copyright (c) 2009, Secure Endpoints Inc.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * - Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
14 * - Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in
16 * the documentation and/or other materials provided with the
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23 * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
24 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
25 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
30 * OF THE POSSIBILITY OF SUCH DAMAGE.
32 **********************************************************************/
36 #include <krb5/roken.h>
41 #error This is a Windows specific implementation.
44 static struct sockaddr
*
45 dupaddr(const sockaddr_gen
* src
)
47 sockaddr_gen
* d
= malloc(sizeof(*d
));
50 memcpy(d
, src
, sizeof(*d
));
53 return (struct sockaddr
*) d
;
56 int ROKEN_LIB_FUNCTION
57 rk_getifaddrs(struct ifaddrs
**ifpp
)
59 SOCKET s
= INVALID_SOCKET
;
62 INTERFACE_INFO
*il
= NULL
;
66 s
= socket(AF_INET
, SOCK_DGRAM
, 0);
67 if (s
== INVALID_SOCKET
)
77 ZeroMemory(il
, il_len
);
79 if (WSAIoctl(s
, SIO_GET_INTERFACE_LIST
, NULL
, 0,
80 (LPVOID
) il
, (DWORD
) il_len
, &cbret
,
89 if (WSAGetLastError() == WSAEFAULT
&& cbret
> il_len
) {
99 /* il is an array of INTERFACE_INFO structures. il_len has the
100 actual size of the buffer. The number of elements is
101 il_len/sizeof(INTERFACE_INFO) */
104 size_t n
= il_len
/ sizeof(INTERFACE_INFO
);
107 for (i
= 0; i
< n
; i
++ ) {
110 ifp
= malloc(sizeof(*ifp
));
114 ZeroMemory(ifp
, sizeof(*ifp
));
116 ifp
->ifa_next
= NULL
;
117 ifp
->ifa_name
= NULL
;
118 ifp
->ifa_flags
= il
[i
].iiFlags
;
119 ifp
->ifa_addr
= dupaddr(&il
[i
].iiAddress
);
120 ifp
->ifa_netmask
= dupaddr(&il
[i
].iiNetmask
);
121 ifp
->ifa_broadaddr
= dupaddr(&il
[i
].iiBroadcastAddress
);
122 ifp
->ifa_data
= NULL
;
125 ifpp
= &ifp
->ifa_next
;
134 if (s
!= INVALID_SOCKET
)
143 void ROKEN_LIB_FUNCTION
144 rk_freeifaddrs(struct ifaddrs
*ifp
)
146 struct ifaddrs
*p
, *q
;
154 free(p
->ifa_dstaddr
);
156 free(p
->ifa_netmask
);