avoid malloc of deps arrays for ldso and vdso

neither has or can have any dependencies, but since commit
4035556907, gratuitous zero-length deps
arrays were being allocated for them. use a dummy array instead.
This commit is contained in:
Rich Felker 2019-03-03 12:42:34 -05:00
parent e612d094b1
commit f034f145bd

View File

@ -134,6 +134,7 @@ static size_t static_tls_cnt;
static pthread_mutex_t init_fini_lock; static pthread_mutex_t init_fini_lock;
static pthread_cond_t ctor_cond; static pthread_cond_t ctor_cond;
static struct dso *builtin_deps[2]; static struct dso *builtin_deps[2];
static struct dso *const no_deps[1];
static struct dso **main_ctor_queue; static struct dso **main_ctor_queue;
static struct fdpic_loadmap *app_loadmap; static struct fdpic_loadmap *app_loadmap;
static struct fdpic_dummy_loadmap app_dummy_loadmap; static struct fdpic_dummy_loadmap app_dummy_loadmap;
@ -1820,6 +1821,7 @@ _Noreturn void __dls3(size_t *sp)
reclaim_gaps(&ldso); reclaim_gaps(&ldso);
/* Load preload/needed libraries, add symbols to global namespace. */ /* Load preload/needed libraries, add symbols to global namespace. */
ldso.deps = (struct dso **)no_deps;
if (env_preload) load_preload(env_preload); if (env_preload) load_preload(env_preload);
load_deps(&app); load_deps(&app);
for (struct dso *p=head; p; p=p->next) for (struct dso *p=head; p; p=p->next)
@ -1841,6 +1843,7 @@ _Noreturn void __dls3(size_t *sp)
vdso.name = ""; vdso.name = "";
vdso.shortname = "linux-gate.so.1"; vdso.shortname = "linux-gate.so.1";
vdso.relocated = 1; vdso.relocated = 1;
vdso.deps = (struct dso **)no_deps;
decode_dyn(&vdso); decode_dyn(&vdso);
vdso.prev = tail; vdso.prev = tail;
tail->next = &vdso; tail->next = &vdso;