Commit 48483bf2 authored by J. Bruce Fields's avatar J. Bruce Fields

nfsd4: simplify recovery dir setting

Move around some of this code, simplify a bit.
Reviewed-by: default avatarBoaz Harrosh <bharrosh@panasas.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@redhat.com>
parent 8e82fa8f
...@@ -45,6 +45,7 @@ ...@@ -45,6 +45,7 @@
/* Globals */ /* Globals */
static struct file *rec_file; static struct file *rec_file;
static char user_recovery_dirname[PATH_MAX] = "/var/lib/nfs/v4recovery";
static int static int
nfs4_save_creds(const struct cred **original_creds) nfs4_save_creds(const struct cred **original_creds)
...@@ -354,13 +355,13 @@ nfsd4_recdir_load(void) { ...@@ -354,13 +355,13 @@ nfsd4_recdir_load(void) {
*/ */
void void
nfsd4_init_recdir(char *rec_dirname) nfsd4_init_recdir()
{ {
const struct cred *original_cred; const struct cred *original_cred;
int status; int status;
printk("NFSD: Using %s as the NFSv4 state recovery directory\n", printk("NFSD: Using %s as the NFSv4 state recovery directory\n",
rec_dirname); user_recovery_dirname);
BUG_ON(rec_file); BUG_ON(rec_file);
...@@ -372,10 +373,10 @@ nfsd4_init_recdir(char *rec_dirname) ...@@ -372,10 +373,10 @@ nfsd4_init_recdir(char *rec_dirname)
return; return;
} }
rec_file = filp_open(rec_dirname, O_RDONLY | O_DIRECTORY, 0); rec_file = filp_open(user_recovery_dirname, O_RDONLY | O_DIRECTORY, 0);
if (IS_ERR(rec_file)) { if (IS_ERR(rec_file)) {
printk("NFSD: unable to find recovery directory %s\n", printk("NFSD: unable to find recovery directory %s\n",
rec_dirname); user_recovery_dirname);
rec_file = NULL; rec_file = NULL;
} }
...@@ -390,3 +391,30 @@ nfsd4_shutdown_recdir(void) ...@@ -390,3 +391,30 @@ nfsd4_shutdown_recdir(void)
fput(rec_file); fput(rec_file);
rec_file = NULL; rec_file = NULL;
} }
/*
* Change the NFSv4 recovery directory to recdir.
*/
int
nfs4_reset_recoverydir(char *recdir)
{
int status;
struct path path;
status = kern_path(recdir, LOOKUP_FOLLOW, &path);
if (status)
return status;
status = -ENOTDIR;
if (S_ISDIR(path.dentry->d_inode->i_mode)) {
strcpy(user_recovery_dirname, recdir);
status = 0;
}
path_put(&path);
return status;
}
char *
nfs4_recoverydir(void)
{
return user_recovery_dirname;
}
...@@ -64,8 +64,6 @@ static struct nfs4_stateid * find_stateid(stateid_t *stid, int flags); ...@@ -64,8 +64,6 @@ static struct nfs4_stateid * find_stateid(stateid_t *stid, int flags);
static struct nfs4_stateid * search_for_stateid(stateid_t *stid); static struct nfs4_stateid * search_for_stateid(stateid_t *stid);
static struct nfs4_delegation * search_for_delegation(stateid_t *stid); static struct nfs4_delegation * search_for_delegation(stateid_t *stid);
static struct nfs4_delegation * find_delegation_stateid(struct inode *ino, stateid_t *stid); static struct nfs4_delegation * find_delegation_stateid(struct inode *ino, stateid_t *stid);
static char user_recovery_dirname[PATH_MAX] = "/var/lib/nfs/v4recovery";
static void nfs4_set_recdir(char *recdir);
static int check_for_locks(struct nfs4_file *filp, struct nfs4_stateowner *lowner); static int check_for_locks(struct nfs4_file *filp, struct nfs4_stateowner *lowner);
/* Locking: */ /* Locking: */
...@@ -4523,7 +4521,7 @@ nfsd4_load_reboot_recovery_data(void) ...@@ -4523,7 +4521,7 @@ nfsd4_load_reboot_recovery_data(void)
int status; int status;
nfs4_lock_state(); nfs4_lock_state();
nfsd4_init_recdir(user_recovery_dirname); nfsd4_init_recdir();
status = nfsd4_recdir_load(); status = nfsd4_recdir_load();
nfs4_unlock_state(); nfs4_unlock_state();
if (status) if (status)
...@@ -4632,40 +4630,3 @@ nfs4_state_shutdown(void) ...@@ -4632,40 +4630,3 @@ nfs4_state_shutdown(void)
nfs4_unlock_state(); nfs4_unlock_state();
nfsd4_destroy_callback_queue(); nfsd4_destroy_callback_queue();
} }
/*
* user_recovery_dirname is protected by the nfsd_mutex since it's only
* accessed when nfsd is starting.
*/
static void
nfs4_set_recdir(char *recdir)
{
strcpy(user_recovery_dirname, recdir);
}
/*
* Change the NFSv4 recovery directory to recdir.
*/
int
nfs4_reset_recoverydir(char *recdir)
{
int status;
struct path path;
status = kern_path(recdir, LOOKUP_FOLLOW, &path);
if (status)
return status;
status = -ENOTDIR;
if (S_ISDIR(path.dentry->d_inode->i_mode)) {
nfs4_set_recdir(recdir);
status = 0;
}
path_put(&path);
return status;
}
char *
nfs4_recoverydir(void)
{
return user_recovery_dirname;
}
...@@ -467,7 +467,7 @@ extern void nfsd4_destroy_callback_queue(void); ...@@ -467,7 +467,7 @@ extern void nfsd4_destroy_callback_queue(void);
extern void nfsd4_shutdown_callback(struct nfs4_client *); extern void nfsd4_shutdown_callback(struct nfs4_client *);
extern void nfs4_put_delegation(struct nfs4_delegation *dp); extern void nfs4_put_delegation(struct nfs4_delegation *dp);
extern __be32 nfs4_make_rec_clidname(char *clidname, struct xdr_netobj *clname); extern __be32 nfs4_make_rec_clidname(char *clidname, struct xdr_netobj *clname);
extern void nfsd4_init_recdir(char *recdir_name); extern void nfsd4_init_recdir(void);
extern int nfsd4_recdir_load(void); extern int nfsd4_recdir_load(void);
extern void nfsd4_shutdown_recdir(void); extern void nfsd4_shutdown_recdir(void);
extern int nfs4_client_to_reclaim(const char *name); extern int nfs4_client_to_reclaim(const char *name);
......
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