diff options
author | bdrewery <bdrewery@FreeBSD.org> | 2017-01-03 23:28:07 +0000 |
---|---|---|
committer | bdrewery <bdrewery@FreeBSD.org> | 2017-01-03 23:28:07 +0000 |
commit | f9e3def0a8d5d23509ea2969d8021e48e436d654 (patch) | |
tree | 1b32e29e3c68fd5400de14a6e23bda37f3f486f5 /libexec/rtld-elf/rtld.c | |
parent | b752680e3280b2b799c3274585c8f5e85dafd6c4 (diff) | |
download | FreeBSD-src-f9e3def0a8d5d23509ea2969d8021e48e436d654.zip FreeBSD-src-f9e3def0a8d5d23509ea2969d8021e48e436d654.tar.gz |
MFC r310025:
Take write lock for rtld_bind before modifying obj_list in dl_iterate_phdr().
Diffstat (limited to 'libexec/rtld-elf/rtld.c')
-rw-r--r-- | libexec/rtld-elf/rtld.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/libexec/rtld-elf/rtld.c b/libexec/rtld-elf/rtld.c index a562363..3b40d39 100644 --- a/libexec/rtld-elf/rtld.c +++ b/libexec/rtld-elf/rtld.c @@ -3545,7 +3545,7 @@ dl_iterate_phdr(__dl_iterate_hdr_callback callback, void *param) error = 0; wlock_acquire(rtld_phdr_lock, &phdr_lockstate); - rlock_acquire(rtld_bind_lock, &bind_lockstate); + wlock_acquire(rtld_bind_lock, &bind_lockstate); for (obj = globallist_curr(TAILQ_FIRST(&obj_list)); obj != NULL;) { TAILQ_INSERT_AFTER(&obj_list, obj, &marker, next); rtld_fill_dl_phdr_info(obj, &phdr_info); @@ -3553,7 +3553,7 @@ dl_iterate_phdr(__dl_iterate_hdr_callback callback, void *param) error = callback(&phdr_info, sizeof phdr_info, param); - rlock_acquire(rtld_bind_lock, &bind_lockstate); + wlock_acquire(rtld_bind_lock, &bind_lockstate); obj = globallist_next(&marker); TAILQ_REMOVE(&obj_list, &marker, next); if (error != 0) { |