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