2016-10-16 08:32:30 +03:00
|
|
|
.\" $NetBSD: arp.4,v 1.14 2016/10/16 05:32:30 wiz Exp $
|
1995-03-01 14:50:52 +03:00
|
|
|
.\"
|
1994-12-22 14:31:31 +03:00
|
|
|
.\" Copyright (c) 1985, 1986, 1988, 1994
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
2003-08-07 15:25:11 +04:00
|
|
|
.\" 3. Neither the name of the University nor the names of its contributors
|
1994-12-22 14:31:31 +03:00
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" from: @(#)arp4.4 6.5 (Berkeley) 4/18/94
|
|
|
|
.\"
|
2016-10-12 11:43:17 +03:00
|
|
|
.Dd October 12, 2016
|
1994-12-22 14:31:31 +03:00
|
|
|
.Dt ARP 4
|
1999-03-22 21:43:46 +03:00
|
|
|
.Os
|
1994-12-22 14:31:31 +03:00
|
|
|
.Sh NAME
|
|
|
|
.Nm arp
|
|
|
|
.Nd Address Resolution Protocol
|
|
|
|
.Sh SYNOPSIS
|
2003-04-16 17:34:34 +04:00
|
|
|
.In netinet/if_ether.h
|
1994-12-22 14:31:31 +03:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The Address Resolution Protocol (ARP) is a protocol used to dynamically
|
2000-10-17 16:23:03 +04:00
|
|
|
map between Internet host addresses and Ethernet addresses.
|
|
|
|
It is used by all the Ethernet interface drivers.
|
|
|
|
It is not specific to Internet protocols or to Ethernet,
|
1994-12-22 14:31:31 +03:00
|
|
|
but this implementation currently supports only that combination.
|
|
|
|
.Pp
|
2002-01-19 06:05:58 +03:00
|
|
|
ARP caches Internet-Ethernet address mappings.
|
1994-12-22 14:31:31 +03:00
|
|
|
When an interface requests a mapping for an address not in the cache,
|
|
|
|
ARP queues the message which requires the mapping and broadcasts
|
|
|
|
a message on the associated network requesting the address mapping.
|
|
|
|
If a response is provided, the new mapping is cached and any pending
|
|
|
|
message is transmitted.
|
|
|
|
ARP will queue at most one packet while waiting for a response to a
|
|
|
|
mapping request;
|
|
|
|
only the most recently ``transmitted'' packet is kept.
|
|
|
|
If the target host does not respond after several requests,
|
|
|
|
the host is considered to be down for a short period (normally 20 seconds),
|
|
|
|
allowing an error to be returned to transmission attempts during this
|
|
|
|
interval.
|
|
|
|
The error is
|
1997-03-07 10:41:25 +03:00
|
|
|
.Er EHOSTDOWN
|
1994-12-22 14:31:31 +03:00
|
|
|
for a non-responding destination host, and
|
1997-03-07 10:41:25 +03:00
|
|
|
.Er EHOSTUNREACH
|
1994-12-22 14:31:31 +03:00
|
|
|
for a non-responding router.
|
|
|
|
.Pp
|
2016-04-04 10:37:07 +03:00
|
|
|
Each ARP cache entry is stored in a network interface which a response
|
|
|
|
of ARP comes in.
|
|
|
|
ARP cache entires time out periodically (normally 20 minutes after validated;
|
1994-12-22 14:31:31 +03:00
|
|
|
entries are not validated when not in use).
|
|
|
|
.Pp
|
|
|
|
ARP entries may be added, deleted or changed with the
|
|
|
|
.Xr arp 8
|
|
|
|
utility.
|
|
|
|
Manually-added entries may be temporary or permanent,
|
|
|
|
and may be
|
|
|
|
.Dq published ,
|
|
|
|
in which case the system will respond to ARP requests for that host
|
|
|
|
as if it were the target of the request.
|
|
|
|
.Pp
|
|
|
|
In the past,
|
|
|
|
ARP was used to negotiate the use of a trailer encapsulation.
|
|
|
|
This is no longer supported.
|
|
|
|
.Sh DIAGNOSTICS
|
1997-03-07 10:41:25 +03:00
|
|
|
.Bl -diag
|
2016-10-12 11:43:17 +03:00
|
|
|
ARP implements Address Conflict Detection.
|
2016-10-16 08:32:30 +03:00
|
|
|
When an address is first added to the host, it is marked tentative and
|
2016-10-12 11:43:17 +03:00
|
|
|
ARP probes the network to discover if another host has the address.
|
|
|
|
If another host replies with the same address, then the local address is
|
2016-10-16 08:32:30 +03:00
|
|
|
marked duplicate and the host will not use it.
|
|
|
|
Otherwise the tentative
|
2016-10-12 11:43:17 +03:00
|
|
|
mark is removed and the host can start using the address.
|
|
|
|
.Pp
|
|
|
|
ARP will defend the host's active address when a conflicting message is
|
|
|
|
received.
|
|
|
|
However, if another conflicting message for the address is found within
|
|
|
|
a 10 second period, then the address is marked duplicate and the host will
|
|
|
|
stop using it.
|
|
|
|
.Pp
|
|
|
|
For some systems such as a router or a server,
|
|
|
|
it is desirable never to give up an assigned address.
|
|
|
|
This can be achieved by setting the
|
|
|
|
.Xr sysctl 7
|
|
|
|
variable
|
|
|
|
.Dv net.inet.ip_dad_count
|
|
|
|
to 0.
|
|
|
|
.Pp
|
|
|
|
In all of the above cases, ARP will log diagnostic messages which include
|
|
|
|
the hardware address of the conflicting host.
|
1997-03-07 10:41:25 +03:00
|
|
|
.El
|
1994-12-22 14:31:31 +03:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr inet 4 ,
|
|
|
|
.Xr route 4 ,
|
|
|
|
.Xr arp 8 ,
|
|
|
|
.Xr ifconfig 8 ,
|
|
|
|
.Xr route 8
|
|
|
|
.sp
|
|
|
|
.Rs
|
|
|
|
.%A Plummer, D.
|
|
|
|
.%B "An Ethernet Address Resolution Protocol"
|
2003-09-07 20:22:20 +04:00
|
|
|
.%T RFC 826
|
1994-12-22 14:31:31 +03:00
|
|
|
.Re
|
|
|
|
.Rs
|
|
|
|
.%A Leffler, S.J.
|
|
|
|
.%A Karels, M.J.
|
1997-03-07 10:41:25 +03:00
|
|
|
.%B "Trailer Encapsulations"
|
2003-09-07 20:22:20 +04:00
|
|
|
.%T RFC 893
|
1994-12-22 14:31:31 +03:00
|
|
|
.Re
|
2016-10-12 11:43:17 +03:00
|
|
|
.Rs
|
|
|
|
.%A Cheshire, S.
|
|
|
|
.%B "IPv4 Address Conflict Detection"
|
|
|
|
.%T RFC 5227
|
|
|
|
.Re
|
2016-04-04 16:29:12 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
Since
|
|
|
|
.Nx 8.0 ,
|
|
|
|
the ARP cache was not stored in the routing table.
|
2016-10-12 11:43:17 +03:00
|
|
|
.Pp
|
|
|
|
Address Conflict Detection was added in
|
|
|
|
.Nx 8.0 .
|