annotate libphobos/libdruntime/gcc/sections/osx.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 // OSX-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.osx;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 version (OSX):
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 import core.stdc.stdio;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 import core.stdc.string, core.stdc.stdlib;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 import core.sys.posix.pthread;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 import core.sys.darwin.mach.dyld;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 import core.sys.darwin.mach.getsect;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 import rt.deh, rt.minfo;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 import rt.util.container.array;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 struct SectionGroup
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 static int opApply(scope int delegate(ref SectionGroup) dg)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 return dg(_sections);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 static int opApplyReverse(scope int delegate(ref SectionGroup) dg)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 return dg(_sections);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 @property immutable(ModuleInfo*)[] modules() const nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 return _moduleGroup.modules;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 @property ref inout(ModuleGroup) moduleGroup() inout nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 return _moduleGroup;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 @property inout(void[])[] gcRanges() inout nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 return _gcRanges[];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 @property immutable(FuncTable)[] ehTables() const nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 return _ehTables[];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 immutable(FuncTable)[] _ehTables;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 ModuleGroup _moduleGroup;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 Array!(void[]) _gcRanges;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 immutable(void)[][2] _tlsImage;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 /****
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 * Boolean flag set to true while the runtime is initialized.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 __gshared bool _isRuntimeInitialized;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 /****
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81 * Gets called on program startup just before GC is initialized.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 void initSections() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 pthread_key_create(&_tlsKey, null);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 _dyld_register_func_for_add_image(&sections_osx_onAddImage);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87 _isRuntimeInitialized = true;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 /***
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 * Gets called on program shutdown just after GC is terminated.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93 void finiSections() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 _sections._gcRanges.reset();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 pthread_key_delete(_tlsKey);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97 _isRuntimeInitialized = false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100 void[]* initTLSRanges() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 return &getTLSBlock();
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 finiTLSRanges(void[]* rng) nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 .free(rng.ptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108 .free(rng);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 void scanTLSRanges(void[]* rng, scope void delegate(void* pbeg, void* pend) nothrow dg) nothrow
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113 dg(rng.ptr, rng.ptr + rng.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116 // NOTE: The Mach-O object file format does not allow for thread local
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117 // storage declarations. So instead we roll our own by putting tls
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 // into the __tls_data and the __tlscoal_nt sections.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 // This function is called by the code emitted by the compiler. It
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121 // is expected to translate an address into the TLS static data to
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122 // the corresponding address in the TLS dynamic per-thread data.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124 // NB: the compiler mangles this function as '___tls_get_addr' even though it is extern(D)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
125 extern(D) void* ___tls_get_addr( void* p )
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
126 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
127 immutable off = tlsOffset(p);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
128 auto tls = getTLSBlockAlloc();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
129 assert(off < tls.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
130 return tls.ptr + off;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
131 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
132
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
133 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
134
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
135 __gshared pthread_key_t _tlsKey;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
136
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
137 size_t tlsOffset(void* p)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
138 in
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
139 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
140 assert(_sections._tlsImage[0].ptr !is null ||
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
141 _sections._tlsImage[1].ptr !is null);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
142 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
143 body
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
144 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
145 // NOTE: p is an address in the TLS static data emitted by the
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
146 // compiler. If it isn't, something is disastrously wrong.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
147 immutable off0 = cast(size_t)(p - _sections._tlsImage[0].ptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
148 if (off0 < _sections._tlsImage[0].length)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
149 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
150 return off0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
151 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
152 immutable off1 = cast(size_t)(p - _sections._tlsImage[1].ptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
153 if (off1 < _sections._tlsImage[1].length)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
154 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
155 size_t sz = (_sections._tlsImage[0].length + 15) & ~cast(size_t)15;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
156 return sz + off1;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
157 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
158 assert(0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
159 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
160
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
161 ref void[] getTLSBlock() nothrow @nogc
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
162 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
163 auto pary = cast(void[]*)pthread_getspecific(_tlsKey);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
164 if (pary is null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
165 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
166 pary = cast(void[]*).calloc(1, (void[]).sizeof);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
167 if (pthread_setspecific(_tlsKey, pary) != 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
168 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
169 import core.stdc.stdio;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
170 perror("pthread_setspecific failed with");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
171 assert(0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
172 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
173 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
174 return *pary;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
175 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
176
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
177 ref void[] getTLSBlockAlloc()
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
178 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
179 auto pary = &getTLSBlock();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
180 if (!pary.length)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
181 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
182 auto imgs = _sections._tlsImage;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
183 immutable sz0 = (imgs[0].length + 15) & ~cast(size_t)15;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
184 immutable sz2 = sz0 + imgs[1].length;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
185 auto p = .malloc(sz2);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
186 memcpy(p, imgs[0].ptr, imgs[0].length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
187 memcpy(p + sz0, imgs[1].ptr, imgs[1].length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
188 *pary = p[0 .. sz2];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
189 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
190 return *pary;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
191 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
192
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
193 __gshared SectionGroup _sections;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
194
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
195 extern (C) void sections_osx_onAddImage(in mach_header* h, intptr_t slide)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
196 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
197 foreach (e; dataSegs)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
198 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
199 auto sect = getSection(h, slide, e.seg.ptr, e.sect.ptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
200 if (sect != null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
201 _sections._gcRanges.insertBack((cast(void*)sect.ptr)[0 .. sect.length]);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
202 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
203
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
204 auto minfosect = getSection(h, slide, "__DATA", "__minfodata");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
205 if (minfosect != null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
206 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
207 // no support for multiple images yet
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
208 // take the sections from the last static image which is the executable
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
209 if (_isRuntimeInitialized)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
210 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
211 fprintf(stderr, "Loading shared libraries isn't yet supported on OSX.\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
212 return;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
213 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
214 else if (_sections.modules.ptr !is null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
215 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
216 fprintf(stderr, "Shared libraries are not yet supported on OSX.\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
217 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
218
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
219 debug(PRINTF) printf(" minfodata\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
220 auto p = cast(immutable(ModuleInfo*)*)minfosect.ptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
221 immutable len = minfosect.length / (*p).sizeof;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
222
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
223 _sections._moduleGroup = ModuleGroup(p[0 .. len]);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
224 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
225
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
226 auto ehsect = getSection(h, slide, "__DATA", "__deh_eh");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
227 if (ehsect != null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
228 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
229 debug(PRINTF) printf(" deh_eh\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
230 auto p = cast(immutable(FuncTable)*)ehsect.ptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
231 immutable len = ehsect.length / (*p).sizeof;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
232
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
233 _sections._ehTables = p[0 .. len];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
234 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
235
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
236 auto tlssect = getSection(h, slide, "__DATA", "__tls_data");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
237 if (tlssect != null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
238 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
239 debug(PRINTF) printf(" tls_data %p %p\n", tlssect.ptr, tlssect.ptr + tlssect.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
240 _sections._tlsImage[0] = (cast(immutable(void)*)tlssect.ptr)[0 .. tlssect.length];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
241 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
242
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
243 auto tlssect2 = getSection(h, slide, "__DATA", "__tlscoal_nt");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
244 if (tlssect2 != null)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
245 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
246 debug(PRINTF) printf(" tlscoal_nt %p %p\n", tlssect2.ptr, tlssect2.ptr + tlssect2.length);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
247 _sections._tlsImage[1] = (cast(immutable(void)*)tlssect2.ptr)[0 .. tlssect2.length];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
248 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
249 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
250
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
251 struct SegRef
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
252 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
253 string seg;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
254 string sect;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
255 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
256
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
257 static immutable SegRef[] dataSegs = [{SEG_DATA, SECT_DATA},
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
258 {SEG_DATA, SECT_BSS},
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
259 {SEG_DATA, SECT_COMMON}];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
260
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
261 ubyte[] getSection(in mach_header* header, intptr_t slide,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
262 in char* segmentName, in char* sectionName)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
263 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
264 version (X86)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
265 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
266 assert(header.magic == MH_MAGIC);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
267 auto sect = getsectbynamefromheader(header,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
268 segmentName,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
269 sectionName);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
270 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
271 else version (X86_64)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
272 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
273 assert(header.magic == MH_MAGIC_64);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
274 auto sect = getsectbynamefromheader_64(cast(mach_header_64*)header,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
275 segmentName,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
276 sectionName);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
277 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
278 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
279 static assert(0, "unimplemented");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
280
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
281 if (sect !is null && sect.size > 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
282 return (cast(ubyte*)sect.addr + slide)[0 .. cast(size_t)sect.size];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
283 return null;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
284 }