Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp286351ybl; Tue, 7 Jan 2020 06:12:08 -0800 (PST) X-Google-Smtp-Source: APXvYqxiOXIJvHBm2lg+WlazhIE1VKbJkYiz4mYxTeSKuW6VdyfYda3WkQN5kj9sek/JiGst9Qgq X-Received: by 2002:a9d:634e:: with SMTP id y14mr18875736otk.162.1578406328015; Tue, 07 Jan 2020 06:12:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578406328; cv=none; d=google.com; s=arc-20160816; b=GIedw5aCHGSUUaNOLskVy3CfbiBIJF+NxhuU1/Nlx3iy885zkikIK1mK94/SzxtuFY vQIp9tjN/xDQjdrpl56INN5NlVfugvOMKmkDgWnOcNZrOhlts0e/Xu9jf0nFpiiTfapi mNK/RoZ+jxLr3OV3wT9GQJorDpmGh/cK/HXgIXszdXwOery28QXYRzhbsngu+SSH2IPv Xmv5DaSCtEta1pgDMIqJEuqgwzM4eccamG471LF9WT5zcGPbF3Nin6E7gbi9sSREgdUk e7zi+YgS/sI5ctvh9FCmCfVgKmAB58jpzWzIJedjQNZLIBBoYdiip5g+MxaDSORnbOxE uHBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=2kBnL5gA8Hu2OCxhQ/ljIeIBv2eKrh+kqk+I83yZiPg=; b=LNy8PHyP4qXIh8sPTHl64WLyZL2LR2oUFXf0XBNWs9zYdY1iq2F3Fa0xouKXIFXON5 FG4FQ+gKVv7FY/meI2jdBKQdaXEiY6PRt6crXB9mOMpw4ed5QlxXVXODZSqD1sDdqWx+ 0sEbDybKwpYsQbKLgYX8hH2ZTxoJW4sy8cFAcO2fwRcOaJwFh5xRYwpU4JnlVohvK2Xu nsd0SV21o+HQCUZqfb35tj/HLijWxCw9tcKE222y2oqiTF/mE7ZvEIeHGZWcbtJNudGu qZ8Kzm5xno05YhFDJv/dgJnKiO7mtIFtaj4nbkiT0JJ0EMh3dFLbIZemrltbicshQDcs aZtw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=ZWBdCh+x; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e26si31030336otj.113.2020.01.07.06.11.23; Tue, 07 Jan 2020 06:12:08 -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=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=ZWBdCh+x; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728048AbgAGMwH (ORCPT + 99 others); Tue, 7 Jan 2020 07:52:07 -0500 Received: from bombadil.infradead.org ([198.137.202.133]:60108 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727869AbgAGMwE (ORCPT ); Tue, 7 Jan 2020 07:52:04 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=2kBnL5gA8Hu2OCxhQ/ljIeIBv2eKrh+kqk+I83yZiPg=; b=ZWBdCh+xKxFQSUSue/qfzQHsj 6T5S7vMsw+xLZ62ufe9Nw3VxsvMHHudJaF8KytEMMXsDhKtJIMWpsjy+CQ2AaJlNh+CZM7spuk1qi /GG/VNY7ofqvL8y2h70Tkp7c2xkCRxKZ1rFFxsF9ewZVdfm5fMyeHS7JZqUgbOIVcUM4enC/7CPfL YvahSVPFgA+tsvy8E7FsjcEDyCoXQ7NeHHA9vZPIY3RKwvTq97SGhEeSWoA7Sbe4ZJF+SklJGS433 rfYX021bytGaEdqU7+9n2lMTY4eAmfRy/GoDNiu+qsLx1wh+rUf9RelcB0PwHzVtNjAEn/Sepic4P CyVpuzEdg==; Received: from hch by bombadil.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1iooL1-0005j8-N5; Tue, 07 Jan 2020 12:51:59 +0000 Date: Tue, 7 Jan 2020 04:51:59 -0800 From: Christoph Hellwig To: Vivek Goyal Cc: Dan Williams , Dave Chinner , Christoph Hellwig , 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: <20200107125159.GA15745@infradead.org> References: <20190821175720.25901-1-vgoyal@redhat.com> <20190821175720.25901-2-vgoyal@redhat.com> <20190826115152.GA21051@infradead.org> <20190827163828.GA6859@redhat.com> <20190828065809.GA27426@infradead.org> <20190828175843.GB912@redhat.com> <20190828225322.GA7777@dread.disaster.area> <20191216181014.GA30106@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191216181014.GA30106@redhat.com> X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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?