From owner-freebsd-net@FreeBSD.ORG Tue May 3 19:38:13 2011 Return-Path: Delivered-To: freebsd-net@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id D2587106564A for ; Tue, 3 May 2011 19:38:13 +0000 (UTC) (envelope-from qing.li@bluecoat.com) Received: from whisker.bluecoat.com (whisker.bluecoat.com [216.52.23.28]) by mx1.freebsd.org (Postfix) with ESMTP id AF56D8FC18 for ; Tue, 3 May 2011 19:38:13 +0000 (UTC) Received: from PWSVL-EXCHTS-01.internal.cacheflow.com ([10.2.2.122]) by whisker.bluecoat.com (8.14.2/8.14.2) with ESMTP id p43JcCd7006875 (version=TLSv1/SSLv3 cipher=AES128-SHA bits=128 verify=FAIL); Tue, 3 May 2011 12:38:12 -0700 (PDT) Received: from PWSVL-EXCMBX-01.internal.cacheflow.com ([fe80::15bc:12e2:4676:340f]) by PWSVL-EXCHTS-01.internal.cacheflow.com ([fe80::5c50:e2ba:8115:4223%20]) with mapi id 14.01.0255.000; Tue, 3 May 2011 12:38:06 -0700 From: "Li, Qing" To: Arnaud Lacombe Thread-Topic: interface ip arp Thread-Index: AQHMCFqrtGblL2pVN0K+AdsrWd9STpR4pYP8gAAxBUiAAMbUgP//ivAOgAAFxbCAAPwlAIABSgWQ Date: Tue, 3 May 2011 19:38:01 +0000 Message-ID: References: <10E473DB-A690-4468-953A-08D87AE07F68@bluecoat.com> In-Reply-To: Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.9.45.9] Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Cc: "freebsd-net@freebsd.org" , Ingo Flaschberger Subject: RE: interface ip arp X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 03 May 2011 19:38:13 -0000 Okay, please give the following patch a try, which should give the behavior= s that you observe in R6.x and R7.x. http://people.freebsd.org/~qingli/arp3.patch Thanks, --Qing > -----Original Message----- > From: Arnaud Lacombe [mailto:lacombar@gmail.com] > Sent: Monday, May 02, 2011 9:06 AM > To: Li, Qing > Cc: freebsd-net@freebsd.org; Ingo Flaschberger > Subject: Re: interface ip arp >=20 > Hi, >=20 > On Mon, May 2, 2011 at 4:03 AM, Li, Qing wrote: > > Please give this patch a try for IPv4 ARP > > > > http://people.freebsd.org/~qingli/arp2.patch > > > Your patch works; the manually added address is kept upon a up/down/up > transition. However, the interface address is still flush, which I > find inconsistent with it being marked 'permanent'. >=20 > - Arnaud >=20 > > --Qing > > > > ________________________________________ > > From: owner-freebsd-net@freebsd.org [owner-freebsd-net@freebsd.org] > on behalf of Li, Qing > > Sent: Monday, May 02, 2011 12:45 AM > > To: Arnaud Lacombe > > Cc: freebsd-net@freebsd.org; Ingo Flaschberger > > Subject: RE: interface ip arp > > > > Your patch doesn't work because the in_lltable_prefix_free() is =A0a > generic function. > > > > The static entries are kept only when issuing if-down command, > however, if the interface > > address is being removed, permanent static entries are gone and have > to be reinstalled. > > > > I already have a working patch for IPv4, just going over the IPv6 > code. > > > > I will post the patch in a few minutes. > > > > -- Qing > > > > ________________________________________ > > From: Arnaud Lacombe [lacombar@gmail.com] > > Sent: Monday, May 02, 2011 12:41 AM > > To: Li, Qing > > Cc: Ingo Flaschberger; freebsd-net@freebsd.org > > Subject: Re: interface ip arp > > > > Hi, > > > > On Sun, May 1, 2011 at 10:50 PM, Li, Qing > wrote: > >> jeez, this bug has been around for quite a while ... > >> > >> Please try patch at =A0http://people.freebsd.org/~qingli/arp.patch > >> > > d'oh!... Concerning Ingo's bug, your patch do the job, my report was > > bad, 4.9-RELEASE and 7.x show the same behavior: > > > > # uname -a > > FreeBSD server 7.1-RELEASE-p13 FreeBSD 7.1-RELEASE-p13 > > # ifconfig em0 up 192.168.45.200/24 > > # arp -n 192.168.45.200 > > ? (192.168.45.200) at 00:03:2d:16:6e:fc on em0 permanent [ethernet] > > # ifconfig em0 down > > # arp -n 192.168.45.200 > > 192.168.45.200 (192.168.45.200) -- no entry > > # ifconfig em0 up > > # arp -n 192.168.45.200 > > 192.168.45.200 (192.168.45.200) -- no entry > > > > The behavioral change I noticed is that permanent address (manually > > added) in the ARP table are flushed along with all other addresses on > >>8.x (cf. the script output of my previous mail) while they are kept > > in the cache on <7.x during a down/up transition. The following patch: > > > > diff --git a/sys/netinet/in.c b/sys/netinet/in.c > > index 1012012..27e44a2 100644 > > --- a/sys/netinet/in.c > > +++ b/sys/netinet/in.c > > @@ -1372,6 +1372,8 @@ in_lltable_prefix_free(struct lltable *llt, > > > > =A0 =A0 =A0 =A0for (i=3D0; i < LLTBL_HASHTBL_SIZE; i++) { > > =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0LIST_FOREACH_SAFE(lle, &llt->lle_head[i]= , lle_next, > next) { > > + =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 if (lle->la_flags & LLE_S= TATIC) > > + =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 continue; > > =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0if (IN_ARE_MASKED_ADDR_E= QUAL((struct > > sockaddr_in *)L3_ADDR(lle), > > =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0= =A0 =A0 =A0 =A0 =A0 =A0 =A0 =A0 pfx, msk)) { > > > > partially restores the old behavior. Only partially as before 8.x, > > interface addresses were not marked as 'permanent'. You could > manually > > add a 'permanent' entry for this address in such a way it would > > survive the down/up transition. In 8.x, the interface address is > > marked as 'permanent', but is removed explicitly by arp_ifscrub(). So > > even the above change would not work for the interface address. > > > > Shouldn't this address be removed later when "removing all L2 entries > > on the given prefix", in which case it would not have to be re-added > > again, if marking it 'permanent' is deliberate ? > > > > Thanks, > > =A0- Arnaud > > _______________________________________________ > > freebsd-net@freebsd.org mailing list > > http://lists.freebsd.org/mailman/listinfo/freebsd-net > > To unsubscribe, send any mail to "freebsd-net- > unsubscribe@freebsd.org" > >