You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
There are a a few non thread-safe libc functions used in Python that can be an issue for free threading, isolated subinterpreters, or sometimes even with the GIL.
In #126316, @vstinner fixed the use setgrent / getgrent. It's probably a good time to look for other similar issues.
clang-tidy
clang-tidy has a concurrency-mt-unsafe check that looks for "known-to-be-unsafe functions".
setpwent, getpwent, and endpwent in pwdmodule.c. These are similar to grpmodule.c and can likely be addressed the same way.
getservbyname, getservbyport, getprotobyname in Modules/socketmodule.c: use getservbyname_r, etc.? Note these thread-safety issues affect the default build because we release the GIL around the relevant calls.
login_tty: not sure it matters as login_tty is usually called after a fork()
Safe due to our usage
getc_unlocked, safe because we use it within a flockfile() call.
mbrtowc() - safe as long as the passed in mbstate_t * is non-NULL, which is the case in CPython.
Safe in glibc
These functions are flagged by clang-tidy because they are not guaranteed to be safe by POSIX, but they are safe in glibc. It'd be nice to verify that they are safe in other libc implementations. I don't think it's worth changing them:
readdir(DIR *dirp): see https://man7.org/linux/man-pages/man3/readdir.3.html: "...in modern implementations (including the glibc implementation), concurrent calls to readdir() that specify different directory streams are thread-safe."
Bug report
There are a a few non thread-safe libc functions used in Python that can be an issue for free threading, isolated subinterpreters, or sometimes even with the GIL.
In #126316, @vstinner fixed the use
setgrent
/getgrent
. It's probably a good time to look for other similar issues.clang-tidy
clang-tidy
has aconcurrency-mt-unsafe
check that looks for "known-to-be-unsafe functions".clang-tidy notes
Prerequisites: install
clang-tidy-18
andbear
.Unsafe libc functions
localeconv()
: not thread-safe, see glibc's manual. Isnl_langinfo
a substitue?setlocale
setpwent
,getpwent
, andendpwent
inpwdmodule.c
. These are similar togrpmodule.c
and can likely be addressed the same way.getservbyname
,getservbyport
,getprotobyname
inModules/socketmodule.c
: usegetservbyname_r
, etc.? Note these thread-safety issues affect the default build because we release the GIL around the relevant calls.dbm_open
,dbm_close
, etc. inModules/_dbmmodule.c
getlogin
: usegetlogin_r
if available?Unfixable by us?
getenv
,setenv
,unsetenv
,putenv
: environment modification isn't thread-safe andgetenv
is used extensively in other C libraries, so putting a lock around our accesses doesn't do much. (Might finally be fixed in glibc, see https://inbox.sourceware.org/libc-alpha/cover.1722193092.git.fweimer@redhat.com/).login_tty
: not sure it matters aslogin_tty
is usually called after afork()
Safe due to our usage
getc_unlocked
, safe because we use it within aflockfile()
call.mbrtowc()
- safe as long as the passed inmbstate_t *
is non-NULL, which is the case in CPython.Safe in glibc
These functions are flagged by clang-tidy because they are not guaranteed to be safe by POSIX, but they are safe in glibc. It'd be nice to verify that they are safe in other libc implementations. I don't think it's worth changing them:
dlerror()
strerror()
: see https://man7.org/linux/man-pages/man3/strerror.3.htmlsystem()
: see https://man7.org/linux/man-pages/man3/system.3.htmlreaddir(DIR *dirp)
: see https://man7.org/linux/man-pages/man3/readdir.3.html: "...in modern implementations (including the glibc implementation), concurrent calls to readdir() that specify different directory streams are thread-safe."wcstombs
: see https://man7.org/linux/man-pages/man3/wcstombs.3.htmlnl_langinfo
: https://www.man7.org/linux/man-pages/man3/nl_langinfo.3.html (as long as locale doesn't change)tcsendbreak
,tcflow
: see https://www.man7.org/linux/man-pages/man3/termios.3.html#ATTRIBUTESsetlogmask
: safe since glibc 2.33strsignal
: not documented as thread-safe, but uses glibc uses TLS internally since 2.32Other
exit()
: apparently concurrent calls toexit()
are not thread-safe, but I don't think it matters for our usages.ptsname()
: we already useptsname_r()
, but the static analyzer gets confusedThe text was updated successfully, but these errors were encountered: