mirror of
https://git.musl-libc.org/git/musl
synced 2025-02-09 06:44:22 +03:00
ldso: fix the dtv update logic in __tls_get_new
if two or more threads accessed tls in a dso that was loaded after the threads were created, then __tls_get_new could do out-of-bound memory access (leading to segfault). accidentally byte count was used instead of element count when the new dtv pointer was computed. (dso->new_dtv is (void**).) it is rare that the same dso provides dtv for several threads, the crash was not observed in practice, but possible to trigger.
This commit is contained in:
parent
8eead3ef18
commit
12978acb30
@ -1280,7 +1280,7 @@ void *__tls_get_new(size_t *v)
|
||||
/* Get new DTV space from new DSO if needed */
|
||||
if (v[0] > (size_t)self->dtv[0]) {
|
||||
void **newdtv = p->new_dtv +
|
||||
(v[0]+1)*sizeof(void *)*a_fetch_add(&p->new_dtv_idx,1);
|
||||
(v[0]+1)*a_fetch_add(&p->new_dtv_idx,1);
|
||||
memcpy(newdtv, self->dtv,
|
||||
((size_t)self->dtv[0]+1) * sizeof(void *));
|
||||
newdtv[0] = (void *)v[0];
|
||||
|
Loading…
x
Reference in New Issue
Block a user