提交 12978acb 编写于 作者: S Szabolcs Nagy 提交者: Rich Felker

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.
上级 8eead3ef
...@@ -1280,7 +1280,7 @@ void *__tls_get_new(size_t *v) ...@@ -1280,7 +1280,7 @@ void *__tls_get_new(size_t *v)
/* Get new DTV space from new DSO if needed */ /* Get new DTV space from new DSO if needed */
if (v[0] > (size_t)self->dtv[0]) { if (v[0] > (size_t)self->dtv[0]) {
void **newdtv = p->new_dtv + 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, memcpy(newdtv, self->dtv,
((size_t)self->dtv[0]+1) * sizeof(void *)); ((size_t)self->dtv[0]+1) * sizeof(void *));
newdtv[0] = (void *)v[0]; newdtv[0] = (void *)v[0];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册