Re: [PATCH 14/15] libnvdimm: support read-only btt backing devices

From: Dan Williams
Date: Sun Jun 21 2015 - 09:22:04 EST


On Sun, Jun 21, 2015 at 3:13 AM, Christoph Hellwig <hch@xxxxxx> wrote:
> On Wed, Jun 17, 2015 at 07:56:02PM -0400, Dan Williams wrote:
>> Upon detection of a read-only backing device arrange for the btt to
>> device to be read only. Implement a catch for the BLKROSET ioctl and
>> only allow a btt-instance to become read-write when the backing-device
>> becomes read-write. Conversely, if a backing-device becomes read-only
>> arrange for its parent btt to be marked read-only. Synchronize these
>> changes under the bus lock.
>
> Eww. I have to say the deeper I look into this code the more I hate
> the stacking nature of btt. It seems more and more we should never
> attach pmem if we want to use a device with btt.

This question has come up before. Making btt an internal property of
a device makes some things cleaner and others more messy. We lose the
ability to place a btt instance on top of a partition, rather than a
whole disk. If we ever need to access the raw device we no longer
have a direct block device to reference. Linux has been doing stacked
configurations to change the personality of block devices since
forever (md, dm, bcache...), why invent something new to handle the
btt-personality of ->rw_bytes() devices?

BTT precludes DAX, if you want both modes on one pmem disk placing BTT
on a partition of the disk for fs metadata and DAX-capable data on the
rest is our proposed solution. We chose this architecture after a
conversation with Dave Chinner about XFS's need to have atomic sector
guarantees for its metadata and wanting to simultaneously enable
XFS-DAX.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
Please read the FAQ at http://www.tux.org/lkml/