1.. _thread_local_storage: 2 3Thread Local Storage (TLS) 4########################## 5 6Thread Local Storage (TLS) allows variables to be allocated on a per-thread 7basis. These variables are stored in the thread stack which means every 8thread has its own copy of these variables. 9 10Zephyr currently requires toolchain support for TLS. 11 12 13Configuration 14************* 15 16To enable thread local storage in Zephyr, :kconfig:option:`CONFIG_THREAD_LOCAL_STORAGE` 17needs to be enabled. Note that this option may not be available if 18the architecture or the SoC does not have the hidden option 19:kconfig:option:`CONFIG_ARCH_HAS_THREAD_LOCAL_STORAGE` enabled, which means 20the architecture or the SoC does not have the necessary code to support 21thread local storage and/or the toolchain does not support TLS. 22 23:kconfig:option:`CONFIG_ERRNO_IN_TLS` can be enabled together with 24:kconfig:option:`CONFIG_ERRNO` to let the variable ``errno`` be a thread local 25variable. This allows user threads to access the value of ``errno`` without 26making a system call. 27 28 29Declaring and Using Thread Local Variables 30****************************************** 31 32The macro ``Z_THREAD_LOCAL`` can be used to declare thread local variables. 33 34For example, to declare a thread local variable in header files: 35 36.. code-block:: c 37 38 extern Z_THREAD_LOCAL int i; 39 40And to declare the actual variable in source files: 41 42.. code-block:: c 43 44 Z_THREAD_LOCAL int i; 45 46Keyword ``static`` can also be used to limit the variable within a source file: 47 48.. code-block:: c 49 50 static Z_THREAD_LOCAL int j; 51 52Using the thread local variable is the same as using other variable, for example: 53 54.. code-block:: c 55 56 void testing(void) { 57 i = 10; 58 } 59