3 * ===================================
4 * HARP | Host ATM Research Platform
5 * ===================================
8 * This Host ATM Research Platform ("HARP") file (the "Software") is
9 * made available by Network Computing Services, Inc. ("NetworkCS")
10 * "AS IS". NetworkCS does not provide maintenance, improvements or
11 * support of any kind.
13 * NETWORKCS MAKES NO WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED,
14 * INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
15 * AND FITNESS FOR A PARTICULAR PURPOSE, AS TO ANY ELEMENT OF THE
16 * SOFTWARE OR ANY SUPPORT PROVIDED IN CONNECTION WITH THIS SOFTWARE.
17 * In no event shall NetworkCS be responsible for any damages, including
18 * but not limited to consequential damages, arising from or relating to
19 * any use of the Software or related support.
21 * Copyright 1994-1998 Network Computing Services, Inc.
23 * Copies of this Software may be made, however, the above copyright
24 * notice must be reproduced on all copies.
26 * @(#) $FreeBSD: src/lib/libatm/ip_addr.c,v 1.3.2.1 2001/09/28 16:52:10 dillon Exp $
31 * User Space Library Functions
32 * ----------------------------
34 * IP address utilities
38 #include <sys/types.h>
39 #include <sys/param.h>
40 #include <sys/socket.h>
42 #include <netinet/in.h>
43 #include <arpa/inet.h>
44 #include <netatm/port.h>
45 #include <netatm/atm.h>
46 #include <netatm/atm_if.h>
47 #include <netatm/atm_sap.h>
48 #include <netatm/atm_sys.h>
49 #include <netatm/atm_ioctl.h>
60 * Return an IP address in a socket address structure, given a character
61 * string with a domain name or a dotted decimal number.
64 * p pointer to a host name or IP address
67 * null error was encountered
68 * struct sockaddr_in * a pointer to a socket address with the
69 * requested IP address
75 struct hostent
*ip_host
;
76 static struct sockaddr_in sin
;
79 * Get IP address of specified host name
81 UM_ZERO(&sin
, sizeof(sin
));
82 sin
.sin_family
= AF_INET
;
83 if (p
[0] >= '0' && p
[0] <= '9') {
85 * IP address is in dotted decimal format
87 if ((sin
.sin_addr
.s_addr
= inet_addr(p
)) == -1) {
92 * Host name is in domain name system format
94 ip_host
= gethostbyname(p
);
96 ip_host
->h_addrtype
!= AF_INET
) {
99 sin
.sin_addr
.s_addr
= *(u_long
*)ip_host
->h_addr_list
[0];
106 * Format an IP address
108 * Return a text-formatted string with an IP address and domain name
109 * given a sockaddr_in with an IP address.
112 * p pointer to sockaddr_in with an IP address
115 * char * pointer to a text-formatted string
119 format_ip_addr(struct in_addr
*addr
)
121 static char host_name
[MAXHOSTNAMELEN
+ 18];
123 struct hostent
*ip_host
;
128 UM_ZERO(host_name
, sizeof(host_name
));
131 * Check for a zero address
133 if (!addr
|| addr
->s_addr
== 0) {
138 * Get address in dotted decimal format
140 ip_num
= inet_ntoa(*addr
);
143 * Look up name in DNS
145 ip_host
= gethostbyaddr(addr
, sizeof(*addr
), AF_INET
);
146 if (ip_host
&& ip_host
->h_name
&&
147 strlen(ip_host
->h_name
)) {
149 * Return host name followed by dotted decimal address
151 snprintf(host_name
, sizeof(host_name
), "%s (%s)",
152 ip_host
->h_name
, ip_num
);
156 * No host name -- just return dotted decimal address