mirror of
https://github.com/alsa-project/alsa-lib.git
synced 2025-11-04 13:30:08 -05:00
general: recoded snd_dlobj_ functions
- changed logic to get/put blocks - added mutex locking of the symbol list - added reference counting (do not free used dl handles) Signed-off-by: Jaroslav Kysela <perex@perex.cz>
This commit is contained in:
parent
be06ab3ee7
commit
91c9c8f1b8
7 changed files with 153 additions and 123 deletions
|
|
@ -94,8 +94,7 @@ int snd_ctl_close(snd_ctl_t *ctl)
|
|||
}
|
||||
err = ctl->ops->close(ctl);
|
||||
free(ctl->name);
|
||||
if (ctl->dl_handle)
|
||||
snd_dlclose(ctl->dl_handle);
|
||||
snd_dlobj_cache_put(ctl->open_func);
|
||||
free(ctl);
|
||||
return err;
|
||||
}
|
||||
|
|
@ -768,7 +767,6 @@ static int snd_ctl_open_conf(snd_ctl_t **ctlp, const char *name,
|
|||
#ifndef PIC
|
||||
extern void *snd_control_open_symbols(void);
|
||||
#endif
|
||||
void *h = NULL;
|
||||
if (snd_config_get_type(ctl_conf) != SND_CONFIG_TYPE_COMPOUND) {
|
||||
if (name)
|
||||
SNDERR("Invalid type for CTL %s definition", name);
|
||||
|
|
@ -854,40 +852,22 @@ static int snd_ctl_open_conf(snd_ctl_t **ctlp, const char *name,
|
|||
#ifndef PIC
|
||||
snd_control_open_symbols();
|
||||
#endif
|
||||
open_func = snd_dlobj_cache_lookup(open_name);
|
||||
open_func = snd_dlobj_cache_get(lib, open_name,
|
||||
SND_DLSYM_VERSION(SND_CONTROL_DLSYM_VERSION), 1);
|
||||
if (open_func) {
|
||||
err = 0;
|
||||
goto _err;
|
||||
}
|
||||
h = snd_dlopen(lib, RTLD_NOW);
|
||||
if (h)
|
||||
open_func = snd_dlsym(h, open_name, SND_DLSYM_VERSION(SND_CONTROL_DLSYM_VERSION));
|
||||
err = 0;
|
||||
if (!h) {
|
||||
SNDERR("Cannot open shared library %s", lib);
|
||||
err = -ENOENT;
|
||||
} else if (!open_func) {
|
||||
SNDERR("symbol %s is not defined inside %s", open_name, lib);
|
||||
snd_dlclose(h);
|
||||
err = open_func(ctlp, name, ctl_root, ctl_conf, mode);
|
||||
if (err >= 0) {
|
||||
(*ctlp)->open_func = open_func;
|
||||
err = 0;
|
||||
} else {
|
||||
snd_dlobj_cache_put(open_func);
|
||||
}
|
||||
} else {
|
||||
err = -ENXIO;
|
||||
}
|
||||
_err:
|
||||
if (type_conf)
|
||||
snd_config_delete(type_conf);
|
||||
if (err >= 0) {
|
||||
err = open_func(ctlp, name, ctl_root, ctl_conf, mode);
|
||||
if (err >= 0) {
|
||||
if (h /*&& (mode & SND_CTL_KEEP_ALIVE)*/) {
|
||||
snd_dlobj_cache_add(open_name, h, open_func);
|
||||
h = NULL;
|
||||
}
|
||||
(*ctlp)->dl_handle = h;
|
||||
err = 0;
|
||||
} else {
|
||||
if (h)
|
||||
snd_dlclose(h);
|
||||
}
|
||||
}
|
||||
free(buf);
|
||||
free(buf1);
|
||||
return err;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue