Re: [PATCH 02/15] libnvdimm: infrastructure for btt devices

From: Christoph Hellwig
Date: Tue Jun 23 2015 - 06:19:30 EST


On Mon, Jun 22, 2015 at 12:02:54PM -0700, Dan Williams wrote:
> I don't see the need to re-invent partitioning which is the path this
> requested rework is putting us on...
>
> However, when the need arises for smaller granularity BTT we can have
> the partition fight then. To be clear, I believe that need is already
> here today, but I'm not in a position to push that agenda at this late
> date.


Instead of all this complaining and moaning let's figure out what
architecture you'd actually want. The one I had in mind is:

+------------------------------+
| block layer (& partitions) |
+---------------+--------------+--------------------+
| pmem driver | btt driver | other consumers |
+---------------+--------------+--------------------+
| pmem API through libnvdimm |
+---------------------------------------------------+

If you really want btt to stack on top of pmem it really
needs to be moved out entirely of libnvdimm and be a
generic block driver just using ->rw_bytes, e.g.:


+------------------------------+
| btt driver |
+------------------------------+
| block layer (& partitions) |
+------------------------------+--------------------+
| pmem driver | other consumers |
+------------------------------+--------------------+
| pmem API through libnvdimm |
+---------------------------------------------------+

Not the current mess where btt pretends to be a stacking block
driver but still ties into libnvdimm.

Add blk mode access to all the schemes, but it's really just
another next to the pmem driver each time. In fact while
looking over the code a bit more I start to wonder why
we need the blk driver at all - just hook into the nfit
do_io routines instead of the low-level API based on what
libnvdimm provides, and don't offer DAX for it. It mostly
seems duplicate code.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/