[PATCH 0/3] RFC improvements to radix-tree related to DAX

From: NeilBrown
Date: Sun Feb 28 2016 - 00:17:53 EST


Hi,

While pondering some issues with DAX and how it uses the radix tree I
conceived the following patches. I don't know if they'll be useful
but I thought I would post them in case they are helpful.

The first is quite independent of the others - it removes some DAX
specific #defines from radix-tree.h which is a generic ADT.

The second makes an extra bit available when exception data is
stored in the radix tree.

The third uses this bit to provide a sleeping lock. With this
it should be possible to delete exceptional entries from the radix
tree in a race-free way without external locking.
Like the page lock it requires an external set of wait_queue_heads.
The same ones used for page_lock would be suitable.

Note that this code is only compile tested.

NeilBrown


---

NeilBrown (3):
DAX: move RADIX_DAX_ definitions to dax.c
radix-tree: make 'indirect' bit available to exception entries.
radix-tree: support locking of individual exception entries.


fs/dax.c | 9 ++
include/linux/radix-tree.h | 28 +++++---
lib/radix-tree.c | 160 ++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 185 insertions(+), 12 deletions(-)

--
Signature