From owner-freebsd-hackers Mon Mar 3 21:38:13 1997 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id VAA25190 for hackers-outgoing; Mon, 3 Mar 1997 21:38:13 -0800 (PST) Received: from alpo.whistle.com (alpo.whistle.com [207.76.204.38]) by freefall.freebsd.org (8.8.5/8.8.5) with ESMTP id VAA25120 for ; Mon, 3 Mar 1997 21:36:49 -0800 (PST) Received: from current1.whistle.com (current1.whistle.com [207.76.205.22]) by alpo.whistle.com (8.8.5/8.8.4) with SMTP id VAA20473; Mon, 3 Mar 1997 21:34:31 -0800 (PST) Message-ID: <331BB3DD.41C67EA6@whistle.com> Date: Mon, 03 Mar 1997 21:32:13 -0800 From: Julian Elischer Organization: Whistle Communications X-Mailer: Mozilla 3.0Gold (X11; I; FreeBSD 2.2-CURRENT i386) MIME-Version: 1.0 To: Bakul Shah CC: hackers@freebsd.org Subject: Re: [FUN/WORK] BSD Networking virtual meeting. References: <199703040432.XAA28477@chai.plexuscom.com> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-hackers@freebsd.org X-Loop: FreeBSD.org Precedence: bulk Bakul Shah wrote: > > May be a networking mailing list should also be set up. > hackers/current/stable have way too much traffic. yes for sure.. (I'm not sure there isn't one..) just looked.. No, not that I could see. > > > and I'm struggling with making routes and ifaddrs go away at > > the right time. > > A prior public discussion of this may be useful. well I have a basic set of patches.. here's the theory: ifaddrs are linked off an ifnet. each ifaddr has a reference count, so that when nothing needs it any more, it can be freed. so far this is what SHOULD happen. unfortunatly, there's a hitch.. If you invalidate and ifaddr, the routes that were set up do not notice, because they have both a pointer to the ifaddr, and a pointer to the ifnet. This is bogus.. they should notice that the ifaddr has been invalidated and free their own reference to it, and get rid of their pointer to the ifnet. If you remove an address from an interface, packets routed using that address should not continue to use that route (now bogus) but should re-evaluate the route. As they (one by one) check the route, the old ifaddr should have less and less references to it, until eventually it reaches 0 and the ifaddr is freed. The other part of the equation is to be proactive about it and whenever an ifaddr is removed, clean out any affected routes in the routing table. This is where I'm hitting problems. at the moment, ARP entries are being removed from the table, but not from the ARP list, (llinfo is not being taken out of the) llinfo list when they are removed due to a change in ifaddr. eventually the llinfo times out (18 minutes arp timeout) and the code suddenly discovers that the rest of that route was freed ages ago, and falls off a random pointer. > > > is there anyone else who'd be intersted? > > I am interested but no mbone access :-( maybe we could use a chat room.. > > > Certainly this idea comes from my own frustration > > in not being able to get my mind around the damn > > routing code.. there's always some !@#$ gotcha that makes anything > > I want to do non-trivial. > > Is this related to your `new' networking framework or are you trying > to make route.c & friends do something unusual? teh framework led to me wanting to make interfaces go away, but this is allin the existing portion of the code, not the new part. > > > Certainly if we can once work out the technology for this we should > > be able to use it to great effect! > > :=)