proc: Supply a function to remove a proc entry by PDE
Supply a function (proc_remove()) to remove a proc entry (and any subtree rooted there) by proc_dir_entry pointer rather than by name and (optionally) root dir entry pointer. This allows us to eliminate all remaining pde->name accesses outside of procfs. Signed-off-by: David Howells <dhowells@redhat.com> Acked-by: Grant Likely <grant.likely@linaro.or> cc: linux-acpi@vger.kernel.org cc: openipmi-developer@lists.sourceforge.net cc: devicetree-discuss@lists.ozlabs.org cc: linux-pci@vger.kernel.org cc: netdev@vger.kernel.org cc: netfilter-devel@vger.kernel.org cc: alsa-devel@alsa-project.org Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
@@ -153,13 +153,6 @@ EXPORT_SYMBOL(snd_seq_root);
|
||||
struct snd_info_entry *snd_oss_root;
|
||||
#endif
|
||||
|
||||
static void snd_remove_proc_entry(struct proc_dir_entry *parent,
|
||||
struct proc_dir_entry *de)
|
||||
{
|
||||
if (de)
|
||||
remove_proc_entry(de->name, parent);
|
||||
}
|
||||
|
||||
static loff_t snd_info_entry_llseek(struct file *file, loff_t offset, int orig)
|
||||
{
|
||||
struct snd_info_private_data *data;
|
||||
@@ -580,7 +573,7 @@ int __exit snd_info_done(void)
|
||||
#ifdef CONFIG_SND_OSSEMUL
|
||||
snd_info_free_entry(snd_oss_root);
|
||||
#endif
|
||||
snd_remove_proc_entry(NULL, snd_proc_root);
|
||||
proc_remove(snd_proc_root);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
@@ -642,7 +635,7 @@ void snd_info_card_id_change(struct snd_card *card)
|
||||
{
|
||||
mutex_lock(&info_mutex);
|
||||
if (card->proc_root_link) {
|
||||
snd_remove_proc_entry(snd_proc_root, card->proc_root_link);
|
||||
proc_remove(card->proc_root_link);
|
||||
card->proc_root_link = NULL;
|
||||
}
|
||||
if (strcmp(card->id, card->proc_root->name))
|
||||
@@ -661,10 +654,8 @@ void snd_info_card_disconnect(struct snd_card *card)
|
||||
if (!card)
|
||||
return;
|
||||
mutex_lock(&info_mutex);
|
||||
if (card->proc_root_link) {
|
||||
snd_remove_proc_entry(snd_proc_root, card->proc_root_link);
|
||||
card->proc_root_link = NULL;
|
||||
}
|
||||
proc_remove(card->proc_root_link);
|
||||
card->proc_root_link = NULL;
|
||||
if (card->proc_root)
|
||||
snd_info_disconnect(card->proc_root);
|
||||
mutex_unlock(&info_mutex);
|
||||
@@ -856,7 +847,7 @@ static void snd_info_disconnect(struct snd_info_entry *entry)
|
||||
list_del_init(&entry->list);
|
||||
root = entry->parent == NULL ? snd_proc_root : entry->parent->p;
|
||||
snd_BUG_ON(!root);
|
||||
snd_remove_proc_entry(root, entry->p);
|
||||
proc_remove(entry->p);
|
||||
entry->p = NULL;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user