mirror of
https://github.com/adulau/aha.git
synced 2025-01-03 22:53:18 +00:00
nfsd: move cache proc (un)registration to separate function
Just some minor cleanup. Also I don't see much point in trying to register further proc entries if initial entries fail; so just stop trying in that case. Acked-by: NeilBrown <neilb@suse.de> Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
This commit is contained in:
parent
e331f606a8
commit
ffe9386b6e
1 changed files with 56 additions and 47 deletions
|
@ -290,44 +290,63 @@ static const struct file_operations cache_flush_operations;
|
||||||
static void do_cache_clean(struct work_struct *work);
|
static void do_cache_clean(struct work_struct *work);
|
||||||
static DECLARE_DELAYED_WORK(cache_cleaner, do_cache_clean);
|
static DECLARE_DELAYED_WORK(cache_cleaner, do_cache_clean);
|
||||||
|
|
||||||
|
static void remove_cache_proc_entries(struct cache_detail *cd)
|
||||||
|
{
|
||||||
|
if (cd->proc_ent == NULL)
|
||||||
|
return;
|
||||||
|
if (cd->flush_ent)
|
||||||
|
remove_proc_entry("flush", cd->proc_ent);
|
||||||
|
if (cd->channel_ent)
|
||||||
|
remove_proc_entry("channel", cd->proc_ent);
|
||||||
|
if (cd->content_ent)
|
||||||
|
remove_proc_entry("content", cd->proc_ent);
|
||||||
|
cd->proc_ent = NULL;
|
||||||
|
remove_proc_entry(cd->name, proc_net_rpc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void create_cache_proc_entries(struct cache_detail *cd)
|
||||||
|
{
|
||||||
|
struct proc_dir_entry *p;
|
||||||
|
|
||||||
|
cd->proc_ent = proc_mkdir(cd->name, proc_net_rpc);
|
||||||
|
if (cd->proc_ent == NULL)
|
||||||
|
return;
|
||||||
|
cd->proc_ent->owner = cd->owner;
|
||||||
|
cd->channel_ent = cd->content_ent = NULL;
|
||||||
|
|
||||||
|
p = create_proc_entry("flush", S_IFREG|S_IRUSR|S_IWUSR, cd->proc_ent);
|
||||||
|
cd->flush_ent = p;
|
||||||
|
if (p == NULL)
|
||||||
|
return;
|
||||||
|
p->proc_fops = &cache_flush_operations;
|
||||||
|
p->owner = cd->owner;
|
||||||
|
p->data = cd;
|
||||||
|
|
||||||
|
if (cd->cache_request || cd->cache_parse) {
|
||||||
|
p = create_proc_entry("channel", S_IFREG|S_IRUSR|S_IWUSR,
|
||||||
|
cd->proc_ent);
|
||||||
|
cd->channel_ent = p;
|
||||||
|
if (p == NULL)
|
||||||
|
return;
|
||||||
|
p->proc_fops = &cache_file_operations;
|
||||||
|
p->owner = cd->owner;
|
||||||
|
p->data = cd;
|
||||||
|
}
|
||||||
|
if (cd->cache_show) {
|
||||||
|
p = create_proc_entry("content", S_IFREG|S_IRUSR|S_IWUSR,
|
||||||
|
cd->proc_ent);
|
||||||
|
cd->content_ent = p;
|
||||||
|
if (p == NULL)
|
||||||
|
return;
|
||||||
|
p->proc_fops = &content_file_operations;
|
||||||
|
p->owner = cd->owner;
|
||||||
|
p->data = cd;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void cache_register(struct cache_detail *cd)
|
void cache_register(struct cache_detail *cd)
|
||||||
{
|
{
|
||||||
cd->proc_ent = proc_mkdir(cd->name, proc_net_rpc);
|
create_cache_proc_entries(cd);
|
||||||
if (cd->proc_ent) {
|
|
||||||
struct proc_dir_entry *p;
|
|
||||||
cd->proc_ent->owner = cd->owner;
|
|
||||||
cd->channel_ent = cd->content_ent = NULL;
|
|
||||||
|
|
||||||
p = create_proc_entry("flush", S_IFREG|S_IRUSR|S_IWUSR,
|
|
||||||
cd->proc_ent);
|
|
||||||
cd->flush_ent = p;
|
|
||||||
if (p) {
|
|
||||||
p->proc_fops = &cache_flush_operations;
|
|
||||||
p->owner = cd->owner;
|
|
||||||
p->data = cd;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cd->cache_request || cd->cache_parse) {
|
|
||||||
p = create_proc_entry("channel", S_IFREG|S_IRUSR|S_IWUSR,
|
|
||||||
cd->proc_ent);
|
|
||||||
cd->channel_ent = p;
|
|
||||||
if (p) {
|
|
||||||
p->proc_fops = &cache_file_operations;
|
|
||||||
p->owner = cd->owner;
|
|
||||||
p->data = cd;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (cd->cache_show) {
|
|
||||||
p = create_proc_entry("content", S_IFREG|S_IRUSR|S_IWUSR,
|
|
||||||
cd->proc_ent);
|
|
||||||
cd->content_ent = p;
|
|
||||||
if (p) {
|
|
||||||
p->proc_fops = &content_file_operations;
|
|
||||||
p->owner = cd->owner;
|
|
||||||
p->data = cd;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rwlock_init(&cd->hash_lock);
|
rwlock_init(&cd->hash_lock);
|
||||||
INIT_LIST_HEAD(&cd->queue);
|
INIT_LIST_HEAD(&cd->queue);
|
||||||
spin_lock(&cache_list_lock);
|
spin_lock(&cache_list_lock);
|
||||||
|
@ -358,17 +377,7 @@ void cache_unregister(struct cache_detail *cd)
|
||||||
list_del_init(&cd->others);
|
list_del_init(&cd->others);
|
||||||
write_unlock(&cd->hash_lock);
|
write_unlock(&cd->hash_lock);
|
||||||
spin_unlock(&cache_list_lock);
|
spin_unlock(&cache_list_lock);
|
||||||
if (cd->proc_ent) {
|
remove_cache_proc_entries(cd);
|
||||||
if (cd->flush_ent)
|
|
||||||
remove_proc_entry("flush", cd->proc_ent);
|
|
||||||
if (cd->channel_ent)
|
|
||||||
remove_proc_entry("channel", cd->proc_ent);
|
|
||||||
if (cd->content_ent)
|
|
||||||
remove_proc_entry("content", cd->proc_ent);
|
|
||||||
|
|
||||||
cd->proc_ent = NULL;
|
|
||||||
remove_proc_entry(cd->name, proc_net_rpc);
|
|
||||||
}
|
|
||||||
if (list_empty(&cache_list)) {
|
if (list_empty(&cache_list)) {
|
||||||
/* module must be being unloaded so its safe to kill the worker */
|
/* module must be being unloaded so its safe to kill the worker */
|
||||||
cancel_delayed_work_sync(&cache_cleaner);
|
cancel_delayed_work_sync(&cache_cleaner);
|
||||||
|
|
Loading…
Reference in a new issue