From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:59619) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YVK96-0003cS-BB for qemu-devel@nongnu.org; Tue, 10 Mar 2015 09:24:31 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1YVK95-0000GM-3B for qemu-devel@nongnu.org; Tue, 10 Mar 2015 09:24:28 -0400 From: Markus Armbruster References: <1425971164-9845-1-git-send-email-mjt@msgid.tls.msk.ru> <20150310085016.GC3770@noname.str.redhat.com> <20150310091759.GC14320@ad.nay.redhat.com> <20150310100936.GD3770@noname.str.redhat.com> Date: Tue, 10 Mar 2015 14:24:16 +0100 In-Reply-To: <20150310100936.GD3770@noname.str.redhat.com> (Kevin Wolf's message of "Tue, 10 Mar 2015 11:09:36 +0100") Message-ID: <87mw3lx9xb.fsf@blackfin.pond.sub.org> MIME-Version: 1.0 Content-Type: text/plain Subject: Re: [Qemu-devel] [PATCH] block/dmg: make it modular if using additional library List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Kevin Wolf Cc: Fam Zheng , qemu-block@nongnu.org, qemu-trivial@nongnu.org, Michael Tokarev , qemu-devel@nongnu.org, Peter Wu , stefanha@redhat.com Kevin Wolf writes: > Am 10.03.2015 um 10:17 hat Fam Zheng geschrieben: >> On Tue, 03/10 09:50, Kevin Wolf wrote: >> > Am 10.03.2015 um 08:06 hat Michael Tokarev geschrieben: >> > > block/dmg can use additional library (libbz2) to read >> > > bzip2-compressed files. Make the block driver to be >> > > a module if libbz2 support is requested, to avoid extra >> > > library dependency by default. >> > > >> > > Signed-off-by: Michael Tokarev >> > >> > First of all: I don't think this is suitable for trivial. The actual >> > code change might be small, but the change in behaviour is important and >> > needs discussion. >> > >> > > This might be questionable, to make the thing to be either >> > > module or built-in depending on build environment, so a >> > > better idea may be to make it modular unconditionally. >> > > This block device format isn't used often. >> > >> > Yes, I'm concerned that making it conditional might be a bit surprising. >> > I'd like to hear some more opinions before applying this. >> >> I don't see the advantage over making it an unconditional module - condition >> only makes it a bit more complicated. >> >> > >> > Also, should we consider making some more rarely used image formats >> > modules even if they don't pull in external dependencies? >> >> Sounds reasonable to me. Is the intention to reduce binary size? Fair argument, but not a paricularly weighty one. The unused code never gets paged in, mostly, and isn't particularly large to begin with. > Yes, that and also that it allows compiling out some drivers without > having to mess with the Makefiles. You just don't install all of them. Second best solution of the configuration management problem "select a subset of the available block drivers", good enough when compiling the unused ones isn't bothersome. But the best solution is still configuration management capable of disabling optional components. > Related to that, Peter also mentioned that you (the user, not developer > or packager) could simply disable a single driver, for example as a > temporary hotfix in the case of security problems in a block driver. > That would actually be an argument for making _all_ drivers modules. And pretty much every other optional component. For me, avoiding bothersome dependencies is a strong practical argument for making a something a loadable module. Other benefits of loadable modules presented so far seem pretty negligible to me. If you want them, no objection from me, as long as the cost is similarly negligible, additional complexity for developers, packagers and users in particular.