Commit 480e32eb authored by Takashi Iwai's avatar Takashi Iwai

ALSA: pcm: Simplify proc file destruction

The proc files are recursively freed by calling with the root
snd_info_entry object, so we don't have to keep each object for
releasing one by one.  Move the release of the PCM stream proc root at
the beginning, so that we can remove the redundant code and resource.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent de89750c
...@@ -481,15 +481,6 @@ struct snd_pcm_substream { ...@@ -481,15 +481,6 @@ struct snd_pcm_substream {
#endif #endif
#ifdef CONFIG_SND_VERBOSE_PROCFS #ifdef CONFIG_SND_VERBOSE_PROCFS
struct snd_info_entry *proc_root; struct snd_info_entry *proc_root;
struct snd_info_entry *proc_info_entry;
struct snd_info_entry *proc_hw_params_entry;
struct snd_info_entry *proc_sw_params_entry;
struct snd_info_entry *proc_status_entry;
struct snd_info_entry *proc_prealloc_entry;
struct snd_info_entry *proc_prealloc_max_entry;
#ifdef CONFIG_SND_PCM_XRUN_DEBUG
struct snd_info_entry *proc_xrun_injection_entry;
#endif
#endif /* CONFIG_SND_VERBOSE_PROCFS */ #endif /* CONFIG_SND_VERBOSE_PROCFS */
/* misc flags */ /* misc flags */
unsigned int hw_opened: 1; unsigned int hw_opened: 1;
...@@ -511,10 +502,8 @@ struct snd_pcm_str { ...@@ -511,10 +502,8 @@ struct snd_pcm_str {
#endif #endif
#ifdef CONFIG_SND_VERBOSE_PROCFS #ifdef CONFIG_SND_VERBOSE_PROCFS
struct snd_info_entry *proc_root; struct snd_info_entry *proc_root;
struct snd_info_entry *proc_info_entry;
#ifdef CONFIG_SND_PCM_XRUN_DEBUG #ifdef CONFIG_SND_PCM_XRUN_DEBUG
unsigned int xrun_debug; /* 0 = disabled, 1 = verbose, 2 = stacktrace */ unsigned int xrun_debug; /* 0 = disabled, 1 = verbose, 2 = stacktrace */
struct snd_info_entry *proc_xrun_debug_entry;
#endif #endif
#endif #endif
struct snd_kcontrol *chmap_kctl; /* channel-mapping controls */ struct snd_kcontrol *chmap_kctl; /* channel-mapping controls */
......
...@@ -536,12 +536,9 @@ static int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr) ...@@ -536,12 +536,9 @@ static int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr)
entry = snd_info_create_card_entry(pcm->card, "info", pstr->proc_root); entry = snd_info_create_card_entry(pcm->card, "info", pstr->proc_root);
if (entry) { if (entry) {
snd_info_set_text_ops(entry, pstr, snd_pcm_stream_proc_info_read); snd_info_set_text_ops(entry, pstr, snd_pcm_stream_proc_info_read);
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
pstr->proc_info_entry = entry;
#ifdef CONFIG_SND_PCM_XRUN_DEBUG #ifdef CONFIG_SND_PCM_XRUN_DEBUG
entry = snd_info_create_card_entry(pcm->card, "xrun_debug", entry = snd_info_create_card_entry(pcm->card, "xrun_debug",
...@@ -551,24 +548,15 @@ static int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr) ...@@ -551,24 +548,15 @@ static int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr)
entry->c.text.write = snd_pcm_xrun_debug_write; entry->c.text.write = snd_pcm_xrun_debug_write;
entry->mode |= 0200; entry->mode |= 0200;
entry->private_data = pstr; entry->private_data = pstr;
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
pstr->proc_xrun_debug_entry = entry;
#endif #endif
return 0; return 0;
} }
static int snd_pcm_stream_proc_done(struct snd_pcm_str *pstr) static int snd_pcm_stream_proc_done(struct snd_pcm_str *pstr)
{ {
#ifdef CONFIG_SND_PCM_XRUN_DEBUG
snd_info_free_entry(pstr->proc_xrun_debug_entry);
pstr->proc_xrun_debug_entry = NULL;
#endif
snd_info_free_entry(pstr->proc_info_entry);
pstr->proc_info_entry = NULL;
snd_info_free_entry(pstr->proc_root); snd_info_free_entry(pstr->proc_root);
pstr->proc_root = NULL; pstr->proc_root = NULL;
return 0; return 0;
...@@ -597,45 +585,33 @@ static int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream) ...@@ -597,45 +585,33 @@ static int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream)
if (entry) { if (entry) {
snd_info_set_text_ops(entry, substream, snd_info_set_text_ops(entry, substream,
snd_pcm_substream_proc_info_read); snd_pcm_substream_proc_info_read);
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_info_entry = entry;
entry = snd_info_create_card_entry(card, "hw_params", entry = snd_info_create_card_entry(card, "hw_params",
substream->proc_root); substream->proc_root);
if (entry) { if (entry) {
snd_info_set_text_ops(entry, substream, snd_info_set_text_ops(entry, substream,
snd_pcm_substream_proc_hw_params_read); snd_pcm_substream_proc_hw_params_read);
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_hw_params_entry = entry;
entry = snd_info_create_card_entry(card, "sw_params", entry = snd_info_create_card_entry(card, "sw_params",
substream->proc_root); substream->proc_root);
if (entry) { if (entry) {
snd_info_set_text_ops(entry, substream, snd_info_set_text_ops(entry, substream,
snd_pcm_substream_proc_sw_params_read); snd_pcm_substream_proc_sw_params_read);
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_sw_params_entry = entry;
entry = snd_info_create_card_entry(card, "status", entry = snd_info_create_card_entry(card, "status",
substream->proc_root); substream->proc_root);
if (entry) { if (entry) {
snd_info_set_text_ops(entry, substream, snd_info_set_text_ops(entry, substream,
snd_pcm_substream_proc_status_read); snd_pcm_substream_proc_status_read);
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_status_entry = entry;
#ifdef CONFIG_SND_PCM_XRUN_DEBUG #ifdef CONFIG_SND_PCM_XRUN_DEBUG
entry = snd_info_create_card_entry(card, "xrun_injection", entry = snd_info_create_card_entry(card, "xrun_injection",
...@@ -645,40 +621,18 @@ static int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream) ...@@ -645,40 +621,18 @@ static int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream)
entry->c.text.read = NULL; entry->c.text.read = NULL;
entry->c.text.write = snd_pcm_xrun_injection_write; entry->c.text.write = snd_pcm_xrun_injection_write;
entry->mode = S_IFREG | 0200; entry->mode = S_IFREG | 0200;
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_xrun_injection_entry = entry;
#endif /* CONFIG_SND_PCM_XRUN_DEBUG */ #endif /* CONFIG_SND_PCM_XRUN_DEBUG */
return 0; return 0;
} }
static int snd_pcm_substream_proc_done(struct snd_pcm_substream *substream)
{
snd_info_free_entry(substream->proc_info_entry);
substream->proc_info_entry = NULL;
snd_info_free_entry(substream->proc_hw_params_entry);
substream->proc_hw_params_entry = NULL;
snd_info_free_entry(substream->proc_sw_params_entry);
substream->proc_sw_params_entry = NULL;
snd_info_free_entry(substream->proc_status_entry);
substream->proc_status_entry = NULL;
#ifdef CONFIG_SND_PCM_XRUN_DEBUG
snd_info_free_entry(substream->proc_xrun_injection_entry);
substream->proc_xrun_injection_entry = NULL;
#endif
snd_info_free_entry(substream->proc_root);
substream->proc_root = NULL;
return 0;
}
#else /* !CONFIG_SND_VERBOSE_PROCFS */ #else /* !CONFIG_SND_VERBOSE_PROCFS */
static inline int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr) { return 0; } static inline int snd_pcm_stream_proc_init(struct snd_pcm_str *pstr) { return 0; }
static inline int snd_pcm_stream_proc_done(struct snd_pcm_str *pstr) { return 0; } static inline int snd_pcm_stream_proc_done(struct snd_pcm_str *pstr) { return 0; }
static inline int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream) { return 0; } static inline int snd_pcm_substream_proc_init(struct snd_pcm_substream *substream) { return 0; }
static inline int snd_pcm_substream_proc_done(struct snd_pcm_substream *substream) { return 0; }
#endif /* CONFIG_SND_VERBOSE_PROCFS */ #endif /* CONFIG_SND_VERBOSE_PROCFS */
static const struct attribute_group *pcm_dev_attr_groups[]; static const struct attribute_group *pcm_dev_attr_groups[];
...@@ -911,15 +865,17 @@ static void snd_pcm_free_stream(struct snd_pcm_str * pstr) ...@@ -911,15 +865,17 @@ static void snd_pcm_free_stream(struct snd_pcm_str * pstr)
#if IS_ENABLED(CONFIG_SND_PCM_OSS) #if IS_ENABLED(CONFIG_SND_PCM_OSS)
struct snd_pcm_oss_setup *setup, *setupn; struct snd_pcm_oss_setup *setup, *setupn;
#endif #endif
/* free all proc files under the stream */
snd_pcm_stream_proc_done(pstr);
substream = pstr->substream; substream = pstr->substream;
while (substream) { while (substream) {
substream_next = substream->next; substream_next = substream->next;
snd_pcm_timer_done(substream); snd_pcm_timer_done(substream);
snd_pcm_substream_proc_done(substream);
kfree(substream); kfree(substream);
substream = substream_next; substream = substream_next;
} }
snd_pcm_stream_proc_done(pstr);
#if IS_ENABLED(CONFIG_SND_PCM_OSS) #if IS_ENABLED(CONFIG_SND_PCM_OSS)
for (setup = pstr->oss.setup_list; setup; setup = setupn) { for (setup = pstr->oss.setup_list; setup; setup = setupn) {
setupn = setup->next; setupn = setup->next;
......
...@@ -93,12 +93,6 @@ static void snd_pcm_lib_preallocate_dma_free(struct snd_pcm_substream *substream ...@@ -93,12 +93,6 @@ static void snd_pcm_lib_preallocate_dma_free(struct snd_pcm_substream *substream
int snd_pcm_lib_preallocate_free(struct snd_pcm_substream *substream) int snd_pcm_lib_preallocate_free(struct snd_pcm_substream *substream)
{ {
snd_pcm_lib_preallocate_dma_free(substream); snd_pcm_lib_preallocate_dma_free(substream);
#ifdef CONFIG_SND_VERBOSE_PROCFS
snd_info_free_entry(substream->proc_prealloc_max_entry);
substream->proc_prealloc_max_entry = NULL;
snd_info_free_entry(substream->proc_prealloc_entry);
substream->proc_prealloc_entry = NULL;
#endif
return 0; return 0;
} }
...@@ -203,21 +197,15 @@ static inline void preallocate_info_init(struct snd_pcm_substream *substream) ...@@ -203,21 +197,15 @@ static inline void preallocate_info_init(struct snd_pcm_substream *substream)
entry->c.text.write = snd_pcm_lib_preallocate_proc_write; entry->c.text.write = snd_pcm_lib_preallocate_proc_write;
entry->mode |= 0200; entry->mode |= 0200;
entry->private_data = substream; entry->private_data = substream;
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_prealloc_entry = entry;
if ((entry = snd_info_create_card_entry(substream->pcm->card, "prealloc_max", substream->proc_root)) != NULL) { if ((entry = snd_info_create_card_entry(substream->pcm->card, "prealloc_max", substream->proc_root)) != NULL) {
entry->c.text.read = snd_pcm_lib_preallocate_max_proc_read; entry->c.text.read = snd_pcm_lib_preallocate_max_proc_read;
entry->private_data = substream; entry->private_data = substream;
if (snd_info_register(entry) < 0) { if (snd_info_register(entry) < 0)
snd_info_free_entry(entry); snd_info_free_entry(entry);
entry = NULL;
}
} }
substream->proc_prealloc_max_entry = entry;
} }
#else /* !CONFIG_SND_VERBOSE_PROCFS */ #else /* !CONFIG_SND_VERBOSE_PROCFS */
......
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