xref: /freebsd/lib/libc/net/eui64.3 (revision fa9896e082a1046ff4fbc75fcba4d18d1f2efc19)
1cf754908SBrooks Davis.\" Copyright 2004 The Aerospace Corporation.  All rights reserved.
2cf754908SBrooks Davis.\"
3cf754908SBrooks Davis.\" Redistribution and use in source and binary forms, with or without
4cf754908SBrooks Davis.\" modification, are permitted provided that the following conditions
5cf754908SBrooks Davis.\" are met:
6cf754908SBrooks Davis.\"
7cf754908SBrooks Davis.\" 1.  Redistributions of source code must retain the above copyright
8cf754908SBrooks Davis.\"     notice, this list of conditions, and the following disclaimer.
9cf754908SBrooks Davis.\" 2.  Redistributions in binary form must reproduce the above copyright
10cf754908SBrooks Davis.\"     notice, this list of conditions, and the following disclaimer in the
11cf754908SBrooks Davis.\"     documentation and/or other materials provided with the distribution.
12cf754908SBrooks Davis.\" 3.  The name of The Aerospace Corporation may not be used to endorse or
13cf754908SBrooks Davis.\"     promote products derived from this software.
14cf754908SBrooks Davis.\"
15cf754908SBrooks Davis.\" THIS SOFTWARE IS PROVIDED BY THE AEROSPACE CORPORATION "AS IS" AND
16cf754908SBrooks Davis.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17cf754908SBrooks Davis.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18cf754908SBrooks Davis.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AEROSPACE CORPORATION BE LIABLE
19cf754908SBrooks Davis.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20cf754908SBrooks Davis.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21cf754908SBrooks Davis.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22cf754908SBrooks Davis.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23cf754908SBrooks Davis.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24cf754908SBrooks Davis.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25cf754908SBrooks Davis.\" SUCH DAMAGE.
26cf754908SBrooks Davis.\"
277387768eSBrooks Davis.\" Copyright (c) 1995
287387768eSBrooks Davis.\"	Bill Paul <wpaul@ctr.columbia.edu>.  All rights reserved.
297387768eSBrooks Davis.\"
307387768eSBrooks Davis.\" Redistribution and use in source and binary forms, with or without
317387768eSBrooks Davis.\" modification, are permitted provided that the following conditions
327387768eSBrooks Davis.\" are met:
337387768eSBrooks Davis.\" 1. Redistributions of source code must retain the above copyright
347387768eSBrooks Davis.\"    notice, this list of conditions and the following disclaimer.
357387768eSBrooks Davis.\" 2. Redistributions in binary form must reproduce the above copyright
367387768eSBrooks Davis.\"    notice, this list of conditions and the following disclaimer in the
377387768eSBrooks Davis.\"    documentation and/or other materials provided with the distribution.
387387768eSBrooks Davis.\" 3. All advertising materials mentioning features or use of this software
397387768eSBrooks Davis.\"    must display the following acknowledgement:
407387768eSBrooks Davis.\"	This product includes software developed by Bill Paul.
417387768eSBrooks Davis.\" 4. Neither the name of the author nor the names of any co-contributors
427387768eSBrooks Davis.\"    may be used to endorse or promote products derived from this software
437387768eSBrooks Davis.\"    without specific prior written permission.
447387768eSBrooks Davis.\"
457387768eSBrooks Davis.\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
467387768eSBrooks Davis.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
477387768eSBrooks Davis.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
487387768eSBrooks Davis.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
497387768eSBrooks Davis.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
507387768eSBrooks Davis.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
517387768eSBrooks Davis.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
527387768eSBrooks Davis.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
537387768eSBrooks Davis.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
547387768eSBrooks Davis.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
557387768eSBrooks Davis.\" SUCH DAMAGE.
567387768eSBrooks Davis.\"
575792ef09SRuslan Ermilov.Dd March 4, 2004
587387768eSBrooks Davis.Dt EUI64 3
597387768eSBrooks Davis.Os
607387768eSBrooks Davis.Sh NAME
617387768eSBrooks Davis.Nm eui64 ,
627387768eSBrooks Davis.\" .Nm eui64_line ,
637387768eSBrooks Davis.Nm eui64_aton ,
647387768eSBrooks Davis.Nm eui64_ntoa ,
657387768eSBrooks Davis.Nm eui64_ntohost ,
667387768eSBrooks Davis.Nm eui64_hostton
677387768eSBrooks Davis.Nd IEEE EUI-64 conversion and lookup routines
687387768eSBrooks Davis.Sh LIBRARY
697387768eSBrooks Davis.Lb libc
707387768eSBrooks Davis.Sh SYNOPSIS
717387768eSBrooks Davis.In sys/types.h
727387768eSBrooks Davis.In sys/eui64.h
737387768eSBrooks Davis.\" .Ft int
747387768eSBrooks Davis.\" .Fn eui64_line "const char *l" "struct eui64 *e" "char *hostname" "size_t len"
757387768eSBrooks Davis.Ft int
767387768eSBrooks Davis.Fn eui64_aton "const char *a" "struct eui64 *e"
777387768eSBrooks Davis.Ft int
787387768eSBrooks Davis.Fn eui64_ntoa "const struct eui64 *id" "char *a" "size_t len"
797387768eSBrooks Davis.Ft int
807387768eSBrooks Davis.Fn eui64_ntohost "char *hostname" "size_t len" "const struct eui64 *id"
817387768eSBrooks Davis.Ft int
827387768eSBrooks Davis.Fn eui64_hostton "const char *hostname" "struct eui64 *id"
837387768eSBrooks Davis.Sh DESCRIPTION
847387768eSBrooks DavisThese functions operate on IEEE EUI-64s using an
857387768eSBrooks Davis.Vt eui64
867387768eSBrooks Davisstructure, which is defined in the header file
877387768eSBrooks Davis.In sys/eui64.h :
887387768eSBrooks Davis.Bd -literal -offset indent
897387768eSBrooks Davis/*
907387768eSBrooks Davis * The number of bytes in an EUI-64.
917387768eSBrooks Davis */
927387768eSBrooks Davis#define EUI64_LEN		8
937387768eSBrooks Davis
947387768eSBrooks Davis/*
957387768eSBrooks Davis * Structure of an IEEE EUI-64.
967387768eSBrooks Davis */
977387768eSBrooks Davisstruct  eui64 {
987387768eSBrooks Davis        u_char octet[EUI64_LEN];
997387768eSBrooks Davis};
1007387768eSBrooks Davis.Ed
1017387768eSBrooks Davis.\" .Pp
1027387768eSBrooks Davis.\" The function
1037387768eSBrooks Davis.\" .Fn eui64_line
1047387768eSBrooks Davis.\" scans
1057387768eSBrooks Davis.\" .Fa l ,
1067387768eSBrooks Davis.\" an
1077387768eSBrooks Davis.\" .Tn ASCII
1087387768eSBrooks Davis.\" string in
1097387768eSBrooks Davis.\" .Xr eui64 5
1107387768eSBrooks Davis.\" format and sets
1117387768eSBrooks Davis.\" .Fa e
1127387768eSBrooks Davis.\" to the EUI-64 specified in the string and
1137387768eSBrooks Davis.\" .Fa h
1147387768eSBrooks Davis.\" to the hostname.
1157387768eSBrooks Davis.\" This function is used to parse lines from
1167387768eSBrooks Davis.\" .Pa /etc/eui64
1177387768eSBrooks Davis.\" into their component parts.
1187387768eSBrooks Davis.Pp
1197387768eSBrooks DavisThe
1207387768eSBrooks Davis.Fn eui64_aton
1217387768eSBrooks Davisfunction converts an
1227387768eSBrooks Davis.Tn ASCII
1237387768eSBrooks Davisrepresentation of an EUI-64 into an
1247387768eSBrooks Davis.Vt eui64
1257387768eSBrooks Davisstructure.
1267387768eSBrooks DavisLikewise,
1277387768eSBrooks Davis.Fn eui64_ntoa
1287387768eSBrooks Davisconverts an EUI-64 specified as an
1297387768eSBrooks Davis.Vt eui64
1307387768eSBrooks Davisstructure into an
1317387768eSBrooks Davis.Tn ASCII
1327387768eSBrooks Davisstring.
1337387768eSBrooks Davis.Pp
1347387768eSBrooks DavisThe
1357387768eSBrooks Davis.Fn eui64_ntohost
1367387768eSBrooks Davisand
1377387768eSBrooks Davis.Fn eui64_hostton
1387387768eSBrooks Davisfunctions map EUI-64s to their corresponding hostnames
1397387768eSBrooks Davisas specified in the
1407387768eSBrooks Davis.Pa /etc/eui64
1417387768eSBrooks Davisdatabase.
1427387768eSBrooks DavisThe
1437387768eSBrooks Davis.Fn eui64_ntohost
1447387768eSBrooks Davisfunction
1457387768eSBrooks Davisconverts from EUI-64 to hostname, and
1467387768eSBrooks Davis.Fn eui64_hostton
1477387768eSBrooks Davisconverts from hostname to EUI-64.
1487387768eSBrooks Davis.Sh RETURN VALUES
1497387768eSBrooks Davis.\" The
1507387768eSBrooks Davis.\" .Fn eui64_line
1517387768eSBrooks Davis.\" function
1527387768eSBrooks Davis.\" returns zero on success and non-zero if it was unable to parse
1537387768eSBrooks Davis.\" any part of the supplied line
1547387768eSBrooks Davis.\" .Fa l .
1557387768eSBrooks Davis.\" It returns the extracted EUI-64 in the supplied
1567387768eSBrooks Davis.\" .Vt eui64
1577387768eSBrooks Davis.\" structure
1587387768eSBrooks Davis.\" .Fa e
1597387768eSBrooks Davis.\" and the hostname in the supplied string
1607387768eSBrooks Davis.\" .Fa h .
1617387768eSBrooks Davis.\" .Pp
1627387768eSBrooks DavisOn success,
1637387768eSBrooks Davis.Fn eui64_ntoa
1647387768eSBrooks Davisreturns a pointer to a string containing an
1657387768eSBrooks Davis.Tn ASCII
1667387768eSBrooks Davisrepresentation of an EUI-64.
1677387768eSBrooks DavisIf it is unable to convert
1687387768eSBrooks Davisthe supplied
1697387768eSBrooks Davis.Vt eui64
1707387768eSBrooks Davisstructure, it returns a
1717387768eSBrooks Davis.Dv NULL
1727387768eSBrooks Davispointer.
1737387768eSBrooks DavisLikewise,
1747387768eSBrooks Davis.Fn eui64_aton
1757387768eSBrooks Davisreturns a pointer to an
1767387768eSBrooks Davis.Vt eui64
1777387768eSBrooks Davisstructure on success and a
1787387768eSBrooks Davis.Dv NULL
1797387768eSBrooks Davispointer on failure.
1807387768eSBrooks Davis.Pp
1817387768eSBrooks DavisThe
1827387768eSBrooks Davis.Fn eui64_ntohost
1837387768eSBrooks Davisand
1847387768eSBrooks Davis.Fn eui64_hostton
1857387768eSBrooks Davisfunctions both return zero on success or non-zero if they were
1867387768eSBrooks Davisunable to find a match in the
1877387768eSBrooks Davis.Pa /etc/eui64
1887387768eSBrooks Davisdatabase.
1897387768eSBrooks Davis.Sh NOTES
190*e7f8dd75SRebecca CranThe user must ensure that the hostname strings passed to the
1917387768eSBrooks Davis.\" .Fn eui64_line ,
1927387768eSBrooks Davis.Fn eui64_ntohost
1937387768eSBrooks Davisand
1947387768eSBrooks Davis.Fn eui64_hostton
1957387768eSBrooks Davisfunctions are large enough to contain the returned hostnames.
1967387768eSBrooks Davis.Sh NIS INTERACTION
1977387768eSBrooks DavisIf the
1987387768eSBrooks Davis.Pa /etc/eui64
1995792ef09SRuslan Ermilovcontains a line with a single
2005792ef09SRuslan Ermilov.Ql +
2015792ef09SRuslan Ermilovin it, the
2027387768eSBrooks Davis.Fn eui64_ntohost
2037387768eSBrooks Davisand
2047387768eSBrooks Davis.Fn eui64_hostton
2057387768eSBrooks Davisfunctions will attempt to consult the NIS
2067387768eSBrooks Davis.Pa eui64.byname
2077387768eSBrooks Davisand
2087387768eSBrooks Davis.Pa eui64.byid
2097387768eSBrooks Davismaps in addition to the data in the
2107387768eSBrooks Davis.Pa /etc/eui64
2117387768eSBrooks Davisfile.
2127387768eSBrooks Davis.Sh SEE ALSO
2137387768eSBrooks Davis.Xr firewire 4 ,
2147387768eSBrooks Davis.Xr eui64 5 ,
2157387768eSBrooks Davis.Xr yp 8
21624a0682cSRuslan Ermilov.Sh HISTORY
21724a0682cSRuslan ErmilovThese functions first appears in
21824a0682cSRuslan Ermilov.Fx 5.3 .
21924a0682cSRuslan ErmilovThey are derived from the
22024a0682cSRuslan Ermilov.Xr ethers 3
22124a0682cSRuslan Ermilovfamily of functions.
222