From owner-freebsd-hackers@freebsd.org Tue Dec 8 19:51:07 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 D4BF39D46C4 for ; Tue, 8 Dec 2015 19:51:07 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from kib.kiev.ua (kib.kiev.ua [IPv6:2001:470:d5e7:1::1]) (using TLSv1 with cipher DHE-RSA-CAMELLIA256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 7E9B41B63 for ; Tue, 8 Dec 2015 19:51:07 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from tom.home (kostik@localhost [127.0.0.1]) by kib.kiev.ua (8.15.2/8.15.2) with ESMTPS id tB8Jp1Y4001029 (version=TLSv1 cipher=DHE-RSA-CAMELLIA256-SHA bits=256 verify=NO); Tue, 8 Dec 2015 21:51:02 +0200 (EET) (envelope-from kostikbel@gmail.com) DKIM-Filter: OpenDKIM Filter v2.10.3 kib.kiev.ua tB8Jp1Y4001029 Received: (from kostik@localhost) by tom.home (8.15.2/8.15.2/Submit) id tB8Jp1tQ001026; Tue, 8 Dec 2015 21:51:01 +0200 (EET) (envelope-from kostikbel@gmail.com) X-Authentication-Warning: tom.home: kostik set sender to kostikbel@gmail.com using -f Date: Tue, 8 Dec 2015 21:51:01 +0200 From: Konstantin Belousov To: Dag-Erling Sm??rgrav Cc: "freebsd-hackers@freebsd.org" Subject: Re: Fwd: DELETE support in the VOP_STRATEGY(9)? Message-ID: <20151208195101.GG82577@kib.kiev.ua> References: <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> <86h9jsrblk.fsf@desk.des.no> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <86h9jsrblk.fsf@desk.des.no> User-Agent: Mutt/1.5.24 (2015-08-30) X-Spam-Status: No, score=-2.0 required=5.0 tests=ALL_TRUSTED,BAYES_00, DKIM_ADSP_CUSTOM_MED,FREEMAIL_FROM,NML_ADSP_CUSTOM_MED autolearn=no autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on tom.home 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:51:08 -0000 On Tue, Dec 08, 2015 at 08:20:39PM +0100, Dag-Erling Sm??rgrav wrote: > Konstantin Belousov writes: > > Dag-Erling Sm??rgrav 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. I wrote that VOP_DELETE() or any other interface should work at the level of data blocks consituing the file data, and its only action should be removing the blocks from the inode, same as is done unlink or truncate. I wrote that any BIO_DELETE bios issued by the filesystem, should be issued by the code which already acts on freeing the blocks. In other words, no new handling or new semantic for BIO_DELETE is required (at least in context of UFS). We already issue BIO_DELETE on UFS. If your argument about being hard or impossbile for VOP_DELETE() is valid, it must be valid for the current UFS code. But I do not see how.