dax: introduce a fs_dax_get_by_bdev() helper
authorDan Williams <dan.j.williams@intel.com>
Wed, 30 Aug 2017 16:16:38 +0000 (09:16 -0700)
committerDan Williams <dan.j.williams@intel.com>
Wed, 30 Aug 2017 16:16:38 +0000 (09:16 -0700)
Add a helper that can replace the following common pattern:

if (blk_queue_dax(bdev->bd_queue))
fs_dax_get_by_host(bdev->bd_disk->disk_name);

This will be used to move dax_device lookup from iomap-operation time to
fs-mount time.

Reviewed-by: Jan Kara <jack@suse.cz>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/dax/super.c
include/linux/dax.h

index 938eb4868f7f78c7264cae58b15a0dcc0565d5c4..b699aac268a6c3c172e3507dff9d17005f79ed2f 100644 (file)
@@ -46,6 +46,8 @@ void dax_read_unlock(int id)
 EXPORT_SYMBOL_GPL(dax_read_unlock);
 
 #ifdef CONFIG_BLOCK
+#include <linux/blkdev.h>
+
 int bdev_dax_pgoff(struct block_device *bdev, sector_t sector, size_t size,
                pgoff_t *pgoff)
 {
@@ -59,6 +61,14 @@ int bdev_dax_pgoff(struct block_device *bdev, sector_t sector, size_t size,
 }
 EXPORT_SYMBOL(bdev_dax_pgoff);
 
+struct dax_device *fs_dax_get_by_bdev(struct block_device *bdev)
+{
+       if (!blk_queue_dax(bdev->bd_queue))
+               return NULL;
+       return fs_dax_get_by_host(bdev->bd_disk->disk_name);
+}
+EXPORT_SYMBOL_GPL(fs_dax_get_by_bdev);
+
 /**
  * __bdev_dax_supported() - Check if the device supports dax for filesystem
  * @sb: The superblock of the device
index df97b7af7e2c7263c4ae9fb1608b19aad1ae02ba..ac8afa18f707410ec6b837051f7395650ac6f4dc 100644 (file)
@@ -57,6 +57,7 @@ static inline void fs_put_dax(struct dax_device *dax_dev)
        put_dax(dax_dev);
 }
 
+struct dax_device *fs_dax_get_by_bdev(struct block_device *bdev);
 #else
 static inline int bdev_dax_supported(struct super_block *sb, int blocksize)
 {
@@ -71,6 +72,11 @@ static inline struct dax_device *fs_dax_get_by_host(const char *host)
 static inline void fs_put_dax(struct dax_device *dax_dev)
 {
 }
+
+static inline struct dax_device *fs_dax_get_by_bdev(struct block_device *bdev)
+{
+       return NULL;
+}
 #endif
 
 int dax_read_lock(void);