Future NFSv4.x work will add several new layout types. Use nfs-layouttype4-<number> in request_module() to allow current and future layout types to be loaded without requiring changes to the module loading code. The kernel issues request_module(nfs4-layouttype4-<number>) which is then mapped to the actual module name in the modprobe aliases file. Something like: alias nfs-layouttype4-1 nfs_layout_nfsv41_files alias nfs-layouttype4-2 nfs_layout_osd2_objects It can be turned off by commenting out the alias, or specifying it off. For example: alias nfs-layouttype4-3 off The module can still be loaded by hand using modprobe. Signed-off-by: Ricardo Labiaga <Ricardo.Labiaga@xxxxxxxxxx> --- fs/nfs/Makefile | 4 ++-- fs/nfs/pnfs.c | 10 +--------- fs/nfs/pnfs.h | 2 +- 3 files changed, 4 insertions(+), 12 deletions(-) diff --git a/fs/nfs/Makefile b/fs/nfs/Makefile index 6c218e7..4776ff9 100644 --- a/fs/nfs/Makefile +++ b/fs/nfs/Makefile @@ -19,5 +19,5 @@ nfs-$(CONFIG_NFS_V4_1) += pnfs.o nfs-$(CONFIG_SYSCTL) += sysctl.o nfs-$(CONFIG_NFS_FSCACHE) += fscache.o fscache-index.o -obj-$(CONFIG_PNFS_FILE_LAYOUT) += nfslayoutdriver.o -nfslayoutdriver-y := nfs4filelayout.o nfs4filelayoutdev.o +obj-$(CONFIG_PNFS_FILE_LAYOUT) += nfs_layout_nfsv41_files.o +nfs_layout_nfsv41_files-y := nfs4filelayout.o nfs4filelayoutdev.o diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index 3494d5e..b2fb693 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c @@ -210,14 +210,7 @@ set_pnfs_layoutdriver(struct nfs_server *server, u32 id) return; if (!find_pnfs(id, &mod)) { - switch (id) { - case LAYOUT_NFSV4_1_FILES: - request_module(LAYOUT_NFSV4_1_FILES_MODULE); - break; - default: - goto out_not_found; - }; - + request_module("%s-%u", LAYOUT_NFSV4_1_MODULE_PREFIX, id); find_pnfs(id, &mod); } @@ -233,7 +226,6 @@ set_pnfs_layoutdriver(struct nfs_server *server, u32 id) return; } -out_not_found: dprintk("%s: No pNFS module found for %u. ", __func__, id); out_err: dprintk("Using NFSv4 I/O\n"); diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h index 6bc27af..f48ef24 100644 --- a/fs/nfs/pnfs.h +++ b/fs/nfs/pnfs.h @@ -73,7 +73,7 @@ void put_layout(struct inode *inode); (srv)->pnfs_curr_ld->ld_policy_ops && \ (srv)->pnfs_curr_ld->ld_policy_ops->opname) -#define LAYOUT_NFSV4_1_FILES_MODULE "nfslayoutdriver" +#define LAYOUT_NFSV4_1_MODULE_PREFIX "nfs-layouttype4" static inline int lo_fail_bit(u32 iomode) { -- 1.5.4.3 -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html