Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp542603ybl; Tue, 7 Jan 2020 10:34:29 -0800 (PST) X-Google-Smtp-Source: APXvYqz5Y6HbRZyZwN+ndTevM6fumzKnbsEojOdKPbZiNwPy5vM4RHwsweM/onMuPloYH7UMgM+P X-Received: by 2002:a05:6808:6c5:: with SMTP id m5mr618951oih.106.1578422069710; Tue, 07 Jan 2020 10:34:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578422069; cv=none; d=google.com; s=arc-20160816; b=soWs2xv6wF/Abmo7PxxJIJv1XmXrqHH+2iQV0URvBLOPolOQnquP5DVsbsPW8F0kTz GaPJ6mFWlt39F3L4DLCGHPWJnTbJxREpfTMVeifn0yPcA57MHJDjR/0pfS+YVWnFGn4s hYHSTUAz7KvxbRssPYC+pwWzo/uItvTqzQy+jBhJspLmBTjlBrx9K5I7wEgctXV9f8iy AskQ/Cbgk1/cMOldEAaIllzAbPbhX1ikrZbNVM2uI6HJxOgvWG20+azxGW0BZ2Q76qXG /ugP6zeffxnzTCtWlru1/H+yCq8szpgbPqvC90Nvxr0TwqOd6w4h6hxbRIQqQZE5wqf9 kaKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=o2v5kMDPXg2q4+QAcC/kCbrlQj05oGBBvgK3JOC1J3M=; b=UOkhu6q3FWt/XyeFGPiuc52ByBW2x6cfKktRJOWB+eZ/KzNHzxLLsVnazEMKnbCeOk q60jOKwvXNd25xXdhG+H++HHPedljWi92yVxQL9Y+KKU9j6XfMUvSgkXW9fyZU/IaqOG gQGptFZYw1HkTRVfmzohHtf9qv03pO6bMKybidUnrVQrCXLdqg6qwYF0pfc+q6bMXQEp WQMloyzlSLDWbeFwyFeklg2lg9XL3aw8wH6K6+GIFPwXgNQLcRlA/9n4pHZJx8LR/RVX o60Fdlb/4Vm+cXchIFk1+0NqN4PUlFDJnjyl/MmSEACiXmmTCenx9DwAEAy5grgdqfEQ g3IA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=V5yCte4r; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 5si399280oil.188.2020.01.07.10.34.17; Tue, 07 Jan 2020 10:34:29 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=V5yCte4r; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728606AbgAGSdT (ORCPT + 99 others); Tue, 7 Jan 2020 13:33:19 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:43099 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728584AbgAGSdT (ORCPT ); Tue, 7 Jan 2020 13:33:19 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1578421998; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=o2v5kMDPXg2q4+QAcC/kCbrlQj05oGBBvgK3JOC1J3M=; b=V5yCte4rgcV861M9EVonxcDrm4wSuMO88Pv89b56oH6H5TI1UJBW5wlFwnh1BvhLVIy7bB lwqM/AbP+s/ulR/og01ufS2BoxLmnLGVuwqjF1Xw2kI2OD944YXT/ifniYXiZPuPkNF5uP tuOCLRg7gEeRrU3NEC1n+dKU3qKSsVg= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-149-U97v-XCQMkax5zcCnuUoeQ-1; Tue, 07 Jan 2020 13:33:14 -0500 X-MC-Unique: U97v-XCQMkax5zcCnuUoeQ-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 2A55418C8C31; Tue, 7 Jan 2020 18:33:13 +0000 (UTC) Received: from horse.redhat.com (unknown [10.18.25.35]) by smtp.corp.redhat.com (Postfix) with ESMTP id E0E4F7C35A; Tue, 7 Jan 2020 18:33:07 +0000 (UTC) Received: by horse.redhat.com (Postfix, from userid 10451) id 6FF242202E9; Tue, 7 Jan 2020 13:33:07 -0500 (EST) Date: Tue, 7 Jan 2020 13:33:07 -0500 From: Vivek Goyal To: Dan Williams Cc: "Darrick J. Wong" , Christoph Hellwig , Dave Chinner , Miklos Szeredi , linux-nvdimm , Linux Kernel Mailing List , "Dr. David Alan Gilbert" , virtio-fs@redhat.com, Stefan Hajnoczi , linux-fsdevel Subject: Re: [PATCH 01/19] dax: remove block device dependencies Message-ID: <20200107183307.GD15920@redhat.com> References: <20190828175843.GB912@redhat.com> <20190828225322.GA7777@dread.disaster.area> <20191216181014.GA30106@redhat.com> <20200107125159.GA15745@infradead.org> <20200107170731.GA472641@magnolia> <20200107180101.GC15920@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.12.1 (2019-06-15) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jan 07, 2020 at 10:07:18AM -0800, Dan Williams wrote: > On Tue, Jan 7, 2020 at 10:02 AM Vivek Goyal wrote: > > > > On Tue, Jan 07, 2020 at 09:29:17AM -0800, Dan Williams wrote: > > > On Tue, Jan 7, 2020 at 9:08 AM Darrick J. Wong wrote: > > > > > > > > On Tue, Jan 07, 2020 at 06:22:54AM -0800, Dan Williams wrote: > > > > > On Tue, Jan 7, 2020 at 4:52 AM Christoph Hellwig wrote: > > > > > > > > > > > > On Mon, Dec 16, 2019 at 01:10:14PM -0500, Vivek Goyal wrote: > > > > > > > > Agree. In retrospect it was my laziness in the dax-device > > > > > > > > implementation to expect the block-device to be available. > > > > > > > > > > > > > > > > It looks like fs_dax_get_by_bdev() is an intercept point where a > > > > > > > > dax_device could be dynamically created to represent the subset range > > > > > > > > indicated by the block-device partition. That would open up more > > > > > > > > cleanup opportunities. > > > > > > > > > > > > > > Hi Dan, > > > > > > > > > > > > > > After a long time I got time to look at it again. Want to work on this > > > > > > > cleanup so that I can make progress with virtiofs DAX paches. > > > > > > > > > > > > > > I am not sure I understand the requirements fully. I see that right now > > > > > > > dax_device is created per device and all block partitions refer to it. If > > > > > > > we want to create one dax_device per partition, then it looks like this > > > > > > > will be structured more along the lines how block layer handles disk and > > > > > > > partitions. (One gendisk for disk and block_devices for partitions, > > > > > > > including partition 0). That probably means state belong to whole device > > > > > > > will be in common structure say dax_device_common, and per partition state > > > > > > > will be in dax_device and dax_device can carry a pointer to > > > > > > > dax_device_common. > > > > > > > > > > > > > > I am also not sure what does it mean to partition dax devices. How will > > > > > > > partitions be exported to user space. > > > > > > > > > > > > Dan, last time we talked you agreed that partitioned dax devices are > > > > > > rather pointless IIRC. Should we just deprecate partitions on DAX > > > > > > devices and then remove them after a cycle or two? > > > > > > > > > > That does seem a better plan than trying to force partition support > > > > > where it is not needed. > > > > > > > > Question: if one /did/ have a partitioned DAX device and used kpartx to > > > > create dm-linear devices for each partition, will DAX still work through > > > > that? > > > > > > The device-mapper support will continue, but it will be limited to > > > whole device sub-components. I.e. you could use kpartx to carve up > > > /dev/pmem0 and still have dax, but not partitions of /dev/pmem0. > > > > So we can't use fdisk/parted to partition /dev/pmem0. Given /dev/pmem0 > > is a block device, I thought tools will expect it to be partitioned. > > Sometimes I create those partitions and use /dev/pmem0. So what's > > the replacement for this. People often have tools/scripts which might > > want to partition the device and these will start failing. > > Partitioning will still work, but dax operation will be declined and > fall back to page-cache. Ok, so if I mount /dev/pmem0p1 with dax enabled, that might fail or filesystem will fall back to using page cache. (But dax will not be enabled). > > > IOW, I do not understand that why being able to partition /dev/pmem0 > > (which is a block device from user space point of view), is pointless. > > How about s/pointless/redundant/. Persistent memory can already be > "partitioned" via namespace boundaries. But that's an entirely different way of partitioning. To me being able to use block devices (with dax capability) in same way as any other block device makes sense. > Block device partitioning is > then redundant and needlessly complicates, as you have found, the > kernel implementation. It does complicate kernel implementation. Is it too hard to solve the problem in kernel. W.r.t partitioning, bdev_dax_pgoff() seems to be the pain point where dax code refers back to block device to figure out partition offset in dax device. If we create a dax object corresponding to "struct block_device" and store sector offset in that, then we could pass that object to dax code and not worry about referring back to bdev. I have written some proof of concept code and called that object "dax_handle". I can post that code if there is interest. IMHO, it feels useful to be able to partition and use a dax capable block device in same way as non-dax block device. It will be really odd to think that if filesystem is on /dev/pmem0p1, then dax can't be enabled but if filesystem is on /dev/mapper/pmem0p1, then dax will work. Thanks Vivek > > The problem will be people that were on dax+ext4 on partitions. Those > people will see a hard failure at mount whereas XFS will fallback to > page cache with a warning in the log. I think ext4 must convert to the > xfs dax handling model before partition support is dropped. >