diff options
author | Szabolcs Nagy <nsz@port70.net> | 2015-11-26 19:59:46 +0100 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2015-11-28 13:34:17 -0500 |
commit | 12978acb3066db738c8c15121e81adbb63739876 (patch) | |
tree | ad1b75f4b307190f31416438b8c6de8494c8f62e /src/network/socketpair.c | |
parent | 8eead3ef18ea71a64ef3cbff8c09bac3b82f1242 (diff) | |
download | musl-12978acb3066db738c8c15121e81adbb63739876.tar.gz musl-12978acb3066db738c8c15121e81adbb63739876.tar.bz2 musl-12978acb3066db738c8c15121e81adbb63739876.tar.xz musl-12978acb3066db738c8c15121e81adbb63739876.zip |
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.
Diffstat (limited to 'src/network/socketpair.c')
0 files changed, 0 insertions, 0 deletions