Commit 07e9eb2b authored by Trond Myklebust's avatar Trond Myklebust

NFS: when we mount with the "nolock" flag we need to use local locking.

Signed-off-by: default avatarTrond Myklebust <trond.myklebust@fys.uio.no>
parent eaffe965
...@@ -295,10 +295,19 @@ nfs_file_write(struct kiocb *iocb, const char __user *buf, size_t count, loff_t ...@@ -295,10 +295,19 @@ nfs_file_write(struct kiocb *iocb, const char __user *buf, size_t count, loff_t
static int do_getlk(struct file *filp, int cmd, struct file_lock *fl) static int do_getlk(struct file *filp, int cmd, struct file_lock *fl)
{ {
struct inode *inode = filp->f_mapping->host; struct inode *inode = filp->f_mapping->host;
int status; int status = 0;
lock_kernel(); lock_kernel();
status = NFS_PROTO(inode)->lock(filp, cmd, fl); /* Use local locking if mounted with "-onolock" */
if (!(NFS_SERVER(inode)->flags & NFS_MOUNT_NONLM))
status = NFS_PROTO(inode)->lock(filp, cmd, fl);
else {
struct file_lock *cfl = posix_test_lock(filp, fl);
if (cfl != NULL) {
memcpy(fl, cfl, sizeof(*fl));
fl->fl_type = F_UNLCK;
}
}
unlock_kernel(); unlock_kernel();
return status; return status;
} }
...@@ -325,7 +334,11 @@ static int do_unlk(struct file *filp, int cmd, struct file_lock *fl) ...@@ -325,7 +334,11 @@ static int do_unlk(struct file *filp, int cmd, struct file_lock *fl)
* still need to complete the unlock. * still need to complete the unlock.
*/ */
lock_kernel(); lock_kernel();
status = NFS_PROTO(inode)->lock(filp, cmd, fl); /* Use local locking if mounted with "-onolock" */
if (!(NFS_SERVER(inode)->flags & NFS_MOUNT_NONLM))
status = NFS_PROTO(inode)->lock(filp, cmd, fl);
else
status = posix_lock_file_wait(filp, fl);
rpc_clnt_sigunmask(NFS_CLIENT(inode), &oldset); rpc_clnt_sigunmask(NFS_CLIENT(inode), &oldset);
return status; return status;
} }
...@@ -351,15 +364,19 @@ static int do_setlk(struct file *filp, int cmd, struct file_lock *fl) ...@@ -351,15 +364,19 @@ static int do_setlk(struct file *filp, int cmd, struct file_lock *fl)
return status; return status;
lock_kernel(); lock_kernel();
status = NFS_PROTO(inode)->lock(filp, cmd, fl); /* Use local locking if mounted with "-onolock" */
/* If we were signalled we still need to ensure that if (!(NFS_SERVER(inode)->flags & NFS_MOUNT_NONLM)) {
* we clean up any state on the server. We therefore status = NFS_PROTO(inode)->lock(filp, cmd, fl);
* record the lock call as having succeeded in order to /* If we were signalled we still need to ensure that
* ensure that locks_remove_posix() cleans it out when * we clean up any state on the server. We therefore
* the process exits. * record the lock call as having succeeded in order to
*/ * ensure that locks_remove_posix() cleans it out when
if (status == -EINTR || status == -ERESTARTSYS) * the process exits.
posix_lock_file(filp, fl); */
if (status == -EINTR || status == -ERESTARTSYS)
posix_lock_file(filp, fl);
} else
status = posix_lock_file_wait(filp, fl);
unlock_kernel(); unlock_kernel();
if (status < 0) if (status < 0)
return status; return status;
...@@ -396,15 +413,6 @@ nfs_lock(struct file *filp, int cmd, struct file_lock *fl) ...@@ -396,15 +413,6 @@ nfs_lock(struct file *filp, int cmd, struct file_lock *fl)
if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID)
return -ENOLCK; return -ENOLCK;
if (NFS_PROTO(inode)->version != 4) {
/* Fake OK code if mounted without NLM support */
if (NFS_SERVER(inode)->flags & NFS_MOUNT_NONLM) {
if (IS_GETLK(cmd))
return LOCK_USE_CLNT;
return 0;
}
}
/* /*
* No BSD flocks over NFS allowed. * No BSD flocks over NFS allowed.
* Note: we could try to fake a POSIX lock request here by * Note: we could try to fake a POSIX lock request here by
......
...@@ -1449,8 +1449,6 @@ static void nfs_kill_super(struct super_block *s) ...@@ -1449,8 +1449,6 @@ static void nfs_kill_super(struct super_block *s)
kill_anon_super(s); kill_anon_super(s);
nfs4_renewd_prepare_shutdown(server);
if (server->client != NULL && !IS_ERR(server->client)) if (server->client != NULL && !IS_ERR(server->client))
rpc_shutdown_client(server->client); rpc_shutdown_client(server->client);
if (server->client_sys != NULL && !IS_ERR(server->client_sys)) if (server->client_sys != NULL && !IS_ERR(server->client_sys))
...@@ -1461,8 +1459,6 @@ static void nfs_kill_super(struct super_block *s) ...@@ -1461,8 +1459,6 @@ static void nfs_kill_super(struct super_block *s)
rpciod_down(); /* release rpciod */ rpciod_down(); /* release rpciod */
destroy_nfsv4_state(server);
if (server->hostname != NULL) if (server->hostname != NULL)
kfree(server->hostname); kfree(server->hostname);
kfree(server); kfree(server);
...@@ -1543,9 +1539,6 @@ static int nfs4_fill_super(struct super_block *sb, struct nfs4_mount_data *data, ...@@ -1543,9 +1539,6 @@ static int nfs4_fill_super(struct super_block *sb, struct nfs4_mount_data *data,
server->wsize = nfs_block_size(data->wsize, NULL); server->wsize = nfs_block_size(data->wsize, NULL);
server->flags = data->flags & NFS_MOUNT_FLAGMASK; server->flags = data->flags & NFS_MOUNT_FLAGMASK;
/* NFSv4 doesn't use NLM locking */
server->flags |= NFS_MOUNT_NONLM;
server->acregmin = data->acregmin*HZ; server->acregmin = data->acregmin*HZ;
server->acregmax = data->acregmax*HZ; server->acregmax = data->acregmax*HZ;
server->acdirmin = data->acdirmin*HZ; server->acdirmin = data->acdirmin*HZ;
...@@ -1790,8 +1783,22 @@ static struct super_block *nfs4_get_sb(struct file_system_type *fs_type, ...@@ -1790,8 +1783,22 @@ static struct super_block *nfs4_get_sb(struct file_system_type *fs_type,
static void nfs4_kill_super(struct super_block *sb) static void nfs4_kill_super(struct super_block *sb)
{ {
struct nfs_server *server = NFS_SB(sb);
nfs_return_all_delegations(sb); nfs_return_all_delegations(sb);
nfs_kill_super(sb); kill_anon_super(sb);
nfs4_renewd_prepare_shutdown(server);
if (server->client != NULL && !IS_ERR(server->client))
rpc_shutdown_client(server->client);
rpciod_down(); /* release rpciod */
destroy_nfsv4_state(server);
if (server->hostname != NULL)
kfree(server->hostname);
kfree(server);
} }
static struct file_system_type nfs4_fs_type = { static struct file_system_type nfs4_fs_type = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment