blob: 852b9aebc6fb70b4b15b6582ba925a85ff186be4 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughes2a0b8732013-10-08 18:50:24 -070028
29#ifndef __BIONIC_PRIVATE_BIONIC_TLS_H_
30#define __BIONIC_PRIVATE_BIONIC_TLS_H_
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080031
Josh Gao5e2285d2017-02-22 12:19:05 -080032#include <locale.h>
33#include <mntent.h>
34#include <stdio.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080035#include <sys/cdefs.h>
Josh Gao5e2285d2017-02-22 12:19:05 -080036#include <sys/param.h>
Elliott Hughesfc69a8a2016-03-04 11:53:09 -080037
Christopher Ferris03eebcb2014-06-13 13:57:51 -070038#include "bionic_macros.h"
Elliott Hughes2a0b8732013-10-08 18:50:24 -070039#include "__get_tls.h"
Josh Gao5e2285d2017-02-22 12:19:05 -080040#include "grp_pwd.h"
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080041
42__BEGIN_DECLS
43
44/** WARNING WARNING WARNING
45 **
46 ** This header file is *NOT* part of the public Bionic ABI/API
47 ** and should not be used/included by user-serviceable parts of
48 ** the system (e.g. applications).
49 **
50 ** It is only provided here for the benefit of the system dynamic
51 ** linker and the OpenGL sub-system (which needs to access the
52 ** pre-allocated slot directly for performance reason).
53 **/
54
Elliott Hughesb30aff42014-05-28 19:35:33 +000055// Well-known TLS slots. What data goes in which slot is arbitrary unless otherwise noted.
Elliott Hughes44b53ad2013-02-11 20:18:47 +000056enum {
Elliott Hughesb30aff42014-05-28 19:35:33 +000057 TLS_SLOT_SELF = 0, // The kernel requires this specific slot for x86.
Elliott Hughes44b53ad2013-02-11 20:18:47 +000058 TLS_SLOT_THREAD_ID,
59 TLS_SLOT_ERRNO,
Elliott Hughes3e898472013-02-12 16:40:24 +000060
Elliott Hughesb30aff42014-05-28 19:35:33 +000061 // These two aren't used by bionic itself, but allow the graphics code to
62 // access TLS directly rather than using the pthread API.
Elliott Hughes44b53ad2013-02-11 20:18:47 +000063 TLS_SLOT_OPENGL_API = 3,
64 TLS_SLOT_OPENGL = 4,
Elliott Hughes3e898472013-02-12 16:40:24 +000065
Elliott Hughesb30aff42014-05-28 19:35:33 +000066 // This slot is only used to pass information from the dynamic linker to
67 // libc.so when the C library is loaded in to memory. The C runtime init
68 // function will then clear it. Since its use is extremely temporary,
69 // we reuse an existing location that isn't needed during libc startup.
Elliott Hughes3e898472013-02-12 16:40:24 +000070 TLS_SLOT_BIONIC_PREINIT = TLS_SLOT_OPENGL_API,
71
Elliott Hughesb30aff42014-05-28 19:35:33 +000072 TLS_SLOT_STACK_GUARD = 5, // GCC requires this specific slot for x86.
Elliott Hughes44b53ad2013-02-11 20:18:47 +000073 TLS_SLOT_DLERROR,
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080074
Andreas Gampe9bbb5a72015-07-28 19:53:54 -070075 // Fast storage for Thread::Current() in ART.
76 TLS_SLOT_ART_THREAD_SELF,
77
Dan Albertaa23b2e2015-08-18 15:09:00 -070078 // Lets TSAN avoid using pthread_getspecific for finding the current thread
79 // state.
80 TLS_SLOT_TSAN,
81
Yabin Cui5e2bd712015-02-20 16:15:33 -080082 BIONIC_TLS_SLOTS // Must come last!
Elliott Hughes44b53ad2013-02-11 20:18:47 +000083};
Elliott Hughes5419b942012-10-16 15:54:46 -070084
Josh Gao5e2285d2017-02-22 12:19:05 -080085// ~3 pages.
86struct bionic_tls {
87 locale_t locale;
88
89 char basename_buf[MAXPATHLEN];
90 char dirname_buf[MAXPATHLEN];
91
92 mntent mntent_buf;
93 char mntent_strings[BUFSIZ];
94
95 char ptsname_buf[32];
96 char ttyname_buf[64];
97
98 char strerror_buf[NL_TEXTMAX];
99 char strsignal_buf[NL_TEXTMAX];
100
101 group_state_t group;
102 passwd_state_t passwd;
103};
104
105#define BIONIC_TLS_SIZE (BIONIC_ALIGN(sizeof(bionic_tls), PAGE_SIZE))
106
Elliott Hughes3e898472013-02-12 16:40:24 +0000107/*
Yabin Cui5e2bd712015-02-20 16:15:33 -0800108 * Bionic uses some pthread keys internally. All pthread keys used internally
Elliott Hughes61706932015-03-31 10:56:58 -0700109 * should be created in constructors, except for keys that may be used in or
110 * before constructors.
111 *
Yabin Cui5e2bd712015-02-20 16:15:33 -0800112 * We need to manually maintain the count of pthread keys used internally, but
113 * pthread_test should fail if we forget.
Elliott Hughes61706932015-03-31 10:56:58 -0700114 *
115 * These are the pthread keys currently used internally by libc:
Elliott Hughes61706932015-03-31 10:56:58 -0700116 * _res_key libc (constructor in BSD code)
Yabin Cui5e2bd712015-02-20 16:15:33 -0800117 */
118
Josh Gao5e2285d2017-02-22 12:19:05 -0800119#define LIBC_PTHREAD_KEY_RESERVED_COUNT 1
Yabin Cui5e2bd712015-02-20 16:15:33 -0800120
Christopher Ferrisc0f89282015-04-15 16:34:57 -0700121/* Internally, jemalloc uses a single key for per thread data. */
122#define JEMALLOC_PTHREAD_KEY_RESERVED_COUNT 1
Yabin Cui5e2bd712015-02-20 16:15:33 -0800123#define BIONIC_PTHREAD_KEY_RESERVED_COUNT (LIBC_PTHREAD_KEY_RESERVED_COUNT + JEMALLOC_PTHREAD_KEY_RESERVED_COUNT)
Christopher Ferris72bbd422014-05-08 11:14:03 -0700124
Elliott Hughes18876212013-12-12 11:02:41 -0800125/*
Yabin Cui5e2bd712015-02-20 16:15:33 -0800126 * Maximum number of pthread keys allocated.
127 * This includes pthread keys used internally and externally.
Elliott Hughes18876212013-12-12 11:02:41 -0800128 */
Yabin Cui5e2bd712015-02-20 16:15:33 -0800129#define BIONIC_PTHREAD_KEY_COUNT (BIONIC_PTHREAD_KEY_RESERVED_COUNT + PTHREAD_KEYS_MAX)
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800130
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800131__END_DECLS
132
Elliott Hughesd3920b32013-02-07 18:39:34 -0800133#if defined(__cplusplus)
Bernhard Rosenkraenzeredad1e12013-09-18 23:37:00 +0200134class KernelArgumentBlock;
Elliott Hughesfc69a8a2016-03-04 11:53:09 -0800135extern void __libc_init_main_thread(KernelArgumentBlock&);
Elliott Hughesd3920b32013-02-07 18:39:34 -0800136#endif
137
Elliott Hughes2a0b8732013-10-08 18:50:24 -0700138#endif /* __BIONIC_PRIVATE_BIONIC_TLS_H_ */