From: Jan Kara Subject: Re: [PATCH v4 07/12] dax: coordinate locking for offsets in PMD range Date: Mon, 3 Oct 2016 11:55:18 +0200 Message-ID: <20161003095518.GM6457@quack2.suse.cz> References: <1475189370-31634-1-git-send-email-ross.zwisler@linux.intel.com> <1475189370-31634-8-git-send-email-ross.zwisler@linux.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: linux-kernel@vger.kernel.org, Theodore Ts'o , Alexander Viro , Andreas Dilger , Andrew Morton , Christoph Hellwig , Dan Williams , Dave Chinner , Jan Kara , Matthew Wilcox , linux-ext4@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-nvdimm@lists.01.org, linux-xfs@vger.kernel.org To: Ross Zwisler Return-path: Content-Disposition: inline In-Reply-To: <1475189370-31634-8-git-send-email-ross.zwisler@linux.intel.com> Sender: owner-linux-mm@kvack.org List-Id: linux-ext4.vger.kernel.org On Thu 29-09-16 16:49:25, Ross Zwisler wrote: > DAX radix tree locking currently locks entries based on the unique > combination of the 'mapping' pointer and the pgoff_t 'index' for the entry. > This works for PTEs, but as we move to PMDs we will need to have all the > offsets within the range covered by the PMD to map to the same bit lock. > To accomplish this, for ranges covered by a PMD entry we will instead lock > based on the page offset of the beginning of the PMD entry. The 'mapping' > pointer is still used in the same way. > > Signed-off-by: Ross Zwisler > --- > fs/dax.c | 37 ++++++++++++++++++++++++------------- > include/linux/dax.h | 2 +- > mm/filemap.c | 2 +- > 3 files changed, 26 insertions(+), 15 deletions(-) > > diff --git a/fs/dax.c b/fs/dax.c > index baef586..406feea 100644 > --- a/fs/dax.c > +++ b/fs/dax.c > @@ -64,10 +64,17 @@ static int __init init_dax_wait_table(void) > } > fs_initcall(init_dax_wait_table); > > +static pgoff_t dax_entry_start(pgoff_t index, void *entry) > +{ > + if (RADIX_DAX_TYPE(entry) == RADIX_DAX_PMD) > + index &= (PMD_MASK >> PAGE_SHIFT); Hum, but if we shift right, top bits of PMD_MASK will become zero - not something we want I guess... You rather want to mask with something like: ~((1UL << (PMD_SHIFT - PAGE_SHIFT)) - 1) > @@ -447,10 +457,11 @@ restart: > return entry; > } > > -void dax_wake_mapping_entry_waiter(struct address_space *mapping, > +void dax_wake_mapping_entry_waiter(void *entry, struct address_space *mapping, > pgoff_t index, bool wake_all) Nitpick: Ordering of arguments would look more logical to me like: dax_wake_mapping_entry_waiter(mapping, index, entry, wake_all) Other than that the patch looks good to me. Honza -- Jan Kara SUSE Labs, CR -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org