From owner-freebsd-hackers@freebsd.org Tue Dec 8 19:20:46 2015 Return-Path: Delivered-To: freebsd-hackers@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 1E8999D4D87 for ; Tue, 8 Dec 2015 19:20:46 +0000 (UTC) (envelope-from des@des.no) Received: from smtp.des.no (smtp.des.no [194.63.250.102]) by mx1.freebsd.org (Postfix) with ESMTP id D8474178E for ; Tue, 8 Dec 2015 19:20:45 +0000 (UTC) (envelope-from des@des.no) Received: from desk.des.no (smtp.des.no [194.63.250.102]) by smtp.des.no (Postfix) with ESMTP id B9952D789; Tue, 8 Dec 2015 19:20:44 +0000 (UTC) Received: by desk.des.no (Postfix, from userid 1001) id 667CE482EF; Tue, 8 Dec 2015 20:20:39 +0100 (CET) From: =?utf-8?Q?Dag-Erling_Sm=C3=B8rgrav?= To: Konstantin Belousov Cc: "freebsd-hackers\@freebsd.org" Subject: Re: Fwd: DELETE support in the VOP_STRATEGY(9)? References: <201512052002.tB5K2ZEA026540@chez.mckusick.com> <86poyhqsdh.fsf@desk.des.no> <86fuzdqjwn.fsf@desk.des.no> <864mfssxgt.fsf@desk.des.no> <86wpsord9l.fsf@desk.des.no> <20151208185818.GD82577@kib.kiev.ua> Date: Tue, 08 Dec 2015 20:20:39 +0100 In-Reply-To: <20151208185818.GD82577@kib.kiev.ua> (Konstantin Belousov's message of "Tue, 8 Dec 2015 20:58:18 +0200") Message-ID: <86h9jsrblk.fsf@desk.des.no> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/24.5 (berkeley-unix) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 08 Dec 2015 19:20:46 -0000 Konstantin Belousov writes: > Dag-Erling Sm=C3=B8rgrav writes: > > The filesystem can ask the layer below if BIO_DELETE is supported, but > > should not assume anything about what it means. For instance, I could > > write a gnop-like module that translates BIO_DELETE into an all-zeroes > > BIO_WRITE and passes everything else unmodified. It would provide a > > stronger guarantee than, say, SATA TRIM but would also have a completely > > different performance profile (even on SSDs, since it would do its work > > synchronously whereas TRIM works asynchronously). > I again agree. This is how UFS issues TRIM. When the data block is freed > and there are no dandling pointers in the inode copy on disk pointing to > the block, BIO_DELETE is issued if volume reports it. Everything else > is up to the geom stack and driver. I'm not sure what point you're trying to make. I get the impression that you didn't really read what I wrote, just skimmed it and then included it as decoration, and that you're making the same mistake I'm trying (unsuccessfully, it seems) to prevent Maxim from making. Please go back and read everything I've written before. Yes, it's long(ish), but that's because it's a difficult problem which won't be solved by pretending it's easy and ignoring everybody who tells you it isn't. > > Anyway, my point is that Maxim needs to revise his assumptions. > Which does not invalidate the fact that a 'punch hole' interface is > useful. Allow me to quote my first email on the subject: | I'm not opposed to the idea of VOP_DELETE or similar, but don't assume | that "punching through" is always the correct semantic, and don't assume | that it will be easy to implement - and it will have to be implemented | correctly at every layer, in every geom, in every storage driver etc. | There are many details to work out and many opportunities for mistakes. DES --=20 Dag-Erling Sm=C3=B8rgrav - des@des.no