1:255.13-alt1
[systemd_ALT.git] / man / threads-aware.xml
blob442e45bbbbadf9a56785d8991aba5847a3aa2c63
1 <?xml version="1.0"?>
2 <!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3   "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
4 <!-- SPDX-License-Identifier: LGPL-2.1-or-later -->
6 <refsect1>
8 <para id="strict">All functions listed here are thread-agnostic and only a single specific thread may operate on a
9 given object during its entire lifetime. It's safe to allocate multiple independent objects and use each from a
10 specific thread in parallel. However, it's not safe to allocate such an object in one thread, and operate or free it
11 from any other, even if locking is used to ensure these threads don't operate on it at the very same time.</para>
13 <para id="safe">All functions listed here are thread-safe and may be called in parallel from multiple threads.</para>
15 <para id='getenv'>The code described here uses
16 <citerefentry project='man-pages'><refentrytitle>getenv</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
17 which is declared to be not multi-thread-safe. This means that the code calling the functions described
18 here must not call
19 <citerefentry project='man-pages'><refentrytitle>setenv</refentrytitle><manvolnum>3</manvolnum></citerefentry>
20 from a parallel thread. It is recommended to only do calls to <function>setenv()</function>
21 from an early phase of the program when no other threads have been started.</para>
23 </refsect1>