Fix mdoc(7)/man(7) mix up.
[netbsd-mini2440.git] / lib / libc / net / inet6_opt_init.3
blob160e1fbaff3eafe546900c12fc0807ad033e0c3c
1 .\"     $NetBSD$
2 .\"     $KAME: inet6_opt_init.3,v 1.7 2004/12/27 05:08:23 itojun Exp $
3 .\"
4 .\" Copyright (C) 2004 WIDE Project.
5 .\" All rights reserved.
6 .\"
7 .\" Redistribution and use in source and binary forms, with or without
8 .\" modification, are permitted provided that the following conditions
9 .\" are met:
10 .\" 1. Redistributions of source code must retain the above copyright
11 .\"    notice, this list of conditions and the following disclaimer.
12 .\" 2. Redistributions in binary form must reproduce the above copyright
13 .\"    notice, this list of conditions and the following disclaimer in the
14 .\"    documentation and/or other materials provided with the distribution.
15 .\" 3. Neither the name of the project nor the names of its 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 THE PROJECT 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 PROJECT 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 .Dd December 23, 2004
32 .Dt INET6_OPT_INIT 3
33 .Os
34 .\"
35 .Sh NAME
36 .Nm inet6_opt_init ,
37 .Nm inet6_opt_append ,
38 .Nm inet6_opt_finish ,
39 .Nm inet6_opt_set_val ,
40 .Nm inet6_opt_next ,
41 .Nm inet6_opt_find ,
42 .Nm inet6_opt_get_val
43 .Nd IPv6 Hop-by-Hop and Destination Options manipulation
44 .\"
45 .Sh SYNOPSIS
46 .In netinet/in.h
47 .Ft "int"
48 .Fn inet6_opt_init "void *extbuf" "socklen_t extlen"
49 .Ft "int"
50 .Fn inet6_opt_append "void *extbuf" "socklen_t extlen" "int offset" "u_int8_t type" "socklen_t len" "u_int8_t align" "void **databufp"
51 .Ft "int"
52 .Fn inet6_opt_finish "void *extbuf" "socklen_t extlen" "int offset"
53 .Ft "int"
54 .Fn inet6_opt_set_val "void *databuf" "int offset" "void *val" "socklen_t vallen"
55 .Ft "int"
56 .Fn inet6_opt_next "void *extbuf" "socklen_t extlen" "int offset" "u_int8_t *typep" "socklen_t *lenp" "void **databufp"
57 .Ft "int"
58 .Fn inet6_opt_find "void *extbuf" "socklen_t extlen" "int offset" "u_int8_t type" "socklen_t *lenp" "void **databufp"
59 .Ft "int"
60 .Fn inet6_opt_get_val "void *databuf" "socklen_t offset" "void *val" "socklen_t vallen"
61 .\"
62 .Sh DESCRIPTION
63 Building and parsing the Hop-by-Hop and Destination options is
64 complicated.
65 The advanced sockets API defines a set of functions to
66 help applications create and manipulate Hop-by-Hope and Destination
67 options.
68 .\"This man page describes the functions specified in
69 .\"IETF Draft RFC3542 while the
70 .\".Xr inet6_options_space 3
71 .\"man page documents the functions defined in RFC 2292.
72 .\"It is expected
73 .\"that this set of functions will supersede those in RFC 2292 but for
74 .\"the time being both APIs are retained.
75 These functions use the
76 formatting rules specified in Appendix B in RFC2460, i.e., that the
77 largest field is placed last in the option.
78 The function prototypes
79 for these functions are all contained in the
80 .In netinet/in.h
81 header file.
82 .\"
83 .Ss inet6_opt_init
84 The
85 .Fn inet6_opt_init
86 function
87 returns the number of bytes needed for an empty
88 extension header, one without any options.
89 If the
90 .Va extbuf
91 argument points to a valid section of memory
92 then the
93 .Fn inet6_opt_init
94 function also initializes the extension header's length field.
95 When attempting to initialize an extension buffer passed in the
96 .Va extbuf argument
97 .Fa extlen
98 must be a positive multiple of 8 or else the function fails and
99 returns \-1 to the caller.
101 .Ss inet6_opt_append
103 .Fn inet6_opt_append
104 function can perform to different jobs.
105 When a valid
106 .Fa extbuf
107 argument is supplied it appends an option to the extension buffer and
108 returns the updated total length as well as a pointer to the newly
109 created option in
110 .Fa databufp .
111 If the value
113 .Fa extbuf
115 .Dv NULL
116 then the
117 .Fn inet6_opt_append function only reports what the total length would
118 be if the option were actually appended.
120 .Fa len
122 .Fa align
123 arguments specify the length of the option and the required data
124 alignment which must be used when appending the option.
126 .Fa offset
127 argument should be the length returned by the
128 .Fn inet6_opt_init
129 function or a previous call to
130 .Fn inet6_opt_append .
133 .Fa type
134 argument is the 8-bit option type.
136 After
137 .Fn inet6_opt_append
138 has been called, the application can use the buffer pointed to by
139 .Fa databufp
140 directly, or use
141 .Fn inet6_opt_set_val
142 to specify the data to be contained in the option.
144 Option types of
145 .Li 0
147 .Li 1
148 are reserved for the
149 .Li Pad1
151 .Li PadN
152 options.
153 All other values from 2 through 255 may be used by applications.
155 The length of the option data is contained in an 8-bit value and so
156 may contain any value from 0 through 255.
159 .Fa align
160 parameter must have a value of 1, 2, 4, or 8 and cannot exceed the
161 value of
162 .Fa len .
163 The alignment values represent no alignment, 16 bit, 32 bit and 64 bit
164 alignments respectively.
166 .Ss inet6_opt_finish
168 .Fn inet6_opt_finish
169 calculates the final padding necessary to make the extension header a
170 multiple of 8 bytes, as required by the IPv6 extension header
171 specification, and returns the extension header's updated total
172 length.
174 .Fa offset
175 argument should be the length returned by
176 .Fn inet6_opt_init
178 .Fn inet6_opt_append .
179 When
180 .Fa extbuf
181 is not
182 .Dv NULL
183 the function also sets up the appropriate padding bytes by inserting a
184 Pad1 or PadN option of the proper length.
186 If the extension header is too small to contain the proper padding
187 then an error of \-1 is returned to the caller.
189 .Ss inet6_opt_set_val
191 .Fn inet6_opt_set_val
192 function inserts data items of various sizes into the data portion of
193 the option.
195 .Fa databuf
196 argument is a pointer to memory that was returned by the
197 .Fn inet6_opt_append
198 call and the
199 .Fa offset argument specifies where the option should be placed in the
200 data buffer.
202 .Fa val
203 argument points to an area of memory containing the data to be
204 inserted into the extension header, and the
205 .Fa vallen
206 argument indicates how much data to copy.
208 The caller should ensure that each field is aligned on its natural
209 boundaries as described in Appendix B of RFC2460.
211 The function returns the offset for the next field which is calculated as
212 .Fa offset
214 .Fa vallen
215 and is used when composing options with multiple fields.
217 .Ss inet6_opt_next
219 .Fn inet6_opt_next
220 function parses received extension headers.
222 .Fa extbuf
224 .Fa extlen
225 arguments specify the location and length of the extension header
226 being parsed.
228 .Fa offset
229 argument should either be zero, for the first option, or the length value
230 returned by a previous call to
231 .Fn inet6_opt_next
233 .Fn inet6_opt_find .
234 The return value specifies the position where to continue scanning the
235 extension buffer.
236 The option is returned in the arguments
237 .Fa typep , lenp ,
239 .Fa databufp .
240 .Fa typep, lenp,
242 .Fa databufp
243 point to the 8-bit option type, the 8-bit option length and the option
244 data respectively.
245 This function does not return any PAD1 or PADN options.
246 When an error occurs or there are no more options the return
247 value is \-1.
249 .Ss inet6_opt_find
251 .Fn inet6_opt_find
252 function searches the extension buffer for a particular option type,
253 passed in through the
254 .Fa type
255 argument.
256 If the option is found then the
257 .Fa lenp
259 .Fa databufp
260 arguments are updated to point to the option's length and data
261 respectively.
262 .Fa extbuf
264 .Fa extlen
265 must point to a valid extension buffer and give its length.
267 .Fa offset
268 argument can be used to search from a location anywhere in the
269 extension header.
270 .Ss inet6_opt_get_val
272 .Fn inet6_opt_get_val
273 function extracts data items of various sizes in the data portion of
274 the option.
276 .Fa databuf
277 is a pointer returned by the
278 .Fn inet6_opt_next
280 .Fn inet6_opt_find
281 functions.
283 .Fa val
284 argument points where the data will be extracted.
286 .Fa offset
287 argument specifies from where in the data portion of the option the
288 value should be extracted; the first byte of option data is specified
289 by an offset of zero.
291 It is expected that each field is aligned on its natural boundaries as
292 described in Appendix B of RFC2460.
294 The function returns the offset for the next field
295 by calculating
296 .Fa offset
298 .Fa vallen
299 which can be used when extracting option content with multiple fields.
300 Robust receivers must verify alignment before calling this function.
302 .Sh DIAGNOSTICS
303 All the functions return
305 on an error.
307 .Sh EXAMPLES
308 RFC3542 gives comprehensive examples in Section 23.
310 KAME also provides examples in the
311 .Pa advapitest
312 directory of its kit.
314 .Sh SEE ALSO
316 .%A W. Stevens
317 .%A M. Thomas
318 .%A E. Nordmark
319 .%A T. Jinmei
320 .%T "Advanced Sockets API for IPv6"
321 .%N RFC3542
322 .%D October 2002
325 .%A S. Deering
326 .%A R. Hinden
327 .%T "Internet Protocol, Version 6 (IPv6) Specification"
328 .%N RFC2460
329 .%D December 1998
331 .Sh HISTORY
332 The implementation first appeared in KAME advanced networking kit.
333 .Sh STANDARDS
334 The functions are documented in
335 .Dq Advanced Sockets API for IPv6
336 .Pq RFC3542 .