From owner-svn-src-all@freebsd.org Sun Jan 24 08:07:21 2016 Return-Path: Delivered-To: svn-src-all@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id B0190A8E31B; Sun, 24 Jan 2016 08:07:21 +0000 (UTC) (envelope-from glebius@FreeBSD.org) Received: from cell.glebi.us (glebi.us [96.95.210.25]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "cell.glebi.us", Issuer "cell.glebi.us" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id 9A1351F79; Sun, 24 Jan 2016 08:07:21 +0000 (UTC) (envelope-from glebius@FreeBSD.org) Received: from cell.glebi.us (localhost [127.0.0.1]) by cell.glebi.us (8.15.2/8.15.2) with ESMTPS id u0O87KlZ008931 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Sun, 24 Jan 2016 00:07:20 -0800 (PST) (envelope-from glebius@FreeBSD.org) Received: (from glebius@localhost) by cell.glebi.us (8.15.2/8.15.2/Submit) id u0O87Kb3008930; Sun, 24 Jan 2016 00:07:20 -0800 (PST) (envelope-from glebius@FreeBSD.org) X-Authentication-Warning: cell.glebi.us: glebius set sender to glebius@FreeBSD.org using -f Date: Sun, 24 Jan 2016 00:07:20 -0800 From: Gleb Smirnoff To: Lawrence Stewart Cc: src-committers@FreeBSD.org, svn-src-all@FreeBSD.org, svn-src-head@FreeBSD.org Subject: Re: svn commit: r294535 - in head/sys/netinet: . cc tcp_stacks Message-ID: <20160124080720.GE1004@FreeBSD.org> References: <201601212234.u0LMYpKT009948@repo.freebsd.org> <56A1D6B2.1010406@freebsd.org> <20160122181816.GB1004@FreeBSD.org> <56A31B78.2090100@freebsd.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <56A31B78.2090100@freebsd.org> User-Agent: Mutt/1.5.24 (2015-08-30) X-BeenThere: svn-src-all@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: "SVN commit messages for the entire src tree \(except for " user" and " projects" \)" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 24 Jan 2016 08:07:21 -0000 Lawrence, On Sat, Jan 23, 2016 at 05:19:36PM +1100, Lawrence Stewart wrote: L> > The problem is that cc.h (or tcp_cc.h) is already depening on many L> > TCP types. So, the structures defined inside are not agnostic, including L> > tcp headers before cc.h is required. L> L> Not in any significant way that tightly couples the API to TCP from L> consumers' perspective. L> L> > The old cc.h used to include tcp.h implicitly, which is a bad style. L> > L> > Since many developers sorted netinet/* includes in a .c file using L> > sort(1), that lead to cc.h always come before actual tcp includes, L> > hiding the real requirement for tcp.h in a .c file. L> L> To provide some more context, I considered that choice to be a lesser L> evil at the time. Linux had set the defacto standard macro naming and L> location so even though I would have put the CC related defines in cc.h L> given the choice, I wanted third-party software which checked for L> modular CC the Linux way to work on FreeBSD. The alphabetical ordering L> of includes is what prompted me to include tcp.h in cc.h so that cc.h L> could happily sit at the top of the list. I probably could have just L> moved cc.h to the cc subdir, in which case it would always come L> logically after the TCP includes as - perhaps that's L> the right solution. Well, if the intent was to provide some sort of compatibility with Linux, then my rename is even more valid! Look what left in the cc.h in the Netflix source (which is kinda forward of FreeBSD): almost the whole file is under _KERNEL. Only the tcp.h pollution left for userland. If Linux has cc.h and we want to put same definitions in cc.h, then we should start new cc.h and keep this one renamed. Because if we provided that one, we won't provide any compatibility, but would just pollute with tcp.h. I am fine with netinet/cc/cc.h. If you agree I can run the rename. -- Totus tuus, Glebius.