if_dl.h revision 1.26 1 1.26 christos /* $NetBSD: if_dl.h,v 1.26 2014/12/03 01:31:37 christos Exp $ */
2 1.5 cgd
3 1.1 cgd /*
4 1.4 mycroft * Copyright (c) 1990, 1993
5 1.4 mycroft * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.12 agc * 3. Neither the name of the University nor the names of its contributors
16 1.1 cgd * may be used to endorse or promote products derived from this software
17 1.1 cgd * without specific prior written permission.
18 1.1 cgd *
19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 1.1 cgd * SUCH DAMAGE.
30 1.1 cgd *
31 1.5 cgd * @(#)if_dl.h 8.1 (Berkeley) 6/10/93
32 1.1 cgd */
33 1.1 cgd
34 1.14 perry /*
35 1.1 cgd * A Link-Level Sockaddr may specify the interface in one of two
36 1.1 cgd * ways: either by means of a system-provided index number (computed
37 1.1 cgd * anew and possibly differently on every reboot), or by a human-readable
38 1.1 cgd * string such as "il0" (for managerial convenience).
39 1.14 perry *
40 1.1 cgd * Census taking actions, such as something akin to SIOCGCONF would return
41 1.1 cgd * both the index and the human name.
42 1.14 perry *
43 1.1 cgd * High volume transactions (such as giving a link-level ``from'' address
44 1.1 cgd * in a recvfrom or recvmsg call) may be likely only to provide the indexed
45 1.1 cgd * form, (which requires fewer copy operations and less space).
46 1.14 perry *
47 1.1 cgd * The form and interpretation of the link-level address is purely a matter
48 1.1 cgd * of convention between the device driver and its consumers; however, it is
49 1.1 cgd * expected that all drivers for an interface of a given if_type will agree.
50 1.1 cgd */
51 1.1 cgd
52 1.9 perry #ifndef _NET_IF_DL_H_
53 1.9 perry #define _NET_IF_DL_H_
54 1.9 perry
55 1.10 kleink #include <sys/ansi.h>
56 1.10 kleink
57 1.10 kleink #ifndef sa_family_t
58 1.10 kleink typedef __sa_family_t sa_family_t;
59 1.11 kleink #define sa_family_t __sa_family_t
60 1.10 kleink #endif
61 1.24 christos #ifndef socklen_t
62 1.24 christos typedef __socklen_t socklen_t;
63 1.24 christos #define socklen_t __socklen_t
64 1.24 christos #endif
65 1.24 christos
66 1.25 christos struct dl_addr {
67 1.24 christos uint8_t dl_type; /* interface type */
68 1.24 christos uint8_t dl_nlen; /* interface name length, no trailing 0 reqd. */
69 1.24 christos uint8_t dl_alen; /* link level address length */
70 1.24 christos uint8_t dl_slen; /* link layer selector length */
71 1.24 christos /*
72 1.24 christos * minimum work area, can be larger; contains both if name
73 1.24 christos * and ll address
74 1.24 christos */
75 1.24 christos char dl_data[12];
76 1.24 christos };
77 1.10 kleink
78 1.1 cgd /*
79 1.1 cgd * Structure of a Link-Level sockaddr:
80 1.1 cgd */
81 1.1 cgd struct sockaddr_dl {
82 1.22 matt uint8_t sdl_len; /* Total length of sockaddr */
83 1.13 wiz sa_family_t sdl_family; /* AF_LINK */
84 1.24 christos uint16_t sdl_index; /* if != 0, system given index for interface */
85 1.25 christos struct dl_addr sdl_addr;
86 1.24 christos #define sdl_type sdl_addr.dl_type
87 1.24 christos #define sdl_nlen sdl_addr.dl_nlen
88 1.24 christos #define sdl_alen sdl_addr.dl_alen
89 1.24 christos #define sdl_slen sdl_addr.dl_slen
90 1.24 christos #define sdl_data sdl_addr.dl_data
91 1.1 cgd };
92 1.1 cgd
93 1.19 dyoung #define satosdl(__sa) ((struct sockaddr_dl *)(__sa))
94 1.19 dyoung #define satocsdl(__sa) ((const struct sockaddr_dl *)(__sa))
95 1.19 dyoung
96 1.16 christos /* We do arithmetic directly with these, so keep them char instead of void */
97 1.16 christos #define LLADDR(s) ((char *)((s)->sdl_data + (s)->sdl_nlen))
98 1.16 christos #define CLLADDR(s) ((const char *)((s)->sdl_data + (s)->sdl_nlen))
99 1.1 cgd
100 1.19 dyoung #ifdef _KERNEL
101 1.19 dyoung uint8_t sockaddr_dl_measure(uint8_t, uint8_t);
102 1.21 dyoung struct sockaddr *sockaddr_dl_alloc(uint16_t, uint8_t,
103 1.21 dyoung const void *, uint8_t, const void *, uint8_t, int);
104 1.21 dyoung struct sockaddr_dl *sockaddr_dl_init(struct sockaddr_dl *, socklen_t, uint16_t,
105 1.21 dyoung uint8_t, const void *, uint8_t, const void *, uint8_t);
106 1.21 dyoung struct sockaddr_dl *sockaddr_dl_setaddr(struct sockaddr_dl *, socklen_t,
107 1.21 dyoung const void *, uint8_t);
108 1.19 dyoung #else
109 1.1 cgd
110 1.1 cgd #include <sys/cdefs.h>
111 1.1 cgd
112 1.1 cgd __BEGIN_DECLS
113 1.18 thorpej void link_addr(const char *, struct sockaddr_dl *);
114 1.18 thorpej char *link_ntoa(const struct sockaddr_dl *);
115 1.1 cgd __END_DECLS
116 1.1 cgd
117 1.8 jtc #endif /* !_KERNEL */
118 1.9 perry
119 1.24 christos #if defined(_KERNEL) || defined(_TEST)
120 1.24 christos // 255 xx: + 255 'a' + / + # + 3 digits + NUL
121 1.24 christos #define LINK_ADDRSTRLEN ((255 * 4) + 5)
122 1.24 christos
123 1.25 christos int dl_print(char *, size_t, const struct dl_addr *);
124 1.26 christos #define DL_PRINT(b, a) (dl_print((b), sizeof(b), (a)), (b))
125 1.24 christos int sdl_print(char *, size_t, const void *);
126 1.24 christos #endif
127 1.24 christos
128 1.17 elad #endif /* !_NET_IF_DL_H_ */
129