From 1129a0915284c725e7a4d578eb8d97edd0a726e4 Mon Sep 17 00:00:00 2001 From: dhy308 Date: Sat, 26 Nov 2022 14:19:16 +0800 Subject: [PATCH] Adjust the lock sequence in the dlopen process. Issue: I6396D Test: libc-test pass Signed-off-by: dhy308 --- porting/linux/user/ldso/dynlink.c | 81 +++++++++++++++---------------- 1 file changed, 38 insertions(+), 43 deletions(-) diff --git a/porting/linux/user/ldso/dynlink.c b/porting/linux/user/ldso/dynlink.c index 5e714b0f..b0b9688e 100644 --- a/porting/linux/user/ldso/dynlink.c +++ b/porting/linux/user/ldso/dynlink.c @@ -2910,8 +2910,37 @@ static void prepare_lazy(struct dso *p) lazy_head = p; } +static void *dlopen_post(struct dso* p, int mode) { + if (p == NULL) { + return p; + } + + p->nr_dlopen++; + if (p->bfs_built) { + for (int i = 0; p->deps[i]; i++) { + p->deps[i]->nr_dlopen++; + + if (mode & RTLD_NODELETE) { + p->deps[i]->flags |= DSO_FLAGS_NODELETE; + } + } + } + +#ifdef HANDLE_RANDOMIZATION + void *handle = assign_valid_handle(p); + if (handle == NULL) { + LD_LOGE("dlopen_post: generate random handle failed"); + do_dlclose(p); + } + + return handle; +#endif + + return p; +} + /* add namespace function */ -static void *dlopen_impl_orig( +static void *dlopen_impl( const char *file, int mode, const char *namespace, const void *caller_addr, const dl_extinfo *extinfo) { struct dso *volatile p, *orig_tail, *orig_syms_tail, *orig_lazy_head, *next; @@ -2933,8 +2962,8 @@ static void *dlopen_impl_orig( #endif if (!file) { - LD_LOGD("dlopen_impl_orig file is null, return head."); - return head; + LD_LOGD("dlopen_impl file is null, return head."); + return dlopen_post(head, mode); } if (extinfo) { @@ -3025,16 +3054,16 @@ static void *dlopen_impl_orig( #ifdef LOAD_ORDER_RANDOMIZATION tasks = create_loadtasks(); if (!tasks) { - LD_LOGE("dlopen_impl_orig create loadtasks failed"); + LD_LOGE("dlopen_impl create loadtasks failed"); goto end; } task = create_loadtask(file, head, ns, true); if (!task) { - LD_LOGE("dlopen_impl_orig create loadtask failed"); + LD_LOGE("dlopen_impl create loadtask failed"); goto end; } if (!load_library_header(task)) { - LD_LOGE("dlopen_impl_orig load library header failed for %{public}s", task->name); + LD_LOGE("dlopen_impl load library header failed for %{public}s", task->name); goto end; } if (reserved_address) { @@ -3042,7 +3071,7 @@ static void *dlopen_impl_orig( } } if (!task->p) { - LD_LOGE("dlopen_impl_orig load library failed for %{public}s", task->name); + LD_LOGE("dlopen_impl load library failed for %{public}s", task->name); error(noload ? "Library %s is not already loaded" : "Error loading shared library %s: %m", @@ -3122,6 +3151,8 @@ static void *dlopen_impl_orig( if (tls_cnt != orig_tls_cnt) install_new_tls(); orig_tail = tail; + + p = dlopen_post(p, mode); end: debug.state = RT_CONSISTENT; _dl_debug_state(); @@ -3142,42 +3173,6 @@ end: return p; } -static void *dlopen_impl( - const char *file, int mode, const char *namespace, const void *caller_addr, const dl_extinfo *extinfo){ - struct dso* p = (struct dso*)dlopen_impl_orig(file, mode, namespace, caller_addr, extinfo); - - if (p == NULL) { - return p; - } - - pthread_rwlock_wrlock(&lock); - - p->nr_dlopen++; - if (p->bfs_built) { - for (int i = 0; p->deps[i]; i++) { - p->deps[i]->nr_dlopen++; - - if (mode & RTLD_NODELETE) { - p->deps[i]->flags |= DSO_FLAGS_NODELETE; - } - } - } - -#ifdef HANDLE_RANDOMIZATION - void *handle = assign_valid_handle(p); - if (handle == NULL) { - LD_LOGE("dlopen_impl: generate random handle failed"); - do_dlclose(p); - } - pthread_rwlock_unlock(&lock); - - return handle; -#endif - - pthread_rwlock_unlock(&lock); - return p; -} - void *dlopen(const char *file, int mode) { const void *caller_addr = __builtin_return_address(0); -- GitLab