xref: /freebsd/lib/libc/net/ethers.3 (revision 77a0943ded95b9e6438f7db70c4a28e4d93946d4)
1.\" Copyright (c) 1995
2.\"	Bill Paul <wpaul@ctr.columbia.edu>.  All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\" 3. All advertising materials mentioning features or use of this software
13.\"    must display the following acknowledgement:
14.\"	This product includes software developed by Bill Paul.
15.\" 4. Neither the name of the author nor the names of any co-contributors
16.\"    may be used to endorse or promote products derived from this software
17.\"    without specific prior written permission.
18.\"
19.\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
20.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29.\" SUCH DAMAGE.
30.\"
31.\" $FreeBSD$
32.\"
33.Dd April 12, 1995
34.Dt ETHERS 3
35.Os FreeBSD 2.1
36.Sh NAME
37.Nm ethers ,
38.Nm ether_line ,
39.Nm ether_aton ,
40.Nm ether_ntoa ,
41.Nm ether_ntohost ,
42.Nm ether_hostton
43.Nd Ethernet address conversion and lookup routines
44.Sh LIBRARY
45.Lb libc
46.Sh SYNOPSIS
47.Fd #include <sys/types.h>
48.Fd #include <sys/socket.h>
49.Fd #include <net/ethernet.h>
50.Ft int
51.Fn ether_line "const char *l" "struct ether_addr *e" "char *hostname"
52.Ft struct ether_addr *
53.Fn ether_aton "const char *a"
54.Ft char *
55.Fn ether_ntoa "const struct ether_addr *n"
56.Ft int
57.Fn ether_ntohost "char *hostname" "const struct ether_addr *e"
58.Ft int
59.Fn ether_hostton "const char *hostname" "struct ether_addr *e"
60.Sh DESCRIPTION
61These functions operate on ethernet addresses using an
62.Ar ether_addr
63structure, which is defined in the header file
64.Aq Pa netinet/if_ether.h :
65.Bd -literal -offset indent
66/*
67 * The number of bytes in an ethernet (MAC) address.
68 */
69#define ETHER_ADDR_LEN		6
70
71/*
72 * Structure of a 48-bit Ethernet address.
73 */
74struct  ether_addr {
75        u_char octet[ETHER_ADDR_LEN];
76};
77.Ed
78.Pp
79The function
80.Fn ether_line
81scans
82.Ar l ,
83an
84.Tn ASCII
85string in
86.Xr ethers 5
87format and sets
88.Ar e
89to the ethernet address specified in the string and
90.Ar h
91to the hostname.
92This function is used to parse lines from
93.Pa /etc/ethers
94into their component parts.
95.Pp
96The
97.Fn ether_aton
98function converts an
99.Tn ASCII
100representation of an ethernet address into an
101.Ar ether_addr
102structure.
103Likewise,
104.Fn ether_ntoa
105converts an ethernet address specified as an
106.Ar ether_addr
107structure into an
108.Tn ASCII
109string.
110.Pp
111The
112.Fn ether_ntohost
113and
114.Fn ether_hostton
115functions map ethernet addresses to their corresponding hostnames
116as specified in the
117.Pa /etc/ethers
118database.
119.Fn ether_ntohost
120converts from ethernet address to hostname, and
121.Fn ether_hostton
122converts from hostname to ethernet address.
123.Sh RETURN VALUES
124.Fn ether_line
125returns zero on success and non-zero if it was unable to parse
126any part of the supplied line
127.Ar l .
128It returns the extracted ethernet address in the supplied
129.Ar ether_addr
130structure
131.Ar e
132and the hostname in the supplied string
133.Ar h .
134.Pp
135On success,
136.Fn ether_ntoa
137returns a pointer to a string containing an
138.Tn ASCII
139representation of an ethernet address.
140If it is unable to convert
141the supplied
142.Ar ether_addr
143structure, it returns a
144.Dv NULL
145pointer.
146Likewise,
147.Fn ether_aton
148returns a pointer to an
149.Ar ether_addr
150structure on success and a
151.Dv NULL
152pointer on failure.
153.Pp
154The
155.Fn ether_ntohost
156and
157.Fn ether_hostton
158functions both return zero on success or non-zero if they were
159unable to find a match in the
160.Pa /etc/ethers
161database.
162.Sh NOTES
163The user must insure that the hostname strings passed to the
164.Fn ether_line ,
165.Fn ether_ntohost
166and
167.Fn ether_hostton
168functions are large enough to contain the returned hostnames.
169.Sh NIS INTERACTION
170If the
171.Pa /etc/ethers
172contains a line with a single + in it, the
173.Fn ether_ntohost
174and
175.Fn ether_hostton
176functions will attempt to consult the NIS
177.Pa ethers.byname
178and
179.Pa ethers.byaddr
180maps in addition to the data in the
181.Pa /etc/ethers
182file.
183.Sh SEE ALSO
184.Xr yp 4 ,
185.Xr ethers 5
186.Sh BUGS
187.Pp
188The
189.Fn ether_aton
190and
191.Fn ether_ntoa
192functions returns values that are stored in static memory areas
193which may be overwritten the next time they are called.
194.Sh HISTORY
195This particular implementation of the
196.Nm
197library functions were written for and first appeared in
198.Fx 2.1 .
199