From owner-freebsd-current@FreeBSD.ORG Sat Nov 17 16:54:14 2007 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 87C2C16A418 for ; Sat, 17 Nov 2007 16:54:14 +0000 (UTC) (envelope-from rwatson@FreeBSD.org) Received: from cyrus.watson.org (cyrus.watson.org [209.31.154.42]) by mx1.freebsd.org (Postfix) with ESMTP id 4068213C467 for ; Sat, 17 Nov 2007 16:54:14 +0000 (UTC) (envelope-from rwatson@FreeBSD.org) Received: from fledge.watson.org (fledge.watson.org [209.31.154.41]) by cyrus.watson.org (Postfix) with ESMTP id 0D22747018; Sat, 17 Nov 2007 11:56:05 -0500 (EST) Date: Sat, 17 Nov 2007 16:53:48 +0000 (GMT) From: Robert Watson X-X-Sender: robert@fledge.watson.org To: Bruce M Simpson In-Reply-To: <473F1B7C.1080907@incunabulum.net> Message-ID: <20071117165225.L11646@fledge.watson.org> References: <4732110D.3090808@interactive-net.de> <200711171227.21855.zec@icir.org> <473EE26E.6050905@incunabulum.net> <200711171428.13522.zec@icir.org> <473F1B7C.1080907@incunabulum.net> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: Marko Zec , Reinhard Haller , freebsd-current@freebsd.org Subject: Re: 7.0-BETA2 routed and multicast registration X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 17 Nov 2007 16:54:14 -0000 On Sat, 17 Nov 2007, Bruce M Simpson wrote: > I take more time out of the weekend to shout about legacy kludge... > > We can put a nice big comment in that says "this is an old crusty hack, it > is NOT SUPPORTED for new code", but it's better not to have kludges there in > the first place. > > We can bring it back in the 7-current train to keep folk happy for now, > sure, but I strongly suggest we get rid of it in future, otherwise, we risk > not taking the step of progress -- EBIKESHED. Speaking of deprecated -- are the interfaces marked as deprecated in the 6.x man pages? If not, there's a reasonabl argument to be made that they weren't deprecated, only eliminated. :-) At this point, in the interest of shipping working apps, it's sounding like we may need to re-add the interfaces to 7.x with clear deprecation markings. I'm not sure I'd go for Julian's suggestion of a sysctl, which simply makes things that should be easy harder for our users, as opposed to third party developers. Robert N M Watson Computer Laboratory University of Cambridge > > If ye wish to know more, read on. > > Marko Zec wrote: >> Nobody is questioning the benefits of having RFC 3678 support added to the >> kernel, but quickly skimming through that document I can't find a line >> stipulating that it should deprecate older interfaces already in use. What >> is the exact benefit of deprecating the 0.0.0.0/8 hack (i.e. RFC 1724 >> compliant ifnet addressing), i.e. why couldn't we have support for both the >> new and the old interface for legacy applications, given that the >> interfaces don't seem to be in conflict? >> > > They aren't mutually exclusive. > > However, sometimes the only way to get people to sit up and take notice about > the finer things in life is to wave a black flag -- even if this happens 6 > months after something actually occurred -- because I can't compel or use > force to make anyone to agree with me, so I have to resort to other methods, > like being irritating to others. > > It is a crusty old hack that creates yet another special case in a bunch of > kernel code. It gives special meaning to the first eight bits of an IPv4 > address which happen to be zero. It ain't elegant. RFC 1724 was only ever > intended to be specific to RIP. > > This is just not the right way to support unnumbered interfaces in IPv4. In > fact, if you look at Linux, they already dealt with this problem by > implementing scoped IPv4 addresses in-kernel -- too many bits of IPv4 depend > upon having an address on a link, such as sockets, routing protocols, IGMP, > hence Stuart Cheshire coming up with RFC 3927. > > Which is why I backported their answer to the problem in the legacy API -- > ip_mreqn. I encourage everyone to look at the patch: > http://people.freebsd.org/~bms/dump/ssm_phase1/ssm_phase1.diff > > I draw everyone's attention to the comment re the use of the ip_mreqn > structure, clearly visible at the top of this patch. > > In short, it needs to go. I realize this is an argument that mostly appeals > to those who don't follow the Law of Excluded Middle in logic, but, sometimes > that's the way the cookie crumbles. > > Open source often serves as an example for how to do things, and the code > that is there is sometimes accepted as gospel, particularly by students, who > might not always question its wisdom or lack thereof; and this is another > thing that I'm getting at. > > Of course anything that comes out of my mouth is, mutatis mutandis, subject > to the same judgement. If I ain't in trouble, I ain't doing my job! > > best, > BMS >