annotate libphobos/libdruntime/gcc/sections/android.d @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 // Bionic-specific support for sections.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 // Copyright (C) 2019-2020 Free Software Foundation, Inc.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 // GCC is free software; you can redistribute it and/or modify it under
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 // the terms of the GNU General Public License as published by the Free
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 // Software Foundation; either version 3, or (at your option) any later
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 // version.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 // GCC is distributed in the hope that it will be useful, but WITHOUT ANY
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 // WARRANTY; without even the implied warranty of MERCHANTABILITY or
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 // for more details.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 // Under Section 7 of GPL version 3, you are granted additional
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 // permissions described in the GCC Runtime Library Exception, version
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 // 3.1, as published by the Free Software Foundation.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 // You should have received a copy of the GNU General Public License and
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 // a copy of the GCC Runtime Library Exception along with this program;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 // <http://www.gnu.org/licenses/>.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 module gcc.sections.android;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 version (CRuntime_Bionic):
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 // debug = PRINTF;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 debug(PRINTF) import core.stdc.stdio;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 import core.stdc.stdlib : malloc, free;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 import rt.deh, rt.minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 import core.sys.posix.pthread;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 import core.stdc.stdlib : calloc;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 import core.stdc.string : memcpy;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 struct SectionGroup
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 static int opApply(scope int delegate(ref SectionGroup) dg)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 return dg(_sections);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 static int opApplyReverse(scope int delegate(ref SectionGroup) dg)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 return dg(_sections);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 @property immutable(ModuleInfo*)[] modules() const nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 return _moduleGroup.modules;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 @property ref inout(ModuleGroup) moduleGroup() inout nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 return _moduleGroup;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 @property immutable(FuncTable)[] ehTables() const nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 auto pbeg = cast(immutable(FuncTable)*)&__start_deh;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 auto pend = cast(immutable(FuncTable)*)&__stop_deh;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 return pbeg[0 .. pend - pbeg];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 @property inout(void[])[] gcRanges() inout nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66 return _gcRanges[];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 ModuleGroup _moduleGroup;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 void[][1] _gcRanges;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74 void initSections() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 pthread_key_create(&_tlsKey, null);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 auto mbeg = cast(immutable ModuleInfo**)&__start_minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79 auto mend = cast(immutable ModuleInfo**)&__stop_minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 _sections.moduleGroup = ModuleGroup(mbeg[0 .. mend - mbeg]);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 auto pbeg = cast(void*)&_tlsend;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 auto pend = cast(void*)&__bss_end__;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 // _tlsend is a 32-bit int and may not be 64-bit void*-aligned, so align pbeg.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 version (D_LP64) pbeg = cast(void*)(cast(size_t)(pbeg + 7) & ~cast(size_t)7);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 _sections._gcRanges[0] = pbeg[0 .. pend - pbeg];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89 void finiSections() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 pthread_key_delete(_tlsKey);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94 void[]* initTLSRanges() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 return &getTLSBlock();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99 void finiTLSRanges(void[]* rng) nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101 .free(rng.ptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 .free(rng);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
103 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
104
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
105 void scanTLSRanges(void[]* rng, scope void delegate(void* pbeg, void* pend) nothrow dg) nothrow
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 dg(rng.ptr, rng.ptr + rng.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110 /* NOTE: The Bionic C library ignores thread-local data stored in the normal
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 * .tbss/.tdata ELF sections, which are marked with the SHF_TLS/STT_TLS
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 * flags. So instead we roll our own by keeping TLS data in the
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113 * .tdata/.tbss sections but removing the SHF_TLS/STT_TLS flags, and
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 * access the TLS data using this function and the _tlsstart/_tlsend
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115 * symbols as delimiters.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116 *
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117 * This function is called by the code emitted by the compiler. It
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 * is expected to translate an address in the TLS static data to
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119 * the corresponding address in the TLS dynamic per-thread data.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122 extern(C) void* __tls_get_addr( void* p ) nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124 debug(PRINTF) printf(" __tls_get_addr input - %p\n", p);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
125 immutable offset = cast(size_t)(p - cast(void*)&_tlsstart);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
126 auto tls = getTLSBlockAlloc();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
127 assert(offset < tls.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
128 return tls.ptr + offset;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
129 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
130
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
131 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
132
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
133 __gshared pthread_key_t _tlsKey;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
134
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
135 ref void[] getTLSBlock() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
136 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
137 auto pary = cast(void[]*)pthread_getspecific(_tlsKey);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
138 if (pary is null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
139 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
140 pary = cast(void[]*).calloc(1, (void[]).sizeof);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
141 if (pthread_setspecific(_tlsKey, pary) != 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
142 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
143 import core.stdc.stdio;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
144 perror("pthread_setspecific failed with");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
145 assert(0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
146 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
147 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
148 return *pary;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
149 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
150
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
151 ref void[] getTLSBlockAlloc() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
152 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
153 auto pary = &getTLSBlock();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
154 if (!pary.length)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
155 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
156 auto pbeg = cast(void*)&_tlsstart;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
157 auto pend = cast(void*)&_tlsend;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
158 auto p = .malloc(pend - pbeg);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
159 memcpy(p, pbeg, pend - pbeg);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
160 *pary = p[0 .. pend - pbeg];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
161 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
162 return *pary;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
163 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
164
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
165 __gshared SectionGroup _sections;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
166
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
167 extern(C)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
168 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
169 /* Symbols created by the compiler/linker and inserted into the
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
170 * object file that 'bracket' sections.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
171 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
172 extern __gshared
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
173 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
174 void* __start_deh;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
175 void* __stop_deh;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
176 void* __start_minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
177 void* __stop_minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
178
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
179 size_t __bss_end__;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
180
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
181 int _tlsstart;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
182 int _tlsend;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
183 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
184 }