[Bug 258360] race between setlocale() and iconv_open() causes segfault
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Reply: bugzilla-noreply_a_freebsd.org: "[Bug 258360] race between setlocale() and iconv_open() causes segfault"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 08 Sep 2021 04:25:07 UTC
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=258360 Bug ID: 258360 Summary: race between setlocale() and iconv_open() causes segfault Product: Base System Version: 13.0-STABLE Hardware: Any OS: Any Status: New Severity: Affects Only Me Priority: --- Component: threads Assignee: threads@FreeBSD.org Reporter: henry.hu.sh@gmail.com This was discovered by Dmitry Wagin in PR 258212. I'm able to reproduce the crash with a very simple program, which simply calls iconv_open() and setlocale() concurrently: #include <iconv.h> #include <pthread.h> #include <locale.h> void* iconv_thread(void* arg) { iconv_open("UTF-8", "UTF-8"); return NULL; } void* locale_thread(void* arg) { setlocale(LC_ALL, "en_US.UTF-8"); return NULL; } int main() { pthread_t t1, t2; pthread_create(&t1, NULL, iconv_thread, NULL); pthread_create(&t2, NULL, locale_thread, NULL); pthread_join(t1, NULL); pthread_join(t2, NULL); } On my machine it has a 7/10 chance of crashing. On another user's machine it only crashes 1/15, so repeated testing is needed. The stack can be seen at https://pastebin.com/raw/isvMUDRd -- You are receiving this mail because: You are the assignee for the bug.