Sync some manuals from bin & sbin with NetBSD-8
[minix.git] / sbin / ping6 / ping6.8
blob544b0e0e03415cf0252fa0eff7b027de7458d7b8
1 .\"     $NetBSD: ping6.8,v 1.30 2015/05/15 08:02:39 kefren Exp $
2 .\"     $KAME: ping6.8,v 1.57 2002/05/26 13:18:25 itojun Exp $
3 .\"
4 .\" Copyright (C) 1995, 1996, 1997, and 1998 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 April 23, 2015
32 .Dt PING6 8
33 .Os
34 .Sh NAME
35 .Nm ping6
36 .Nd send
37 .Tn ICMPv6 ECHO_REQUEST
38 packets to network hosts
39 .Sh SYNOPSIS
40 .Nm ping6
41 .\" without IPsec, or new IPsec
42 .Op Fl dfHmnNoqRtvwW
43 .\" old IPsec
44 .\" .Op Fl AdEfnNqRtvwW
45 .Op Fl a Ar addrtype
46 .Op Fl b Ar bufsiz
47 .Op Fl c Ar count
48 .Op Fl g Ar gateway
49 .Op Fl h Ar hoplimit
50 .Op Fl I Ar interface
51 .Op Fl i Ar wait
52 .Op Fl l Ar preload
53 .Op Fl p Ar pattern
54 .\" new IPsec
55 .Op Fl P Ar policy
56 .Op Fl S Ar sourceaddr
57 .Op Fl s Ar packetsize
58 .Op Fl x Ar maxwait
59 .Op Fl X Ar deadline
60 .Op Ar hops ...
61 .Ar host
62 .Sh DESCRIPTION
63 .Nm
64 uses the
65 .Tn ICMPv6
66 protocol's mandatory
67 .Tn ICMP6_ECHO_REQUEST
68 datagram to elicit an
69 .Tn ICMP6_ECHO_REPLY
70 from a host or gateway.
71 .Tn ICMP6_ECHO_REQUEST
72 datagrams (``pings'') have an IPv6 header,
73 and
74 .Tn ICMPv6
75 header formatted as documented in RFC 2463.
76 The options are as follows:
77 .Bl -tag -width Ds
78 .\" old IPsec
79 .\" .It Fl A
80 .\" Enables transport-mode IPsec authentication header
81 .\" .Pq experimental .
82 .It Fl a Ar addrtype
83 Generate ICMPv6 Node Information Node Addresses query, rather than echo-request.
84 .Ar addrtype
85 must be a string constructed of the following characters.
86 .Bl -tag -width Ds -compact
87 .It Ic a
88 requests unicast addresses from all of the responder's interfaces.
89 If the character is omitted,
90 only those addresses which belong to the interface which has the
91 responder's address are requests.
92 .It Ic c
93 requests responder's IPv4-compatible and IPv4-mapped addresses.
94 .It Ic g
95 requests responder's global-scope addresses.
96 .It Ic s
97 requests responder's site-local addresses.
98 .It Ic l
99 requests responder's link-local addresses.
100 .It Ic A
101 requests responder's anycast addresses.
102 Without this character, the responder will return unicast addresses only.
103 With this character, the responder will return anycast addresses only.
104 Note that the specification does not specify how to get responder's
105 anycast addresses.
106 This is an experimental option.
108 .It Fl b Ar bufsiz
109 Set socket buffer size.
110 .It Fl c Ar count
111 Stop after sending
112 .Pq and receiving
113 .Ar count
114 .Tn ECHO_RESPONSE
115 packets.
116 .It Fl d
117 Set the
118 .Dv SO_DEBUG
119 option on the socket being used.
120 .\" .It Fl E
121 .\" Enables transport-mode IPsec encapsulated security payload
122 .\" .Pq experimental .
123 .It Fl f
124 Flood ping.
125 Outputs packets as fast as they come back or one hundred times per second,
126 whichever is more.
127 For every
128 .Tn ECHO_REQUEST
129 sent a period
130 .Dq \&.
131 is printed, while for every
132 .Tn ECHO_REPLY
133 received a backspace is printed.
134 This provides a rapid display of how many packets are being dropped.
135 Only the super-user may use this option.
136 .Bf -emphasis
137 This can be very hard on a network and should be used with caution.
139 .It Fl g Ar gateway
140 Specifies to use
141 .Ar gateway
142 as the next hop to the destination.
143 The gateway must be a neighbor of the sending node.
144 .It Fl H
145 Specifies to try reverse-lookup of IPv6 addresses.
148 command does not try reverse-lookup unless the option is specified.
149 .It Fl h Ar hoplimit
150 Set the IPv6 hoplimit.
151 .It Fl I Ar interface
152 Source packets with the given interface address.
153 This flag applies if the ping destination is a multicast address,
154 or link-local/site-local unicast address.
155 .It Fl i Ar wait
156 Wait
157 .Ar wait
158 seconds
159 .Em between sending each packet .
160 The default is to wait for one second between each packet.
161 This option is incompatible with the
162 .Fl f
163 option.
164 .It Fl l Ar preload
166 .Ar preload
167 is specified,
169 sends that many packets as fast as possible before falling into its normal
170 mode of behavior.
171 Only the super-user may use this option.
172 .It Fl m
173 By default,
175 asks the kernel to fragment packets to fit into the minimum IPv6 MTU.
176 .Fl m
177 will suppress the behavior in the following two levels:
178 when the option is specified once, the behavior will be disabled for
179 unicast packets.
180 When the option is specified more than once, it will be disabled for both
181 unicast and multicast packets.
182 .It Fl n
183 Numeric output only.
184 No attempt will be made to lookup symbolic names from addresses in the reply.
185 .It Fl N
186 Probe node information multicast group
187 .Pq Li ff02::2:xxxx:xxxx .
188 .Ar host
189 must be string hostname of the target
190 .Pq must not be a numeric IPv6 address .
191 Node information multicast group will be computed based on given
192 .Ar host ,
193 and will be used as the final destination.
194 Since node information multicast group is a link-local multicast group,
195 outgoing interface needs to be specified by
196 .Fl I
197 option.
198 .It Fl o
199 Exit successfully after receiving one reply packet.
200 .It Fl p Ar pattern
201 You may specify up to 16
202 .Dq pad
203 bytes to fill out the packet you send.
204 This is useful for diagnosing data-dependent problems in a network.
205 For example,
206 .Dq Li \-p ff
207 will cause the sent packet to be filled with all
208 ones.
209 .\" new IPsec
210 .It Fl P Ar policy
211 .Ar policy
212 specifies IPsec policy to be used for the probe.
213 .It Fl q
214 Quiet output.
215 Nothing is displayed except the summary lines at startup time and
216 when finished.
217 .It Fl R
218 Make the kernel believe that the target
219 .Ar host
221 or the first
222 .Ar hop
223 if you specify
224 .Ar hops
226 is reachable, by injecting upper-layer reachability confirmation hint.
227 The option is meaningful only if the target
228 .Ar host
229 .Pq or the first hop
230 is a neighbor.
231 .It Fl S Ar sourceaddr
232 Specifies the source address of request packets.
233 The source address must be one of the unicast addresses of the sending node,
234 and must be numeric.
235 .It Fl s Ar packetsize
236 Specifies the number of data bytes to be sent.
237 The default is 56, which translates into 64
238 .Tn ICMP
239 data bytes when combined
240 with the 8 bytes of
241 .Tn ICMP
242 header data.
243 You may need to specify
244 .Fl b
245 as well to extend socket buffer size.
246 .It Fl t
247 Generate ICMPv6 Node Information supported query types query,
248 rather than echo-request.
249 .Fl s
250 has no effect if
251 .Fl t
252 is specified.
253 .It Fl v
254 Verbose output.
255 .Tn ICMP
256 packets other than
257 .Tn ECHO_RESPONSE
258 that are received are listed.
259 .It Fl w
260 Generate ICMPv6 Node Information DNS Name query, rather than echo-request.
261 .Fl s
262 has no effect if
263 .Fl w
264 is specified.
265 .It Fl W
266 Same as
267 .Fl w ,
268 but with old packet format based on 03 draft.
269 This option is present for backward compatibility.
270 .Fl s
271 has no effect if
272 .Fl w
273 is specified.
274 .It Fl x Ar maxwait
275 Time in milliseconds to wait for a reply for each packet sent.
276 .It Fl X Ar deadline
277 Specify a timeout, in seconds, before ping exits regardless of
278 how many packets have been received.
279 .It Ar hops
280 IPv6 addresses for intermediate nodes,
281 which will be put into type 0 routing header.
282 .It Ar host
283 IPv6 address of the final destination node.
286 When using
288 for fault isolation, it should first be run on the local host, to verify
289 that the local network interface is up and running.
290 Then, hosts and gateways further and further away should be
291 .Dq pinged .
292 Round-trip times and packet loss statistics are computed.
293 If duplicate packets are received, they are not included in the packet
294 loss calculation, although the round trip time of these packets is used
295 in calculating the round-trip time statistics.
296 When the specified number of packets have been sent
297 .Pq and received
298 or if the program is terminated with a
299 .Dv SIGINT ,
300 a brief summary is displayed, showing the number of packets sent and
301 received, and the minimum, maximum, mean, and standard deviation of
302 the round-trip times.
304 This program is intended for use in network testing, measurement and
305 management.
306 Because of the load it can impose on the network, it is unwise to use
308 during normal operations or from automated scripts.
309 .\" .Sh ICMP PACKET DETAILS
310 .\" An IP header without options is 20 bytes.
311 .\" An
312 .\" .Tn ICMP
313 .\" .Tn ECHO_REQUEST
314 .\" packet contains an additional 8 bytes worth of
315 .\" .Tn ICMP
316 .\" header followed by an arbitrary amount of data.
317 .\" When a
318 .\" .Ar packetsize
319 .\" is given, this indicated the size of this extra piece of data
320 .\" .Pq the default is 56 .
321 .\" Thus the amount of data received inside of an IP packet of type
322 .\" .Tn ICMP
323 .\" .Tn ECHO_REPLY
324 .\" will always be 8 bytes more than the requested data space
325 .\" .Pq the Tn ICMP header .
326 .\" .Pp
327 .\" If the data space is at least eight bytes large,
328 .\" .Nm
329 .\" uses the first eight bytes of this space to include a timestamp which
330 .\" it uses in the computation of round trip times.
331 .\" If less than eight bytes of pad are specified, no round trip times are
332 .\" given.
333 .Sh DUPLICATE AND DAMAGED PACKETS
335 will report duplicate and damaged packets.
336 Duplicate packets should never occur when pinging a unicast address,
337 and seem to be caused by
338 inappropriate link-level retransmissions.
339 Duplicates may occur in many situations and are rarely
340 .Pq if ever
341 a good sign, although the presence of low levels of duplicates may not
342 always be cause for alarm.
343 Duplicates are expected when pinging a multicast address,
344 since they are not really duplicates but replies from different hosts
345 to the same request.
347 Damaged packets are obviously serious cause for alarm and often
348 indicate broken hardware somewhere in the
350 packet's path
351 .Pq in the network or in the hosts .
352 .Sh TRYING DIFFERENT DATA PATTERNS
354 (inter)network
355 layer should never treat packets differently depending on the data
356 contained in the data portion.
357 Unfortunately, data-dependent problems have been known to sneak into
358 networks and remain undetected for long periods of time.
359 In many cases the particular pattern that will have problems is something
360 that does not have sufficient
361 .Dq transitions ,
362 such as all ones or all zeros, or a pattern right at the edge, such as
363 almost all zeros.
364 It is not
365 necessarily enough to specify a data pattern of all zeros (for example)
366 on the command line because the pattern that is of interest is
367 at the data link level, and the relationship between what you type and
368 what the controllers transmit can be complicated.
370 This means that if you have a data-dependent problem you will probably
371 have to do a lot of testing to find it.
372 If you are lucky, you may manage to find a file that either
373 cannot
374 be sent across your network or that takes much longer to transfer than
375 other similar length files.
376 You can then examine this file for repeated patterns that you can test
377 using the
378 .Fl p
379 option of
380 .Nm Ns .
381 .Sh EXIT STATUS
383 exits with 0 on success (the host is alive),
384 and non-zero if the arguments are incorrect or the host is not responding.
385 .Sh EXAMPLES
386 Normally,
388 works just like
389 .Xr ping 8
390 would work; the following will send ICMPv6 echo request to
391 .Li dst.foo.com .
392 .Bd -literal -offset indent
393 ping6 -n dst.foo.com
396 The following will probe hostnames for all nodes on the network link attached to
397 .Li wi0
398 interface.
399 The address
400 .Li ff02::1
401 is named the link-local all-node multicast address, and the packet would
402 reach every node on the network link.
403 .Bd -literal -offset indent
404 ping6 -w ff02::1%wi0
407 The following will probe addresses assigned to the destination node,
408 .Li dst.foo.com .
409 .Bd -literal -offset indent
410 ping6 -a agl dst.foo.com
412 .Sh SEE ALSO
413 .Xr netstat 1 ,
414 .Xr icmp6 4 ,
415 .Xr inet6 4 ,
416 .Xr ip6 4 ,
417 .Xr ifconfig 8 ,
418 .Xr ping 8 ,
419 .Xr routed 8 ,
420 .Xr traceroute 8 ,
421 .Xr traceroute6 8
423 .%A A. Conta
424 .%A S. Deering
425 .%T "Internet Control Message Protocol (ICMPv6) for the Internet Protocol Version 6 (IPv6) Specification"
426 .%N RFC 2463
427 .%D December 1998
430 .%A Matt Crawford
431 .%T "IPv6 Node Information Queries"
432 .%N draft-ietf-ipngwg-icmp-name-lookups-09.txt
433 .%D May 2002
434 .%O work in progress material
436 .Sh HISTORY
438 .Xr ping 8
439 command appeared in
440 .Bx 4.3 .
443 command with IPv6 support first appeared in the WIDE Hydrangea IPv6
444 protocol stack kit.
445 .Sh BUGS
446 .\" except for bsdi
448 is intentionally separate from
449 .Xr ping 8 .